diff --git a/DkimSigner.sln b/DkimSigner.sln
index 03725b4e..109a42f1 100644
--- a/DkimSigner.sln
+++ b/DkimSigner.sln
@@ -55,6 +55,7 @@ Global
Ex2016 CU18|Any CPU = Ex2016 CU18|Any CPU
Ex2016 CU19|Any CPU = Ex2016 CU19|Any CPU
Ex2016 CU2|Any CPU = Ex2016 CU2|Any CPU
+ Ex2016 CU20|Any CPU = Ex2016 CU20|Any CPU
Ex2016 CU3|Any CPU = Ex2016 CU3|Any CPU
Ex2016 CU4|Any CPU = Ex2016 CU4|Any CPU
Ex2016 CU5|Any CPU = Ex2016 CU5|Any CPU
@@ -72,6 +73,7 @@ Global
Ex2019 CU6|Any CPU = Ex2019 CU6|Any CPU
Ex2019 CU7|Any CPU = Ex2019 CU7|Any CPU
Ex2019 CU8|Any CPU = Ex2019 CU8|Any CPU
+ Ex2019 CU9|Any CPU = Ex2019 CU9|Any CPU
Ex2019 Preview|Any CPU = Ex2019 Preview|Any CPU
Ex2019 RTM|Any CPU = Ex2019 RTM|Any CPU
Release|Any CPU = Release|Any CPU
@@ -169,6 +171,7 @@ Global
{3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2016 CU19|Any CPU.Build.0 = Ex2016 CU19|Any CPU
{3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2016 CU2|Any CPU.ActiveCfg = Ex2016 CU2|Any CPU
{3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2016 CU2|Any CPU.Build.0 = Ex2016 CU2|Any CPU
+ {3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2016 CU20|Any CPU.ActiveCfg = Ex2016 CU20|Any CPU
{3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2016 CU3|Any CPU.ActiveCfg = Ex2016 CU3|Any CPU
{3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2016 CU3|Any CPU.Build.0 = Ex2016 CU3|Any CPU
{3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2016 CU4|Any CPU.ActiveCfg = Ex2016 CU4|Any CPU
@@ -203,6 +206,7 @@ Global
{3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2019 CU7|Any CPU.Build.0 = Ex2019 CU7|Any CPU
{3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2019 CU8|Any CPU.ActiveCfg = Ex2019 CU8|Any CPU
{3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2019 CU8|Any CPU.Build.0 = Ex2019 CU8|Any CPU
+ {3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2019 CU9|Any CPU.ActiveCfg = Ex2019 CU9|Any CPU
{3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2019 Preview|Any CPU.ActiveCfg = Ex2019 Preview|Any CPU
{3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2019 Preview|Any CPU.Build.0 = Ex2019 Preview|Any CPU
{3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2019 RTM|Any CPU.ActiveCfg = Ex2019 RTM|Any CPU
@@ -255,6 +259,8 @@ Global
{8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU18|Any CPU.ActiveCfg = Release|Any CPU
{8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU19|Any CPU.ActiveCfg = Release|Any CPU
{8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU2|Any CPU.ActiveCfg = Release|Any CPU
+ {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU20|Any CPU.ActiveCfg = Debug|Any CPU
+ {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU20|Any CPU.Build.0 = Debug|Any CPU
{8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU3|Any CPU.ActiveCfg = Release|Any CPU
{8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU4|Any CPU.ActiveCfg = Release|Any CPU
{8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU5|Any CPU.ActiveCfg = Release|Any CPU
@@ -272,6 +278,8 @@ Global
{8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2019 CU6|Any CPU.ActiveCfg = Release|Any CPU
{8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2019 CU7|Any CPU.ActiveCfg = Release|Any CPU
{8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2019 CU8|Any CPU.ActiveCfg = Release|Any CPU
+ {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2019 CU9|Any CPU.ActiveCfg = Debug|Any CPU
+ {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2019 CU9|Any CPU.Build.0 = Debug|Any CPU
{8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2019 Preview|Any CPU.ActiveCfg = Release|Any CPU
{8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2019 RTM|Any CPU.ActiveCfg = Release|Any CPU
{8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Release|Any CPU.ActiveCfg = Release|Any CPU
diff --git a/Lib/Exchange 2016 CU20/Microsoft.Exchange.Data.Common.dll b/Lib/Exchange 2016 CU20/Microsoft.Exchange.Data.Common.dll
new file mode 100644
index 00000000..48e86310
Binary files /dev/null and b/Lib/Exchange 2016 CU20/Microsoft.Exchange.Data.Common.dll differ
diff --git a/Lib/Exchange 2016 CU20/Microsoft.Exchange.Data.Transport.dll b/Lib/Exchange 2016 CU20/Microsoft.Exchange.Data.Transport.dll
new file mode 100644
index 00000000..615d6636
Binary files /dev/null and b/Lib/Exchange 2016 CU20/Microsoft.Exchange.Data.Transport.dll differ
diff --git a/Lib/Exchange 2016 CU20/microsoft.exchange.data.common.xml b/Lib/Exchange 2016 CU20/microsoft.exchange.data.common.xml
new file mode 100644
index 00000000..a086b7a1
--- /dev/null
+++ b/Lib/Exchange 2016 CU20/microsoft.exchange.data.common.xml
@@ -0,0 +1,9082 @@
+
+
+
+ Microsoft.Exchange.Data.Common
+
+
+
+ The class represents exceptions that are caused by invalid input data.
+
+
+ The constructor creates a new exception with the error message message.
+ The error message for this .
+
+
+ The constructor creates a new serializable object.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new object from an inner exception.
+ The exception that caused this to be thrown.
+ The error message for this object.
+
+
+ The namespace contains classes that support localization and error handling.
+
+
+ The class enables access to the assembly name to aid in constructing localized strings.
+
+
+ The method returns a that accesses resources specified by a given base name and assembly.
+ The assembly containing the resources.
+ The root name of the resources.
+
+
+ The method returns the string identified by the resource ID name.
+ The resource ID of the string to return.
+
+
+ The method returns a string that corresponds to a given culture and resource ID.
+ A object representing the culture of the string to retrieve.
+ The resource ID of the string to return.
+
+
+ The interface defines a contract for localized exceptions.
+
+
+ The class defines a contract for localized strings.
+
+
+ The class uses localized strings for exception messages.
+
+
+ The constructor creates a new with a localized string for the error message.
+ A object to use for this object's message.
+
+
+ The constructor uses a localized error message to create a new object from an inner exception.
+ The error message for this object.
+ The exception that caused this to be thrown.
+
+
+ The constructor creates a new serializable object.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The method uses information in the exception argument e to generate an error code.
+ The exception on which to base the error code.
+
+
+ The method is called when this object is serialized.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ Returns .
+
+
+ Returns .
+
+
+ The structure defines a localizable string.
+
+
+ The constructor creates a new object.
+ The contents of the new object.
+
+
+ The constructor creates a new object.
+ The resource ID of the string with which to initialize this object.
+ The resource manager to use for looking up the string.
+ Strings to be inserted into the message identified by id.
+
+
+ The field is true if this object is empty. Otherwise, the property is false.
+
+
+ The method compares this object with another.
+ The method returns true if the strings are identical. Otherwise it returns false.
+ The object to compare.
+
+
+ The method compares this object to another.
+ The method returns true if the strings are equal. Otherwise it returns false.
+ The object to compare.
+
+
+ The method joins an array of strings together with a separator.
+ The method returns a object containing the objects in value separated by separator.
+ The string that will appear between the string fragments after they are joined into a new object.
+ An array containing objects to be joined as strings.
+
+
+ The operator compares two objects.
+ The operator returns true if s1 and s2 are equal. Otherwise, it returns false.
+ A to compare.
+ A to compare.
+
+
+ The implicit conversion operator from to .
+ The resulting string.
+ The object to convert.
+
+
+ The operator overload compares the magnitude of two objects.
+ The operator returns true if s1 is not equal to s2. Otherwise it returns false.
+ The first to compare.
+ The second to compare.
+
+
+ The method uses the specified object to return a string representation of this object.
+ A format string.
+ A object to use to format format.
+
+
+ The method is called when this object is serialized.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about this object.
+
+
+ The method uses the specified object to return a string representation of this object.
+ A object to use to format this as it is converted to a string.
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ The class represents an exception for an operation that failed because of a temporary condition.
+
+
+ The method creates a new object with a localized message.
+ The message for this object.
+
+
+ The constructor creates a new object from a localized message and an inner exception.
+ The message for this object.
+ The exception that caused this to be thrown.
+
+
+ The constructor creates a serializable object.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The namespace contains types that enable you to read and write iCalendar data.
+
+
+ The enumeration contains values that control how objects behave while reading iCalendar data.
+
+
+ Indicates that the will not throw exceptions for errors in incoming iCalendar data. Instead, the CalendarReader object will set its property.
+
+
+ Indicates that the will throw an exception on any error encountered in incoming iCalendar data. This is the default value of the property.
+
+
+ The enumeration contains values that indicate either that the iCalendar data is compliant with RFC2445, or that indicate the problem that caused the iCalendar data to fail to comply with RFC2445.
+
+
+ The incoming iCalendar data is fully compliant with RFC2445.
+
+
+ An end tag was encountered for a different component than the one that is currently open.
+
+
+ A component name was empty.
+
+
+ A parameter name was empty.
+
+
+ A property name was empty.
+
+
+ An end tag has no corresponding opening tag.
+
+
+ A parameter name contained an invalid character.
+
+
+ Parameter text contained an invalid character.
+
+
+ A property name contained an invalid character.
+
+
+ A property value contained an invalid character.
+
+
+ A quoted string contained an invalid character.
+
+
+ A parameter value was invalid.
+
+
+ A value was formatted incorrectly.
+
+
+ One or more components were not closed properly.
+
+
+ A parameter name is missing.
+
+
+ A component tag contained a parameter.
+
+
+ A property was encountered outside of a component.
+
+
+ A property was truncated.
+
+
+ The iCalendar stream ended unexpectedly.
+
+
+ The class returns information about parameters in an iCalendar stream.
+
+
+ The method reads the next parameter.
+ The method returns true if there was another parameter to read. Otherwise, the method returns false.
+
+
+ The method reads the next value in the current parameter.
+ The method returns true if there was another value to read. Otherwise, the method returns false.
+
+
+ The class represents an RFC2445 Period object.
+
+
+ The constructor creates a new object with the specified start and end times.
+ The end time for this structure.
+ The start time for this structure.
+
+
+ The method creates a new object with the specified start time and duration.
+ The duration for this structure.
+ The start time for this structure.
+
+
+ The method returns a string representation of this structure.
+ If is true, then the returned string contains the start date and end date. If is false, then the returned string contains the start date and duration.
+
+
+ The property gets a Boolean value that indicates whether the end date of this structure is explicitly defined.
+ The property returns true if this structure is defined with a start and end date. If the property returns false if this structure is defined with a start time and a duration.
+
+
+ The structure returns information about properties in an iCalendar data stream.
+
+
+ The method moves to the next property.
+ The method returns true if there was another property to read. Otherwise, the method returns false.
+
+
+ The method moves to the next property value.
+ The method returns true if there was another property value to read. Otherwise, the method returns false.
+
+
+ The method reads a value and returns it as a structure.
+ The property returns a DateTime structure with a DateTimeKind of Coordinated Universal Time (UTC) if the property contains a UTC value; otherwise, the DateTimeKind in the returned DateTime structure is DateTimeKind.Unspecified.
+
+
+ The method reads a value and returns it as a structure.
+ The property returns a DateTime structure with a DateTimeKind of Coordinated Universal Time (UTC) if the property contains a UTC value; otherwise, the DateTimeKind in the returned DateTime structure is DateTimeKind.Unspecified.
+ A enumeration value that specifies how to interpret the value as a structure.
+
+
+ The method returns the current value as a structure.
+ A enumeration value that specifies how to interpret the value as a structure.
+
+
+ The class provides a forward-only non-cached reader for iCalendar data streams.
+
+
+ The constructor creates a new object that reads from the stream parameter.
+ A stream that contains iCalendar data.
+
+
+ The constructor creates a new object.
+ A CalendarComplianceMode enumeration value.
+ A string that describes the encoding of stream.
+ A stream that contains iCalendar data.
+
+
+ The method checks if the specified calendar reader has been disposed.
+ The name of the method calling the method.
+
+
+ The method closes this structure and any resources it used to read iCalendar data.
+
+
+ The method releases all managed and unmanaged resources used by the .
+
+
+ The method releases the unmanaged resources used by the and optionally releases the managed resources.
+ Releasesboth managed and unmanaged resources when set to true; releases only unmanaged resources when set to false.
+
+
+ The method moves to the first child component of the current component.
+ The method returns true if there was a child component. Otherwise, the method returns false.
+
+
+ The method moves to the next component.
+ The method returns true if there was another component. Otherwise, the method returns false.
+
+
+ The method moves to the next component that has the same parent as the current component.
+ The method returns true if there was another child component. Otherwise, the method returns false.
+
+
+ The method resets the of this structure.
+
+
+ The structure represents a TIME value type as defined in RFC2445.
+
+
+ The constructor creates a new structure.
+ A structure to use for initializing the property.
+ A Boolean value indicating whether this structure represents local or Coordinated Universal Time (UTC).
+
+
+ The enumeration indicates the type of an iCalendar value.
+
+
+ Indicates that the value is binary.
+
+
+ Indicates that the value is Boolean.
+
+
+ Indicates that the value is a CalAddress.
+
+
+ Indicates that the value is a Date.
+
+
+ Indicates that the value is a .
+
+
+ Indicates that the value is a Duration.
+
+
+ Indicates that the value is a Float.
+
+
+ Indicates that the value is an Integer.
+
+
+ Indicates that the value is a Period.
+
+
+ Indicates that the value is a Recurrence.
+
+
+ Indicates that the value is text.
+
+
+ Indicates that the value is a Time.
+
+
+ Indicates that the value is an xtype.
+
+
+ Indicates that the value is a URI.
+
+
+ Indicates that the value is a UTC-Offset.
+
+
+ The class writes iCalendar data to an underlying stream and performs limited validation on the data written.
+
+
+ The constructor creates a new object that writes to the stream that is passed in the stream parameter.
+ The object into which to write iCalendar data.
+
+
+ The constructor creates a new object that writes to the stream that is passed in the stream parameter and uses the encoding that is specified by the encodingName parameter.
+ The name of the encoding to use when writing iCalendar data.
+ The object into which to write iCalendar data.
+ The stream parameter or encodingName parameter is null.
+ The stream parameter cannot be written to.
+
+
+ The method closes this object but does not close the underlying stream.
+
+
+ The method releases all managed and unmanaged resources used by the .
+
+
+ The method releases the unmanaged resources used by the and optionally releases the managed resources.
+ Release both managed and unmanaged resources if set to true; releases only unmanaged resources if set to false.
+
+
+ The method ends the current component.
+
+
+ The method flushes all data up to the last closed property to the underlying stream.
+
+
+ The method starts a new component that is identified by the componentId parameter.
+ A enumeration value that indicates the component to start.
+ The componentId parameter value that was passed represents a component that is not allowed within the current component.
+
+
+ The method starts a new component that is identified by the name parameter.
+ The name of the component to start.
+ The name parameter was passed as a null reference (Nothing in Visual Basic).
+ The componentId parameter value that was passed represents a component that is not allowed within the current component.
+
+
+ The method starts a new iCalendar parameter that is identified by the parameterId parameter.
+ A enumeration value that indicates the parameter to start.
+ The parameterId value that was passed represents an iCalendar parameter that is not allowed within the current property.
+
+
+ The method starts a new iCalendar parameter that is identified by the name parameter.
+ The name of the parameter to start.
+ The name parameter was passed as a null reference (Nothing in Visual Basic).
+ The name parameter value that was passed represents an iCalendar parameter that is not allowed within the current property.
+
+
+ The method starts a new iCalendar property that is identified by the propertyId parameter.
+ A enumeration value that indicates the property to start.
+ The propertyId value that was passed represents an iCalendar property that is not allowed within the current component.
+
+
+ The method starts a new property that is identified by the name parameter.
+ A string that indicates the property to start.
+ The name parameter was passed as a null reference (Nothing in Visual Basic).
+ The name parameter value that was passed represents an iCalendar property that is not allowed within the current component.
+
+
+ The method writes a component from a object.
+ A object that is positioned at the start of the component to be written by this object.
+ The reader parameter that was passed is positioned on an iCalendar component that is not allowed within the current component.
+
+
+ The method reads an iCalendar parameter from a structure and writes it to the stream that this object owns.
+ A structure that is positioned at the start of the parameter to be written.
+
+
+ The method writes an iCalendar parameter that is identified by the parameterId parameter that contains the value in the value parameter.
+ The value of the parameter to write.
+ A enumeration value that indicates the type of parameter to write.
+
+
+ The method writes an iCalendar parameter with the name that is specified by the name parameter and the value that is specified by the value parameter.
+ The value of the parameter to write.
+ The name of the parameter to write.
+
+
+ The method writes a parameter value to the stream that this object owns.
+ The parameter value to write.
+
+
+ The method reads a property from a structure and writes it to the stream that this object owns.
+ A structure that is positioned at the start of the property to write.
+
+
+ The method writes an iCalendar property that is identified by the propertyId parameter and that has the value given by the value parameter.
+ A enumeration value that indicates the type of property to write.
+ The value of the property.
+
+
+ The method writes an iCalendar property that has the name that is specified by the name parameter and the value that is specified by the value parameter.
+ The value of the parameter to write.
+ The name of the parameter to write.
+
+
+ The method writes a Boolean value to the current property in the stream that this object owns.
+ The Boolean value to write.
+
+
+ The method writes a value to the current property in the stream that this object owns.
+ A value to write.
+
+
+ The method writes a value to the current property in the stream that this object owns.
+ A value to write.
+
+
+ The method writes a value to the current property in the stream that this object owns.
+ A value to write.
+
+
+ The method writes an integer value to the current property in the stream that this object owns.
+ The integer value to write.
+
+
+ The method writes an as a value to the current property in the stream that this object owns.
+ The to write.
+
+
+ The method writes a value to the current property in the stream that this object owns.
+ The value to write.
+
+
+ The method writes a single precision floating point value to the current property in the stream that this object owns.
+ A single precision floating point value to write.
+
+
+ The method writes a string value to the current property in the stream that this object owns.
+ The value to write.
+
+
+ The method writes a value to the current property in the stream that this object owns.
+ The value to write.
+
+
+ The enumeration contains values that identify the iCalendar components that are specified in RFC 2445
+
+
+ Indicates a daylight sub-component in a VTIMEZONE component.
+
+
+ Indicates that the reader is positioned outside the root component level.
+
+
+ Indicates a standard sub-component in a VTIMEZONE component.
+
+
+ Indicates a custom x-component.
+
+
+ Indicates an alarm component.
+
+
+ Indicates the root-level iCalendar object type.
+
+
+ Indicates an event component.
+
+
+ Indicates a free/busy component.
+
+
+ Indicates a journal component.
+
+
+ Indicates a time zone component.
+
+
+ Indicates a to-do component.
+
+
+ The enumeration contains values that represent recurrence frequencies as defined by RFC2445.
+
+
+ Indicates a recurrence value of Daily.
+
+
+ Indicates a recurrence value of Hourly.
+
+
+ Indicates a recurrence value of Minutely.
+
+
+ Indicates a recurrence value of Monthly.
+
+
+ Indicates a recurrence value of Secondly.
+
+
+ Indicates an error in the recurrence rule.
+
+
+ Indicates a recurrence value of Weekly.
+
+
+ a recurrence value of Yearly.
+
+
+ The class represents an exception that is thrown when iCalendar data is encountered that does not comply with RFC2445.
+
+
+ The constructor creates a new exception.
+ The message for this exception.
+
+
+ The constructor creates a new serializable exception.
+ The StreamingContext object that contains contextual information about the source or destination.
+ The SerializationInfo object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new exception.
+ The inner exception that caused this to be thrown.
+ The message for this object.
+
+
+ The enumeration contains values that identify parameters.
+
+
+ Indicates an altrepparam (alternate text representation)) parameter.
+
+
+ Indicates a cutypeparam (calendar user type)) parameter.
+
+
+ Indicates a cnparam (common name) parameter.
+
+
+ Indicates a deltoparam (delegatee) parameter.
+
+
+ Indicates a delfromparam (delegator) parameter.
+
+
+ Indicates a dirparam (directory entry) parameter.
+
+
+ Indicates an encodingparam (inline encoding) parameter.
+
+
+ Indicates an fmttypeparam (format type) parameter.
+
+
+ Indicates an fbtypeparam (free/busy time type) parameter.
+
+
+ Indicates a languageparam (language for text) parameter.
+
+
+ Indicates a memberparam (group or list membership) parameter.
+
+
+ Indicates a roleparam (participation role) parameter.
+
+
+ Indicates a partstatparam (participation status) parameter.
+
+
+ Indicates a rangeparam (recurrence identifier range) parameter.
+
+
+ Indicates a reltypeparam (relationship type) parameter.
+
+
+ Indicates a rsvpparam (RSVP expectation) parameter.
+
+
+ Indicates a sentbyparam (sent by) parameter.
+
+
+ Indicates a tzidparam (reference to time zone object) parameter.
+
+
+ Indicates a trigrelparam (alarm trigger relationship) parameter.
+
+
+ Indicates an xparam (non-standard unregistered) parameter.
+
+
+ Indicates a valuetypeparam (property value data type) parameter.
+
+
+ The enumeration contains values that identify iCalendar properties.
+
+
+ Indicates an action property.
+
+
+ Indicates an attachment property.
+
+
+ Indicates an attendee property.
+
+
+ Indicates a calendar scale property.
+
+
+ Indicates a categories property.
+
+
+ Indicates a classification property.
+
+
+ Indicates a comment property.
+
+
+ Indicates a date/time completed property.
+
+
+ Indicates a contact property.
+
+
+ Indicates a date/time created property.
+
+
+ Indicates a date/time due property.
+
+
+ Indicates a date/time end property
+
+
+ Indicates a date/time stamp property.
+
+
+ Indicates a date/time start property.
+
+
+ Indicates a description property.
+
+
+ Indicates a duration property.
+
+
+ Indicates an exception date/time property.
+
+
+ Indicates an exception rule property.
+
+
+ Indicates a free/busy property.
+
+
+ Indicates a geographic position property.
+
+
+ Indicates a last modified property.
+
+
+ Indicates a location property.
+
+
+ Indicates a method property.
+
+
+ Indicates an organizer property.
+
+
+ Indicates a percent complete property.
+
+
+ Indicates a priority property.
+
+
+ Indicates a product identifier property.
+
+
+ Indicates a recurrence date/times property.
+
+
+ Indicates a Recurrence ID property.
+
+
+ Indicates a recurrence rule property.
+
+
+ Indicates a related to property.
+
+
+ Indicates a repeat property.
+
+
+ Indicates a request status property.
+
+
+ Indicates a resources property.
+
+
+ Indicates a sequence property.
+
+
+ Indicates a status property.
+
+
+ Indicates a summary property.
+
+
+ Indicates a time zone ID property.
+
+
+ Indicates a time zone name property.
+
+
+ Indicates a time zone offset from property.
+
+
+ Indicates a time zone offset to property.
+
+
+ Indicates a time zone URL property.
+
+
+ Indicates a time transparency property.
+
+
+ Indicates a trigger property.
+
+
+ Indicates a UID property.
+
+
+ Indicates any unrecognized property.
+
+
+ Indicates a URL property.
+
+
+ Indicates an iCal version property.
+
+
+ The class represents an iCalendar recurrence rule value type as defined by RFC 2445.
+
+
+ The constructor creates a new object that has default values.
+
+
+ The constructor creates a new object and initializes it with the recurrence information in the parameter value.
+ A string that contains a correctly formatted iCalendar recurrence rule value type as defined by RFC 2445.
+
+
+ The property gets or sets a that represents the value of the UNTIL property when it is defined with an RFC 2445 date.
+ The property returns a DateTime structure that represents a Coordinated Universal Time (UTC) date.
+
+
+ The property gets or sets a that represents the value of the UNTIL property when it is defined with an RFC 2445 datetime.
+ The property returns a DateTime structure that represents a Coordinated Universal Time (UTC) time.
+
+
+ The structure represents a bydaylist recurrence value.
+
+
+ The constructor creates a new structure that has a given weekday and week number.
+ The number of the week in the year.
+ The day of the week in the numbered week that is specified by occurrenceNumber.
+
+
+ The enumeration contains values that indicate which properties are valid on a object.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that no properties are valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ The namespace contains types that enable you to read and write TNEF data.
+
+
+ The enumeration specifies the level of a Tnef Attribute.
+
+
+ Indicates an Attachment-level attribute.
+
+
+ Indicates a Message-level attribute.
+
+
+ The enumeration contains values that identify TNEF attributes.
+
+
+ Indicates the attAidOwner attribute. This is equivalent to the PR_OWNER_APPT_ID MAPI property.
+
+
+ Indicates theattAttachCreateDate attribute. This is equivalent to the PR_CREATION_TIME MAPI property.
+
+
+ Indicates the attAttachDataattribute attribute. This is equivalent to the PR_ATTACH_DATA_BIN or PR_ATTACH_DATA_OBJ MAPI property.
+
+
+ Indicates the attAttachmentattribute attribute. This is equivalent to the arbitrary attachment MAPI properties
+
+
+ Indicates the attAttachMetaFile attribute attribute. This is equivalent to the PR_ATTACH_RENDERING MAPI property.
+
+
+ Indicates the attAttachModifyDate attribute. This is equivalent to the PR_LAST_MODIFICATION_TIME MAPI property.
+
+
+ Indicates the attAttachRenddata attribute.
+
+
+ Indicates the attAttachTitle attribute. This is equivalent to the PR_ATTACH_FILENAME MAPI property.
+
+
+ Indicates the attAttachTransportFilename attribute. This is equivalent to the PR_ATTACH_TRANSPORT_NAME MAPI property.
+
+
+ Indicates the attBody attribute. This is equivalent to the PR_BODY
+
+
+ Indicates the attConversationId attribute. This is equivalent to the PR_CONVERSATION_KEY MAPI property attribute.
+
+
+ Indicates the attDateEnd attribute. This is equivalent to the PR_END_DATE MAPI property.
+
+
+ Indicates the attDateModified attribute. This is equivalent to the PR_LAST_MODIFICATION_TIME MAPI property.
+
+
+ Indicates the attDateRecd attribute. This is equivalent to the PR_MESSAGE_DELIVERY_TIME MAPI property.
+
+
+ Indicates the attDateSent attribute. This is equivalent to the PR_CLIENT_SUBMIT_TIME MAPI property.
+
+
+ Indicates the attDateStart attribute. This is equivalent to the PR_START_DATE MAPI property.
+
+
+ Indicates the attDelegate attribute. This is equivalent to the PR_RCVD_REPRESENTING_xxx MAPI property.
+
+
+ Indicates the attFrom attribute. This is equivalent to the PR_SENDER_ENTRYID and PR_SENDER_NAME MAPI properties.
+
+
+ Indicates the attMapiProps attribute. This is equivalent to an arbitrary MAPI property list
+
+
+ Indicates the attMessageClass attribute. This is equivalent to the PR_MESSAGE_CLASS MAPI property.
+
+
+ Indicates the attMessageId attribute. This is equivalent to the PR_SEARCH_KEY property.
+
+
+ Indicates the attMessageStatus attribute. This is equivalent to the PR_MESSAGE_FLAGS MAPI property.
+
+
+ Indicates the attNull attribute.
+
+
+ Indicates the attOemCodepage attribute.
+
+
+ Indicates the attOriginalMessageClass attribute. This is equivalent to the PR_ORIG_MESSAGE_CLASS MAPI property.
+
+
+ Indicates the attOwner attribute. This is equivalent to the PR_RCVD_REPRESENTING_xxx or PR_SENT_REPRESENTING_xxx MAPI property.
+
+
+ Indicates the attParentId attribute. This is equivalent to the PR_PARENT_KEY MAPI property.
+
+
+ Indicates the attPriority attribute. This is equivalent to the PR_IMPORTANCE property.
+
+
+ Indicates the attRecipTable attribute. This is equivalent to the PR_MESSAGE_RECIPIENTS MAPI property.
+
+
+ Indicates the attRequestRes attribute. This is equivalent to the PR_RESPONSE_REQUESTED MAPI property.
+
+
+ Indicates the attSentFor attribute. This is equivalent to the PR_SENT_REPRESENTING_xxx
+
+
+ Indicates the attSubject attribute. This is equivalent to the PR_SUBJECT MAPI property.
+
+
+ Indicates the attTnefVersion attribute.
+
+
+ The enumeration contains values that control whether a object will throw exceptions when it encounters errors in incoming Tnef data.
+
+
+ Indicates that the will not throw exceptions for errors in incoming Tnef data.
+
+
+ Indicates that the will throw an exception on any error encountered in incoming Tnef data. This is the default value of the property.
+
+
+ The enumeration contains values that specify whether incoming Tnef data is compliant and, if not, what caused the noncompliance.
+
+
+ The incoming Tnef data contains too many attributes.
+
+
+ The incoming Tnef data is fully compliant.
+
+
+ One or more of the attributes are invalid.
+
+
+ The checksum on one or more attributes is invalid.
+
+
+ The length of one or more attributes is incorrect.
+
+
+ One or more attributes are incorrectly applied to a message or an attachment.
+
+
+ One or more attributes have an invalid value.
+
+
+ The date is invalid.
+
+
+ The message class is invalid.
+
+
+ The codepage is not supported.
+
+
+ The length of one or more properties is invalid.
+
+
+ The row count is invalid.
+
+
+ The signature on the incoming Tnef data is invalid.
+
+
+ The version information in the incoming Tnef data is invalid.
+
+
+ The incoming Tnef data contains parts that are nested too deeply.
+
+
+ The incoming Tnef data is truncated.
+
+
+ One or more properties in the incoming Tnef data are of an unsupported type.
+
+
+ The class represents an exception thrown when noncompliant Tnef data is encountered.
+
+
+ The constructor creates a new object with a message specified by the message parameter.
+ The message for this object.
+
+
+ The constructor creates a new serializable object.
+ The StreamingContext object that contains contextual information about the source or destination.
+ The SerializationInfo object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new outer object from an inner exception.
+ The inner exception that caused this to be thrown.
+ The message for this object.
+
+
+ The structure encapsulates the name or name ID of a named MAPI property.
+
+
+ The constructor creates a new structure from a GUID and an integer.
+ The integer ID to assign to the property.
+ The GUID to assign to the property.
+
+
+ The constructor creates a new structure from a GUID and a string.
+ The GUID to assign to the property.
+ The string to assign to the property.
+
+
+ The property gets the name ID of this structure.
+ The property returns the name ID for this structure.
+
+
+ The enumeration contains values indicating how a name is stored in a structure.
+
+
+ The name is stored as an integer.
+
+
+ The name is stored as a string.
+
+
+ The enumeration contains values that represent MAPI properties applied to a Tnef message.
+
+
+ Indicates the MAPI property PR_AB_DEFAULT_DIR.
+
+
+ Indicates the MAPI property PR_AB_DEFAULT_PAB.
+
+
+ Indicates the MAPI property PR_AB_PROVIDER_ID.
+
+
+ Indicates the MAPI property PR_AB_PROVIDERS.
+
+
+ Indicates the MAPI property PR_AB_SEARCH_PATH.
+
+
+ Indicates the MAPI property PR_AB_SEARCH_PATH_UPDATE.
+
+
+ Indicates the MAPI property PR_ACCESS.
+
+
+ Indicates the MAPI property PR_ACCESS_LEVEL.
+
+
+ Indicates the MAPI property PR_ACCOUNT.
+
+
+ Indicates the MAPI property PR_ACKNOWLEDGEMENT_MODE.
+
+
+ Indicates the MAPI property PR_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_ALTERNATE_RECIPIENT.
+
+
+ Indicates the MAPI property PR_ALTERNATE_RECIPIENT_ALLOWED.
+
+
+ Indicates the MAPI property PR_ANR.
+
+
+ Indicates the MAPI property PR_ASSISTANT.
+
+
+ Indicates the MAPI property PR_ASSISTANT_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_ASSOC_CONTENT_COUNT.
+
+
+ Indicates the MAPI property PR_ATTACH_ADDITIONAL_INFO.
+
+
+ Indicates the MAPI property PR_ATTACH_CONTENT_BASE.
+
+
+ Indicates the MAPI property PR_ATTACH_CONTENT_ID.
+
+
+ Indicates the MAPI property PR_ATTACH_CONTENT_LOCATION.
+
+
+ Indicates the MAPI property PR_ATTACH_DATA_BIN or PR_ATTACH_DATA_OBJ.
+
+
+ Indicates the MAPI property PR_ATTACH_DISPOSITION.
+
+
+ Indicates the MAPI property PR_ATTACH_ENCODING.
+
+
+ Indicates the MAPI property PR_ATTACH_EXTENSION.
+
+
+ Indicates the MAPI property PR_ATTACH_FILENAME.
+
+
+ Indicates the MAPI property PR_ATTACH_FLAGS.
+
+
+ Indicates the MAPI property PR_ATTACHMENT_HIDDEN.
+
+
+ Indicates the MAPI property PR_ATTACH_LONG_FILENAME.
+
+
+ Indicates the MAPI property PR_ATTACH_LONG_PATHNAME.
+
+
+ Indicates the MAPI property PR_ATTACHMENT_FLAGS.
+
+
+ Indicates the MAPI property PR_ATTACHMENT_X400_PARAMETERS.
+
+
+ Indicates the MAPI property PR_ATTACH_METHOD.
+
+
+ Indicates the MAPI property PR_ATTACH_MIME_SEQUENCE.
+
+
+ Indicates the MAPI property PR_ATTACH_MIME_TAG.
+
+
+ Indicates the MAPI property PR_ATTACH_NETSCAPE_MAC_INFO.
+
+
+ Indicates the MAPI property PR_ATTACH_NUM.
+
+
+ Indicates the MAPI property PR_ATTACH_PATHNAME.
+
+
+ Indicates the MAPI property PR_ATTACH_RENDERING.
+
+
+ Indicates the MAPI property PR_ATTACH_SIZE.
+
+
+ Indicates the MAPI property PR_ATTACH_TAG.
+
+
+ Indicates the MAPI property PR_ATTACH_TRANSPORT_NAME.
+
+
+ Indicates the MAPI property PR_AUTHORIZING_USERS.
+
+
+ Indicates the MAPI property PR_AUTO_FORWARD_COMMENT.
+
+
+ Indicates the MAPI property PR_AUTO_FORWARDED.
+
+
+ Indicates the PR_AUTO_RESPONSE_SUPPRESS.
+
+
+ Indicates the MAPI property PR_BEEPER_TELEPHONE_NUMBER_W.
+
+
+ Indicates the MAPI property PR_BIRTHDAY.
+
+
+ Indicates the MAPI property PR_BODY.
+
+
+ Indicates the MAPI property PR_BODY_CONTENT_ID.
+
+
+ Indicates the MAPI property PR_BODY_CONTENT_LOCATION.
+
+
+ Indicates the MAPI property PR_BODY_CRC.
+
+
+ Indicates the MAPI property PR_BODY_HTML with binary data.
+
+
+ Indicates the MAPI property PR_BUSINESS2_TELEPHONE_NUMBER_A.
+
+
+ Indicates the MAPI property PR_BUSINESS_ADDRESS_CITY.
+
+
+ Indicates the MAPI property PR_BUSINESS_ADDRESS_COUNTRY.
+
+
+ Indicates the MAPI property PR_BUSINESS_ADDRESS_POSTAL_CODE.
+
+
+ Indicates the MAPI property PR_BUSINESS_ADDRESS_STREET.
+
+
+ Indicates the MAPI property PR_BUSINESS_FAX_NUMBER.
+
+
+ Indicates the MAPI property PR_BUSINESS_HOME_PAGE.
+
+
+ Indicates the MAPI property PR_CALLBACK_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_CAR_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_CHILDRENS_NAMES.
+
+
+ Indicates the MAPI property PR_CLIENT_SUBMIT_TIME.
+
+
+ Indicates the MAPI property PR_COMMENT.
+
+
+ Indicates the MAPI property PR_COMMON_VIEWS_ENTRYID.
+
+
+ Indicates the MAPI property PR_COMPANY_MAIN_PHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_COMPANY_NAME.
+
+
+ Indicates the MAPI property PR_COMPUTER_NETWORK_NAME.
+
+
+ Indicates the MAPI property PR_CONTACT_ADDRTYPES.
+
+
+ Indicates the MAPI property PR_CONTACT_DEFAULT_ADDRESS_INDEX.
+
+
+ Indicates the MAPI property PR_CONTACT_EMAIL_ADDRESSES.
+
+
+ Indicates the MAPI property PR_CONTACT_ENTRYIDS.
+
+
+ Indicates the MAPI property PR_CONTACT_VERSION.
+
+
+ Indicates the MAPI property PR_CONTAINER_CLASS.
+
+
+ Indicates the MAPI property PR_CONTAINER_CONTENTS.
+
+
+ Indicates the MAPI property PR_CONTAINER_FLAGS.
+
+
+ Indicates the MAPI property PR_CONTAINER_HIERARCHY.
+
+
+ Indicates the MAPI property PR_CONTAINER_MODIFY_VERSION.
+
+
+ Indicates the MAPI property PR_CONTENT_CONFIDENTIALITY_ALGORITHM_ID.
+
+
+ Indicates the MAPI property PR_CONTENT_CORRELATOR.
+
+
+ Indicates the MAPI property PR_CONTENT_COUNT.
+
+
+ Indicates the MAPI property PR_CONTENT_IDENTIFIER.
+
+
+ Indicates the MAPI property PR_CONTENT_INTEGRITY_CHECK.
+
+
+ Indicates the MAPI property PR_CONTENT_LENGTH.
+
+
+ Indicates the MAPI property PR_CONTENT_RETURN_REQUESTED.
+
+
+ Indicates the MAPI property PR_CONTENTS_SORT_ORDER.
+
+
+ Indicates the MAPI property PR_CONTENT_UNREAD.
+
+
+ Indicates the MAPI property PR_CONTROL_FLAGS.
+
+
+ Indicates the MAPI property PR_CONTROL_ID.
+
+
+ Indicates the MAPI property PR_CONTROL_STRUCTURE.
+
+
+ Indicates the MAPI property PR_CONTROL_TYPE.
+
+
+ Indicates the MAPI property PR_CONVERSATION_INDEX.
+
+
+ Indicates the MAPI property PR_CONVERSATION_KEY.
+
+
+ Indicates the MAPI property PR_CONVERSATION_TOPIC.
+
+
+ Indicates the MAPI property PR_CONVERSION_EITS.
+
+
+ Indicates the MAPI property PR_CONVERSION_PROHIBITED.
+
+
+ Indicates the MAPI property PR_CONVERSION_WITH_LOSS_PROHIBITED.
+
+
+ Indicates the MAPI property PR_CONVERTED_EITS.
+
+
+ Indicates the MAPI property PR_CORRELATE.
+
+
+ Indicates the MAPI property PR_CORRELATE_MTSID.
+
+
+ Indicates the MAPI property PR_COUNTRY.
+
+
+ Indicates the MAPI property PR_CREATE_TEMPLATES.
+
+
+ Indicates the MAPI property PR_CREATION_TIME.
+
+
+ Indicates the MAPI property PR_CREATION_VERSION.
+
+
+ Indicates the MAPI property PR_CURRENT_VERSION.
+
+
+ Indicates the MAPI property PR_CUSTOMER_ID.
+
+
+ Indicates the MAPI property PR_DEFAULT_PROFILE.
+
+
+ Indicates the MAPI property PR_DEFAULT_STORE.
+
+
+ Indicates the MAPI property PR_DEFAULT_VIEW_ENTRYID.
+
+
+ Indicates the MAPI property PR_DEF_CREATE_DL.
+
+
+ Indicates the MAPI property PR_DEF_CREATE_MAILUSER.
+
+
+ Indicates the MAPI property PR_DEFERRED_DELIVERY_TIME.
+
+
+ Indicates the MAPI property PR_DELEGATION.
+
+
+ Indicates the MAPI property PR_DELETE_AFTER_SUBMIT.
+
+
+ Indicates the MAPI property PR_DELIVER_TIME.
+
+
+ Indicates the MAPI property PR_DELIVERY_POINT.
+
+
+ Indicates the MAPI property PR_DELTAX.
+
+
+ Indicates the MAPI property PR_DELTAY.
+
+
+ Indicates the MAPI property PR_DEPARTMENT_NAME.
+
+
+ Indicates the MAPI property PR_DEPTH.
+
+
+ Indicates the MAPI property PR_DETAILS_TABLE.
+
+
+ Indicates the MAPI property PR_DISCARD_REASON.
+
+
+ Indicates the MAPI property PR_DISCLOSE_RECIPIENTS.
+
+
+ Indicates the MAPI property PR_DISCLOSURE_OF_RECIPIENTS.
+
+
+ Indicates the MAPI property PR_DISCRETE_VALUES.
+
+
+ Indicates the MAPI property PR_DISC_VAL.
+
+
+ Indicates the MAPI property PR_DISPLAY_BCC.
+
+
+ Indicates the MAPI property PR_DISPLAY_CC.
+
+
+ Indicates the MAPI property PR_DISPLAY_NAME.
+
+
+ Indicates the MAPI property PR_DISPLAY_NAME_PREFIX.
+
+
+ Indicates the MAPI property PR_DISPLAY_TO.
+
+
+ Indicates the MAPI property PR_DISPLAY_TYPE.
+
+
+ Indicates the MAPI property PR_DL_EXPANSION_HISTORY.
+
+
+ Indicates the MAPI property PR_DL_EXPANSION_PROHIBITED.
+
+
+ Indicates the MAPI property PR_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_END_DATE.
+
+
+ Indicates the MAPI property PR_ENTRYID.
+
+
+ Indicates the MAPI property PR_EXPAND_BEGIN_TIME.
+
+
+ Indicates the MAPI property PR_EXPANDED_BEGIN_TIME.
+
+
+ Indicates the MAPI property PR_EXPANDED_END_TIME.
+
+
+ Indicates the MAPI property PR_EXPAND_END_TIME.
+
+
+ Indicates the MAPI property PR_EXPIRY_TIME.
+
+
+ Indicates the MAPI property PR_EXPLICIT_CONVERSION.
+
+
+ Indicates the MAPI property PR_FILTERING_HOOKS.
+
+
+ Indicates the MAPI property PR_FINDER_ENTRYID.
+
+
+ Indicates the MAPI property PR_FOLDER_ASSOCIATED_CONTENTS.
+
+
+ Indicates the MAPI property PR_FOLDER_TYPE.
+
+
+ Indicates the MAPI property PR_FORM_CATEGORY.
+
+
+ Indicates the MAPI property PR_FORM_CATEGORY_SUB.
+
+
+ Indicates the MAPI property PR_FORM_ClsID.
+
+
+ Indicates the MAPI property PR_FORM_CONTACT_NAME.
+
+
+ Indicates the MAPI property PR_FORM_DESIGNER_GUID.
+
+
+ Indicates the MAPI property PR_FORM_DESIGNER_NAME.
+
+
+ Indicates the MAPI property PR_FORM_HIDDEN.
+
+
+ Indicates the MAPI property PR_FORM_HOST_MAP.
+
+
+ Indicates the MAPI property PR_FORM_MESSAGE_BEHAVIOR.
+
+
+ Indicates the MAPI property PR_FORM_VERSION.
+
+
+ Indicates the MAPI property PR_FTP_SITE.
+
+
+ Indicates the MAPI property PR_GENDER.
+
+
+ Indicates the MAPI property PR_GENERATION.
+
+
+ Indicates the MAPI property PR_GIVEN_NAME.
+
+
+ Indicates the MAPI property PR_GOVERNMENT_ID_NUMBER.
+
+
+ Indicates the MAPI property PR_HASATTACH.
+
+
+ Indicates the MAPI property PR_HEADER_FOLDER_ENTRYID.
+
+
+ Indicates the MAPI property PR_HOBBIES.
+
+
+ Indicates the MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_HOME_ADDRESS_CITY.
+
+
+ Indicates the MAPI property PR_HOME_ADDRESS_COUNTRY.
+
+
+ Indicates the MAPI property PR_HOME_ADDRESS_POSTAL_CODE.
+
+
+ Indicates the MAPI property PR_HOME_ADDRESS_POST_OFFICE_BOX.
+
+
+ Indicates the MAPI property PR_HOME_ADDRESS_STATE_OR_PROVINCE.
+
+
+ Indicates the MAPI property PR_HOME_ADDRESS_STREET.
+
+
+ Indicates the MAPI property PR_HOME_FAX_NUMBER.
+
+
+ Indicates the MAPI property PR_HOME_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_ICON.
+
+
+ Indicates the MAPI property PR_IDENTITY_DISPLAY.
+
+
+ Indicates the MAPI property PR_IDENTITY_ENTRYID.
+
+
+ Indicates the MAPI property PR_IDENTITY_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_IMPLICIT_CONVERSION_PROHIBITED.
+
+
+ Indicates the MAPI property PR_IMPORTANCE.
+
+
+ Indicates the MAPI property PR_INCOMPLETE_COPY.
+
+
+ Indicates the Internet Mail Override Charset.
+
+
+ Indicates the Internet Mail Override Format.
+
+
+ Indicates the MAPI property PR_INITIAL_DETAILS_PANE.
+
+
+ Indicates the MAPI property PR_INITIALS.
+
+
+ Indicates the MAPI property PR_IN_REPLY_TO_ID.
+
+
+ Indicates the MAPI property PR_INSTANCE_KEY.
+
+
+ Indicates the MAPI property PR_INTERNET_APPROVED.
+
+
+ Indicates the MAPI property PR_INTERNET_ARTICLE_NUMBER.
+
+
+ Indicates the MAPI property PR_INTERNET_CONTROL.
+
+
+ Indicates the MAPI property PR_INTERNET_CPID.
+
+
+ Indicates the MAPI property PR_INTERNET_DISTRIBUTION.
+
+
+ Indicates the MAPI property PR_INTERNET_FOLLOWUP_TO.
+
+
+ Indicates the MAPI property PR_INTERNET_LINES.
+
+
+ Indicates the MAPI property PR_INTERNET_MESSAGE_ID.
+
+
+ Indicates the MAPI property PR_INTERNET_NEWSGROUPS.
+
+
+ Indicates the MAPI property PR_INTERNET_NNTP_PATH.
+
+
+ Indicates the MAPI property PR_INTERNET_ORGANIZATION.
+
+
+ Indicates the MAPI property PR_INTERNET_PRECEDENCE.
+
+
+ Indicates the MAPI property PR_INTERNET_REFERENCES.
+
+
+ Indicates the MAPI property PR_IPM_ID.
+
+
+ Indicates the MAPI property PR_IPM_OUTBOX_ENTRYID.
+
+
+ Indicates the MAPI property PR_IPM_OUTBOX_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_IPM_RETURN_REQUESTED.
+
+
+ Indicates the MAPI property PR_IPM_SENTMAIL_ENTRYID.
+
+
+ Indicates the MAPI property PR_IPM_SENTMAIL_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_IPM_SUBTREE_ENTRYID.
+
+
+ Indicates the MAPI property PR_IPM_SUBTREE_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_IPM_WASTEBASKET_ENTRYID.
+
+
+ Indicates the MAPI property PR_IPM_WASTEBASKET_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_ISDN_NUMBER.
+
+
+ Indicates the MAPI property PR_KEYWORD.
+
+
+ Indicates the MAPI property PR_LANGUAGE.
+
+
+ Indicates the MAPI property PR_LANGUAGES.
+
+
+ Indicates the MAPI property PR_LAST_MODIFICATION_TIME.
+
+
+ Indicates the MAPI property PR_LATEST_DELIVERY_TIME.
+
+
+ Indicates the MAPI property PR_LIST_HELP.
+
+
+ Indicates the MAPI property PR_LIST_SUBSCRIBE.
+
+
+ Indicates the MAPI property PR_LIST_UNSUBSCRIBE.
+
+
+ Indicates the MAPI property PR_LOCALITY.
+
+
+ Indicates the Store property, ptagLocallyDelivered.
+
+
+ Indicates the MAPI property PR_LOCATION.
+
+
+ Indicates the MAPI property PR_LOCK_BRANCH_ID.
+
+
+ Indicates the MAPI property PR_LOCK_DEPTH.
+
+
+ Indicates the MAPI property PR_LOCK_ENLISTMENT_CONTEXT.
+
+
+ Indicates the MAPI property PR_LOCK_EXPIRY_TIME.
+
+
+ Indicates the MAPI property PR_LOCK_PERSISTENT.
+
+
+ Indicates the MAPI property PR_LOCK_RESOURCE_DID.
+
+
+ Indicates the MAPI property PR_LOCK_RESOURCE_FID.
+
+
+ Indicates the MAPI property PR_LOCK_RESOURCE_MID.
+
+
+ Indicates the MAPI property PR_LOCK_SCOPE.
+
+
+ Indicates the MAPI property PR_LOCK_TIMEOUT.
+
+
+ Indicates the MAPI property PR_LOCK_TYPE.
+
+
+ Indicates the MAPI property PR_MAIL_PERMISSION.
+
+
+ Indicates the MAPI property PR_MANAGER_NAME.
+
+
+ Indicates the MAPI property PR_MAPPING_SIGNATURE.
+
+
+ Indicates the MAPI property PR_MDB_PROVIDER.
+
+
+ Indicates the MAPI property PR_MESSAGE_ATTACHMENTS.
+
+
+ Indicates the MAPI property PR_MESSAGE_CC_ME.
+
+
+ Indicates the MAPI property PR_MESSAGE_CLASS.
+
+
+ Indicates the MAPI property PR_MESSAGE_CODEPAGE.
+
+
+ Indicates the MAPI property PR_MESSAGE_DELIVERY_ID.
+
+
+ Indicates the MAPI property PR_MESSAGE_DELIVERY_TIME.
+
+
+ Indicates the MAPI property PR_MESSAGE_DOWNLOAD_TIME.
+
+
+ Indicates the MAPI property PR_MESSAGE_FLAGS.
+
+
+ Indicates the MAPI property PR_MESSAGE_RECIPIENTS.
+
+
+ Indicates the MAPI property PR_MESSAGE_RECIP_ME.
+
+
+ Indicates the MAPI property PR_MESSAGE_SECURITY_LABEL.
+
+
+ Indicates the MAPI property PR_MESSAGE_SIZE.
+
+
+ Indicates the MAPI property PR_MESSAGE_SUBMISSION_ID.
+
+
+ Indicates the MAPI property PR_MESSAGE_TOKEN.
+
+
+ Indicates the MAPI property PR_MESSAGE_TO_ME.
+
+
+ Indicates the MAPI property PR_MHS_COMMON_NAME.
+
+
+ Indicates the MAPI property PR_MIDDLE_NAME.
+
+
+ Indicates the MAPI property PR_MINI_ICON.
+
+
+ Indicates the MAPI property PR_MOBILE_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_MODIFY_VERSION.
+
+
+ Indicates the MAPI property PR_MSG_STATUS.
+
+
+ Indicates the MAPI property PR_NDR_DIAG_CODE.
+
+
+ Indicates the MAPI property PR_NDR_REASON_CODE.
+
+
+ Indicates the MAPI property PR_NDR_STATUS_CODE.
+
+
+ Indicates the MAPI property PR_NEWSGROUP_NAME.
+
+
+ Indicates the MAPI property PR_NICKNAME.
+
+
+ Indicates the MAPI property PR_NNTP_XREF.
+
+
+ Indicates the MAPI property PR_NON_RECEIPT_NOTIFICATION_REQUESTED.
+
+
+ Indicates the MAPI property PR_NON_RECEIPT_REASON.
+
+
+ Indicates the MAPI property PR_NORMALIZED_SUBJECT.
+
+
+ Indicates the MAPI property PR_NT_SECURITY_DESCRIPTOR.
+
+
+ Indicates the MAPI property PR_NULL.
+
+
+ Indicates the MAPI property PR_Object_TYPE.
+
+
+ Indicates the MAPI property PR_OBSOLETED_IPMS.
+
+
+ Indicates the MAPI property PR_OFFICE2_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_OFFICE_LOCATION.
+
+
+ Indicates the MAPI property PR_OFFICE_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_OOF_REPLY_TYPE.
+
+
+ Indicates the MAPI property PR_ORGANIZATIONAL_ID_NUMBER.
+
+
+ Indicates the MAPI property PR_ORIG_ENTRYID.
+
+
+ Indicates the MAPI property PR_ORIGINAL_AUTHOR_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_ORIGINAL_AUTHOR_ENTRYID.
+
+
+ Indicates the MAPI property PR_ORIGINAL_AUTHOR_NAME.
+
+
+ Indicates the MAPI property PR_ORIGINAL_AUTHOR_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_ORIGINAL_DELIVERY_TIME.
+
+
+ Indicates the MAPI property PR_ORIGINAL_DISPLAY_BCC.
+
+
+ Indicates the MAPI property PR_ORIGINAL_DISPLAY_CC.
+
+
+ Indicates the MAPI property PR_ORIGINAL_DISPLAY_NAME.
+
+
+ Indicates the MAPI property PR_ORIGINAL_DISPLAY_TO.
+
+
+ Indicates the MAPI property PR_ORIGINAL_EITS.
+
+
+ Indicates the MAPI property PR_ORIGINAL_ENTRYID.
+
+
+ Indicates the MAPI property PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_ORIGINALLY_INTENDED_RECIP_ENTRYID.
+
+
+ Indicates the MAPI property PR_ORIGINALLY_INTENDED_RECIPIENT_NAME.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENDER_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENDER_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENDER_ENTRYID.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENDER_NAME.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENDER_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENSITIVITY.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENT_REPRESENTING_ENTRYID.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENT_REPRESENTING_NAME.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENT_REPRESENTING_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SUBJECT.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SUBMIT_TIME.
+
+
+ Indicates the MAPI property PR_ORIGINATING_MTA_CERTIFICATE.
+
+
+ Indicates the MAPI property PR_ORIGINATOR_AND_DL_EXPANSION_HISTORY.
+
+
+ Indicates the MAPI property PR_ORIGINATOR_CERTIFICATE.
+
+
+ Indicates the MAPI property PR_ORIGINATOR_DELIVERY_REPORT_REQUESTED.
+
+
+ Indicates the MAPI property PR_ORIGINATOR_NON_DELIVERY_REPORT_REQUESTED.
+
+
+ Indicates the MAPI property PR_ORIGINATOR_REQUESTED_ALTERNATE_RECIPIENT.
+
+
+ Indicates the MAPI property PR_ORIGINATOR_RETURN_ADDRESS.
+
+
+ Indicates the MAPI property PR_ORIGIN_CHECK.
+
+
+ Indicates the MAPI property PR_ORIG_MESSAGE_CLASS.
+
+
+ Indicates the MAPI property PR_OTHER_ADDRESS_CITY.
+
+
+ Indicates the MAPI property PR_OTHER_ADDRESS_COUNTRY.
+
+
+ Indicates the MAPI property PR_OTHER_ADDRESS_POSTAL_CODE.
+
+
+ Indicates the MAPI property PR_OTHER_ADDRESS_POST_OFFICE_BOX.
+
+
+ Indicates the MAPI property PR_OTHER_ADDRESS_STATE_OR_PROVINCE.
+
+
+ Indicates the MAPI property PR_OTHER_ADDRESS_STREET.
+
+
+ Indicates the MAPI property PR_OTHER_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_OWNER_APPT_ID.
+
+
+ Indicates the MAPI property PR_OWN_STORE_ENTRYID.
+
+
+ Indicates the MAPI property PR_PAGER_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_PARENT_DISPLAY.
+
+
+ Indicates the MAPI property PR_PARENT_ENTRYID.
+
+
+ Indicates the MAPI property PR_PARENT_KEY.
+
+
+ Indicates the MAPI property PR_PERSONAL_HOME_PAGE.
+
+
+ Indicates the MAPI property PR_PHYSICAL_DELIVERY_BUREAU_FAX_DELIVERY.
+
+
+ Indicates the MAPI property PR_PHYSICAL_DELIVERY_MODE.
+
+
+ Indicates the MAPI property PR_PHYSICAL_DELIVERY_REPORT_REQUEST.
+
+
+ Indicates the MAPI property PR_PHYSICAL_FORWARDING_ADDRESS.
+
+
+ Indicates the MAPI property PR_PHYSICAL_FORWARDING_ADDRESS_REQUESTED.
+
+
+ Indicates the MAPI property PR_PHYSICAL_FORWARDING_PROHIBITED.
+
+
+ Indicates the MAPI property PR_PHYSICAL_RENDITION_ATTRIBUTES.
+
+
+ Indicates the MAPI property PR_POSTAL_ADDRESS.
+
+
+ Indicates the MAPI property PR_POSTAL_CODE.
+
+
+ Indicates the MAPI property PR_POST_FOLDER_ENTRIES.
+
+
+ Indicates the MAPI property PR_POST_FOLDER_NAMES.
+
+
+ Indicates the MAPI property PR_POST_OFFICE_BOX.
+
+
+ Indicates the MAPI property PR_POST_REPLY_DENIED.
+
+
+ Indicates the MAPI property PR_POST_REPLY_FOLDER_ENTRIES.
+
+
+ Indicates the MAPI property PR_POST_REPLY_FOLDER_NAMES.
+
+
+ Indicates the MAPI property PR_PREFERRED_BY_NAME.
+
+
+ Indicates the MAPI property PR_PREPROCESS.
+
+
+ Indicates the MAPI property PR_PRIMARY_CAPABILITY.
+
+
+ Indicates the MAPI property PR_PRIMARY_FAX_NUMBER.
+
+
+ Indicates the MAPI property PR_PRIMARY_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_PRIORITY.
+
+
+ Indicates the MAPI property PR_PROFESSION.
+
+
+ Indicates the MAPI property PR_PROFILE_NAME.
+
+
+ Indicates the MAPI property PR_PROOF_OF_DELIVERY.
+
+
+ Indicates the MAPI property PR_PROOF_OF_DELIVERY_REQUESTED.
+
+
+ Indicates the MAPI property PR_PROOF_OF_SUBMISSION.
+
+
+ Indicates the MAPI property PR_PROOF_OF_SUBMISSION_REQUESTED.
+
+
+ Indicates the MAPI property PROP_ID_SECURE_MAX.
+
+
+ Indicates the MAPI property PROP_ID_SECURE_MIN.
+
+
+ Indicates the MAPI property PR_PROVIDER_DISPLAY.
+
+
+ Indicates the MAPI property PR_PROVIDER_DLL_NAME.
+
+
+ Indicates the MAPI property PR_PROVIDER_ORDINAL.
+
+
+ Indicates the MAPI property PR_PROVIDER_SUBMIT_TIME.
+
+
+ Indicates the MAPI property PR_PROVIDER_UID.
+
+
+ Indicates the MAPI property PR_PUID.
+
+
+ Indicates the MAPI property PR_RADIO_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_RCVD_REPRESENTING_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_RCVD_REPRESENTING_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_RCVD_REPRESENTING_ENTRYID.
+
+
+ Indicates the MAPI property PR_RCVD_REPRESENTING_NAME.
+
+
+ Indicates the MAPI property PR_RCVD_REPRESENTING_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_READ_RECEIPT_ENTRYID.
+
+
+ Indicates the MAPI property PR_READ_RECEIPT_REQUESTED.
+
+
+ Indicates the MAPI property PR_READ_RECEIPT_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_RECEIPT_TIME.
+
+
+ Indicates the MAPI property PR_RECEIVED_BY_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_RECEIVED_BY_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_RECEIVED_BY_ENTRYID.
+
+
+ Indicates the MAPI property PR_RECEIVED_BY_NAME.
+
+
+ Indicates the MAPI property PR_RECEIVED_BY_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_RECEIVE_FOLDER_SETTINGS.
+
+
+ Indicates the MAPI property PR_RECIPIENT_CERTIFICATE.
+
+
+ Indicates the MAPI property PR_RECIPIENT_NUMBER_FOR_ADVICE.
+
+
+ Indicates the MAPI property PR_RECIPIENT_REASSIGNMENT_PROHIBITED.
+
+
+ Indicates the MAPI property PR_RECIPIENT_STATUS.
+
+
+ Indicates the MAPI property PR_RECIPIENT_TYPE.
+
+
+ Indicates the MAPI property PR_RECORD_KEY.
+
+
+ Indicates the MAPI property PR_REDIRECTION_HISTORY.
+
+
+ Indicates the MAPI property PR_REFERRED_BY_NAME.
+
+
+ Indicates the MAPI property PR_REGISTERED_MAIL_TYPE.
+
+
+ Indicates the MAPI property PR_RELATED_IPMS.
+
+
+ Indicates the MAPI property PR_REMOTE_PROGRESS.
+
+
+ Indicates the MAPI property PR_REMOTE_PROGRESS_TEXT.
+
+
+ Indicates the MAPI property PR_REMOTE_VALIDATE_OK.
+
+
+ Indicates the MAPI property PR_RENDERING_POSITION.
+
+
+ Indicates the MAPI property PR_REPLY_RECIPIENT_ENTRIES.
+
+
+ Indicates the MAPI property PR_REPLY_RECIPIENT_NAMES.
+
+
+ Indicates the MAPI property PR_REPLY_REQUESTED.
+
+
+ Indicates the MAPI property PR_REPLY_TIME.
+
+
+ Indicates the MAPI property PR_REPORT_ENTRYID.
+
+
+ Indicates the MAPI property PR_REPORTING_DL_NAME.
+
+
+ Indicates the MAPI property PR_REPORTING_MTA_CERTIFICATE.
+
+
+ Indicates the MAPI property PR_REPORT_NAME.
+
+
+ Indicates the MAPI property PR_REPORT_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_REPORT_TAG.
+
+
+ Indicates the MAPI property PR_REPORT_TEXT.
+
+
+ Indicates the MAPI property PR_REPORT_TIME.
+
+
+ Indicates the MAPI property PR_REQUESTED_DELIVERY_METHOD.
+
+
+ Indicates the MAPI property PR_RESOURCE_FLAGS.
+
+
+ Indicates the MAPI property PR_RESOURCE_METHODS.
+
+
+ Indicates the MAPI property PR_RESOURCE_PATH.
+
+
+ Indicates the MAPI property PR_RESOURCE_TYPE.
+
+
+ Indicates the MAPI property PR_RESPONSE_REQUESTED.
+
+
+ Indicates the MAPI property PR_RESPONSIBILITY.
+
+
+ Indicates the MAPI property PR_RETURNED_IPM.
+
+
+ Indicates the MAPI property PR_ROWID.
+
+
+ Indicates the MAPI property PR_ROW_TYPE.
+
+
+ Indicates the MAPI property PR_RTF_COMPRESSED.
+
+
+ Indicates the MAPI property PR_RTF_IN_SYNC.
+
+
+ Indicates the MAPI property PR_RTF_SYNC_BODY_COUNT.
+
+
+ Indicates the MAPI property PR_RTF_SYNC_BODY_CRC.
+
+
+ Indicates the MAPI property PR_RTF_SYNC_BODY_TAG.
+
+
+ Indicates the MAPI property PR_RTF_SYNC_PREFIX_COUNT.
+
+
+ Indicates the MAPI property PR_RTF_SYNC_TRAILING_COUNT.
+
+
+ Indicates the MAPI property PR_SEARCH.
+
+
+ Indicates the MAPI property PR_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_SECURITY.
+
+
+ Indicates the MAPI property PR_SELECTABLE.
+
+
+ Indicates the MAPI property PR_SENDER_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_SENDER_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_SENDER_ENTRYID.
+
+
+ Indicates the MAPI property PR_SENDER_NAME.
+
+
+ Indicates the MAPI property PR_SENDER_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_SEND_INTERNET_ENCODING.
+
+
+ Indicates the property on IPM.Outlook.Recall messages.
+
+
+ Indicates the MAPI property PR_SEND_RICH_INFO.
+
+
+ Indicates the MAPI property PR_SENSITIVITY.
+
+
+ Indicates the MAPI property PR_SENTMAIL_ENTRYID.
+
+
+ Indicates the MAPI property PR_SENT_REPRESENTING_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_SENT_REPRESENTING_ENTRYID.
+
+
+ Indicates the MAPI property PR_SENT_REPRESENTING_NAME.
+
+
+ Indicates the MAPI property PR_SENT_REPRESENTING_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_SERVICE_DELETE_FILES.
+
+
+ Indicates the MAPI property PR_SERVICE_DLL_NAME.
+
+
+ Indicates the MAPI property PR_SERVICE_ENTRY_NAME.
+
+
+ Indicates the MAPI property PR_SERVICE_EXTRA_UIDS.
+
+
+ Indicates the MAPI property PR_SERVICE_NAME.
+
+
+ Indicates the MAPI property PR_SERVICES.
+
+
+ Indicates the MAPI property PR_SERVICE_SUPPORT_FILES.
+
+
+ Indicates the MAPI property PR_SERVICE_UID.
+
+
+ Indicates the MAPI property PR_SEVEN_BIT_DISPLAY_NAME.
+
+
+ Indicates the MAPI property PR_SMTP_ADDRESS.
+
+
+ Indicates the MAPI property PR_SPOOLER_STATUS.
+
+
+ Indicates the MAPI property PR_SPOUSE_NAME.
+
+
+ Indicates the MAPI property PR_START_DATE.
+
+
+ Indicates the MAPI property PR_STATE_OR_PROVINCE.
+
+
+ Indicates the MAPI property PR_STATUS.
+
+
+ Indicates the MAPI property PR_STATUS_CODE.
+
+
+ Indicates the MAPI property PR_STATUS_STRING.
+
+
+ Indicates the MAPI property PR_STORE_ENTRYID.
+
+
+ Indicates the MAPI property PR_STORE_PROVIDERS.
+
+
+ Indicates the MAPI property PR_STORE_RECORD_KEY.
+
+
+ Indicates the MAPI property PR_STORE_STATE.
+
+
+ Indicates the MAPI property PR_STORE_SUPPORT_MASK.
+
+
+ Indicates the MAPI property PR_STREET_ADDRESS.
+
+
+ Indicates the MAPI property PR_SUBFOLDERS.
+
+
+ Indicates the MAPI property PR_SUBJECT.
+
+
+ Indicates the MAPI property PR_SUBJECT_IPM.
+
+
+ Indicates the MAPI property PR_SUBJECT_PREFIX.
+
+
+ Indicates the MAPI property PR_SUBMIT_FLAGS.
+
+
+ Indicates the MAPI property PR_SUPERSEDES.
+
+
+ Indicates the MAPI property PR_SUPPLEMENTARY_INFO.
+
+
+ Indicates the MAPI property PR_SURNAME.
+
+
+ Indicates the MAPI property PR_TELEX_NUMBER.
+
+
+ Indicates the MAPI property PR_TEMPLATEID.
+
+
+ Indicates the MAPI property PR_TITLE.
+
+
+ Indicates the MAPI property PR_TNEF_CORRELATION_KEY.
+
+
+ Indicates the MAPI property PR_TRANSMITABLE_DISPLAY_NAME.
+
+
+ Indicates the MAPI property PR_TRANSPORT_KEY.
+
+
+ Indicates the MAPI property PR_TRANSPORT_MESSAGE_HEADERS.
+
+
+ Indicates the MAPI property PR_TRANSPORT_PROVIDERS.
+
+
+ Indicates the MAPI property PR_TRANSPORT_STATUS.
+
+
+ Indicates the MAPI property PR_TTYTDD_PHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_TYPE_OF_MTS_USER.
+
+
+ Indicates the MAPI property PR_USER_CERTIFICATE.
+
+
+ Indicates the MAPI property PR_USER_X509_CERTIFICATE.
+
+
+ Indicates the MAPI property PR_VALID_FOLDER_MASK.
+
+
+ Indicates the MAPI property PR_VIEWS_ENTRYID.
+
+
+ Indicates the MAPI property PR_WEDDING_ANNIVERSARY.
+
+
+ Indicates the MAPI property PR_X400_CONTENT_TYPE.
+
+
+ Indicates the MAPI property PR_X400_DEFERRED_DELIVERY_CANCEL.
+
+
+ Indicates the MAPI property PR_XPOS.
+
+
+ Indicates the MAPI property PR_YPOS.
+
+
+ The class is a nested reader that reads individual properties from a TNEF attribute or a recipient row.
+
+
+ The method moves to the next property.
+ The method returns true if there was another property to which to move. Otherwise, returns false.
+
+
+ The method moves to the next row in the current RecipientTable attribute.
+ The method returns true if there was another row to which to move. Otherwise, returns false.
+
+
+ The method moves to the next value in the current property.
+ The method returns true if there was another value to which to move. Otherwise, returns false.
+
+
+ The method reads the raw value of the current attribute value.
+ The method returns the number of characters read.
+ When this method returns, it contains the specified byte array with the values between index and (offset + count - 1) replaced by the characters read from the current source.
+ The place in buffer at which to begin writing.
+ The maximum number of characters to read. If the end of the stream is reached before count of characters is read into buffer, the current method returns.
+
+
+ The method reads the current attribute value.
+ When this method returns, it contains the specified character array with the values between index and (offset + count - 1) replaced by the characters read from the current source.
+ The place in buffer at which to begin writing.
+ The maximum number of characters to read. If the end of the stream is reached before count of characters is read into buffer, the current method returns.
+
+
+ The structure contains MAPI attribute property identifiers.
+
+
+ The constructor creates a new structure identified by the tag parameter.
+ An integer specifying the type of this structure.
+
+
+ The constructor creates a new structure identified by the parameters id and type.
+ A enumeration value used to identify this structure.
+ A enumeration value indicating whether this structure is for an attachment or a message.
+
+
+ The field represents a PR_AB_DEFAULT_DIR MAPI property.
+
+
+ The field represents a PR_AB_DEFAULT_PAB MAPI property.
+
+
+ The field represents a PR_AB_PROVIDER_ID MAPI property.
+
+
+ The field represents a PR_AB_PROVIDERS MAPI property.
+
+
+ The field represents a PR_AB_SEARCH_PATH MAPI property.
+
+
+ The field represents a PR_AB_SEARCH_PATH_UPDATE MAPI property.
+
+
+ The field represents a PR_ACCESS MAPI property.
+
+
+ The field represents a PR_ACCESS_LEVEL MAPI property.
+
+
+ The field represents a PR_ACCOUNT_A MAPI property.
+
+
+ The field represents a PR_ACCOUNT_W MAPI property.
+
+
+ The field represents a PR_ACKNOWLEDGEMENT_MODE MAPI property.
+
+
+ The field represents a PR_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_ALTERNATE_RECIPIENT MAPI property.
+
+
+ The field represents a PR_ALTERNATE_RECIPIENT_ALLOWED MAPI property.
+
+
+ The field represents a PR_ANR_A MAPI property.
+
+
+ The field represents a PR_ANR_W MAPI property.
+
+
+ The field represents a PR_ASSISTANT_A MAPI property.
+
+
+ The field represents a PR_ASSISTANT_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_ASSISTANT_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_ASSISTANT_W MAPI property.
+
+
+ The field represents a PR_ASSOC_CONTENT_COUNT MAPI property.
+
+
+ The field represents a PR_ATTACH_ADDITIONAL_INFO MAPI property.
+
+
+ The field represents a PR_ATTACH_CONTENT_BASE_A MAPI property.
+
+
+ The field represents a PR_ATTACH_CONTENT_BASE_W MAPI property.
+
+
+ The field represents a PR_ATTACH_CONTENT_ID_A MAPI property.
+
+
+ The field represents a PR_ATTACH_CONTENT_ID_W MAPI property.
+
+
+ The field represents a PR_ATTACH_CONTENT_LOCATION_A MAPI property.
+
+
+ The field represents a PR_ATTACH_CONTENT_LOCATION_W MAPI property.
+
+
+ The field represents a PR_ATTACH_DATA_BIN MAPI property.
+
+
+ The field represents a PR_ATTACH_DATA_OBJ MAPI property.
+
+
+ The field represents a PR_ATTACH_DISPOSITION_A MAPI property.
+
+
+ The field represents a PR_ATTACH_DISPOSITION_W MAPI property.
+
+
+ The field represents a PR_ATTACH_ENCODING MAPI property.
+
+
+ The field represents a PR_ATTACH_EXTENSION_A MAPI property.
+
+
+ The field represents a PR_ATTACH_EXTENSION_W MAPI property.
+
+
+ The field represents a PR_ATTACH_FILENAME_A MAPI property.
+
+
+ The field represents a PR_ATTACH_FILENAME_W MAPI property.
+
+
+ The field represents a PR_ATTACH_FLAGS MAPI property.
+
+
+ The field represents a PR_ATTACHMENT_HIDDEN MAPI property.
+
+
+ The field represents a PR_ATTACH_LONG_FILENAME_A MAPI property.
+
+
+ The field represents a PR_ATTACH_LONG_FILENAME_W MAPI property.
+
+
+ The field represents a PR_ATTACH_LONG_PATHNAME_A MAPI property.
+
+
+ The field represents a PR_ATTACH_LONG_PATHNAME_W MAPI property.
+
+
+ The field represents a PR_ATTACHMENT_FLAGS MAPI property.
+
+
+ The field represents a PR_ATTACHMENT_X400_PARAMETERS MAPI property.
+
+
+ The field represents a PR_ATTACH_METHOD MAPI property.
+
+
+ The field represents a PR_ATTACH_MIME_SEQUENCE MAPI property.
+
+
+ The field represents a PR_ATTACH_MIME_TAG_A MAPI property.
+
+
+ The field represents a PR_ATTACH_MIME_TAG_W MAPI property.
+
+
+ The field represents a PR_ATTACH_NETSCAPE_MAC_INFO MAPI property.
+
+
+ The field represents a PR_ATTACH_NUM MAPI property.
+
+
+ The field represents a PR_ATTACH_PATHNAME_A MAPI property.
+
+
+ The field represents a PR_ATTACH_PATHNAME_W MAPI property.
+
+
+ The field represents a PR_ATTACH_RENDERING MAPI property.
+
+
+ The field represents a PR_ATTACH_SIZE MAPI property.
+
+
+ The field represents a PR_ATTACH_TAG MAPI property.
+
+
+ The field represents a PR_ATTACH_TRANSPORT_NAME_A MAPI property.
+
+
+ The field represents a PR_ATTACH_TRANSPORT_NAME_W MAPI property.
+
+
+ The field represents a PR_AUTHORIZING_USERS MAPI property.
+
+
+ The field represents a PR_AUTO_FORWARD_COMMENT_A MAPI property.
+
+
+ The field represents a PR_AUTO_FORWARD_COMMENT_W MAPI property.
+
+
+ The field represents a PR_AUTO_FORWARDED MAPI property.
+
+
+ The field represents a PR_AUTO_RESPONSE_SUPPRESS MAPI property.
+
+
+ The field represents a PR_BEEPER_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_BEEPER_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_BIRTHDAY MAPI property.
+
+
+ The field represents a PR_BODY_A MAPI property.
+
+
+ The field represents a PR_BODY_CONTENT_ID_A MAPI property.
+
+
+ The field represents a PR_BODY_CONTENT_ID_W MAPI property.
+
+
+ The field represents a PR_BODY_CONTENT_LOCATION_A MAPI property.
+
+
+ The field represents a PR_BODY_CONTENT_LOCATION_W MAPI property.
+
+
+ The field represents a PR_BODY_CRC MAPI property.
+
+
+ The field represents a PR_BODY_HTML_A MAPI property.
+
+
+ The field represents a data MAPI property.
+
+
+ The field represents a PR_BODY_HTML_W MAPI property.
+
+
+ The field represents a PR_BODY_W MAPI property.
+
+
+ The field represents a PR_BUSINESS2_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_BUSINESS2_TELEPHONE_NUMBER_A_MV MAPI property.
+
+
+ The field represents a PR_BUSINESS2_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_BUSINESS2_TELEPHONE_NUMBER_W_MV MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_CITY_A MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_CITY_W MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_COUNTRY_A MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_COUNTRY_W MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_POSTAL_CODE_A MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_POSTAL_CODE_W MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_STREET_A MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_STREET_W MAPI property.
+
+
+ The field represents a PR_BUSINESS_FAX_NUMBER_A MAPI property.
+
+
+ The field represents a PR_BUSINESS_FAX_NUMBER_W MAPI property.
+
+
+ The field represents a PR_BUSINESS_HOME_PAGE_A MAPI property.
+
+
+ The field represents a PR_BUSINESS_HOME_PAGE_W MAPI property.
+
+
+ The field represents a PR_CALLBACK_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_CALLBACK_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_CAR_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_CAR_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_CHILDRENS_NAMES_A MAPI property.
+
+
+ The field represents a PR_CHILDRENS_NAMES_W MAPI property.
+
+
+ The field represents a PR_CLIENT_SUBMIT_TIME MAPI property.
+
+
+ The field represents a PR_COMMENT_A MAPI property.
+
+
+ The field represents a PR_COMMENT_W MAPI property.
+
+
+ The field represents a PR_COMMON_VIEWS_ENTRYID MAPI property.
+
+
+ The field represents a PR_COMPANY_MAIN_PHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_COMPANY_MAIN_PHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_COMPANY_NAME_A MAPI property.
+
+
+ The field represents a PR_COMPANY_NAME_W MAPI property.
+
+
+ The field represents a PR_COMPUTER_NETWORK_NAME_A MAPI property.
+
+
+ The field represents a PR_COMPUTER_NETWORK_NAME_W MAPI property.
+
+
+ The field represents a PR_CONTACT_ADDRTYPES_A MAPI property.
+
+
+ The field represents a PR_CONTACT_ADDRTYPES_W MAPI property.
+
+
+ The field represents a PR_CONTACT_DEFAULT_ADDRESS_INDEX MAPI property.
+
+
+ The field represents a PR_CONTACT_EMAIL_ADDRESSES_A MAPI property.
+
+
+ The field represents a PR_CONTACT_EMAIL_ADDRESSES_W MAPI property.
+
+
+ The field represents a PR_CONTACT_ENTRYIDS MAPI property.
+
+
+ The field represents a PR_CONTACT_VERSION MAPI property.
+
+
+ The field represents a PR_CONTAINER_CLASS_A MAPI property.
+
+
+ The field represents a PR_CONTAINER_CLASS_W MAPI property.
+
+
+ The field represents a PR_CONTAINER_CONTENTS MAPI property.
+
+
+ The field represents a PR_CONTAINER_FLAGS MAPI property.
+
+
+ The field represents a PR_CONTAINER_HIERARCHY MAPI property.
+
+
+ The field represents a PR_CONTAINER_MODIFY_VERSION MAPI property.
+
+
+ The field represents a PR_CONTENT_CONFIDENTIALITY_ALGORITHM_ID MAPI property.
+
+
+ The field represents a PR_CONTENT_CORRELATOR MAPI property.
+
+
+ The field represents a PR_CONTENT_COUNT MAPI property.
+
+
+ The field represents a PR_CONTENT_IDENTIFIER_A MAPI property.
+
+
+ The field represents a PR_CONTENT_IDENTIFIER_W MAPI property.
+
+
+ The field represents a PR_CONTENT_INTEGRITY_CHECK MAPI property.
+
+
+ The field represents a PR_CONTENT_LENGTH MAPI property.
+
+
+ The field represents a PR_CONTENT_RETURN_REQUESTED MAPI property.
+
+
+ The field represents a PR_CONTENTS_SORT_ORDER MAPI property.
+
+
+ The field represents a PR_CONTENT_UNREAD MAPI property.
+
+
+ The field represents a PR_CONTROL_FLAGS MAPI property.
+
+
+ The field represents a PR_CONTROL_ID MAPI property.
+
+
+ The field represents a PR_CONTROL_STRUCTURE MAPI property.
+
+
+ The field represents a PR_CONTROL_TYPE MAPI property.
+
+
+ The field represents a PR_CONVERSATION_INDEX MAPI property.
+
+
+ The field represents a PR_CONVERSATION_KEY MAPI property.
+
+
+ The field represents a PR_CONVERSATION_TOPIC_A MAPI property.
+
+
+ The field represents a PR_CONVERSATION_TOPIC_W MAPI property.
+
+
+ The field represents a PR_CONVERSION_EITS MAPI property.
+
+
+ The field represents a PR_CONVERSION_PROHIBITED MAPI property.
+
+
+ The field represents a PR_CONVERSION_WITH_LOSS_PROHIBITED MAPI property.
+
+
+ The field represents a PR_CONVERTED_EITS MAPI property.
+
+
+ The field represents a PR_CORRELATE MAPI property.
+
+
+ The field represents a PR_CORRELATE_MTSID MAPI property.
+
+
+ The field represents a PR_COUNTRY_A MAPI property.
+
+
+ The field represents a PR_COUNTRY_W MAPI property.
+
+
+ The field represents a PR_CREATE_TEMPLATES MAPI property.
+
+
+ The field represents a PR_CREATION_TIME MAPI property.
+
+
+ The field represents a PR_CREATION_VERSION MAPI property.
+
+
+ The field represents a PR_CURRENT_VERSION MAPI property.
+
+
+ The field represents a PR_CUSTOMER_ID_A MAPI property.
+
+
+ The field represents a PR_CUSTOMER_ID_W MAPI property.
+
+
+ The field represents a PR_DEFAULT_PROFILE MAPI property.
+
+
+ The field represents a PR_DEFAULT_STORE MAPI property.
+
+
+ The field represents a PR_DEFAULT_VIEW_ENTRYID MAPI property.
+
+
+ The field represents a PR_DEF_CREATE_DL MAPI property.
+
+
+ The field represents a PR_DEF_CREATE_MAILUSER MAPI property.
+
+
+ The field represents a PR_DEFERRED_DELIVERY_TIME MAPI property.
+
+
+ The field represents a PR_DELEGATION MAPI property.
+
+
+ The field represents a PR_DELETE_AFTER_SUBMIT MAPI property.
+
+
+ The field represents a PR_DELIVER_TIME MAPI property.
+
+
+ The field represents a PR_DELIVERY_POINT MAPI property.
+
+
+ The field represents a PR_DELTAX MAPI property.
+
+
+ The field represents a PR_DELTAY MAPI property.
+
+
+ The field represents a PR_DEPARTMENT_NAME_A MAPI property.
+
+
+ The field represents a PR_DEPARTMENT_NAME_W MAPI property.
+
+
+ The field represents a PR_DEPTH MAPI property.
+
+
+ The field represents a PR_DETAILS_TABLE MAPI property.
+
+
+ The field represents a PR_DISCARD_REASON MAPI property.
+
+
+ The field represents a PR_DISCLOSE_RECIPIENTS MAPI property.
+
+
+ The field represents a PR_DISCLOSURE_OF_RECIPIENTS MAPI property.
+
+
+ The field represents a PR_DISCRETE_VALUES MAPI property.
+
+
+ The field represents a PR_DISC_VAL MAPI property.
+
+
+ The field represents a PR_DISPLAY_BCC_A MAPI property.
+
+
+ The field represents a PR_DISPLAY_BCC_W MAPI property.
+
+
+ The field represents a PR_DISPLAY_CC_A MAPI property.
+
+
+ The field represents a PR_DISPLAY_CC_W MAPI property.
+
+
+ The field represents a PR_DISPLAY_NAME_A MAPI property.
+
+
+ The field represents a PR_DISPLAY_NAME_PREFIX_A MAPI property.
+
+
+ The field represents a PR_DISPLAY_NAME_PREFIX_W MAPI property.
+
+
+ The field represents a PR_DISPLAY_NAME_W MAPI property.
+
+
+ The field represents a PR_DISPLAY_TO_A MAPI property.
+
+
+ The field represents a PR_DISPLAY_TO_W MAPI property.
+
+
+ The field represents a PR_DISPLAY_TYPE MAPI property.
+
+
+ The field represents a PR_DL_EXPANSION_HISTORY MAPI property.
+
+
+ The field represents a PR_DL_EXPANSION_PROHIBITED MAPI property.
+
+
+ The field represents a PR_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_END_DATE MAPI property.
+
+
+ The field represents a PR_ENTRYID MAPI property.
+
+
+ The field represents a PR_EXPAND_BEGIN_TIME MAPI property.
+
+
+ The field represents a PR_EXPANDED_BEGIN_TIME MAPI property.
+
+
+ The field represents a PR_EXPANDED_END_TIME MAPI property.
+
+
+ The field represents a PR_EXPAND_END_TIME MAPI property.
+
+
+ The field represents a PR_EXPIRY_TIME MAPI property.
+
+
+ The field represents a PR_EXPLICIT_CONVERSION MAPI property.
+
+
+ The field represents a PR_FILTERING_HOOKS MAPI property.
+
+
+ The field represents a PR_FINDER_ENTRYID MAPI property.
+
+
+ The field represents a PR_FOLDER_ASSOCIATED_CONTENTS MAPI property.
+
+
+ The field represents a PR_FOLDER_TYPE MAPI property.
+
+
+ The field represents a PR_FORM_CATEGORY_A MAPI property.
+
+
+ The field represents a PR_FORM_CATEGORY_SUB_A MAPI property.
+
+
+ The field represents a PR_FORM_CATEGORY_SUB_W MAPI property.
+
+
+ The field represents a PR_FORM_CATEGORY_W MAPI property.
+
+
+ The field represents a PR_FORM_ClsID MAPI property.
+
+
+ The field represents a PR_FORM_CONTACT_NAME_A MAPI property.
+
+
+ The field represents a PR_FORM_CONTACT_NAME_W MAPI property.
+
+
+ The field represents a PR_FORM_DESIGNER_GUID MAPI property.
+
+
+ The field represents a PR_FORM_DESIGNER_NAME_A MAPI property.
+
+
+ The field represents a PR_FORM_DESIGNER_NAME_W MAPI property.
+
+
+ The field represents a PR_FORM_HIDDEN MAPI property.
+
+
+ The field represents a PR_FORM_HOST_MAP MAPI property.
+
+
+ The field represents a PR_FORM_MESSAGE_BEHAVIOR MAPI property.
+
+
+ The field represents a PR_FORM_VERSION_A MAPI property.
+
+
+ The field represents a PR_FORM_VERSION_W MAPI property.
+
+
+ The field represents a PR_FTP_SITE_A MAPI property.
+
+
+ The field represents a PR_FTP_SITE_W MAPI property.
+
+
+ The field represents a PR_GENDER MAPI property.
+
+
+ The field represents a PR_GENERATION_A MAPI property.
+
+
+ The field represents a PR_GENERATION_W MAPI property.
+
+
+ The field represents a PR_GIVEN_NAME_A MAPI property.
+
+
+ The field represents a PR_GIVEN_NAME_W MAPI property.
+
+
+ The field represents a PR_GOVERNMENT_ID_NUMBER_A MAPI property.
+
+
+ The field represents a PR_GOVERNMENT_ID_NUMBER_W MAPI property.
+
+
+ The field represents a PR_HASATTACH MAPI property.
+
+
+ The field represents a PR_HEADER_FOLDER_ENTRYID MAPI property.
+
+
+ The field represents a PR_HOBBIES_A MAPI property.
+
+
+ The field represents a PR_HOBBIES_W MAPI property.
+
+
+ The field represents a PR_HOME2_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_HOME2_TELEPHONE_NUMBER_A_MV MAPI property.
+
+
+ The field represents a PR_HOME2_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_HOME2_TELEPHONE_NUMBER_W_MV MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_CITY_A MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_CITY_W MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_COUNTRY_A MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_COUNTRY_W MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_POSTAL_CODE_A MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_POSTAL_CODE_W MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_POST_OFFICE_BOX_A MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_POST_OFFICE_BOX_W MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_STATE_OR_PROVINCE_A MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_STATE_OR_PROVINCE_W MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_STREET_A MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_STREET_W MAPI property.
+
+
+ The field represents a PR_HOME_FAX_NUMBER_A MAPI property.
+
+
+ The field represents a PR_HOME_FAX_NUMBER_W MAPI property.
+
+
+ The field represents a PR_HOME_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_HOME_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_ICON MAPI property.
+
+
+ The field represents a PR_IDENTITY_DISPLAY_A MAPI property.
+
+
+ The field represents a PR_IDENTITY_DISPLAY_W MAPI property.
+
+
+ The field represents a PR_IDENTITY_ENTRYID MAPI property.
+
+
+ The field represents a PR_IDENTITY_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_IMPLICIT_CONVERSION_PROHIBITED MAPI property.
+
+
+ The field represents a PR_IMPORTANCE MAPI property.
+
+
+ The field represents a PR_INCOMPLETE_COPY MAPI property.
+
+
+ The field represents a Charset MAPI property.
+
+
+ The field represents a Format MAPI property.
+
+
+ The field represents a PR_INITIAL_DETAILS_PANE MAPI property.
+
+
+ The field represents a PR_INITIALS_A MAPI property.
+
+
+ The field represents a PR_INITIALS_W MAPI property.
+
+
+ The field represents a PR_IN_REPLY_TO_ID_A MAPI property.
+
+
+ The field represents a PR_IN_REPLY_TO_ID_W MAPI property.
+
+
+ The field represents a PR_INSTANCE_KEY MAPI property.
+
+
+ The field represents a PR_INTERNET_APPROVED_A MAPI property.
+
+
+ The field represents a PR_INTERNET_APPROVED_W MAPI property.
+
+
+ The field represents a PR_INTERNET_ARTICLE_NUMBER MAPI property.
+
+
+ The field represents a PR_INTERNET_CONTROL_A MAPI property.
+
+
+ The field represents a PR_INTERNET_CONTROL_W MAPI property.
+
+
+ The field represents a PR_INTERNET_CPID MAPI property.
+
+
+ The field represents a PR_INTERNET_DISTRIBUTION_A MAPI property.
+
+
+ The field represents a PR_INTERNET_DISTRIBUTION_W MAPI property.
+
+
+ The field represents a PR_INTERNET_FOLLOWUP_TO_A MAPI property.
+
+
+ The field represents a PR_INTERNET_FOLLOWUP_TO_W MAPI property.
+
+
+ The field represents a PR_INTERNET_LINES MAPI property.
+
+
+ The field represents a PR_INTERNET_MESSAGE_ID_A MAPI property.
+
+
+ The field represents a PR_INTERNET_MESSAGE_ID_W MAPI property.
+
+
+ The field represents a PR_INTERNET_NEWSGROUPS_A MAPI property.
+
+
+ The field represents a PR_INTERNET_NEWSGROUPS_W MAPI property.
+
+
+ The field represents a PR_INTERNET_NNTP_PATH_A MAPI property.
+
+
+ The field represents a PR_INTERNET_NNTP_PATH_W MAPI property.
+
+
+ The field represents a PR_INTERNET_ORGANIZATION_A MAPI property.
+
+
+ The field represents a PR_INTERNET_ORGANIZATION_W MAPI property.
+
+
+ The field represents a PR_INTERNET_PRECEDENCE_A MAPI property.
+
+
+ The field represents a PR_INTERNET_PRECEDENCE_W MAPI property.
+
+
+ The field represents a PR_INTERNET_REFERENCES_A MAPI property.
+
+
+ The field represents a PR_INTERNET_REFERENCES_W MAPI property.
+
+
+ The field represents a PR_IPM_ID MAPI property.
+
+
+ The field represents a PR_IPM_OUTBOX_ENTRYID MAPI property.
+
+
+ The field represents a PR_IPM_OUTBOX_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_IPM_RETURN_REQUESTED MAPI property.
+
+
+ The field represents a PR_IPM_SENTMAIL_ENTRYID MAPI property.
+
+
+ The field represents a PR_IPM_SENTMAIL_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_IPM_SUBTREE_ENTRYID MAPI property.
+
+
+ The field represents a PR_IPM_SUBTREE_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_IPM_WASTEBASKET_ENTRYID MAPI property.
+
+
+ The field represents a PR_IPM_WASTEBASKET_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_ISDN_NUMBER_A MAPI property.
+
+
+ The field represents a PR_ISDN_NUMBER_W MAPI property.
+
+
+ The field represents a PR_KEYWORD_A MAPI property.
+
+
+ The field represents a PR_KEYWORD_W MAPI property.
+
+
+ The field represents a PR_LANGUAGE_A MAPI property.
+
+
+ The field represents a PR_LANGUAGES_A MAPI property.
+
+
+ The field represents a PR_LANGUAGES_W MAPI property.
+
+
+ The field represents a PR_LANGUAGE_W MAPI property.
+
+
+ The field represents a PR_LAST_MODIFICATION_TIME MAPI property.
+
+
+ The field represents a PR_LATEST_DELIVERY_TIME MAPI property.
+
+
+ The field represents a PR_LIST_HELP_A MAPI property.
+
+
+ The field represents a PR_LIST_HELP_W MAPI property.
+
+
+ The field represents a PR_LIST_SUBSCRIBE_A MAPI property.
+
+
+ The field represents a PR_LIST_SUBSCRIBE_W MAPI property.
+
+
+ The field represents a PR_LIST_UNSUBSCRIBE_A MAPI property.
+
+
+ The field represents a PR_LIST_UNSUBSCRIBE_W MAPI property.
+
+
+ The field represents a PR_LOCALITY_A MAPI property.
+
+
+ The field represents a PR_LOCALITY_W MAPI property.
+
+
+ The field represents a PR_LOCATION_A MAPI property.
+
+
+ The field represents a PR_LOCATION_W MAPI property.
+
+
+ The field represents a PR_LOCK_BRANCH_ID MAPI property.
+
+
+ The field represents a PR_LOCK_DEPTH MAPI property.
+
+
+ The field represents a PR_LOCK_ENLISTMENT_CONTEXT MAPI property.
+
+
+ The field represents a PR_LOCK_EXPIRY_TIME MAPI property.
+
+
+ The field represents a PR_LOCK_PERSISTENT MAPI property.
+
+
+ The field represents a PR_LOCK_RESOURCE_DID MAPI property.
+
+
+ The field represents a PR_LOCK_RESOURCE_FID MAPI property.
+
+
+ The field represents a PR_LOCK_RESOURCE_MID MAPI property.
+
+
+ The field represents a PR_LOCK_SCOPE MAPI property.
+
+
+ The field represents a PR_LOCK_TIMEOUT MAPI property.
+
+
+ The field represents a PR_LOCK_TYPE MAPI property.
+
+
+ The field represents a PR_MAIL_PERMISSION MAPI property.
+
+
+ The field represents a PR_MANAGER_NAME_A MAPI property.
+
+
+ The field represents a PR_MANAGER_NAME_W MAPI property.
+
+
+ The field represents a PR_MAPPING_SIGNATURE MAPI property.
+
+
+ The field represents a PR_MDB_PROVIDER MAPI property.
+
+
+ The field represents a PR_MESSAGE_ATTACHMENTS MAPI property.
+
+
+ The field represents a PR_MESSAGE_CC_ME MAPI property.
+
+
+ The field represents a PR_MESSAGE_CLASS_A MAPI property.
+
+
+ The field represents a PR_MESSAGE_CLASS_W MAPI property.
+
+
+ The field represents a PR_MESSAGE_CODEPAGE MAPI property.
+
+
+ The field represents a PR_MESSAGE_DELIVERY_ID MAPI property.
+
+
+ The field represents a PR_MESSAGE_DELIVERY_TIME MAPI property.
+
+
+ The field represents a PR_MESSAGE_DOWNLOAD_TIME MAPI property.
+
+
+ The field represents a PR_MESSAGE_FLAGS MAPI property.
+
+
+ The field represents a PR_MESSAGE_RECIPIENTS MAPI property.
+
+
+ The field represents a PR_MESSAGE_RECIP_ME MAPI property.
+
+
+ The field represents a PR_MESSAGE_SECURITY_LABEL MAPI property.
+
+
+ The field represents a PR_MESSAGE_SIZE MAPI property.
+
+
+ The field represents a PR_MESSAGE_SUBMISSION_ID MAPI property.
+
+
+ The field represents a PR_MESSAGE_TOKEN MAPI property.
+
+
+ The field represents a PR_MESSAGE_TO_ME MAPI property.
+
+
+ The field represents a PR_MHS_COMMON_NAME_A MAPI property.
+
+
+ The field represents a PR_MHS_COMMON_NAME_W MAPI property.
+
+
+ The field represents a PR_MIDDLE_NAME_A MAPI property.
+
+
+ The field represents a PR_MIDDLE_NAME_W MAPI property.
+
+
+ The field represents a PR_MINI_ICON MAPI property.
+
+
+ The field represents a PR_MOBILE_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_MOBILE_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_MODIFY_VERSION MAPI property.
+
+
+ The field represents a PR_MSG_STATUS MAPI property.
+
+
+ The field represents a PR_NDR_DIAG_CODE MAPI property.
+
+
+ The field represents a PR_NDR_REASON_CODE MAPI property.
+
+
+ The field represents a PR_NDR_STATUS_CODE MAPI property.
+
+
+ The field represents a PR_NEWSGROUP_NAME_A MAPI property.
+
+
+ The field represents a PR_NEWSGROUP_NAME_W MAPI property.
+
+
+ The field represents a PR_NICKNAME_A MAPI property.
+
+
+ The field represents a PR_NICKNAME_W MAPI property.
+
+
+ The field represents a PR_NNTP_XREF_A MAPI property.
+
+
+ The field represents a PR_NNTP_XREF_W MAPI property.
+
+
+ The field represents a PR_NON_RECEIPT_NOTIFICATION_REQUESTED MAPI property.
+
+
+ The field represents a PR_NON_RECEIPT_REASON MAPI property.
+
+
+ The field represents a PR_NORMALIZED_SUBJECT_A MAPI property.
+
+
+ The field represents a PR_NORMALIZED_SUBJECT_W MAPI property.
+
+
+ The field represents a PR_NT_SECURITY_DESCRIPTOR MAPI property.
+
+
+ The field represents a PR_NULL MAPI property.
+
+
+ The field represents a PR_Object_TYPE MAPI property.
+
+
+ The field represents a PR_OBSOLETED_IPMS MAPI property.
+
+
+ The field represents a PR_OFFICE2_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_OFFICE2_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_OFFICE_LOCATION_A MAPI property.
+
+
+ The field represents a PR_OFFICE_LOCATION_W MAPI property.
+
+
+ The field represents a PR_OFFICE_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_OFFICE_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_OOF_REPLY_TYPE MAPI property.
+
+
+ The field represents a PR_ORGANIZATIONAL_ID_NUMBER_A MAPI property.
+
+
+ The field represents a PR_ORGANIZATIONAL_ID_NUMBER_W MAPI property.
+
+
+ The field represents a PR_ORIG_ENTRYID MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_ENTRYID MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_NAME_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_NAME_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DELIVERY_TIME MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_BCC_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_BCC_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_CC_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_CC_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_NAME_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_NAME_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_TO_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_TO_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_EITS MAPI property.
+
+
+ The field represents a PR_ORIGINAL_ENTRYID MAPI property.
+
+
+ The field represents a PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_ORIGINALLY_INTENDED_RECIP_ENTRYID MAPI property.
+
+
+ The field represents a PR_ORIGINALLY_INTENDED_RECIPIENT_NAME MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_ENTRYID MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_NAME_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_NAME_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENSITIVITY MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_ENTRYID MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_NAME_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_NAME_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SUBJECT_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SUBJECT_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SUBMIT_TIME MAPI property.
+
+
+ The field represents a PR_ORIGINATING_MTA_CERTIFICATE MAPI property.
+
+
+ The field represents a PR_ORIGINATOR_AND_DL_EXPANSION_HISTORY MAPI property.
+
+
+ The field represents a PR_ORIGINATOR_CERTIFICATE MAPI property.
+
+
+ The field represents a PR_ORIGINATOR_DELIVERY_REPORT_REQUESTED MAPI property.
+
+
+ The field represents a PR_ORIGINATOR_NON_DELIVERY_REPORT_REQUESTED MAPI property.
+
+
+ The field represents a PR_ORIGINATOR_REQUESTED_ALTERNATE_RECIPIENT MAPI property.
+
+
+ The field represents a PR_ORIGINATOR_RETURN_ADDRESS MAPI property.
+
+
+ The field represents a PR_ORIGIN_CHECK MAPI property.
+
+
+ The field represents a PR_ORIG_MESSAGE_CLASS_A MAPI property.
+
+
+ The field represents a PR_ORIG_MESSAGE_CLASS_W MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_CITY_A MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_CITY_W MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_COUNTRY_A MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_COUNTRY_W MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_POSTAL_CODE_A MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_POSTAL_CODE_W MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_POST_OFFICE_BOX_A MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_POST_OFFICE_BOX_W MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_STATE_OR_PROVINCE_A MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_STATE_OR_PROVINCE_W MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_STREET_A MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_STREET_W MAPI property.
+
+
+ The field represents a PR_OTHER_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_OTHER_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_OWNER_APPT_ID MAPI property.
+
+
+ The field represents a PR_OWN_STORE_ENTRYID MAPI property.
+
+
+ The field represents a PR_PAGER_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_PAGER_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_PARENT_DISPLAY_A MAPI property.
+
+
+ The field represents a PR_PARENT_DISPLAY_W MAPI property.
+
+
+ The field represents a PR_PARENT_ENTRYID MAPI property.
+
+
+ The field represents a PR_PARENT_KEY MAPI property.
+
+
+ The field represents a PR_PERSONAL_HOME_PAGE_A MAPI property.
+
+
+ The field represents a PR_PERSONAL_HOME_PAGE_W MAPI property.
+
+
+ The field represents a PR_PHYSICAL_DELIVERY_BUREAU_FAX_DELIVERY MAPI property.
+
+
+ The field represents a PR_PHYSICAL_DELIVERY_MODE MAPI property.
+
+
+ The field represents a PR_PHYSICAL_DELIVERY_REPORT_REQUEST MAPI property.
+
+
+ The field represents a PR_PHYSICAL_FORWARDING_ADDRESS MAPI property.
+
+
+ The field represents a PR_PHYSICAL_FORWARDING_ADDRESS_REQUESTED MAPI property.
+
+
+ The field represents a PR_PHYSICAL_FORWARDING_PROHIBITED MAPI property.
+
+
+ The field represents a PR_PHYSICAL_RENDITION_ATTRIBUTES MAPI property.
+
+
+ The field represents a PR_POSTAL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_POSTAL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_POSTAL_CODE_A MAPI property.
+
+
+ The field represents a PR_POSTAL_CODE_W MAPI property.
+
+
+ The field represents a PR_POST_FOLDER_ENTRIES MAPI property.
+
+
+ The field represents a PR_POST_FOLDER_NAMES_A MAPI property.
+
+
+ The field represents a PR_POST_FOLDER_NAMES_W MAPI property.
+
+
+ The field represents a PR_POST_OFFICE_BOX_A MAPI property.
+
+
+ The field represents a PR_POST_OFFICE_BOX_W MAPI property.
+
+
+ The field represents a PR_POST_REPLY_DENIED MAPI property.
+
+
+ The field represents a PR_POST_REPLY_FOLDER_ENTRIES MAPI property.
+
+
+ The field represents a PR_POST_REPLY_FOLDER_NAMES_A MAPI property.
+
+
+ The field represents a PR_POST_REPLY_FOLDER_NAMES_W MAPI property.
+
+
+ The field represents a PR_PREFERRED_BY_NAME_A MAPI property.
+
+
+ The field represents a PR_PREFERRED_BY_NAME_W MAPI property.
+
+
+ The field represents a PR_PREPROCESS MAPI property.
+
+
+ The field represents a PR_PRIMARY_CAPABILITY MAPI property.
+
+
+ The field represents a PR_PRIMARY_FAX_NUMBER_A MAPI property.
+
+
+ The field represents a PR_PRIMARY_FAX_NUMBER_W MAPI property.
+
+
+ The field represents a PR_PRIMARY_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_PRIMARY_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_PRIORITY MAPI property.
+
+
+ The field represents a PR_PROFESSION_A MAPI property.
+
+
+ The field represents a PR_PROFESSION_W MAPI property.
+
+
+ The field represents a PR_PROFILE_NAME_A MAPI property.
+
+
+ The field represents a PR_PROFILE_NAME_W MAPI property.
+
+
+ The field represents a PR_PROOF_OF_DELIVERY MAPI property.
+
+
+ The field represents a PR_PROOF_OF_DELIVERY_REQUESTED MAPI property.
+
+
+ The field represents a PR_PROOF_OF_SUBMISSION MAPI property.
+
+
+ The field represents a PR_PROOF_OF_SUBMISSION_REQUESTED MAPI property.
+
+
+ The field represents a PR_PROVIDER_DISPLAY_A MAPI property.
+
+
+ The field represents a PR_PROVIDER_DISPLAY_W MAPI property.
+
+
+ The field represents a PR_PROVIDER_DLL_NAME_A MAPI property.
+
+
+ The field represents a PR_PROVIDER_DLL_NAME_W MAPI property.
+
+
+ The field represents a PR_PROVIDER_ORDINAL MAPI property.
+
+
+ The field represents a PR_PROVIDER_SUBMIT_TIME MAPI property.
+
+
+ The field represents a PR_PROVIDER_UID MAPI property.
+
+
+ The field represents a PR_PUID_A MAPI property.
+
+
+ The field represents a PR_PUID_W MAPI property.
+
+
+ The field represents a PR_RADIO_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_RADIO_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_ENTRYID MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_NAME_A MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_NAME_W MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_READ_RECEIPT_ENTRYID MAPI property.
+
+
+ The field represents a PR_READ_RECEIPT_REQUESTED MAPI property.
+
+
+ The field represents a PR_READ_RECEIPT_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_RECEIPT_TIME MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_ENTRYID MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_NAME_A MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_NAME_W MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_RECEIVE_FOLDER_SETTINGS MAPI property.
+
+
+ The field represents a PR_RECIPIENT_CERTIFICATE MAPI property.
+
+
+ The field represents a PR_RECIPIENT_NUMBER_FOR_ADVICE_A MAPI property.
+
+
+ The field represents a PR_RECIPIENT_NUMBER_FOR_ADVICE_W MAPI property.
+
+
+ The field represents a PR_RECIPIENT_REASSIGNMENT_PROHIBITED MAPI property.
+
+
+ The field represents a PR_RECIPIENT_STATUS MAPI property.
+
+
+ The field represents a PR_RECIPIENT_TYPE MAPI property.
+
+
+ The field represents a PR_RECORD_KEY MAPI property.
+
+
+ The field represents a PR_REDIRECTION_HISTORY MAPI property.
+
+
+ The field represents a PR_REFERRED_BY_NAME_A MAPI property.
+
+
+ The field represents a PR_REFERRED_BY_NAME_W MAPI property.
+
+
+ The field represents a PR_REGISTERED_MAIL_TYPE MAPI property.
+
+
+ The field represents a PR_RELATED_IPMS MAPI property.
+
+
+ The field represents a PR_REMOTE_PROGRESS MAPI property.
+
+
+ The field represents a PR_REMOTE_PROGRESS_TEXT_A MAPI property.
+
+
+ The field represents a PR_REMOTE_PROGRESS_TEXT_W MAPI property.
+
+
+ The field represents a PR_REMOTE_VALIDATE_OK MAPI property.
+
+
+ The field represents a PR_RENDERING_POSITION MAPI property.
+
+
+ The field represents a PR_REPLY_RECIPIENT_ENTRIES MAPI property.
+
+
+ The field represents a PR_REPLY_RECIPIENT_NAMES_A MAPI property.
+
+
+ The field represents a PR_REPLY_RECIPIENT_NAMES_W MAPI property.
+
+
+ The field represents a PR_REPLY_REQUESTED MAPI property.
+
+
+ The field represents a PR_REPLY_TIME MAPI property.
+
+
+ The field represents a PR_REPORT_ENTRYID MAPI property.
+
+
+ The field represents a PR_REPORTING_DL_NAME MAPI property.
+
+
+ The field represents a PR_REPORTING_MTA_CERTIFICATE MAPI property.
+
+
+ The field represents a PR_REPORT_NAME_A MAPI property.
+
+
+ The field represents a PR_REPORT_NAME_W MAPI property.
+
+
+ The field represents a PR_REPORT_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_REPORT_TAG MAPI property.
+
+
+ The field represents a PR_REPORT_TEXT_A MAPI property.
+
+
+ The field represents a PR_REPORT_TEXT_W MAPI property.
+
+
+ The field represents a PR_REPORT_TIME MAPI property.
+
+
+ The field represents a PR_REQUESTED_DELIVERY_METHOD MAPI property.
+
+
+ The field represents a PR_RESOURCE_FLAGS MAPI property.
+
+
+ The field represents a PR_RESOURCE_METHODS MAPI property.
+
+
+ The field represents a PR_RESOURCE_PATH_A MAPI property.
+
+
+ The field represents a PR_RESOURCE_PATH_W MAPI property.
+
+
+ The field represents a PR_RESOURCE_TYPE MAPI property.
+
+
+ The field represents a PR_RESPONSE_REQUESTED MAPI property.
+
+
+ The field represents a PR_RESPONSIBILITY MAPI property.
+
+
+ The field represents a PR_RETURNED_IPM MAPI property.
+
+
+ The field represents a PR_ROWID MAPI property.
+
+
+ The field represents a PR_ROW_TYPE MAPI property.
+
+
+ The field represents a PR_RTF_COMPRESSED MAPI property.
+
+
+ The field represents a PR_RTF_IN_SYNC MAPI property.
+
+
+ The field represents a PR_RTF_SYNC_BODY_COUNT MAPI property.
+
+
+ The field represents a PR_RTF_SYNC_BODY_CRC MAPI property.
+
+
+ The field represents a PR_RTF_SYNC_BODY_TAG_A MAPI property.
+
+
+ The field represents a PR_RTF_SYNC_BODY_TAG_W MAPI property.
+
+
+ The field represents a PR_RTF_SYNC_PREFIX_COUNT MAPI property.
+
+
+ The field represents a PR_RTF_SYNC_TRAILING_COUNT MAPI property.
+
+
+ The field represents a PR_SEARCH MAPI property.
+
+
+ The field represents a PR_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_SECURITY MAPI property.
+
+
+ The field represents a PR_SELECTABLE MAPI property.
+
+
+ The field represents a PR_SENDER_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_SENDER_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_SENDER_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_SENDER_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_SENDER_ENTRYID MAPI property.
+
+
+ The field represents a PR_SENDER_NAME_A MAPI property.
+
+
+ The field represents a PR_SENDER_NAME_W MAPI property.
+
+
+ The field represents a PR_SENDER_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_SEND_INTERNET_ENCODING MAPI property.
+
+
+ The field represents a messages MAPI property.
+
+
+ The field represents a PR_SEND_RICH_INFO MAPI property.
+
+
+ The field represents a PR_SENSITIVITY MAPI property.
+
+
+ The field represents a PR_SENTMAIL_ENTRYID MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_ENTRYID MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_NAME_A MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_NAME_W MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_SERVICE_DELETE_FILES_A MAPI property.
+
+
+ The field represents a PR_SERVICE_DELETE_FILES_W MAPI property.
+
+
+ The field represents a PR_SERVICE_DLL_NAME_A MAPI property.
+
+
+ The field represents a PR_SERVICE_DLL_NAME_W MAPI property.
+
+
+ The field represents a PR_SERVICE_ENTRY_NAME MAPI property.
+
+
+ The field represents a PR_SERVICE_EXTRA_UIDS MAPI property.
+
+
+ The field represents a PR_SERVICE_NAME_A MAPI property.
+
+
+ The field represents a PR_SERVICE_NAME_W MAPI property.
+
+
+ The field represents a PR_SERVICES MAPI property.
+
+
+ The field represents a PR_SERVICE_SUPPORT_FILES_A MAPI property.
+
+
+ The field represents a PR_SERVICE_SUPPORT_FILES_W MAPI property.
+
+
+ The field represents a PR_SERVICE_UID MAPI property.
+
+
+ The field represents a PR_SEVEN_BIT_DISPLAY_NAME MAPI property.
+
+
+ The field represents a PR_SMTP_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_SMTP_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_SPOOLER_STATUS MAPI property.
+
+
+ The field represents a PR_SPOUSE_NAME_A MAPI property.
+
+
+ The field represents a PR_SPOUSE_NAME_W MAPI property.
+
+
+ The field represents a PR_START_DATE MAPI property.
+
+
+ The field represents a PR_STATE_OR_PROVINCE_A MAPI property.
+
+
+ The field represents a PR_STATE_OR_PROVINCE_W MAPI property.
+
+
+ The field represents a PR_STATUS MAPI property.
+
+
+ The field represents a PR_STATUS_CODE MAPI property.
+
+
+ The field represents a PR_STATUS_STRING_A MAPI property.
+
+
+ The field represents a PR_STATUS_STRING_W MAPI property.
+
+
+ The field represents a PR_STORE_ENTRYID MAPI property.
+
+
+ The field represents a PR_STORE_PROVIDERS MAPI property.
+
+
+ The field represents a PR_STORE_RECORD_KEY MAPI property.
+
+
+ The field represents a PR_STORE_STATE MAPI property.
+
+
+ The field represents a PR_STORE_SUPPORT_MASK MAPI property.
+
+
+ The field represents a PR_STREET_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_STREET_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_SUBFOLDERS MAPI property.
+
+
+ The field represents a PR_SUBJECT_A MAPI property.
+
+
+ The field represents a PR_SUBJECT_IPM MAPI property.
+
+
+ The field represents a PR_SUBJECT_PREFIX_A MAPI property.
+
+
+ The field represents a PR_SUBJECT_PREFIX_W MAPI property.
+
+
+ The field represents a PR_SUBJECT_W MAPI property.
+
+
+ The field represents a PR_SUBMIT_FLAGS MAPI property.
+
+
+ The field represents a PR_SUPERSEDES_A MAPI property.
+
+
+ The field represents a PR_SUPERSEDES_W MAPI property.
+
+
+ The field represents a PR_SUPPLEMENTARY_INFO_A MAPI property.
+
+
+ The field represents a PR_SUPPLEMENTARY_INFO_W MAPI property.
+
+
+ The field represents a PR_SURNAME_A MAPI property.
+
+
+ The field represents a PR_SURNAME_W MAPI property.
+
+
+ The field represents a PR_TELEX_NUMBER_A MAPI property.
+
+
+ The field represents a PR_TELEX_NUMBER_W MAPI property.
+
+
+ The field represents a PR_TEMPLATEID MAPI property.
+
+
+ The field represents a PR_TITLE_A MAPI property.
+
+
+ The field represents a PR_TITLE_W MAPI property.
+
+
+ The field represents a PR_TNEF_CORRELATION_KEY MAPI property.
+
+
+ The field represents a PR_TRANSMITABLE_DISPLAY_NAME_A MAPI property.
+
+
+ The field represents a PR_TRANSMITABLE_DISPLAY_NAME_W MAPI property.
+
+
+ The field represents a PR_TRANSPORT_KEY MAPI property.
+
+
+ The field represents a PR_TRANSPORT_MESSAGE_HEADERS_A MAPI property.
+
+
+ The field represents a PR_TRANSPORT_MESSAGE_HEADERS_W MAPI property.
+
+
+ The field represents a PR_TRANSPORT_PROVIDERS MAPI property.
+
+
+ The field represents a PR_TRANSPORT_STATUS MAPI property.
+
+
+ The field represents a PR_TTYTDD_PHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_TTYTDD_PHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_TYPE_OF_MTS_USER MAPI property.
+
+
+ The field represents a PR_USER_CERTIFICATE MAPI property.
+
+
+ The field represents a PR_USER_X509_CERTIFICATE MAPI property.
+
+
+ The field represents a PR_VALID_FOLDER_MASK MAPI property.
+
+
+ The field represents a PR_VIEWS_ENTRYID MAPI property.
+
+
+ The field represents a PR_WEDDING_ANNIVERSARY MAPI property.
+
+
+ The field represents a PR_X400_CONTENT_TYPE MAPI property.
+
+
+ The field represents a PR_X400_DEFERRED_DELIVERY_CANCEL MAPI property.
+
+
+ The field represents a PR_XPOS MAPI property.
+
+
+ The field represents a PR_YPOS MAPI property.
+
+
+ The operator overload performs implicit type conversions from to integer.
+ A representing the converted integer parameter tag.
+ The integer to convert.
+
+
+ The operator overload performs implicit type conversions from integer to .
+ An integer representing the converted parameter tag.
+ The to convert.
+
+
+ The enumeration contains values that specify TNEF property types.
+
+
+ Indicates an application time value.
+
+
+ Indicates a counted byte array.
+
+
+ Indicates a 16-bit Boolean value. '0' is false. Non-zero is true.
+
+
+ Indicates an OLE GUID.
+
+
+ Indicates a signed 64-bit integer that represents a base ten decimal with four digits to the right of the decimal point.
+
+
+ Indicates a floating point double.
+
+
+ Indicates a 32-bit error value.
+
+
+ Indicates a signed 16-bit value.
+
+
+ Indicates the 8-byte signed integer.
+
+
+ Indicates a signed 32-bit value.
+
+
+ Indicates the multivariable flag. The value part of the property contains multiple values.
+
+
+ Indicates the NULL property value.
+
+
+ Indicates the embedded object in a property
+
+
+ Indicates a 4-byte floating point value.
+
+
+ Indicates a null-terminated 8-bit character string.
+
+
+ Indicates a FILETIME 64-bit integer specifying the number of 100ns periods since Jan 1, 1601.
+
+
+ Indicates a null-terminated Unicode string.
+
+
+ Indicates an interface. The caller does not specify the type.
+
+
+ The class enables you to read properties from a TNEF stream in a forward-only manner.
+
+
+ The constructor creates a new object that reads TNEF data from the inputStream argument.
+ A stream containing binary TNEF data.
+
+
+ The constructor creates a new object and sets the input stream, codepage, and compliance mode.
+ An integer indicating the codepage to use when decoding the input stream.
+ A stream containing binary TNEF data.
+ A enumeration value indicating whether to throw exceptions when noncompliant TNEF data is encountered.
+
+
+ The method closes the TNEF stream that this object owns.
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method reads an undecoded attribute value from the TNEF stream that this object owns.
+ When this method returns, it contains the specified character array with the values between index and (index + count - 1) replaced by the characters read from the current source.
+ The place in buffer at which to begin writing.
+ The maximum number of characters to read. If the end of the stream is reached before count of characters is read into buffer, the current method returns.
+
+
+ The method reads the next attribute in the TNEF stream that this object owns.
+ The method returns true if there was another attribute to read. It returns false if there were no more attributes.
+
+
+ The method sets the back to .
+
+
+ Releases all resources used by the .
+
+
+ The class produces a TNEF stream by writing attributes and properties.
+
+
+ The constructor creates a new object with an attachment key specified by the attachmentKey parameter for output to the Stream parameter outputStream.
+ The attachment key for this object.
+ The Stream object to which to write.
+
+
+ The constructor creates a new object.
+ The attachment key for this object.
+ An integer representing the code page to use when writing output to outputStream.
+ The Stream object to which to write.
+
+
+ The constructor creates a new object.
+ The attachment key for this object.
+ A enumeration value.
+ An integer representing the code page to use when writing output to outputStream.
+ The Stream object to which to write.
+
+
+ The method closes this object and the stream that it owns.
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method flushes any buffered data to the stream that this object owns.
+
+
+ The method returns a object that can be used to write an embedded message using the codepage specified by the messageCodePage parameter.
+ An integer representing the code page to use when writing the embedded message.
+
+
+ The method sets the code page used to write to the TNEF stream that this object owns.
+ An integer representing the code page to use when writing.
+
+
+ The method starts a new attribute in the stream that this object owns.
+ A enumeration value indicating the attribute to write.
+ A enumeration value indicating whether the attribute to be written is for a message or for an attachment.
+
+
+ The method starts the property specified by the tag parameter in the TNEF stream that this object owns.
+ A enumeration value identifying the property to start.
+
+
+ The method starts a named property.
+ An integer representing the name of the named property to start.
+ A enumeration value identifying the property to start.
+ The GUID for the property set in which to start a new property.
+
+
+ The method starts a named property in the current attribute or row.
+ A enumeration value identifying the property to start.
+ The name of the named property to start.
+ The GUID for the property set in which to start a new property.
+
+
+ The method starts a property value.
+
+
+ The method starts a new row in a RecipientTable attribute.
+
+
+ Releases all resources used by the .
+
+
+ The method writes all properties in the parameter reader to the output stream owned by this object.
+ A from which to read the properties to write to the output stream owned by this object.
+
+
+ The method writes the current attribute in the parameter reader to the output stream owned by this object.
+ A structure positioned on the attribute to write to the output stream owned by this object.
+
+
+ The method reads a raw value from the byte parameter and writes it to the output stream owned by this object.
+ A byte array containing data to write to the stream that this owns.
+ An integer indicating where in buffer to begin reading data.
+ An integer indicating the number of bytes to write from buffer into the stream that this owns.
+
+
+ The method writes a standard TNEF OemCodePage attribute.
+ An integer representing the code page to write. This value will be used to encode 8-bit string values as they are written.
+
+
+ The method reads the current property from the parameter propertyReader and writes it to the output stream that this object owns.
+ A structure positioned on the property to write.
+
+
+ The method writes a property identified by the tag parameter with the Boolean value specified by the value parameter.
+ The Boolean value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the raw value specified by the value parameter.
+ A byte array containing the value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the DateTime value specified by the value parameter.
+ A DateTime object containing the value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the double value specified by the value parameter.
+ A double precision floating point value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the GUID value specified by the value parameter.
+ A GUID object to write.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the short integer value specified by the value parameter.
+ A short integer value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the integer value specified by the value parameter.
+ An integer value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the long integer value specified by the value parameter.
+ A long integer value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the value specified by the value parameter.
+ An object to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the floating point value specified by the value parameter.
+ A single precision floating point value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the value contained in the value parameter.
+ A enumeration value specifying the property to write.
+ A stream containing the property value to write to this property.
+
+
+ The method writes a property identified by the tag parameter with the value specified by the value parameter.
+ A string containing the property value to write to this property.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the value contained in the value parameter.
+ A TextReader object positioned on the property value to write to this property.
+ A enumeration value specifying the property to write.
+
+
+ The method writes an object property.
+ A GUID object containing the object IID to write.
+ A enumeration value specifying the property to write.
+ A stream object from which to read the raw data to write.
+
+
+ The method writes a raw property value from a byte array.
+ A byte array containing data to write.
+ An integer indicating where in buffer to begin reading data.
+ An integer indicating the number of bytes to write from buffer.
+
+
+ The method reads a text property value from a character array and writes it to the stream that this object owns.
+ A character array containing data to write.
+ An integer indicating where in buffer to begin reading data.
+ An integer indicating the number of characters to write from buffer.
+
+
+ The method writes a Boolean property value to the stream that this object owns.
+ A Boolean value to write.
+
+
+ The method writes the value contained in the value parameter and then ends it.
+ A byte array containing a value to write.
+
+
+ The method writes a DateTime value and then ends it.
+ A DateTime object to write.
+
+
+ The method writes a double precision floating point value and then ends it.
+ A double precision floating point value to write.
+
+
+ The method writes a GUID value and then ends it.
+ A GUID object to write.
+
+
+ The method writes a short integer value and then ends it.
+ A short integer value to write.
+
+
+ The method writes an integer property value and then ends it.
+ An integer value to write.
+
+
+ The method writes a long integer property value and then ends it.
+ A long integer to write.
+
+
+ The method writes and object as a property value and then ends it.
+ An object to write.
+
+
+ The method writes a single precision floating point value as a property value and then ends it.
+ A single precision floating point value to write.
+
+
+ The method reads bytes from the stream parameter, writes them to the output stream that this object owns, and ends the property value.
+ A stream containing the value to write.
+
+
+ The method writes a string to a property value and then ends it.
+ A string containing a value to write.
+
+
+ The method reads text from the reader parameter, writes it to the TNEF stream that this object owns, and then ends the property value.
+ A TextReader object positioned on the value to write.
+
+
+ The method writes an object property value and ends it.
+ A GUID object identifying the property value to write.
+ A stream containing the value to write.
+
+
+ The method writes the standard preamble TNEF version parameter.
+
+
+ The contains an enumeration value specifying not to overwrite the TnefVersion and OemCodePage attributes in the TNEF stream that this object owns.
+
+
+ Indicates not to overwrite the TnefVersion and OemCodePage attributes.
+
+
+ The namespace contains types that enable you to read and write vCard data.
+
+
+ The enumeration sets the compliance mode for vCard contacts.
+
+
+ Indicates that exceptions should not be thrown for non-compliant vCard contacts.
+
+
+ Indicates that vCard data must follow the vCard 3.0 standard.
+
+
+ The enumeration defines vCard contact compliance errors.
+
+
+ The vCard data complies with the vCard 3.0 standard.
+
+
+ A vCard data component closes with a different component name.
+
+
+ The vCard component name was not specified.
+
+
+ A required vCard data parameter was not supplied.
+
+
+ A required vCard parameter name was not specified.
+
+
+ A vCard data tag was closed without a corresponding beginning tag.
+
+
+ An invalid character is present in the vCard parameter name.
+
+
+ An invalid character is present in a vCard parameter's text.
+
+
+ An invalid character is present in a vCard property name.
+
+
+ An invalid character is present in a vCard property value.
+
+
+ An invalid character is present in a quoted string.
+
+
+ A vCard parameter has an invalid value.
+
+
+ A vCard value is in the wrong format for the value.
+
+
+ Not all vCard components that were opened have been closed.
+
+
+ A vCard parameter name is missing.
+
+
+ A vCard component cannot have an associated parameter.
+
+
+ All vCard properties must be inside a vCard component.
+
+
+ A property ended unexpectedly.
+
+
+ A stream ended unexpectedly.
+
+
+ The class reads contact information from a vCard contact parameter.
+
+
+ The method advances to and reads the next parameter.
+ The method returns true if there is another parameter to read; otherwise, false if there are no more parameters on the current property.
+
+
+ The method returns the next value of a multi-value parameter.
+ The method returns true if there is another value to read; otherwise, false if there are no more values on the current parameter.
+
+
+ The method returns the value of a parameter.
+ The value of the parameter.
+
+
+ The property gets the name of the parameter.
+ The name of the parameter.
+
+
+ The property returns the identifier for the parameter.
+ A instance containing the identity of the parameter.
+
+
+ The class reads the contents of vCard properties.
+
+
+ The method overrides the current character set and/or encoding for the current property value.
+ The decoder to use. Can be null.
+ The character set to use. Can be null.
+
+
+ The method returns the property value as a stream.
+ A instance containing the property value.
+
+
+ The method advances to the next property and reads the value.
+ The method returns true if another property is available; otherwise, false if there are no more properties to read.
+
+
+ The method advances to and reads the next value on a property.
+ The method returns true if there is another value on the property; otherwise, false if there are no more values to return.
+
+
+ The method parses a property value according to its type and returns it as an object.
+ he method returns an instance containing the property value.
+
+
+ The method parses the value according to its type and returns it as an object. Values are separated by the specified separators.
+ The method returns an instance containing the property value.
+ Separators on which reading should stop.
+
+
+ The method reads the property value as a Boolean value.
+ The method returns the property as a value.
+
+
+ The method returns the property value as a Boolean value. Values are separated by the specified separators.
+ The method returns the property as a value.
+ Separators on which reading should stop.
+
+
+ The method returns the property value as a byte array.
+ The method returns an array of bytes.
+
+
+ The method returns the property value as a date and time.
+ The method returns the property value as a instance.
+ One of the enumeration values.
+
+
+ The method return the property value as a date and time. Values are separated by the specified separators.
+ The method returns the property value as a instance.
+ Separators on which reading should stop.
+ One of the enumeration values.
+
+
+ The method returns the property value as a double.
+ The method returns the property value as a instance.
+
+
+ The method returns the property value as a double. Values are separated by the specified separators.
+ The method returns the property value as a instance.
+ Separators on which reading should stop.
+
+
+ The method returns the property value as an integer.
+ The method returns the property value as a instance.
+
+
+ The method returns the property value as an integer. Values are separated by the specified separators.
+ The method returns the property value as a instance.
+ Separators on which reading should stop.
+
+
+ The method returns the property value as a string.
+ The method returns the property value as a instance.
+
+
+ Values are separated by the specified separators.
+ The method returns the property value as a instance.
+ Separators on which reading should stop.
+
+
+ The method returns the property value as a time span.
+ The method returns the property value as a instance.
+
+
+ The method returns the property value as a time span. Values are separated by the specified separators.
+ The method returns the property value as a instance.
+ Separators on which reading should stop.
+
+
+ The property gets the last value separator read.
+ One of the enumeration values.
+
+
+ The property gets the name of the property.
+ The name of the property.
+
+
+ The property gets a parameter reader that reads the property parameters.
+ A instance that reads the property's parameters..
+
+
+ The property gets the identifier for the property.
+ A object containing the property identifier.
+
+
+ The property returns the type of the parameter.
+ One of the enumeration values.
+
+
+ The class isa a forward-only, non-cached reader for vCard data.
+
+
+ The constructor initializes a new instance of the class on the specified stream.
+ A object containing the vCard data.
+
+
+ The constructor initializes a new instance of the class on the specified stream with the specified encoding and compliance mode.
+ A object the specifies the encoding used on the vCard data stream.
+ One of the enumeration values that specifies the compliance level required on the vCard data.
+ A object containing the vCard data.
+
+
+ The method checks if the specified contact reader has been disposed.
+ The name of the method calling the method.
+ The method of the has been called.
+
+
+ The method closes the reader and disposes of any resources.
+
+
+ The method releases resources held by the instance.
+
+
+ The method releases managed resources held by the instance.
+ false if called from the finalizer; otherwise, true.
+
+
+ The method reads the next vCard in the data stream.
+ The method returns true if there is another vCard in the data stream; otherwise, false if the data stream has no more vCard data.
+
+
+ The method resets the vCard compliance requirement to .
+
+
+ The gets the vCard 3.0 standard compliance mode.
+ One of the enumeration values.
+
+
+ The property gets the current status of the vCard data.
+ One of the enumeration values.
+
+
+ The property gets a property read that reads the properties of the current vCard.
+ A for the current vCard data.
+
+
+ The enumeration specifies valid separator characters for vCard data.
+
+
+ The valid separator character is a comma (,).
+
+
+ There is no valid separator character.
+
+
+ The valid separator character is a semicolon (;).
+
+
+ The enumeration specifies the data type of vCard property values.
+
+
+ Contact value is a binary array of bytes.
+
+
+ Contact value is a value.
+
+
+ Contact value is the date portion of a value.
+
+
+ Contact value is a value.
+
+
+ Contact value is a float value.
+
+
+ Contact value is an integer value.
+
+
+ Contact value is a phone number represented as a value.
+
+
+ Contact value is a value.
+
+
+ Contact value is the time portion of a value.
+
+
+ Contact value type is unknown.
+
+
+ Contact value is a URI represented as a value.
+
+
+ Contact value is an offset from UTC represented as a value.
+
+
+ Contact value is an embedded vCard represented as an array of bytes.
+
+
+ The class writes structured vCard information to a stream.
+
+
+ The constructor initializes a new object.
+
+
+ The constructor initializes a new object.
+
+
+ The method closes the object.
+
+
+ The method disposes all resources.
+
+
+ The method disposes all resources.
+
+
+ The ends a vCard entry.
+
+
+ The method flushes all data to the underlying stream.
+
+
+ The method starts a new parameter identified by the parameter identifier.
+
+
+ The method starts a new parameter identified by the parameter name.
+
+
+ The method starts a new property that is identified by the property identifier.
+
+
+ The method starts a new property that is identified by the property name.
+
+
+ The method starts a new vCard entry.
+
+
+ The method writes a vCard that is read from the object.
+
+
+ The method writes a parameter that is read by the object.
+
+
+ The method writes a parameter based on parameter identifier.
+
+
+ The method writes a parameter based on parameter name.
+
+
+ The method writes a parameter value.
+
+
+ The method writes a property that is read by the reader.
+ The reader to get the property from.
+
+
+ The method writes a property.
+
+
+ The method writes a property.
+
+
+ The method writes a Boolean value.
+
+
+ The method writes a byte array.
+
+
+ The method writes a DateTime value.
+
+
+ The property writes a T:System.Double value.
+
+
+ The method writes a 32-bit integer value.
+
+
+ The method writes the property value stored in the Object.
+
+
+ The writes data from the stream into a vCard property value.
+
+
+ The method writes a string value to the vCard.
+
+
+ The method writes a property value with the specified content value separator.
+
+
+ The method writes a DateTime value with a value separator.
+
+
+ The method writes a T:System.Double value with a value separator.
+
+
+ The method writes a 32-bit integer value with a value separator.
+
+
+ The method writes the property value stored in the Object with a value separator.
+
+
+ The method writes a string property value to the vCard with value separators.
+
+
+ The method writes a parameter.
+
+
+ The exception thrown when vCard data parsing errors occur.
+
+
+ The constructor initializes a new instance of the class with the specified error message.
+ The message that describes the error.
+
+
+ The constructor initializes a new instance of the class with the specified serialized data.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor initializes a new instance of the class with the specified error message and a reference to the inner exception that is the cause of this exception.
+ The inner exception reference.
+ The message that describes the error.
+
+
+ The enumeration defines vCard data parameters.
+
+
+ The character set used for the vCard.
+
+
+ The character encoding used for the vCard.
+
+
+ The language used for text in the vCard.
+
+
+ The data type for the vCard data.
+
+
+ Unknown vCard parameter.
+
+
+ The data type of the vCard value.
+
+
+ The enumeration defines vCard contact component properties.
+
+
+ Street address of the contact.
+
+
+ The person acting on behalf of this contact.
+
+
+ The date of birth of the contact.
+
+
+ Categories to which the contact is assigned.
+
+
+ Access classification for the contact.
+
+
+ Full name (FN) of the contact.
+
+
+ E-mail address of the contact.
+
+
+ Geocoded location of the contact.
+
+
+ Job title of the contact.
+
+
+ Public key/certificate associated with the contact.
+
+
+ Postal address label of the contact.
+
+
+ Logo image of the contact.
+
+
+ Electronic mail software used by the contact.
+
+
+ Name of the contact's vCard.
+
+
+ Nickname of the contact.
+
+
+ Notes associated with the contact.
+
+
+ Organization affiliation of the contact.
+
+
+ Phone number of the contact.
+
+
+ Photo of the contact.
+
+
+ Product identifier associated with the contact.
+
+
+ Profile of the contact.
+
+
+ Last change date of the contact.
+
+
+ Role of the contact.
+
+
+ Sort string used when sorting contacts.
+
+
+ Sound information associated with the contact.
+
+
+ Source of the contact information.
+
+
+ Structured name of the contact.
+
+
+ Time zone of the contact's location.
+
+
+ Identifier associated with the contact.
+
+
+ Unknown contact property.
+
+
+ URL of Web resource associated with the contact.
+
+
+ Version of the contact information.
+
+
+ The namespace contains types that enable you to work with cultures and character sets to produce localized content.
+
+
+ The class exposes information about a character set.
+
+
+ The method returns a read-only object that represents the character set specified by the codePage parameter.
+ The code page of the desired character set.
+
+
+ The method returns a read-only object that represents the character set specified by the name parameter.
+ The name of the desired character set.
+
+
+ The method returns an object for the specified code page.
+ The code page for which an encoding is desired.
+ The code page specified by the codePage parameter is invalid or is not installed.
+
+
+ The method returns an object for the specified character set name.
+ The name of the character set for which a is desired.
+ The code page specified by the name parameter is invalid or is not installed.
+
+
+ The method attempts to put a object into the charset out parameter that corresponds to the codePage parameter. does not throw an exception if it fails.
+ The method returns true if it is successful. Otherwise, it returns false.
+ The code page for which to obtain a object.
+ A in which to store the result.
+
+
+ The method attempts to put a object into the charset out parameter that corresponds to the name parameter. does not throw an exception if it fails.
+ The method returns true if it is successful. Otherwise, it returns false.
+ A in which to store the result.
+ The character set name for which to obtain a object.
+
+
+ The attempts to put the for the character set that this object represents into the encoding out parameter. does not throw an exception if it fails.
+ The method returns true if it is successful. Otherwise, it returns false.
+ A object in which to store the result.
+
+
+ The method attempts to put the object for the character set specified by the codePage parameter into the encoding out parameter.
+ The method returns true if it is successful. Otherwise, it returns false.
+ The code page for which to obtain an .
+ A object in which to store the result.
+
+
+ The method attempts to get a object for the character set specified by the name parameter.
+ The method returns true if it is successful. Otherwise, it returns false.
+ A object in which to store the result.
+ The name of the character set to obtain.
+
+
+ The property gets a Boolean value that indicates whether the character set represented by this object can be detected by the class.
+ The property is true if the character set can be detected. Otherwise it is false.
+
+
+ The exception is thrown when a requested character set is not installed.
+
+
+ The constructor creates a new for the code page described by the codePage parameter.
+ The code page that was not installed.
+
+
+ The constructor creates a new for the character set described by the charsetName parameter.
+ The character set that was not installed.
+
+
+ The constructor creates a new exception with a message for a given code page.
+ The code page for which a character set was not installed.
+ The message for this .
+
+
+ The constructor creates a new serializable exception.
+ The StreamingContext object that contains contextual information about the source or destination.
+ The SerializationInfo object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new exception with a message for a given character set.
+ The character set that was not installed.
+ The message for this exception.
+
+
+ The constructor creates a new from an inner exception.
+ The code page for which a character set is not installed.
+ The exception that caused this to be thrown.
+ The message for this exception.
+
+
+ The constructor creates a new from an inner exception.
+ The character set that is not installed.
+ The exception that caused this to be thrown.
+ The message for this exception.
+
+
+ The class represents an e-mail culture.
+
+
+ The method returns a read-only object that represents the culture that corresponds to the locale ID parameter, lcid.
+ The locale ID for which to get a culture.
+
+
+ The method gets a read-only object that represents the culture specified by the name parameter.
+ The name of the culture to get.
+
+
+ attempts to put a object that corresponds to the lcid parameter into the culture out parameter. does not throw an exception if it fails.
+ The locale ID for which to obtain a culture.
+ A object in which to store the result.
+
+
+ attempts to put a object that corresponds to the name parameter into the culture out parameter. does not throw an exception if it fails.
+ A object in which to store the result.
+ The name of the culture to obtain.
+
+
+ The property gets the locale ID of the culture represented by this object.
+ The locale ID of the culture represented by this object. If the property returns zero, there is no standard locale ID for the culture.
+
+
+ The is thrown when an invalid or unknown code page or character set is encountered.
+
+
+ The constructor creates a new .
+ The invalid code page.
+
+
+ The constructor creates a new .
+ The invalid character set.
+
+
+ The constructor creates a new with a message.
+ The invalid code page.
+ The message for this exception.
+
+
+ The constructor creates a new serializable object.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new object with a message.
+ The invalid character set.
+ The message for this object.
+
+
+ The constructor creates a new object from an inner exception.
+ The invalid code page.
+ The exception that caused this to be thrown.
+ The message for this object.
+
+
+ The constructor creates a new from an inner exception.
+ The invalid character set.
+ The exception that caused this to be thrown.
+ The message for this object.
+
+
+ The class detects the best code page to use for encoding specified text.
+
+
+ The constructor creates a new object.
+
+
+ The method adds a character to this object.
+ The character to add.
+
+
+ The method adds text from a character array to this object.
+ The text to add.
+
+
+ The method adds text from a string to this object.
+ The text to add.
+
+
+ The method adds text from a to this object.
+ A containing the text to add.
+
+
+ The method adds a specified amount of text from a to this object.
+ A containing the text to add.
+ The maximum number of characters to add.
+
+
+ The method adds text from a character array to this object.
+ A character array containing text to add.
+ The number of characters to read.
+ The zero-based index of the first character to read.
+
+
+ The method adds text from a to this object.
+ The string from which to add text.
+ The number of characters to read.
+ The zero-based index of the first character to read.
+
+
+ The method takes the preferred character set into account and gets the code page that can best represent the text added to this object.
+ Set to true to allow common fallback exception characters. Otherwise, set to false.
+ The preferred character set for representing the text added to this object.
+
+
+ The method gets the code page that best represents the text added to this object and best fits the preferred culture.
+ Set to true to allow common fallback exception characters. Otherwise, set to false.
+ The preferred culture from which to choose a character set to represent the text added to this object.
+
+
+ The method returns an integer that indicates the percentage of the text added to this object that the specified code page can represent.
+ An integer indicating a code page.
+
+
+ The method gets a list of code pages that will encode the text added to this object, ordered from best to worst, subject to the preference indicated by the preferredCharset parameter..
+ Set to true to allow common fallback exception characters. Otherwise, set to false.
+ The preferred character set for representing the text added to this object.
+
+
+ The method returns a list of code pages that will encode the text added to this object, ordered from best to worst, subject to the preference indicated by the culture parameter.
+ Set to true to allow common fallback exception characters. Otherwise, set to false.
+ The preferred culture in which to choose the character set for the data added to this object.
+
+
+ The method resets this object.
+
+
+ The is thrown when an uninstalled or unrecognized culture is encountered.
+
+
+ The constructor creates a new object.
+ The locale ID that was not recognized.
+
+
+ The constructor creates a new object.
+ The name of the culture that was not recognized.
+
+
+ The constructor creates a new with a message.
+ The locale ID that was not recognized.
+ The message for this exception.
+
+
+ The constructor creates a new serializable object.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new object with a message.
+ The culture name that was not recognized.
+ The message for this exception.
+
+
+ The constructor creates a new from an inner exception.
+ The locale ID that was not recognized.
+ The exception that caused this to be thrown.
+ The message for this exception.
+
+
+ The constructor creates a new from an inner exception.
+ The culture name that was not recognized.
+ The exception that caused this to be thrown.
+ The message for this exception.
+
+
+ The namespace contains types that enable you to read and write MIME data by using either stream-based or DOM-based methods.
+
+
+ The class represents a MIME address header.
+
+
+ The constructor constructs a new object.
+ The display name of the new object.
+
+
+ The method copies the contents of this object into destination.
+ The destination object in which to store a deep copy of this object.
+
+
+ The method indicates whether value is valid for this header.
+ The method returns true if value is valid; otherwise, the method returns false.
+ The value to evaluate.
+
+
+ The static method creates a new with the name specified in name, and the address items specified in value.
+ One of AddressParserFlags: , , or .
+ The address header to put in the returned by .
+ The display name for the returned by .
+
+
+ The class represents a recipient or group of recipients.
+
+
+ The method copies the contents of this object into destination.
+ The destination object in which to store the contents of this object.
+
+
+ The method tries to get the display name of this object.
+ The method returns true if it successfully read the display name. If the encoding of the display name is unsupported, returns false, and displayName is set to null.
+ The string in which to store the display name.
+
+
+ The method tries to get the display name of this object and makes available information about the original encoding of the display name.
+ The converted display name.
+ A structure used to control the decoding.
+ A structure that exposes details about the conversion.
+
+
+ The property gets or sets the display name for the recipient or group of recipients represented by this object.
+ The property returns the display name for this object
+
+
+ The enumeration controls how addresses are parsed.
+
+
+ Square brackets in e-mail addresses are treated like angle brackets.
+
+
+ Comments are ignored and can be used as part of the display name.
+
+
+ Comments are enabled.
+
+
+ The class represents a simple Multipurpose Internet Mail Extensions (MIME) text header
+
+
+ The constructor creates a new instance of the class that has the name that is specified in name and the value that is specified in value.
+ The value of this .
+ The name for this .
+
+
+ The method copies the contents of this object into destination.
+ The destination object in which to store a copy of this object.
+
+
+ The method indicates whether value is valid for the object.
+ The method returns true if value is valid; otherwise the method returns false.
+ The value to evaluate.
+
+
+ The property gets or sets the value of this class.
+ The property returns a string representation of the 7-bit ASCII header.
+
+
+ The enumeration specifies how a stream is cached during loading.
+
+
+ Specifies the creation of a new stream to hold the contents of the original Multipurpose Internet Mail Extensions (MIME) stream. You can close the original MIME stream immediately after it is parsed.
+
+
+ Specifies the use of the source MIME stream as the data store. is not supported when a Stream interface is used. Also, the source stream must support seeking. The source stream should not be closed until all operations on the Document Object Model (DOM) are finished. You must manually close the source stream.
+
+
+ Specifies the use of the source MIME stream as the data store. is not supported when a Stream interface is used. Also, the source stream must support seeking. The source stream should not be closed until all operations on the DOM are finished. You must manually close the source stream. When the is disposed, the source stream is automatically disposed also.
+
+
+ The class represents a structured Multipurpose Internet Mail Extensions (MIME) header with parameters.
+
+
+ The method parses the header.
+
+
+ The property returns the indicated by name.
+ A string that identifies the to get.
+
+
+ The class represents a Content-Disposition header.
+
+
+ The constructor creates a new object.
+
+
+ The constructor constructs a new object that has the value that is specified by value.
+ The value of the Content-Disposition header that is represented by this object. The value parameter must not contain any Multipurpose Internet Mail Extensions (MIME) parameters.
+
+
+ The method puts a deep copy of this object into destination.
+ The destination object in which to store a deep copy of this object.
+
+
+ The method indicates whether value is valid for this header.
+ The method returns true if value is valid; otherwise, the method returns false.
+ The value to evaluate.
+
+
+ The property gets and sets the value of this object.
+ The value of the property is a string that contains the value of this object. This value excludes any comments or folding whitespace, and the trailing semicolon. Header parameters remain intact when is assigned.
+
+
+ The enumeration specifies the supported content transfer encodings.
+
+
+ Each three-byte sequence is encoded in a four-byte, seven-bit sequence. This results in a one-third increase in the message size. This is the most common format applied to attachments.
+
+
+ The data is not line-oriented and may have eight-bit data. The Simple Mail Transfer Protocol (SMTP) that is used to send this Multipurpose Internet Mail Extensions (MIME) part must support the BDAT extension for this encoding to be valid.
+
+
+ The data is encoded in the BinHex format for transport and results in seven-bit data.
+
+
+ Some byte data requires the full eight-bit range of bytes, but the data is still line-oriented. The SMTP must support the BDAT extension for this encoding to be valid.
+
+
+ The data is seven-bit encoded and each character that is not seven-bit will be escaped into a three-byte sequence of characters. This is the most common format applied to bodies that contain mostly seven-bit sequences.
+
+
+ Every byte is seven bits. This is the default transfer encoding.
+
+
+ The content transfer encoding is unknown.
+
+
+ The data is encoded in a variant of Unix-to-Unix encode (UUENCODE) format for transport and results in seven-bit data. The data encoding is line-oriented, and is seven-bit compliant.
+
+
+ The class represents a Multipurpose Internet Mail Extensions (MIME) Content-Type header.
+
+
+ The constructor creates a new object that has default values.
+
+
+ The constructor creates a new object that specifies the type specified by value.
+ The content type value for this object.
+
+
+ The method puts a deep copy of this object into destination.
+ The destination object in which to store a copy of this object.
+
+
+ Returns .
+
+
+ The property gets or sets the media type for this object.
+ The property returns a string that contains the media type for this object.
+
+
+ The property gets or sets the subtype for this object.
+ The returns a string that contains the subtype for the Content-Type header represented by this object.
+
+
+ The property gets or sets the value of the Content-Type header represented by this object.
+ The property returns a string that contains the value of the Content-Type header represented by this object.
+
+
+ The class represents a header that contains structured date and time information.
+
+
+ The constructor creates a new object that has the given name and dateTime.
+ A DateTime object that specifies the Coordinated Universal Time (UTC) or local date and time to use when the new object is created.
+ A string that contains the name of the to be created.
+
+
+ The constructor creates a new object that has the given name, dateTime, and timeZoneOffset.
+ A TimeSpan object that specifies the offset that the new object uses to calculate the local time.
+ A DateTime object that specifyies the universal date and time to use when the object is created.
+ A string that contains the name of the to be created.
+
+
+ The method puts a deep copy of this object into destination.
+ The destination object in which to store a deep copy of this object.
+
+
+ The method indicates whether value is valid for this header.
+ The method returns true if value is valid; otherwise the method returns false.
+ The value to evaluate.
+
+
+ The property gets or sets the date and time represented by this object.
+ The property always returns the local time.
+
+
+ The property gets or sets the value of the Multipurpose Internet Mail Extensions (MIME) date header stored in this object.
+ The property returns an ASCII string that represents the MIME date in this DateHeader object.
+
+
+ The enumeration indicates the encodings to try when you are trying to decode Multipurpose Internet Mail Extensions (MIME) headers.
+
+
+ Try all the other encodings represented by the enumeration.
+
+
+ Pass control characters in the header without fixing them.
+
+
+ Try to decode headers by using DBCS decoding.
+
+
+ Return the raw headers if encoding fails.
+
+
+ Try to decode headers by using Japanese Industrial Standard (JIS) decoding.
+
+
+ Do not try to decode any headers because the value is already converted to Unicode.
+
+
+ Try to decode headers by using the encoding specified in RFC2047.
+
+
+ Try to decode headers by using the encoding specified in RFC2231.
+
+
+ Try to decode headers by using UTF8 decoding.
+
+
+ The structure specifies how to decode incoming headers.
+
+
+ The constructor creates a new structure that has the specified by decodingFlags.
+ The enumeration that specifies the encodings to use when trying to decode incoming headers.
+
+
+ The constructor creates a new structure that has the specified by decodingFlags and the encoding specified by encoding.
+ The System.Text.Encoding object that specifies the encoding for incoming headers if no character set information is specified in the incoming document.
+ The enumeration that specifies the encodings to use when trying to decode incoming headers.
+
+
+ The constructor creates a new structure that has the specified by decodingFlags and the encoding specified by charsetName.
+ A string that specifies the character set for incoming headers and parameters if no character set information is specified in the incoming document.
+ A enumeration that specifies the encodings to use when trying to decode incoming headers and parameters.
+
+
+ The static field is a structure that specifies that all supported encodings should be tried when decoding incoming headers.
+
+
+ The static field is a DecodingOptions structure that specifies that incoming headers will not be decoded.
+
+
+ The property gets the character set that is used for incoming headers.
+ The property returns an Encoding object that represents the encoding assumed for incoming headers when no character set is specified in the incoming document.
+
+
+ The property gets the character set name that is used for incoming headers.
+ The property returns the character set name that is assumed for incoming headers when no character set is specified in the incoming document.
+
+
+ The property returns the that is used for decoding incoming headers.
+ The enumeration returns the enumeration that specifies the encodings to try when trying to decode incoming headers.
+
+
+ The structure indicates whether incoming Multipurpose Internet Mail Extensions (MIME) headers were successfully decoded.
+
+
+ The enumeration provides various instructions related to encoding headers.
+
+
+ Enable RFC2231 encoding for parameters.
+
+
+ Force reencoding of headers with the encoding specified in .
+
+
+ No special encoding instructions are specified.
+
+
+ The class specifies how to encode outgoing headers.
+
+
+ The constructor initializes a new object.
+ A string that contains the name of the character set to use when encoding headers.
+ A string that contains the culture name to use for headers.
+ An enumeration that specifies various encoding instructions.
+
+
+ The enumeration indicates which encoding was detected in the header.
+
+
+ Indicates that unencoded 8-bit data was detected in the header.
+
+
+ Indicates that mislabeled Japanese Industrial Standard (JIS)–encoded data was detected in the header.
+
+
+ Indicates that the header encoding was not recognized.
+
+
+ Indicates that data encoded according to RFC2047 was detected in the header.
+
+
+ Indicates that data encoded according to RFC2231 was detected in the header.
+
+
+ The abstract class represents a general Multipurpose Internet Mail Extensions (MIME) header.
+
+
+ The method puts a deep copy of this object into destination.
+ The destination object in which to put a deep copy of this object.
+
+
+ The method creates a new object of the type specified by headerID.
+ A enumeration that specifies the type of Multipurpose Internet Mail Extensions (MIME) header to create.
+
+
+ The static method creates a new object that has the name that is specified by name.
+ A string that specifies the name of the object to create.
+
+
+ The static method returns the that corresponds to a header name.
+ A string that contains the name for which to return the corresponding .
+
+
+ The method indicates whether name is valid for this header.
+ The method returns true if name is valid; otherwise the method returns false.
+ The name to evaluate.
+
+
+ The method indicates whether value is valid for this header.
+ The method returns true if value is valid; otherwise the method returns false.
+ The value to evaluate.
+
+
+ The static method creates a object by reading a .
+ A object from which to read header information.
+
+
+ The method tries to get the value of this object. does not throw an exception if it fails
+ The method returns false if it is unable to return the value of the current header.
+ A object to fill with the value of the current header.
+
+
+ The property gets or sets the value of this object.
+ The property returns a string representation of the 7-bit ASCII header. You can override this to do RFC 2047 encoding.
+
+
+ The enumeration identifies header types.
+
+
+ Identifies an AdHoc header.
+
+
+ Identifies an ApparentlyTo header.
+
+
+ Identifies an Approved header.
+
+
+ Identifies an Article header.
+
+
+ Identifies a Bcc header.
+
+
+ Identifies a Bytes header.
+
+
+ Identifies a Cc header.
+
+
+ Identifies a Comments header.
+
+
+ Identifies a ContentBase header.
+
+
+ Identifies a ContentClass header.
+
+
+ Identifies a ContentDescription header.
+
+
+ Identifies a ContentDisposition header.
+
+
+ Identifies a ContentId header.
+
+
+ Identifies a ContentLanguage header.
+
+
+ Identifies a ContentLocation header.
+
+
+ Identifies a ContentMD5 header.
+
+
+ Identifies a ContentTransferEncoding header.
+
+
+ Identifies a ContentType header.
+
+
+ Identifies a Control header.
+
+
+ Identifies a Date header.
+
+
+ Identifies a DeferredDelivery header.
+
+
+ Identifies a DispositionNotificationTo header.
+
+
+ Identifies a Distribution header.
+
+
+ Identifies an Encoding header.
+
+
+ Identifies an Encrypted header.
+
+
+ Identifies an Expires header.
+
+
+ Identifies an ExpiryDate header.
+
+
+ Identifies a FollowUpTo header.
+
+
+ Identifies a From header.
+
+
+ Identifies an Importance header.
+
+
+ Identifies an InReplyTo header.
+
+
+ Identifies a Keywords header.
+
+
+ Identifies a Lines header.
+
+
+ Identifies a ListHelp header.
+
+
+ Identifies a ListSubscribe header.
+
+
+ Identifies a ListUnsubscribe header.
+
+
+ Identifies a MessageId header.
+
+
+ Identifies a MimeVersion header.
+
+
+ Identifies a NewsGroups header.
+
+
+ Identifies an NntpPostingHost header.
+
+
+ Identifies an Organization header.
+
+
+ Identifies a Path header.
+
+
+ Identifies a Precedence header.
+
+
+ Identifies a Priority header.
+
+
+ Identifies a Received header.
+
+
+ Identifies a References header.
+
+
+ Identifies a ReplyBy header.
+
+
+ Identifies a ReplyTo header.
+
+
+ Identifies a ResentBcc header.
+
+
+ Identifies a ResentCc header.
+
+
+ Identifies a ResentDate header.
+
+
+ Identifies a ResentFrom header.
+
+
+ Identifies a ResentMessageId header.
+
+
+ Identifies a ResentReplyTo header.
+
+
+ Identifies a ResentSender header.
+
+
+ Identifies a ResentTo header.
+
+
+ Identifies a ReturnPath header.
+
+
+ Identifies a ReturnReceiptTo header.
+
+
+ Identifies a RR header.
+
+
+ Identifies a Sender header.
+
+
+ Identifies a Sensitivity header.
+
+
+ Identifies a Subject header.
+
+
+ Identifies a Summary header.
+
+
+ Identifies a Supercedes header.
+
+
+ Identifies a To header.
+
+
+ Identifies an Unknown header.
+
+
+ Identifies an XMSMailPriority header.
+
+
+ Identifies an XPriority header.
+
+
+ Identifies an XRef header.
+
+
+ The class represents an ordered list of headers.
+
+
+ The method copies the contents of this object into destination.
+ A object in which to store a deep copy of this object.
+
+
+ The method returns an array that contains all objects in this object that are of the name specified by headerId.
+ A enumeration value that specifies the name of object to retrieve.
+
+
+ The method returns an array that contains all objects in this object that have the name specified by name.
+ A string that specifies the name of the objects to return.
+
+
+ The method returns the first object in this object that is of the name specified by headerId.
+ A enumeration value that specifies the name of the object to return.
+
+
+ The method returns the first object in this object that is of the name specified by name.
+ A string that specifies the name of the object to return.
+
+
+ The method returns the next object of the same name as the object that you supply.
+ The object returned is the next one in this object that has the same name as refHeader.
+ A object that specifies the name of the object to return.
+
+
+ The method uses a object to create a object.
+ A object from which to read a list of headers.
+
+
+ The method removes all headers in the current part that have the name specified by headerId.
+ A enumeration value that indicates the name of the headers to remove.
+
+
+ The method removes all headers in the current part that have the name specified by name.
+ A string that indicates the name of the headers to remove.
+
+
+ The method writes the headers in this object to stream.
+ An structure that describes how to encode the data as it is written to the stream.
+ A object that controls the data that is written to the stream.
+ The stream to write to.
+
+
+ The structure returns information about an address header.
+
+
+ The method moves to the next address in the header.
+ The method returns true if it successfully moved to the next address header. The method returns false if no more address headers are present or if the is not currently positioned on an address header.
+
+
+ The method tries to get the display name of the current address header.
+ A string in which to store the display name.
+
+
+ The method tries to get the display name of the current address header and makes available information about the encoding of the display name.
+ A string in which to store the display name.
+ A structure that is used to control the decoding.
+ A structure that exposes details about the decoding.
+
+
+ The enumeration controls the action that will be taken if noncompliant Multipurpose Internet Mail Extensions (MIME) text is encountered.
+
+
+ No exceptions are thrown when noncompliant MIME text is encountered.
+
+
+ Parsing will fail if noncompliant MIME text is encountered.
+
+
+ The enumeration flags report any errors that are found in the incoming Multipurpose Internet Mail Extensions (MIME) content or report that the MIME content is compliant.
+
+
+ A line was found in a MIME part body that was terminated by a bare linefeed.
+
+
+ A line was found in a MIME part header that was terminated by a bare linefeed.
+
+
+ The incoming MIME content was compliant.
+
+
+ A boundary was not of the correct form.
+
+
+ An external body was specified by using an invalid syntax.
+
+
+ A header was not of the correct form.
+
+
+ A composite part contained an invalid transfer-encoding value.
+
+
+ A line was found that was longer than 1000 characters.
+
+
+ A body separator was missing.
+
+
+ A required boundary was missing.
+
+
+ A composite header was missing a boundary parameter.
+
+
+ The class represents a Multipurpose Internet Mail Extensions (MIME) document.
+
+
+ The constructor creates a new blank object.
+
+
+ The constructor creates a new object.
+ A object that limits the allowed complexity of incoming Multipurpose Internet Mail Extensions (MIME) documents.
+ A structure that describes how to decode incoming headers.
+
+
+ The method readies this object for garbage collection.
+
+
+ The method readies this object for garbage collection.
+ Set disposing to true when you are calling from a finalizer. Otherwise, set disposing to false.
+
+
+ The method loads a stream of Multipurpose Internet Mail Extensions (MIME) data into this object.
+ A enumeration value that controls the treatment of the input MIME stream.
+ A stream that contains the MIME data to load into this object.
+
+
+ The method writes the Multipurpose Internet Mail Extensions (MIME) data in the Document Object Model (DOM) to stream.
+ The stream into which to write the MIME data that is contained in this object.
+
+
+ The method writes the Multipurpose Internet Mail Extensions (MIME) data in the Document Object Model (DOM) to stream by using encodingOptions and filter.
+ An class that controls how to encode the MIME data as it is written to stream.
+ A object that controls which headers and what content is written to stream.
+ The stream into which to write the MIME data that is contained in this object.
+
+
+ The callback is called when the end of a root Multipurpose Internet Mail Extensions (MIME) part has been reached.
+
+
+ The class provides information about Multipurpose Internet Mail Extensions (MIME) errors in objects in the namespace.
+
+
+ The constructor creates a new object by using message.
+ A string that contains the error message for this exception.
+
+
+ The constructor creates a new object that can be serialized by using info and context.
+ Describes the source and destination of the serialized stream, and provides an additional caller-defined context.
+ Contains all the data that is needed to serialize or deserialize this object.
+
+
+ The constructor creates a new from message and innerException.
+ The inner exception that triggered this object.
+ A string that contains the error message for this object.
+
+
+ The class represents a MIME address group.
+
+
+ The constructor creates an empty object using default values.
+
+
+ The constructor creates an empty object using the display name displayName.
+ A string containing the display name to use for this object.
+
+
+ The method puts a deep copy of this MimeGroup object into destination.
+ A object in which to store a deep copy of this object.
+
+
+ The structure returns information about Multipurpose Internet Mail Extensions (MIME) headers.
+
+
+ The method moves to the next header.
+ The method returns true if there is another header to read. Otherwise, it returns false.
+
+
+ The method tries to get the value of the current header and put it in value.
+ The method returns true if it was able to decode the header. It returns false, and sets value to null, if it was unable to decode the header.
+ A string in which to store the value of this header.
+
+
+ The method tries to get the value of the current header and put it in value.
+ The method returns true if it was able to decode the header. It returns false, and sets value to null, if it was unable to decode the header.
+ A structure that is used to control the decoding.
+ A string in which to store the value of the header read by this .
+ A structure that exposes details about the decoding.
+
+
+ The class controls the allowed complexity of Multipurpose Internet Mail Extensions (MIME) read by a object or used to create a .
+
+
+ The class is the base class for nodes within a object.
+
+
+ The method puts a object onto the end of the list of children that belong to this object.
+ The object to append to the list of the children of this object.
+
+
+ The method copies this object into destination.
+ The object into which to copy this object.
+
+
+ Returns .
+
+
+ The method inserts a new object after a specified object in the list of the children of this object.
+ The object to insert after.
+ The object to insert.
+
+
+ The method inserts a new object before a specified object in the list of the children of this object.
+ The object to insert before.
+ The object to insert.
+
+
+ The method puts a at the start of the list of the children of this object.
+ The object to insert.
+
+
+ The method removes all children of this object.
+
+
+ The method removes the specified child object from the list of the children of this object.
+ The object to remove.
+
+
+ The method removes this object from its parent.
+
+
+ The method replaces a specified child object with another specified object.
+ The object to replace.
+ The object to insert.
+
+
+ The method throws an exception if the owning is read-only.
+ The name of the calling method.
+
+
+ The method writes the Multipurpose Internet Mail Extensions (MIME) data in this to writer.
+ The into which to write the data in this .
+
+
+ The method writes the Multipurpose Internet Mail Extensions (MIME) data in this to stream.
+ The stream into which to write the data in this object.
+
+
+ The method writes the Multipurpose Internet Mail Extensions (MIME) data in this object into stream by using encodingOptions.
+ The object that controls the encoding that is used when the MIME data is written.
+ The stream into which to write the MIME data.
+
+
+ The property gets a bool value that indicates whether the owning is read-only.
+ The property returns true if the owning is read-only; otherwise the property returns false.
+
+
+ The structure lets you enumerate over the children of a object.
+
+
+ The method releases all resources used by the .
+
+
+ The method moves to the next object.
+ The method returns true if there was another object to move to.
+
+
+ The method returns this to its initial state.
+
+
+ The callback class customizes the way in which Multipurpose Internet Mail Extensions (MIME) data is written.
+
+
+ The constructor creates a .
+
+
+ The method is called after all data in a part are output, before the boundary or next part or end boundary is written.
+ The just written.
+ The Stream that is being written to.
+
+
+ The method is called before a is written.
+ Set the return value to true to suppress the writing of header; set the return value to false to write header.
+ The that will be written.
+ The Stream that is being written to.
+
+
+ The method is called at the beginning of a part, after the part boundary has been written.
+ Set the return value to true to suppress the writing of headerList; set the return value to false to write headerList.
+ The Stream to write to.
+ The object to filter.
+
+
+ The method is called before a part boundary is written.
+ Set the return value to true to suppress the writing of part; set the return value to false to write part.
+ The to filter.
+ The Stream to write to.
+
+
+ The method is called after the Multipurpose Internet Mail Extensions (MIME) part boundary is written.
+ The to filter.
+ The Stream to write to.
+
+
+ The class represents a Multipurpose Internet Mail Extensions (MIME) parameter.
+
+
+ The constructor creates a new object that has the name name.
+ The name of the object to create.
+
+
+ The constructor creates a new MimeParameter object that has the name name and the value value.
+ The value for the object to create.
+ The name of the object to create.
+
+
+ The method puts a deep copy of this object into destination.
+ The object into which to put a copy of this object.
+
+
+ The method puts the value of this object into value, but does not throw an exception if the encoding is unsupported.
+ The method returns true if decoding was successful, in which case value contains the Multipurpose Internet Mail Extensions (MIME) part value. It returns false if the decoding was unsuccessful, in which case value is empty.
+ The string in which to put the value of this MimeParameter object if decoding is successful.
+
+
+ The method puts the value of this object into value, but does not throw an exception if the encoding is unsupported.
+ A structure that is used to control the decoding.
+ A string in which to store the display name.
+ A structure that exposes details about the decoding.
+
+
+ The property gets the value of this object.
+ The value returned is the fully decoded Unicode value of the parameter. For RFC2231-encoded parameters, this value contains all the fragments of the header decoded and combined together. The string returned is never null.
+
+
+ The structure returns information about a object.
+
+
+ The method reads the next parameter.
+ The method returns true if there is another parameter to read.
+
+
+ The method tries to get the value of this parameter, but does not throw an exception if its encoding is not supported.
+ The method returns true if the encoding was understood, in which case value contains the parameter value. Otherwise, the method returns false, in which case value is empty.
+ A string in which to store the value.
+
+
+ The method tries to get the value of this parameter, but does not throw an exception if its encoding is not supported.
+ The method returns true if the encoding was understood, in which case value contains the parameter value. Otherwise, the method returns false, in which case value is empty.
+ A structure that is used to control the decoding.
+ A string in which to store the value.
+ A structure that exposes details about the decoding.
+
+
+ The class represents a Multipurpose Internet Mail Extensions (MIME) part.
+
+
+ The constructor creates a blank object.
+
+
+ The constructor creates a new MimePart object and adds a Content-Type header.
+ A string that represents the Content Type for this header.
+
+
+ The constructor creates a new object, gives it a specified Content-Type header, and sets the content.
+ A stream that contains Multipurpose Internet Mail Extensions (MIME) content to put in this header.
+ A enumeration value that specifies how to treat contentStream.
+ A string that contains the Content-Type header to use.
+ A enumeration value that describes the content transfer encoding to apply to contentType and contentStream.
+
+
+ The method creates a new object, gives it a specified content type, and sets the content.
+ A stream that contains Multipurpose Internet Mail Extensions (MIME) content to put in this header.
+ A enumeration value that specifies how to treat contentStream.
+ A string that contains the Content-Type header to use.
+ A string that describes the content transfer encoding to apply to contentType and contentStream.
+
+
+ The method stores a copy of this object in destination.
+ An object in which to store a copy of this object.
+
+
+ The method releases all resources used by the class.
+
+
+ The method releases the unmanaged resources used by the class and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method returns a stream that will be written to by using the specified content transfer encoding.
+ A ContentTransferEncoding enumeration value that will be set on this object.
+
+
+ The method returns a stream that will be written to by using the specified content transfer encoding.
+ The content transfer encoding to use when writing to this object.
+
+
+ The method sets the content of this object.
+ A stream that contains the content.
+ A enumeration value that specifies how to treat contentStream.
+ A enumeration value that specifies the content transfer encoding to use when setting the content by using contentStream.
+
+
+ The method sets the content of this object.
+ A stream that contains the content.
+ A enumeration value that specifies how to treat contentStream.
+ A string that specifies the content transfer encoding to use when setting the content by using contentStream.
+
+
+ The method gets a stream that can be used to read the content of this object.
+ A stream into which to put the read stream.
+
+
+ The method writes the contents of this object to a stream.
+ An enumeration value that specifies how to encode the data as it is written to stream.
+ A callback object that controls the data as it is written to stream.
+ The stream to write to.
+
+
+ The structure encapsulates an enumerable tree of the parts of this MIME message.
+
+
+ The method returns an enumerator that can be used to iterate over the contents of this structure.
+ A enumeration value that controls what the returned enumerates.
+
+
+ The enumeration controls how a object walks its tree.
+
+
+ Include parts from embedded message content subtrees.
+
+
+ All non-empty multipart or message nodes are visited both before and after its children have been visited. This allows you to do any work required to close a multipart or message node.
+
+
+ The structure provides rich control over the enumeration of the contents of a structure.
+
+
+ The method makes the next MimPart object in this PartSubtree structure the current one.
+ The method returns true if it successfully moved to the next object in this structure. Otherwise, if the is empty or if there are no more objects in it, the method returns false.
+
+
+ The method causes the next call to the method to skip the children of the current object and move to the next available parent object.
+
+
+ The method sets the to null and causes the root object to be returned by the next call to the method.
+
+
+ Releases all resources used by the .
+
+
+ The property gets the depth of the current object within the structure that belongs to this object.
+ The value of the property is zero for the root node of a structure.
+
+
+ The class returns information about a MIME stream.
+
+
+ The constructor creates a new object.
+ A Stream object that contains MIME data.
+
+
+ The constructor creates a new object.
+ A structure that determines the allowed complexity of incoming MIME documents.
+ A structure that is used to control the decoding.
+ A stream that contains MIME data.
+ If there is a missing MIME-Version header, inferMime indicates whether this MimeReader object will infer the presence of MIME content from the presence of a Content-Type or Content-Transfer-Encoding header. See Remarks.
+
+
+ The method closes the current stream and releases any resources (such as sockets and file handles) that are associated with the current stream.
+
+
+ The method copies a whole MIME part, both headers and content, into stream.
+ The stream into which to copy the headers and content for the current part.
+
+
+ The method releases the resources that are used by the .
+
+
+ The method Releases the unmanaged resources used by the and optionally releases the managed resources.
+ Set the value of the disposing parameter to true to release both managed and unmanaged resources. Set the value to false to release only unmanaged resources.
+
+
+ The method makes the unparsed headers available for reading.
+
+
+ The method reads at most count bytes into buffer, starting at offset bytes.
+ The return value for the method is the number of bytes that are actually written. This value may be less than the number of bytes that is specified by count if, for example, there are fewer than count bytes left between the current position and the end of the current part.
+ The byte array to write data into.
+ The number of bytes into buffer to begin writing data.
+ The number of bytes to try to read into buffer.
+
+
+ The method moves to the start of the first child part within the current part.
+ The method returns true if it successfully moved to the start of the first child part. If the current part has no children, the method moves to the end of the current part and returns false.
+
+
+ The method moves to the beginning of the current part, which allows for the reading of the headers for the current part.
+
+
+ The method moves to the next part in the MIME source stream.
+ The method returns true if it successfully moved to the next part. If there are no parts left to move to, the method moves to the end of the MIME message and returns false.
+
+
+ The method moves the current position to the next sibling of the current part.
+ The method returns true if it successfully moved the current position to the next sibling part. If the current part has no siblings, or if there are no more siblings in the current part, the method moves the current position to the end of the current part and returns false.
+
+
+ The method reads at most count bytes into buffer, without decoding them, starting at offset bytes.
+ The return value for the method is the number of bytes that are actually written. This value may be less than the number of bytes that is specified by count if, for example, there are fewer than count bytes left between the current position and the end of the current part.
+ The byte array to write data into.
+ The number of bytes into buffer to begin writing data.
+ The number of bytes to try to read into buffer.
+
+
+ The method resets the of the reader to .
+
+
+ The method gets a stream that contains the content of the current part body.
+ The method returns true if it successfully decoded the MIME content into result. If the content is empty, its encoding is unsupported, or it cannot be decoded for any other reason, the method returns false.
+ The stream that contains the returned content.
+
+
+ The class represents the sender or recipient of a MIME message.
+
+
+ The constructor initializes a new instance of the class with default values.
+
+
+ The constructor initializes a new instance of the class with.
+ A string containing the value to use for initializing the property.
+ A string containing the value to use for initializing the property.
+
+
+ The method copies this method into destination.
+ The object into which to copy this object.
+
+
+ The method indicates whether the specified string is a valid email address for the object.
+ The method returns true if email is a valid email address; otherwise the method returns false.
+ The email address to evaluate.
+
+
+ The method returns a object created from address using the contained in flags.
+ The e-mail address to use when creating the returned object.
+ The enumeration value controlling how address is parsed.
+
+
+ The class writes MIME to a stream.
+
+
+ The constructor creates a new object that will write MIME data to data.
+ A stream into which MIME data will be written.
+
+
+ The constructor creates a new object.
+ A class controlling how the MIME data is encoded as it is written.
+ Set to true to force writing of the Mime-Version tag.
+ A stream into which MIME data will be written.
+
+
+ The method closes the stream to which this object writes.
+
+
+ Releases all resources used by the .
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method closes the stream to which this writes.
+
+
+ The method ends the current group so that other recipients will be added outside of the current group.
+ This exception is thrown if the stream has already been flushed, the current header cannot contain recipients, or the current position does not allow recipients to be written.
+
+
+ The method ends the current part.
+
+
+ The method flushes the data in this object to the underlying stream.
+
+
+ The method returns a stream to which you can write the content of the current part using the current value of Content-Transfer-Encoding header.
+ The method throws this exception if is called twice, if the Content-Transfer-Encoding header has not been written, or if it has been written with a value representing an unrecognized encoding.
+
+
+ The method starts an e-mail group.
+ The name of this e-mail group.
+
+
+ The method starts a header using the header ID value in the headerID parameter.
+ A enumeration value identifying the kind of header to write.
+
+
+ The method starts a header using the name supplied by the name parameter.
+ A string specifying the name of the header to start.
+
+
+ The method begins a new MIME part.
+
+
+ The method writes an address from the specified by the reader parameter.
+ A structure containing the address to write.
+
+
+ The method writes content from a object to the stream that this object owns.
+ A object containing content to write to the output stream.
+
+
+ The method writes content from a source Stream to the stream that this object owns.
+ The stream from which to read MIME content.
+
+
+ The method writes data from a buffer into the stream that this object owns.
+ A byte array containing data to write to the stream that this owns.
+ An integer indicating where in buffer to begin reading data.
+ An integer indicating the number of bytes to write from buffer into the stream that this owns.
+
+
+ The method writes the next header from a object into the stream that this object owns.
+ A object that is positioned on the header to be read into the stream that this owns.
+
+
+ The method writes a header of a specified type and specified value to the stream that this object owns.
+ A string containing the value of the header that will be written.
+ A enumeration value indicating the kind of header to write.
+
+
+ The method writes a header of a specified type and specified value to the stream that this object owns.
+ A string containing the value of the header that will be written.
+ A string containing the name of the header to write.
+
+
+ The method writes a Date-Time value to the current header.
+ The DateTime value to write to the current header in the stream that this object owns.
+
+
+ The method writes a value specified by a string to the stream that this object owns.
+ A string containing the value to write to the stream that this object owns.
+
+
+ The method writes a parameter to the current header in the stream that this object owns.
+ A containing the parameter to write.
+
+
+ The method writes a parameter to the current header in the stream that this object owns.
+ The value of the parameter to write.
+ The name of the parameter to write.
+
+
+ The method writes a part to the stream that this object owns.
+ A MimeReader object positioned at the start of the part to write to the stream that this object owns.
+
+
+ The method writes content from a source stream to the stream that this object owns and does not apply an encoding to the content as it is written.
+ A stream containing the content to be written to the stream that this object owns.
+
+
+ The method writes content from a byte array to the stream that this object owns and does not apply an encoding to the content as it is written.
+ A byte array containing content to write to the stream that this object owns.
+ An integer indicating where in buffer to begin reading.
+ An integer indicating the number of bytes to read from buffer.
+
+
+ The method writes a recipient to the stream that this object owns.
+ The display name of the recipient.
+ The address of the recipient.
+
+
+ The property gets a string containing the part boundary for the current part.
+ When the property is accessed in a multipart document at the start of a part, returns a string containing the part boundary. Otherwise, returns null.
+
+
+ The class represents a "Received" header.
+
+
+ The constructor creates a new object.
+ The value of the TCP-info of the By-domain clause of this object.
+ The value to assign to the By clause. If the by parameter is passed as null, the constructor attempts to get this value from the byTcpInfo parameter.
+ The value of the TCP-info of the From-domain clause of this object.
+ The date the message associated with the Received header represented by this object was processed.
+ The link for the message associated with the Received header represented by this object.
+ The value of the path or mailbox for the Received header represented by this object.
+ The value to assign to the From clause. If the from parameter is passed as null, the constructor attempts to get this value from the fromTcpInfo parameter.
+ The ID of the message associated with the Received header represented by this object.
+ The protocol used to preprocess the Received header represented by this object.
+
+
+ The method copies this object into the destination parameter.
+ The object into which to copy this object.
+
+
+ The method indicates whether value is valid for this header.
+ The method returns true if value is valid; otherwise the method returns false.
+ The value to evaluate.
+
+
+ The class represents a MIME header.
+
+
+ The constructor creates a new object from name and value strings.
+ The name to assign to the header represented by this object.
+ The value to assign to the header represented by this object.
+
+
+ The method puts a copy of this object into the destination parameter.
+ The object into which to copy this object.
+
+
+ The method indicates whether value is valid for this header.
+ The method returns true if value is valid; otherwise the method returns false.
+ The value to evaluate.
+
+
+ The method tries to get the value of this object.
+ A string in which to place the value of this object.
+
+
+ The method tries to get the value of this object and makes available information about the encoding of the header.
+ A string in which to store the value of this object.
+ A structure that exposes details about the decoding.
+ A structure that is used to control the decoding.
+
+
+ The namespace contains types that enable you to easily convert MIME content from one encoding to another.
+
+
+ The class decodes base64-encoded data.
+
+
+ The constructor creates a new object.
+
+
+ The method decodes base64-encoded data.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the binary-encoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully encoded. The completed parameter is set to true when either all the input is consumed but the data is not flushed, or the rest of the input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to convert.
+ Set flush to true if this is the last block of data to be converted. Otherwise, set flush to false.
+ A byte array that contains the base64-encoded data to convert to binary.
+ The zero-based byte offset in input at which to begin reading the data to convert.
+ This exception is thrown if input contains invalid base64-encoded data.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set to true to release both managed and unmanaged resources. Set to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are required to store dataCount bytes of base64-encoded data after it has been decoded.
+ The maximum number of bytes needed to store the dataCount base64-encoded bytes after they have been decoded.
+ The number of bytes of base64-encoded data.
+
+
+ The method resets the internal state of this object.
+
+
+ The class encodes data into the base64 encoding.
+
+
+ The constructor creates a new default object.
+
+
+ The constructor initializes a new instance of the class with the LineLength property that is indicated by the lineLength parameter.
+ A value of 76 enables lines that are 76 characters long to be terminated by using CRLF. A value of 0 disables soft wrapping.
+ The lineLength parameter was neither 0 nor 76.
+
+
+ The method applies base64 encoding to data that is provided in a byte array.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the base64-encoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully encoded. The completed parameter is set to true when either all the input is consumed but the data is not flushed, or the rest of the input was flushed.
+ The zero-based byte offset in output at which to begin writing the encoded data.
+ Set flush to true if this is the last block of data to be converted. Otherwise, set flush to false.
+ A byte array that contains the binary data to encode.
+ The zero-based byte offset in input at which to begin reading the data to convert.
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize are less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set this parameter to true to release both managed and unmanaged resources. Set this parameter to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are required to store dataCount bytes of binary data after it has been encoded.
+ The number of bytes of binary data to encode.
+
+
+ The method resets the internal state of this object.
+
+
+ The property gets or sets a value that controls how the encoded data will be wrapped.
+ The property returns 0 or 76. A value of 0 indicates that no wrapping will be performed. A value of 76 indicates that at most 76 characters will come before a CRLF.
+
+
+ The class decodes BinHex data.
+
+
+ The constructor creates a new object that has default values.
+
+
+ The constructor creates a new object and specifies whether the resource fork is included in the output.
+ Set dataForkOnly to true to exclude the resource fork from the output. Set it to false to include the resource fork.
+
+
+ The method decodes BinHex-encoded data.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the decoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully decoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to decode.
+ Set flush to true if this is the last block of data to be decoded. Otherwise, set flush to false.
+ A byte array that contains the BinHex-encoded data to convert to binary.
+ The zero-based byte offset in input at which to begin reading the data to decode.
+ This exception is thrown if input contains invalid BinHex data.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set to true to release both managed and unmanaged resources. Set to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are needed to store dataCount bytes of BinHex data after it has been decoded.
+ The number of bytes of BinHex data.
+
+
+ The method resets the internal state of this object.
+
+
+ The property gets or sets a Boolean value that determines whether the resource fork is included in the output.
+ The property returns true if only the data fork is to be included in the conversion result. If the resource fork is to be included also, the property returns false.
+
+
+ The property gets a object.
+ The property returns the object that represents the Mac Binary Header in the BinHex-encoded data.
+
+
+ The class applies BinHex encoding.
+
+
+ The constructor creates a new object that has default values.
+
+
+ The constructor creates a new object that will include the Mac Binary Header header in its output.
+ A object that is used to write a Mac Binary Header to the output.
+
+
+ The method applies BinHex encoding.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the BinHex-encoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully encoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to convert.
+ Set flush to true if this is the last block of data to be encoded. Otherwise, set flush to false.
+ A byte array that contains the data to encode.
+ The zero-based byte offset in input at which to begin reading the data to encode.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set the value to true to release both managed and unmanaged resources. Set the value to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are needed to store dataCount bytes of data after it has been BinHex-encoded.
+ The number of bytes to BinHex encode.
+
+
+ The method resets the internal state of this object.
+
+
+ The class is a base class for the encoders and decoders in the namespace.
+
+
+ The constructor creates a new object with default values.
+
+
+ When overridden in a derived class, the method encodes or decodes sourceStream and writes it to destinationStream.
+ The stream that contains the data to encode or decode.
+ The stream that will contain the decoded or encoded results.
+
+
+ When overridden in a derived class, the method encodes or decodes data.
+ The number of bytes to use in output.
+ Set flush to true if this is the last block of data to be encoded or decoded. Otherwise, set flush to false.
+ The number of bytes actually read from input.
+ A byte array that will contain the result of the encoding or decoding.
+ The maximum number of bytes to be read from input.
+ The number of bytes actually written to output.
+ A Boolean value indicating that all data has been successfully encoded or decoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to encode or decode.
+ A byte array containing the data to encode or decode.
+ The zero-based byte offset in input at which to begin reading the data to encode or decode.
+
+
+ Releases the resources used by the .
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method returns a that decodes data encoded with the encoding specified by the name parameter.
+ The type of data the returned decoder will decode. Possible values are:Base64QuotedPrintableUUEncodeBinHex
+ The name parameter was not one of "Base64," "QuotedPrintable," "UUEncode," or "BinHex."
+
+
+ The method returns a object that can encode data by using the encoding specified by the name parameter.
+ The type of data the returned encoder will encode. Possible values are:Base64QuotedPrintableUUEncodeBinHex
+ The name parameter was not one of "Base64," "QuotedPrintable," "UUEncode," or "BinHex."
+
+
+ When overridden in a derived class, the method returns the maximum number of bytes needed to store the result of encoding or decoding dataCount bytes of raw or encoded data, respectively.
+ The number of bytes of data to encode or decode.
+
+
+ When overridden in a derived class, the method resets this object's internal state.
+
+
+ The class provides an exception for internal errors in the namespace.
+
+
+ The constructor creates a new with an informative message.
+ A string that contains the error message for this exception.
+
+
+ The constructor creates a new that can be serialized by using information and context.
+ Describes the source and destination of the serialized stream, and provides an additional caller-defined context.
+ Contains all the data that is needed to serialize or deserialize this object.
+
+
+ The constructor creates a new from an inner exception.
+ A string that contains the error message for this exception.
+ The inner exception that triggered this .
+
+
+ The class uses an object derived from to encode or decode data as it is read or written.
+
+
+ The constructor creates a new that uses encoder to encode or decode data as it is read from or written to stream, depending on the value of access.
+ An object derived from to use for encoding or decoding data as it is read or written.
+ The object to read or write to.
+ An enumeration value specifying whether stream is to be read from or written to.
+
+
+ The method closes the object that this owns.
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method clears all buffers in this object and causes any buffered data to be written.
+ The stream does not support writing.
+ The data source or repository is not open.
+
+
+ The method encodes or decodes data as it reads from the object that this object owns.
+ The method returns the total number of bytes read into the array.
+ An integer indicating where in array to place the data.
+ A byte array that will contain the read data.
+ An integer indicating the number of bytes to attempt to read.
+ array was null.
+ The sum of offset and count is greater than the array length.
+ The sum of offset and count is less than zero.
+ The that this object owns does not support reading.
+
+
+ The method moves the current position.
+ The method returns the current position after the seek operation has completed.
+ The possibly negative number of bytes to move from the position specified by origin.
+ A enumeration value indicating the location used to calculate the final seek position.
+ The requested seek position is less than zero.
+ The stream does not support seeking.
+
+
+ The method sets the length of the stream.
+ A long integer representing the desired length of the stream.
+ The stream does not support both writing and seeking.
+
+
+ The method encodes or decodes data as it writes it to the object that this object owns.
+ An integer indicating where in array to begin reading data.
+ A byte array that contains the source data.
+ An integer indicating the number of bytes to attempt to write.
+ Length of array minus offset is less than count.
+ array is null.
+ The stream does not support writing.
+ Either offset or count is negative, or the sum of offset and count is greater than the array length.
+
+
+ The property gets a Boolean value indicating whether this supports reading.
+ The property returns true if the object that this owns supports reading. Otherwise, if the object that this owns is closed or was opened with write-only privileges, returns false.
+
+
+ The property gets a Boolean value indicating whether the object that this object owns supports seeking.
+ The property returns true if seeking is supported. It returns false if the stream that this object owns is closed or if it was constructed from an operating system handle.
+
+
+ The property gets a Boolean value indicating whether the object that this object owns can be written to.
+ The property returns true if writing is supported. If the object that this object owns is closed or was opened with read-only access, the property returns false.
+
+
+ The property gets or sets a long integer value representing the current position within the object that this object owns.
+ You attempted to assign a value less than zero to the property.
+ The stream does not support seeking.
+
+
+ The enumeration contains values that indicate the access type for a stream.
+
+
+ Indicates read access.
+
+
+ Indicates write access.
+
+
+ The class represents a Mac Binary header in a BinHex data stream.
+
+
+ The constructor creates a new object with default values.
+
+
+ The constructor constructs a new object from a valid Mac Binary header contained in the bytes parameter.
+ A valid Mac Binary header.
+ The length of bytes is not 128.
+ The bytes parameter contains corrupt data.
+
+
+ The property gets the checksum for this .
+ The 16-bit CRC field for this .
+
+
+ The property gets or sets the creation date for this object.
+ The property returns the Coordinated Universal Time (UTC) creation date and time for this instance of the object.
+
+
+ The property gets or sets the Creator field of the Mac Binary Header represented by this object.
+ The property returns an Apple-defined four-byte ASCII sequence identifying the application that created the BinHex stream associated with this object.
+
+
+ The property gets or sets the FileName field of the Mac Binary header that this object represents.
+ The name of the file.
+
+
+ The property gets or sets an integer value representing the Type field in the Mac Binary header that this object represents.
+ An Apple-defined four byte sequence encoding for the file type.
+
+
+ The property gets or sets the FinderFlags field of the Mac Binary header represented by this object.
+ An Apple-defined FinderFlags field value.
+
+
+ The property gets or sets the ModificationDate field of the Mac Binary header that this object owns.
+ The property returns the Coordinated Universal Time (UTC) date and time of the modification date for this instance of the object.
+
+
+ The property gets the old Mac Binary header version, which must be 0.
+ The property returns 0.
+
+
+ The class decodes QuotedPrintable data.
+
+
+ The constructor creates a new object that has default values.
+
+
+ The method decodes QuotedPrintable data.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the decoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully decoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to decode.
+ Set flush to true if this is the last block of data to be decoded. Otherwise, set flush to false.
+ A byte array that contains the data to decode.
+ The zero-based byte offset in input at which to begin reading the data to decode.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if one any of the following sare true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set this to true to release both managed and unmanaged resources. Set this to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are needed to store dataCount bytes of data after it has been decoded.
+ The number of bytes of data to decode.
+
+
+ The method resets the internal state of this object.
+
+
+ The class applies QuotedPrintable encoding.
+
+
+ The constructor creates a new that has default values.
+
+
+ The constructor creates a new object.
+ Set ebcdicDictionary to true to include EBCDIC extensions.
+
+
+ The method applies QuotedPrintable encoding.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the encoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully encoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to encode.
+ Set flush to true if this is the last block of data to be encoded. Otherwise, set flush to false.
+ A byte array that contains the data to encode.
+ The zero-based byte offset in input at which to begin reading the data to encode.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set to true to release both managed and unmanaged resources. Set to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are needed to store dataCount bytes of data after it has been encoded.
+ The number of bytes to encode.
+
+
+ The method resets the internal state of this object.
+
+
+ The property returns a Boolean value that indicates whether EBCDIC extensions are being used.
+ The property returns true if the EBCDIC dictionary is being used. Otherwise, the property returns false.
+
+
+ The class decodes UUCP-encoded data.
+
+
+ The constructor creates a new object that has default values.
+
+
+ The method decodes UUCP data.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the decoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully decoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to decode.
+ Set flush to true if this is the last block of data to be decoded. Otherwise, set flush to false.
+ A byte array that contains the data to decode.
+ The zero-based byte offset in input at which to begin reading the data to decode.
+ This exception is thrown if input contains invalid UUCP data.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set the value to true to release both managed and unmanaged resources. Set the value to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are needed to store dataCount bytes of data after it has been decoded.
+ The number of bytes of data to decode.
+
+
+ The method resets the internal state of this object.
+
+
+ The class applies UUCP encoding.
+
+
+ The constructor creates a new that has default values.
+
+
+ The constructor creates a new object.
+ The file name to include in the UUCP prologue.
+
+
+ The method applies UUCP encoding.
+ The number of bytes to use in output.
+ The number of bytes hat are actually read from input.
+ A byte array that will contain the encoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully encoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to encode.
+ Set flush to true if this is the last block of data to be encoded. Otherwise, set flush to false.
+ A byte array that contains the data to encode.
+ The zero-based byte offset in input at which to begin reading the data to encode.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set this to true to release both managed and unmanaged resources. Set this to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are needed to store dataCount bytes of data after it has been encoded.
+ The number of bytes to encode.
+
+
+ The method resets the internal state of this object.
+
+
+ The property gets or sets the file name to include in the UUCP prologue.
+ The property returns the file name of the UUCP prologue.
+
+
+ The namespace contains types that enable you to easily convert data among different formats such as HTML, RTF, enriched text, and plain text.
+
+
+ The type is a read-only, forward-only pull mode converter based on the TextReader class.
+
+
+ The constructor constructs a new that converts sourceStream by using converter.
+ The Stream object containing text to convert.
+ The object that will be used to convert sourceStream.
+
+
+ The constructor constructs a new that converts sourceReader by using converter.
+ The object that will be used to convert data from sourceReader.
+ The object containing data to convert.
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method reads the converted character that will be returned by the next call to .
+
+
+ The method reads the next character from the input stream.
+ If successful, the return value for the method is the character read. Otherwise, -1 is returned.
+
+
+ The method reads count bytes from the input stream, starting at offset, and stores them in buffer.
+ The method returns the number of characters read.
+ The maximum number of characters to read. If the end of the stream is reached before count of characters is read into buffer, the current method returns.
+ When this method returns, it contains the specified character array with the values between index and (index + count - 1) replaced by the characters read from the current source.
+ The place in buffer at which to begin writing.
+
+
+ The class is a stream-based converter that can be configured for reading or writing.
+
+
+ The constructor creates a new read-only object for converting sourceReader by using converter.
+ The object to use for the conversion.
+ The from which to read the unconverted input.
+
+
+ The constructor creates a new object for writing converted content into destinationWriter by using conversion.
+ The to which to write the converted output.
+ The object to use for the conversion.
+
+
+ The constructor creates a new object that uses converter to either read from or write into stream, based on the value supplied by access.
+ The object to use when reading to or writing from stream.
+ The object to read from or write into.
+ The enumeration that specifies whether to read from or write to stream.
+
+
+ The method closes the .
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method clears all buffers for this and causes any buffered data to be written to the destination TextWriter that it owns.
+
+
+ The method reads and converts count bytes from the input stream and stores them in buffer, starting at offset.
+ The return value for the method is the number of characters read.
+ The place in buffer at which to begin writing.
+ The maximum number of characters to read. If the end of the stream is reached before count of characters is read into buffer, the current method returns.
+ When this method returns, it contains the specified character array with the values between index and (index + count - 1) replaced by characters read and converted from the current source.
+
+
+ The method throws a NotSupportedException. The object does not support seeks.
+ This parameter is ignored.
+ This parameter is ignored.
+
+
+ The method throws a NotSupportedException.
+ This parameter is ignored.
+
+
+ The method converts and writes count bytes from buffer, starting at offset, into the destination TextWriter that it owns.
+ The starting index in the buffer.
+ The number of characters to write.
+ The character array to write data from.
+
+
+ The property indicates whether the current stream supports reading.
+
+
+ The property returns false to indicate that the object does not support seeks.
+
+
+ The property indicates whether this can be written to.
+
+
+ The property throws a .
+
+
+ The property throws a . The class does not support seeks.
+
+
+ The type specifies the access mode for a ConverterStream object.
+
+
+ Specifies that the associated ConverterStream is open for reading.
+
+
+ Specifies that the associated ConverterStream is open for writing.
+
+
+ The type is a write-only converter that is derived from the class. Source documents are written into and the output is written into a or object.
+
+
+ The constructor creates a new object that uses converter to write converted output to destinationStream.
+ The to write the converted data to.
+ The to use for the conversion.
+
+
+ The constructor creates a new object that uses converter to write converted output to destinationWriter.
+ The to write the converted data to.
+ The to use for the conversion.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set the value to true to release both managed and unmanaged resources. Set the value to false to release only unmanaged resources.
+
+
+ The method clears all buffers for this object and causes any buffered data to be written to the destination or stream that it owns.
+
+
+ The method writes a single character into the destination or object that it owns.
+ The character to write into the or object that this owns.
+
+
+ The method converts buffer and writes it to the or object that this owns.
+ The character array that contains the text to convert and write.
+
+
+ The method converts value and writes it to the or object that this owns.
+ The string that contains the text to convert and write.
+
+
+ The method converts and writes count characters from buffer, starting at index, into the or that this owns.
+ The number of characters to write.
+ The character array to write data from.
+ The starting index in the buffer.
+
+
+ The method appends a new line to value, converts the resulting string, and writes it to the or object that this owns.
+ The string to convert and write.
+
+
+ The class converts enriched text to HTML.
+
+
+ The constructor creates a new object.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the byte order mark or determined by the property.
+ The property returns true if the byte order mark in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.
+
+
+ The property gets or sets a Boolean value indicating whether the HTML will be stripped of executable scripts.
+ The property returns true if executable scripts will be removed. Otherwise, this property returns false.
+
+
+ The class converts enriched text to plain text.
+
+
+ The constructor creates a new object.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the byte order mark or determined by the property.
+ The property returns true if the byte order mark in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.
+
+
+ The enumeration contains values that determine how headers and footers are interpreted before they are inserted into converted output.
+
+
+ The header or footer contains properly-formatted HTML and will be converted to the output format.
+
+
+ The header or footer contains plain text. If the plain text contains any special characters (for example, '<' or '&'), they will be escaped, when necessary, as they are written to the output.
+
+
+ The enumeration contains values that represent HTML attributes.
+
+
+ The HTML markup Abbr.
+
+
+ The HTML markup Accept.
+
+
+ The HTML markup AcceptCharset.
+
+
+ The HTML markup AccessKey.
+
+
+ The HTML markup Action.
+
+
+ The HTML markup Align.
+
+
+ The HTML markup Alink.
+
+
+ The HTML markup Alt.
+
+
+ The HTML markup Archive.
+
+
+ The HTML markup Axis.
+
+
+ The HTML markup Backgroun.
+
+
+ The HTML markup BGColor.
+
+
+ The HTML markup Border.
+
+
+ The HTML markup CellPaddin.
+
+
+ The HTML markup CellSpacin.
+
+
+ The HTML markup Char.
+
+
+ The HTML markup CharOff.
+
+
+ The HTML markup Charset.
+
+
+ The HTML markup Checked.
+
+
+ The HTML markup Cite.
+
+
+ The HTML markup Class.
+
+
+ The HTML markup ClassId.
+
+
+ The HTML markup Clear.
+
+
+ The HTML markup Code.
+
+
+ The HTML markup CodeBase.
+
+
+ The HTML markup CodeType.
+
+
+ The HTML markup Color.
+
+
+ The HTML markup Cols.
+
+
+ The HTML markup ColSpan.
+
+
+ The HTML markup Compact.
+
+
+ The HTML markup Content.
+
+
+ The HTML markup Coords.
+
+
+ The HTML markup Data.
+
+
+ The HTML markup DateTime.
+
+
+ The HTML markup Declare.
+
+
+ The HTML markup Defer.
+
+
+ The HTML markup Dir.
+
+
+ The HTML markup Disabled.
+
+
+ The HTML markup DynSrc.
+
+
+ The HTML markup EncType.
+
+
+ The HTML markup Face.
+
+
+ The HTML markup For.
+
+
+ The HTML markup Frame.
+
+
+ The HTML markup FrameBorder.
+
+
+ The HTML markup Headers.
+
+
+ The HTML markup Height.
+
+
+ The HTML markup Href.
+
+
+ The HTML markup HrefLang.
+
+
+ The HTML markup Hspace.
+
+
+ The HTML markup HttpEquiv.
+
+
+ The HTML markup Id.
+
+
+ The HTML markup IsMap.
+
+
+ The HTML markup Label.
+
+
+ The HTML markup Lang.
+
+
+ The HTML markup Language.
+
+
+ The HTML markup LeftMargin.
+
+
+ The HTML markup Link.
+
+
+ The HTML markup LongDesc.
+
+
+ The HTML markup LowSrc.
+
+
+ The HTML markup MarginHeight.
+
+
+ The HTML markup MarginWidth.
+
+
+ The HTML markup MaxLength.
+
+
+ The HTML markup Media.
+
+
+ The HTML markup Method.
+
+
+ The HTML markup Multiple.
+
+
+ The HTML markup Name.
+
+
+ The HTML markup NoHref.
+
+
+ The HTML markup NoResize.
+
+
+ The HTML markup NoShade.
+
+
+ The HTML markup NoWrap.
+
+
+ The HTML markup Object.
+
+
+ The HTML markup Profile.
+
+
+ The HTML markup Prompt.
+
+
+ The HTML markup ReadOnly.
+
+
+ The HTML markup Rel.
+
+
+ The HTML markup Rev.
+
+
+ The HTML markup Rows.
+
+
+ The HTML markup RowSpan.
+
+
+ The HTML markup Rules.
+
+
+ The HTML markup Scheme.
+
+
+ The HTML markup Scope.
+
+
+ The HTML markup Scrolling.
+
+
+ The HTML markup Selected.
+
+
+ The HTML markup Shape.
+
+
+ The HTML markup Size.
+
+
+ The HTML markup Span.
+
+
+ The HTML markup Src.
+
+
+ The HTML markup StandBy.
+
+
+ The HTML markup Start.
+
+
+ The HTML markup Style.
+
+
+ The HTML markup Summary.
+
+
+ The HTML markup TabIndex.
+
+
+ The HTML markup Target.
+
+
+ The HTML markup Text.
+
+
+ The HTML markup Title.
+
+
+ The HTML markup TopMargin.
+
+
+ The HTML markup Type.
+
+
+ The HTML markup Unknown.
+
+
+ The HTML markup UseMap.
+
+
+ The HTML markup Valign.
+
+
+ The HTML markup Value.
+
+
+ The HTML markup ValueType.
+
+
+ The HTML markup Version.
+
+
+ The HTML markup Vlink.
+
+
+ The HTML markup Vspace.
+
+
+ The HTML markup Width.
+
+
+ The class provides a reader for attributes inside an HTML tag token.
+
+
+ The method returns the name of the attribute as a string.
+ The name of the attribute as a string.
+
+
+ The method returns an arbitrarily long attribute name in chunks.
+ The method returns the number of characters successfully read.
+ Offset into the attribute name to start reading characters.
+ The maximum number of characters to return.
+ Character array that will receive the attribute name.
+
+
+ The method advances to the next attribute in the tag token.
+ The method returns true if the reader advances to the first or next attribute; otherwise, false to indicate that there are no more attributes to read.
+
+
+ The method returns the attribute value as a string.
+ The method returns the attribute value as a string.
+
+
+ The method reads the current attribute value into a character array.
+ The method returns the number of characters read from the attribute value.
+ The position in the attribute value to begin reading..
+ The number of characters to read from the attribute value.
+ The character array that will receive the attribute value.
+
+
+ The property gets a value indicating whether the current attribute as an associated value.
+ The property returns true if the attribute has a value; otherwise, it returns false.
+
+
+ The property gets the current attribute identifier.
+ The method returns one of the enumeration values identifying the current attribute; or if the attribute is not an identified attribute.
+
+
+ The property gets a value indicating whether the attribute name is longer than 128 characters.
+ The property is true if the attribute name is longer than 128 characters; otherwise the property is false.
+
+
+ The property gets a value indicating whether the attribute value is longer than 128 characters.
+ The property is true if the attribute value is longer than 128 characters; otherwise the property is false.
+
+
+ The class is a forward-only parser for HTML documents.
+
+
+ The constructor initializes a new instance of the class that reads data from the specified text reader.
+ The object that contains the HTML document.
+
+
+ The constructor initializes a new instance of the class that reads data from the specified data stream using the specified encoding.
+ The object that contains the HTML document.
+
+
+ The method closes the instance and releases resources used by the instance.
+
+
+ The method releases resource used by the instance.
+ true if the method is called from the finalizer; otherwise, false.
+
+
+ The method reads an HTML tag without parsing the internal text to HTML tokens.
+ The method returns the number of characters successfully read from the input stream.
+ The starting location in the input data to start reading.
+ The number of characters to read from the input stream.
+ The character array that will receive the incoming characters.
+
+
+ The method advances to the next HTML token.
+ The method returns true if it advances to the next token; otherwise, the method returns false to indicate that there are no more tokens to read.
+
+
+ The method reads an HTML tag name as a string.
+ The method returns a string containing the HTML tag name.
+
+
+ The method returns the HTML tag name as a series of chunks in a character array.
+ The method returns the number of characters successfully read from the input stream.
+ The starting location in the input data to start reading.
+ The number of characters to read from the input stream.
+ The character array that will receive the incoming characters.
+
+
+ The method reads the text of an HTML token.
+ The method returns the number of characters successfully read from the input stream.
+ The starting location in the input data to start reading.
+ The number of characters to read from the input stream.
+ The character array that will receive the incoming characters.
+
+
+ The property gets an attribute reader that will parse the attributes of an HTML tag.
+ The property gets an instance that parses the attributes of an HTML tag.
+
+
+ The property gets the current nesting depth of the HTML document.
+ The returns the current nesting depth of the HTML document.
+
+
+ The property gets or sets a value that indicates whether the byte order mark in the HTML document is used to select the input code page.
+ The property returns true if the byte order mark should be respected; otherwise, the property returns false.
+
+
+ The property gets or sets the character encoding that is used when parsing the input stream.
+ The property gets the object that is used when parsing the input stream.
+
+
+ The parameter gets or sets a value that indicates whether the HTML stream should me normalized.
+ The parameter is true if the input HTML should be normalized; otherwise the property is false.
+
+
+ The property gets the depth delta associated with the OverlappedClose and OverlappedReopen tokens.
+ The property gets the overlapped depth.
+
+
+ The property gets the identifier for the current HTML tag.
+ The property returns one of the enumeration values indicating the identifier of the current tag, or return if the current tag cannot be identified.
+
+
+ The property gets a value indicating whether the current tag was inserted when normalizing the HTML document.
+ The property returns true if the current tag was inserted when normalizing the HTML document; otherwise, the property returns false if the current tag is present in the HTML document.
+
+
+ The property gets a value that indicates whether the current HTML tag is extremely long.
+ The property returns true if the current tag name is extremely long; otherwise, the property returns false.
+
+
+ The property gets the kind of token that the is currently processing.
+ The property returns one of the enumeration values indicating the kind of token that the is currently processing.
+
+
+ The delegate is called to enable custom filtering of specific HTML tags.
+
+
+ The class is passed to the delegate and is used to get information about the tag that caused the callback and to filter the tag as it is written to the output.
+
+
+ The method suppresses the output of the content between the tag that caused the callback to the delegate and its end tag.
+
+
+ The method suppresses the output of the tag that caused the callback to the delegate from the output of the conversion.
+
+
+ The method suppresses the output of the tag that caused the callback to the delegate from the output of the conversion and allows you to control whether output of the end tag is also suppressed.
+ Set this parameter to true to preserve the end tag. Set this parameter to false to suppress the output of both the start tag and the end tag.
+
+
+ The method causes the callback to be called for the current tag's corresponding end tag.
+
+
+ The method writes the tag that caused the callback to the output.
+
+
+ The method writes the tag that caused the callback to the output and optionally controls whether the attributes originally present are written.
+ Set this parameter to true to write the attributes originally present. Otherwise, set this parameter to false to suppress them.
+
+
+ The property gets a Boolean value indicating whether the tag that caused the callback to the delegate is an empty element tag.
+ The property returns true if the current tag is empty. Otherwise, it returns false.
+
+
+ The property gets a Boolean value indicating whether the tag that caused the callback to the delegate is an end tag.
+ The property returns true if the current tag is an end tag. Otherwise it returns false.
+
+
+ The structure is a collection of structures that represent the attributes of the HTML tag that caused the callback to the delegate.
+
+
+ The property gets the structure identified by index.
+ The zero-based index of the structure to get.
+
+
+ The class provides methods that allow you to iterate over a collection of structures.
+
+
+ Releases all resources used by .
+
+
+ The method moves the current position to the next structure.
+ The method returns true if there was another structure to which to move. Otherwise it returns false.
+
+
+ The method resets this structure.
+
+
+ The structure contains information about an attribute in the current HTML tag.
+
+
+ The static field contains a filled with empty values, which do not map to any attribute.
+
+
+ The method reads the attribute value or value part into a character array.
+ The returns the number of characters read into buffer.
+ The place in buffer at which to begin writing.
+ The maximum number of characters to read. If the end of the attribute value is reached before count of characters is read into buffer, the current method returns.
+ When this method returns, it contains the specified character array with the values between index and (index + count - 1) replaced by characters read and converted from the stored attribute value.
+
+
+ The method writes the attribute name and value to the output.
+
+
+ The method writes the attribute name to the output.
+
+
+ The method writes the attribute value to the output.
+
+
+ The enumeration contains values that represent HTML tags.
+
+
+ The HTML markup A.
+
+
+ The HTML markup Abbr.
+
+
+ The HTML markup Acronym.
+
+
+ The HTML markup Address.
+
+
+ The HTML markup Applet.
+
+
+ The HTML markup Area.
+
+
+ The HTML markup B.
+
+
+ The HTML markup Base.
+
+
+ The HTML markup BaseFont.
+
+
+ The HTML markup Bdo.
+
+
+ The HTML markup BGSound.
+
+
+ The HTML markup Big.
+
+
+ The HTML markup Blink.
+
+
+ The HTML markup BlockQuote.
+
+
+ The HTML markup Body.
+
+
+ The HTML markup BR.
+
+
+ The HTML markup Button.
+
+
+ The HTML markup Caption.
+
+
+ The HTML markup Center.
+
+
+ The HTML markup Cite.
+
+
+ The HTML markup Code.
+
+
+ The HTML markup Col.
+
+
+ The HTML markup ColGroup.
+
+
+ The HTML markup Comment.
+
+
+ The HTML markup DD.
+
+
+ The HTML markup Del.
+
+
+ The HTML markup Dfn.
+
+
+ The HTML markup Dir.
+
+
+ The HTML markup Div.
+
+
+ The HTML markup DL.
+
+
+ The HTML markup DT.
+
+
+ The HTML markup EM.
+
+
+ The HTML markup Embed.
+
+
+ The HTML markup FieldSet.
+
+
+ The HTML markup Font.
+
+
+ The HTML markup Form.
+
+
+ The HTML markup Frame.
+
+
+ The HTML markup FrameSet.
+
+
+ The HTML markup H1.
+
+
+ The HTML markup H2.
+
+
+ The HTML markup H3.
+
+
+ The HTML markup H4.
+
+
+ The HTML markup H5.
+
+
+ The HTML markup H6.
+
+
+ The HTML markup Head.
+
+
+ The HTML markup HR.
+
+
+ The HTML markup Html.
+
+
+ The HTML markup I.
+
+
+ The HTML markup Iframe.
+
+
+ The HTML markup Image.
+
+
+ The HTML markup Img.
+
+
+ The HTML markup Input.
+
+
+ The HTML markup Ins.
+
+
+ The HTML markup IsIndex.
+
+
+ The HTML markup Kbd.
+
+
+ The HTML markup Label.
+
+
+ The HTML markup Legend.
+
+
+ The HTML markup LI.
+
+
+ The HTML markup Link.
+
+
+ The HTML markup Listing.
+
+
+ The HTML markup Map.
+
+
+ The HTML markup Marquee.
+
+
+ The HTML markup Menu.
+
+
+ The HTML markup Meta.
+
+
+ The HTML markup NextId.
+
+
+ The HTML markup NoBR.
+
+
+ The HTML markup NoEmbed.
+
+
+ The HTML markup NoFrames.
+
+
+ The HTML markup NoScript.
+
+
+ The HTML markup Object.
+
+
+ The HTML markup OL.
+
+
+ The HTML markup OptGroup.
+
+
+ The HTML markup Option.
+
+
+ The HTML markup P.
+
+
+ The HTML markup Param.
+
+
+ The HTML markup PlainText.
+
+
+ The HTML markup Pre.
+
+
+ The HTML markup Q.
+
+
+ The HTML markup RP.
+
+
+ The HTML markup RT.
+
+
+ The HTML markup Ruby.
+
+
+ The HTML markup S.
+
+
+ The HTML markup Samp.
+
+
+ The HTML markup Script.
+
+
+ The HTML markup Select.
+
+
+ The HTML markup Small.
+
+
+ The HTML markup Span.
+
+
+ The HTML markup Strike.
+
+
+ The HTML markup Strong.
+
+
+ The HTML markup Style.
+
+
+ The HTML markup Sub.
+
+
+ The HTML markup Sup.
+
+
+ The HTML markup Table.
+
+
+ The HTML markup Tbody.
+
+
+ The HTML markup TD.
+
+
+ The HTML markup TextArea.
+
+
+ The HTML markup Tfoot.
+
+
+ The HTML markup TH.
+
+
+ The HTML markup Thead.
+
+
+ The HTML markup Title.
+
+
+ The HTML markup TR.
+
+
+ The HTML markup TT.
+
+
+ The HTML markup U.
+
+
+ The HTML markup UL.
+
+
+ An unknown tag was encountered.
+
+
+ The HTML markup Var.
+
+
+ The HTML markup Wbr.
+
+
+ The HTML markup Xml.
+
+
+ The HTML markup Xmp.
+
+
+ The converts HTML to enriched text.
+
+
+ The constructor creates a new object.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the byte order mark or determined by the property.
+ The property returns true if the byte order mark in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the meta tag or determined by the property.
+ The property returns true if the meta tag in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.
+
+
+ The property gets or sets a enumeration value that indicates whether headers and footers will be interpreted as text or as HTML.
+ If the property is set to , then and are interpreted as HTML and only the text that would be visible in the HTML fragment after it was rendered will be inserted into the output. Otherwise, if the property is set to , then and are interpreted as raw plain text that will be properly escaped and inserted directly into the output.
+
+
+ The conversion object transforms HTML. It is used to normalize and filter HTML, convert HTML to use a different code page, and inject text into HTML.
+
+
+ The constructor creates a new conversion object.
+
+
+ The property gets or sets a Boolean value that indicates whether output HTML will be stripped of executable scripts.
+ The property returns true if executable scripts will be removed. Otherwise, this property returns false.
+
+
+ The enumeration identifies the current token type being processed by an object.
+
+
+ Indicates that the current tag does not contain any elements, such as the <BR> tag.
+
+
+ Indicates that the current tag is the end tag of an element, such as </A>
+
+
+ Indicates that the current tag is an HTML tag inserted by HTML normalization to close an HTML element that is not the most recently opened HTML element.
+
+
+ Indicates that the current tag is an HTML tag inserted by HTML normalization to reopon an HTML element that was closed by an element.
+
+
+ Indicates that the current tag is a special HTML tag, such as a comment.
+
+
+ Indicates that the current tag is the start tag of an HTML element, such as <A>.
+
+
+ Indicates that the current token is text between an HTML start tag and an HTML end tag.
+
+
+ The class converts HTML to RTF.
+
+
+ The constructor creates a new object.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the byte order mark or determined by the property.
+ The property returns true if the byte order mark in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.If the property is set to true, but the byte order mark is not present, then the property will be used to determine the encoding.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the meta tag or determined by the property.
+ The property returns true if the meta tag in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.If the property is set to true, but the meta tag contains no encoding information, then the property will be used to determine the encoding.
+
+
+ The property gets or sets a enumeration value that indicates whether headers and footers will be interpreted as text or as HTML.
+ If the property is set to , then and are interpreted as HTML and only the text that would be visible in the HTML fragment after it was rendered will be inserted into the output. Otherwise, if the property is set to , then and are interpreted as raw plain text that will be properly escaped and inserted directly into the output.
+
+
+ The class converts HTML to plain text.
+
+
+ The constructor creates a new object.
+
+
+ The constructor creates a new object and allows you to specify the text extraction mode.
+ A enumeration value specifying whether or not to preserve formatting in extracted text.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the byte order mark or determined by the property.
+ The property returns true if the byte order mark in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.If the property is set to true, but the byte order mark is not present, then the property is used to determine the encoding.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the meta tag or determined by the property.
+ The property returns true if the meta tag in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.If the property is set to true, but the byte order mark is not present, then the property is used to determine the encoding.
+
+
+ The property gets or sets a enumeration value that indicates whether headers and footers will be interpreted as text or as HTML.
+ If the property is set to , then and are interpreted as HTML and only the text that would be visible in the HTML fragment after it was rendered will be inserted into the output. Otherwise, if the property is set to , then and are interpreted as raw plain text that will be properly escaped and inserted directly into the output.
+
+
+ The class provides methods that allow you to easily write HTML tags, HTML attribute, and text to an output HTML document.
+
+
+ The constructor creates a new object with a specified as the output.
+ The object to which to write HTML.
+
+
+ The constructor creates a new object that outputs to a given object using a given encoding.
+ The object to which to write HTML.
+ The encoding to use when writing to output.
+
+
+ The method closes the instance and releases any resources used by the instance.
+
+
+ The method disposes of the instance.
+ true if the method is not called by the finalizer; otherwise, false.
+
+
+ The method clears all buffers for this and causes any buffered data to be written to the destination object or object that it owns.
+
+
+ The method writes an HTML attribute to the output stream.
+ An that contains the attribute to write.
+
+
+ The writes the attribute specified by an enumeration value.
+ A string containing the value of the attribute to write.
+ A enumeration value identifying the attribute to write.
+
+
+ The method writes an attribute with the specified name and value.
+ The name of the attribute to write.
+ The value of the attribute.
+
+
+ The method reads an attribute value from a buffer and writes it to the output with the name specified by the id parameter.
+ The starting index in buffer.
+ The character array to write the value data from.
+ The number of characters to write.
+ A enumeration value identifying the attribute to write.
+
+
+ The method reads an attribute value from a buffer and writes it to the output with a name specified by the name parameter.
+ The number of characters to write.
+ The character array to write the value data from.
+ The name of the attribute to write.
+ The starting index in buffer.
+
+
+ The method writes the attribute name identified by id to the output.
+ A enumeration value that specifies the attribute name to write to the output.
+
+
+ The method writes an attribute name to the HTML output stream.
+ A object that contains the attribute to write to the output stream.
+
+
+ The method writes the specified attribute name to the output.
+ The attribute name to write.
+
+
+ The method writes an attribute value to the HTML output stream.
+ The object that contains the attribute to write to the HMTL output stream.
+
+
+ The method writes an attribute value to the output.
+ The attribute value to write.
+
+
+ The method reads an attribute value from a buffer and writes it to the output.
+ The number of characters to write.
+ The character array to write data from.
+ The starting index in buffer.
+
+
+ The method writes the empty element tag identified by id to the output.
+ A enumeration value specifying an empty element tag to write.
+
+
+ The method writes an empty element tag to the output.
+ The empty element tag to write.
+
+
+ The method writes the end tag identified by id to the output.
+ A enumeration value that identifies the end tag to write.
+
+
+ The method writes an end tag to the output.
+ The end tag to write.
+
+
+ The method copies the original content of an HTML element and writes it to the HTML output stream.
+ A object containing the text to write to the output stream.
+
+
+ The method writes a string containing HTML markup directly to the output, without escaping special characters.
+ The HTML markup to write.
+
+
+ The method reads HTML from a buffer and writes it directly to the output, without escaping special characters.
+ The number of characters to write.
+ The character array to write data from.
+ The starting index in buffer.
+
+
+ The method writes the start tag identified by id to the output.
+ A enumeration value that identifies the start tag to write.
+
+
+ The method writes a start tag to the output.
+ The start tag to write.
+
+
+ The method copies an HTML element, including attributes, to the HTML output stream.
+ The object that contains the element to write to the HTML output stream.
+
+
+ The method writes the text content of an HTML element to the HTML output stream.
+ The that contains the text to write to the HTML output stream.
+
+
+ The method writes text to the output.
+ The text to write.
+
+
+ The method reads text from a buffer and writes it to the output.
+ The number of characters to write.
+ The character array to write text from.
+ The starting index in buffer.
+
+
+ The enumeration contains values that identify the state of a object.
+
+
+ The object is inside a tag and has started an attribute. The object can append a value to the current attribute, start the next attribute, or write another tag or text.
+
+
+ The object is not inside a tag. The object can write a tag or text.
+
+
+ The object is inside a tag, but has not started an attribute. The object can start an attribute or write another tag or text.
+
+
+ The class extracts compressed Rich Text Format (RTF).
+
+
+ The constructor creates a new object.
+
+
+ The enumeration indicates the kind of compression that will be performed.
+
+
+ The contents of the destination stream will be compressed.
+
+
+ The contents of the destination stream will have a compression header but will not be compressed.
+
+
+ The class implements a conversion from Rich Text Format (RTF) to HTML.
+
+
+ The constructor creates a new object.
+
+
+ The property specifies whether to extract encapsulated HTML present in the input Rich Text Format (RTF) or to ignore encapsulated HTML in the input and perform normal conversion of RTF into HTML.
+ The property returns a Boolean value that indicates whether to extract encapsulated HTML present in the input.
+
+
+ The property gets a Boolean value that indicates whether the source RTF document contains encapsulated HTML.
+ The property returns true if both the property is true and the source RTF document contains encapsulated HTML. Otherwise, if either the property is false or the source RTF document does not contain encapsulated HTML, this property returns false.
+
+
+ The property gets or sets a Boolean value that indicates whether the property will be stripped of executable scripts.
+ The property returns true if executable scripts will be removed. Otherwise, the property returns false.
+
+
+ The class implements a conversion from RTF to RTF.
+
+
+ The constructor creates a new object.
+
+
+ The class implements a conversion that converts from Rich Text Format (RTF) to compressed RTF.
+
+
+ The constructor creates a new object.
+
+
+ The class implements a conversion from Rich Text Format (RTF) to text.
+
+
+ The constructor creates a new object.
+
+
+ The constructor creates a new object and allows you to specify the text extraction mode.
+ A enumeration value specifying whether or not to preserve formatting in extracted text.
+
+
+ The class is an abstract base class representing a transformation of text or other data from one format to another.
+
+
+ The method converts the entire contents of sourceStream from its format to the format specified by this object and stores the result in destinationStream.
+ The stream that contains the data to convert.
+ The stream in which to store the conversion.
+
+
+ The method converts the entire contents of sourceStream from its format to the format of destinationWriter and writes the result to destinationWriter.
+ The destination TextWriter object in which to write the converted data.
+ The Stream object that contains the data to convert.
+
+
+ The method converts the entire contents of sourceReader from its format to the format of destinationStream and stores the result in destinationStream.
+ The Stream object in which to store the converted data.
+ The TextReader object that reads the data to convert.
+
+
+ The method converts the entire contents of sourceReader from its format to the format of destinationWriter and writes the result to destinationWriter.
+ The destination TextWriter object in which to write the converted data.
+ The TextReader object that reads the data to convert.
+
+
+ The property gets or sets the internal input buffer size, in bytes, for stream input.
+ The actual read buffer size in bytes.
+
+
+ The exception is thrown when a data format error causes an unrecoverable error.
+
+
+ The constructor creates a new object with a specified message.
+ The message for this exception.
+
+
+ The constructor creates a new object that can be serialized by using info and context.
+ Describes the source and destination of the serialized stream and provides an additional caller-defined context.
+ Contains all the data that is needed to serialize or deserialize this object.
+
+
+ The constructor creates a new object from message and innerException.
+ A string that contains the error message for this object.
+ The inner exception that triggered this exception.
+
+
+ The enumeration contains values that specify how text will be extracted.
+
+
+ Indicates that the text only is to be extracted. Any formatting will be ignored.
+
+
+ Indicates that formatting will be preserved in extracted text.
+
+
+ The implements a conversion from text to HTML.
+
+
+ The constructor creates a new object.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the byte order mark or determined by the property.
+ The property returns true if the byte order mark in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.
+
+
+ The property gets or sets a Boolean value indicating whether the output HTML will be stripped of executable scripts.
+ The property returns true if executable scripts will be removed from the output HTML. Otherwise, this property returns false.
+
+
+ The object converts from text to RTF.
+
+
+ The constructor creates a new object.
+
+
+ The object converts from text to text.
+
+
+ The constructor creates a new object.
+
+
+ The constructor creates a new object with the specified by mode.
+ A enumeration value that indicates how text will be converted.
+
+
+ The enumeration controls how text will be converted.
+
+
+ Indicates that characters will only be translated from one code page to another. In this mode, wrapping and other transformations cannot be performed. For example, no text injection will occur.
+
+
+ Indicates that input text will be parsed and new line characters will be normalized.
+
+
+
\ No newline at end of file
diff --git a/Lib/Exchange 2016 CU20/microsoft.exchange.data.transport.xml b/Lib/Exchange 2016 CU20/microsoft.exchange.data.transport.xml
new file mode 100644
index 00000000..d75ee16a
--- /dev/null
+++ b/Lib/Exchange 2016 CU20/microsoft.exchange.data.transport.xml
@@ -0,0 +1,1792 @@
+
+
+
+ Microsoft.Exchange.Data.Transport
+
+
+
+ The exception is thrown if a problem is encountered with the configuration of the computer that is running Microsoft Exchange Server 2007.
+
+
+ The constructor creates a new exception with a localized string for the error message.
+ A object to use for the error message for this object.
+
+
+ The constructor creates a new exception with the error message message.
+ The error message for this .
+
+
+ The constructor creates a new object from an inner exception.
+ The exception that caused this to be thrown.
+ A object to use for the error message for this object.
+
+
+ The constructor creates a new serializable object.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new object from an inner exception.
+ The exception that caused this to be thrown.
+ The error message for this object.
+
+
+ The namespace contains types that support the extension of the Microsoft Exchange Server 2010 transport behavior.
+
+
+ The class is the base class for classes that represent a domain for which the server accepts messages.
+
+
+ When overridden in a derived class, the constructor initializes a new instance of the class derived from the class.
+
+
+ When overridden in a derived class, the property gets a Boolean value that indicates whether the domain represented by the instance of the class derived from the class is in the Active Directory directory service forest of the server.
+ The property returns true if the domain is in the Active Directory forest of the server; otherwise, the property returns false.
+
+
+ The property gets the tenant identifier for the accepted domain.
+ The value of the property is a object.
+
+
+ When overridden in a derived class, the property gets a Boolean value that indicates whether the address book contains all recipients for the domain represented by the instance of the class derived from the class.
+ When overridden in a derived class, the property returns true if the address book contains all the recipients for the domain represented by the instance of the class derived from the class; otherwise, the property returns false.
+
+
+ The class is the base class for derived classes that represent a collection of classes that inherit from the class.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ When overridden in a derived class, the method finds in the collection the instance of the class derived from the class that represents the domain specified by the smtpAddress parameter.
+ When overridden in a derived class, the collection contains an instance of the class that represents the domain specified by the smtpAddress parameter and the method returns that instance of the class derived from the class; otherwise, the method returns null.
+ An instance of the class that represents the domain or domain part to find.
+
+
+ When overridden in a derived class, the method finds in the collection the instance of the class derived from the class that represents the domain specified by the domainName parameter.
+ When overridden in a derived class, the collection contains an instance of the class that represents the domain specified by the domainName parameter and the method returns that instance of the class derived from the class; otherwise, the method returns null.
+ A string value that contains the domain or domain part to find.
+
+
+ When overridden in a derived class, the method returns an enumerator object that represents the collection.
+ The method returns an enumerator object that can be used to iterate through the collection.
+
+
+ The class is the base class for classes that provide top-level access to the Recipient API objects for a virtual server.
+
+
+ When overridden in a derived class, the method indicates whether the address book contains the specified address.
+ The method returns true if the address book contains the address specified by the smtpAddress parameter; otherwise, the method returns false.
+ The proxy or primary address for which the method will look.
+
+
+ When overridden in a derived class, the method finds addresses in the address book that are based on the addresses specified in the recipients parameter.
+ When overridden in a derived class, the method returns an array of objects.
+ An instance of the object that contains proxy addresses, primary addresses, or both.
+
+
+ When overridden in a derived class, the method finds an address in the address book based on the address specified in the smtpAddress parameter.
+ When overridden in a derived class, the method returns an instance of the object that represents the address found.
+ An instance of the object that contains a proxy or primary address.
+
+
+ When overridden in a derived class, the method finds addresses in the address book that are based on the addresses specified in the smtpAddresses parameter.
+ When overridden in a derived class, the method returns an array of objects.
+ An instance of the object that contains proxy addresses or primary addresses, or both.
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ When overridden in a derived class, the method indicates whether the specified recipient belongs to the specified group.
+ When overridden in a derived class, the method returns true if the specified recipient is a member of the specified group; otherwise, the method returns false.
+ The proxy or primary address of the recipient.
+ The proxy or primary address of the group.
+
+
+ When overridden in a derived class, the method indicates whether the specified addresses refer to the same recipient.
+ The method returns true if the specified addresses refer to the same recipient; otherwise, the method returns false.
+ The first recipient address to compare.
+ The second recipient address to compare.
+
+
+ The class is the base class for derived classes that represent a recipient.
+
+
+ When overridden in a derived class, the method returns the Spam Confidence Level (SCL) threshold for the recipient for the action that is specified by the action parameter.
+ The value to return if no custom threshold is specified.
+ One of the valid enumeration values that specifies the action to take for messages that exceed the threshold.
+ The action parameter is not one of the valid enumeration values or the defaultValue parameter is outside the range of 0-9 and is not Int.MaxValue.
+
+
+ The method indicates whether a recipient is a blocked sender.
+ The property returns true if the sender is blocked; otherwise, it returns false.
+ The object that represents the sender's address.
+
+
+ When overridden in a derived class, the method gets a value that indicates whether messages from the recipient that is represented by this instance of the class to the recipient that is specified by the recipientAddress parameter should bypass anti-spam tests.
+ The method returns true if the address for the recipient that is specified by the recipientAddress parameter is in the list of trusted recipients for the recipient that is represented by this instance of the class or if the domain for the recipient that is specified by the recipientAddress parameter is in the list of trusted domains for the recipient that is specified by this instance of the class; otherwise, the method returns false.
+ An instance of the class that represents the recipient to check for anti-spam bypass for messages from the recipient that is represented by this instance of the class.
+
+
+ When overridden in a derived class, the method returns a value that indicates whether a message to the recipient that is specified by the senderAddress parameter to the recipient that is represented by this instance of the class should bypass anti-spam tests.
+ The method returns true if the address for the sender that is specified by the senderAddress parameter is in the list of trusted senders for the recipient that is represented by this instance of the class or if the domain for the sender that is specified by the senderAddress parameter is in the list of trusted domains for the recipient that is specified by this instance of the class; otherwise, the method returns false.
+ An instance of the class that represents the sender to check for anti-spam bypass for messages to the recipient that is represented by this instance of the class.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether the recipient should be bypassed from anti-spam processing.
+ When overridden in a derived class, the property returns true if the recipient should be bypassed from anti-spam processing; otherwise, the property returns false.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether the recipient can only receive messages from authenticated senders.
+ When overridden in a derived class, the property returns true if the recipient can only receive messages from authenticated senders; otherwise, the property returns false.
+
+
+ The property gets a recipient's Windows Live Id.
+ The property returns a that represents the recipient's Windows Live Id.
+
+
+ The exception thrown when a transient error is detected when accessing an address book.
+
+
+ The constructor initializes a new instance of the class with the specified error message.
+ The message that describes the error.
+
+
+ The constructor initializes a new instance of the class with the specified error message.
+ The message that describes the error.
+
+
+ The constructor initializes a new instance of the class with the specified error message and a reference to the inner exception that is the cause of this exception.
+ The message that describes the error.
+ The inner exception reference.
+
+
+ The constructor initializes a new instance of the class with the specified serialized data.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor initializes a new instance of the class with the specified error message and a reference to the inner exception that is the cause of this exception.
+ The message that describes the error.
+ The inner exception reference.
+
+
+ The class is the class from which all agent classes derive.
+
+
+ When overridden in a derived class, the constructor initializes a new instance of the class derived from the class.
+
+
+ When overridden in a derived class, the method gets a object to mark the executing event handler to execute asynchronously.
+ When overridden in a derived class, the method returns a object that is used by an asynchronous event handler.
+
+
+ The class represents an asynchronous state object that is used by asynchronous transport agents.
+
+
+ The method is a callback to indicate that the asynchronous event handler completed execution.
+
+
+ The method initializes the current thread for use by an agent.
+
+
+ The class is the base class from which all transport agent factory classes derive.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ When overridden in a derived class, the method releases all resources used by the derived class.
+
+
+ The class is the base class for all agent managers. Agent managers provide additional properties about an agent.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The class provides a read-only interface to the mail item envelope.
+
+
+ The method returns a stream containing the mail message contents.
+ The method returns a object containing the MIME content of the message.
+
+
+ The method returns the value of an extended property that is an array or list.
+ The method returns true if the specified parameter is found; otherwise, the method returns false.
+ Name of the requested property.
+ If a property with the specified name is found, this parameter is set to a collection wrapper for the actual array or list value. If the property is not found, or if the property type does not match the type specified in the ItemT parameter, or if the actual value is null, this parameter is set to null.
+
+
+ The method returns the value of an extended property.
+ The method returns true if the specified property is found and its type matches the T parameter; otherwise, the method returns false.
+ The name of the requested property.
+ If a property with the specified name is not found or its type does not match the T parameter, this parameter is set to the default value of the type specified by the T parameter. Otherwise, the actual value is returned for immutable types; if the property is of type a cloned instance is returned; a is thrown for collections.
+
+
+ The property gets the date and time that the mail item was received for delivery.
+ The property returns the date and time that the mail item was received for delivery.
+
+
+ The property gets the order or speed at which the message should be sent by the messaging system.
+ One of the enumeration values indicating the priority for the mail item.
+
+
+ The property gets the DSN format requested for this mail message.
+ One of the enumeration values.
+
+
+ The gets the identifier for the message envelope.
+ The property returns the message envelope identifier as a string.
+
+
+ The property gets the routing address of the mail sender.
+ The property returns a object containing the routing address of the mail sender.
+
+
+ The gets the delivery method that this e-mail message comes from.
+ The returns one of the enumeration values.
+
+
+ The property gets the incoming mail message.
+ The property returns a instance containing a read-only copy of the mail message.
+
+
+ The gets the length of the message MIME stream.
+ The returns the length of the MIME data stream.
+
+
+ The property gets a value indicating whether the transport should retry delivery until the message is delivered successfully.
+ The property is true if the transport should retry delivery until the message is delivered successfully; otherwise, the property is false..
+
+
+ The property gets the original AUTH provider for the mail message.
+ The property returns the original AUTH provider as a object.
+
+
+ The property gets the HELO/EHLO string presented to the SMTP server.
+ he property returns the HELO/EHLO string presented to the SMTP server as a object.
+
+
+ The property gets the collection of recipients on the message, including to, cc and bcc recipients.
+ The property returns a instance containing the message recipients.
+
+
+ The property gets the tenant to which the item belongs.
+ he property returns object that identifies the tenant.
+
+
+ The enumeration indicates the direction in which a message is coming or going.
+
+
+ The message is coming from a Delivery Agent.
+
+
+ For an incoming message, the message comes from the pickup directory, the replay directory, a Delivery Status Notification (DSN), or the mail submission API. For an outgoing message, the message is going to a server that is not a Simple Mail Transfer Protocol (SMTP) server or it is an application message on the destination server.
+
+
+ The message is coming from or going to a mailbox.
+
+
+ The message is coming from or going to an SMTP endpoint.
+
+
+ The direction of the message cannot be determined.
+
+
+ The enumeration specifies the delivery priority of an e-mail message.
+
+
+ A higher priority than normal for delivery.
+
+
+ A lower priority than normal for delivery.
+
+
+ A normal priority for delivery.
+
+
+ The enumeration defines the domain to use when adding a recipient to a delivery queue.
+
+
+ Use the routing override domain when adding the recipient to the delivery queue.
+
+
+ Use the e-mail address domain when adding the recipient to the delivery queue.
+
+
+ The enumeration specifies the format used for Delivery Status Notification (DSN) messages.
+
+
+ Include the whole original message.
+
+
+ Include only the headers of the original message.
+
+
+ Use the default DSN format.
+
+
+ The enumeration specifies the type of Delivery Status Notification (DSN) to use.
+
+
+ An expanded DSN is used.
+
+
+ A failure DSN is used.
+
+
+ The enumeration specifies the type of Delivery Status Notification (DSN) requested.
+
+
+ A delay DSN is requested.
+
+
+ A failure DSN is requested.
+
+
+ A never DSN is requested.
+
+
+ A requested DSN type is not specified.
+
+
+ A success DSN is requested.
+
+
+ The class is the base class for derived classes that represent a Simple Mail Transfer Protocol (SMTP) recipient.
+
+
+ When overridden in a derived class, the method sets the property to the instance of the structure that is specified. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The routing domain to which mail is redirected for this recipient.
+
+
+ When overridden in a derived class, the property gets the outbound delivery method to the destination for the for this instance of the class.
+ When overridden in a derived class, the property returns one of the valid enumeration values.
+
+
+ The property gets the recipient's category.
+ The property returns a object that represents the recipient's categories.
+ Thrown when a mail recipient has been deleted.
+
+
+ The class is the base class for derived classes that represent a collection of objects that inherit from the class.
+
+
+ When overridden in a derived class, the method adds the specified object to the collection.
+ The address to add to the collection.
+ The collection is read-only.
+
+
+ When overridden in a derived class, the method removes all items from the collection.
+
+
+ When overridden in a derived class, the method removes a recipient from the collection based on the specified .
+ The method returns true if the recipient specified by the recipient parameter existed in the collection and the method successfully removed the recipient from the collection; otherwise, the method returns false.
+ The recipient to remove.
+
+
+ When overridden in a derived class, the method removes a recipient from the collection based on the specified .
+ The method returns an integer value that represents the number of recipients removed from the collection.
+ The Simple Mail Transfer Protocol (SMTP) address to remove.
+
+
+ When overridden in a derived class, the method removes a recipient from the collection based on the specified .
+ The method returns true if the recipient existed in the collection and the recipient was successfully removed; otherwise, the method returns false.
+ One of the values.
+ One of the values.
+ The recipient to remove.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether recipients can be added to the collection.
+ The property returns true ifthis instance of the class allows the addition new recipients; otherwise, the property returns false.
+
+
+ The structure provides properties and methods for enumerating an instance of the class.
+
+
+ The method releases all resources used by this instance of the class.
+
+
+ The method sets the enumerator to the first element in the collection.
+
+
+ The class is a base class from which classes derive that implement methods and properties for managing the Internet Protocol (IP) Allow/Deny list of the server.
+
+
+ When overridden in a derived class, the method adds a new entry to the Internet Protocol (IP) Allow/Deny list that returns a Deny status.
+ The IP address of the entry.
+ The length of time between when the entry is added and when the entry expires.
+ Optional comments associated with the entry.
+
+
+ When overridden in a derived class, the method determines whether the specified IP address is on the Allow list, the Deny list, or neither list.
+ The method returns one of the valid enumeration values.
+ The IP address to check.
+
+
+ The class is the base class for derived classes that represent the envelope of an e-mail message.
+
+
+ When overridden in a derived class, the method gets a readable stream that contains the Multipurpose Internet Mail Extensions (MIME) content for the derived class.
+ When overridden in a derived class, the method returns a read-only stream.
+
+
+ When overridden in a derived class, the method gets a writeable stream that contains the Multipurpose Internet Mail Extensions (MIME) content for the derived class.
+ When overridden in a derived class, the method returns a write-only stream.
+
+
+ When overridden in a derived class, the method specifies that the message will remain in queue until it is delivered, without expiring or generating a non-delivery report (NDR). Executing the method sets the value of the property to true. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+
+
+ When overridden in a derived class, the method gets a value that indicates the inbound delivery method for this instance of the class.
+ The property returns one of the valid enumeration values.
+
+
+ When overridden in a derived class, the property returns a Boolean value that indicates whether the message is marked for special delivery. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The property returns true if Transport will continue to try to deliver the message until it is successful, without a message expiration or non-delivery report (NDR); otherwise, the property returns false.
+
+
+ Returns .
+
+
+ The property gets the tenant to which the message belongs.
+ The property returns a that represents the tenant identifier. An empty GUID is returned for unscoped mail.
+ Thrown when the MailItem has already been deferred.
+
+
+ The enumeration specifies the lists on which an Internet Protocol (IP) address is found.
+
+
+ The specified IP address is on the Allow list.
+
+
+ The specified IP address is on the Deny list.
+
+
+ The specified IP address is not on the Allow list or the Deny list.
+
+
+ The class is a collection of e-mail recipients.
+
+
+ The method determines if the specified address is in the collection.
+ The method returns true if the specified routing address is present in the collection; otherwise, the method returns false.
+ The routing address to locate in the collection.
+
+
+ The method returns an enumerator that can be used to iterate over the items in the collection.
+ The method returns an instance that can be used to iterate over the items in the collection.
+
+
+ The property gets the number of items in the colleciton.
+ The property the number of items in the collection.
+
+
+ The gets the envelope recipient at the specified index in the collection.
+ The returns the at the specified index.
+ The index of the object to return.
+
+
+ The enumeration defines categories for e-mail recipients.
+
+
+ The e-mail recipient is managed by the server.
+
+
+ The e-mail recipient is in a different organization from the processing server.
+
+
+ The e-mail recipient is in a same organization as the processing server.
+
+
+ The enumeration specifies types of recipients.
+
+
+ The recipient is a contact.
+
+
+ The recipient is a distribution list.
+
+
+ The recipient is a dynamic distribution list.
+
+
+ The recipient is a public folder.
+
+
+ The recipient is of an unknown type.
+
+
+ The recipient is a user.
+
+
+ The class is the base class for derived classes that provide information about remote domains that the administrator has configured.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ Returns .
+
+
+ The class is the base class for derived classes that represent a collection of objects that inherit from the class.
+
+
+ When overriden in a derived class, the constructor creates a new instance of the class that is derived from the class.
+
+
+ When overridden in a derived class, the method returns an instance of the class that represents the domain in the Simple Mail Transfer Protocol (SMTP) address that is specified by the smtpAddress parameter.
+ An instance of the class that contains the domain for which to search.
+
+
+ When overridden in a derived class, the method returns an instance of the class that represents the domain that is specified by the domainName parameter.
+ The Simple Mail Transfer Protocol (SMTP) domain name for which to search.
+
+
+ The structure represents an address that is used to route data.
+
+
+ The method initializes a new instance of the structure by using the specified address.
+ The address value.
+
+
+ The method initializes a new instance of the structure by using the specified local part and domain part of an address.
+ The domain part of the address.
+ The local part of the address.
+
+
+ The field contains an empty instance of the structure that contains null for the address.
+
+
+ The field contains an instance of the structure that represents a null reverse path address.
+
+
+ The method compares this instance of the structure with the specified object.
+ The following table lists the return values for the method.ValueMeaningLess than zeroThe address value of this instance of the structure is less than the address value of the structure specified.ZeroThe address value of this instance of the structure is equal to the address value of the structure specified.Greater than zeroThe address value of this instance of the structure is greater than the address value of the structure specified.
+ An object that evaluates a structure or string.
+
+
+ The method compares this instance of the structure with the specified object.
+ The following table lists the return values for the method.ValueMeaningLess than zeroThe address value of this instance of the structure is less than the address value of the structure specified.ZeroThe address value of this instance of the structure is equal to the address value of the structure specified.Greater than zeroThe address value of this instance of the structure is greater than the address value of the structure specified.
+ An instance of the structure against which to compare.
+
+
+ The method determines whether this instance of the structure is equal to the object specified.
+ The method returns a value of true if the object specified by the address parameter is an instance of the structure and the address is equal to the address in this instance of the structure; otherwise, the method returns a value of false.
+ The object against which to compare this instance of the structure.
+
+
+ The property gets a value that indicates whether the address specified by the address parameter is valid as a Simple Mail Transfer Protocol (SMTP) address.
+ The property returns a value of true if the data that is contained in the structure is valid as a Simple Mail Transfer Protocol (SMTP) address; otherwise, the property returns a value of false.
+ The address to evaluate.
+
+
+ The method compares two specified instances of the structure for equality.
+ The method returns a value of true if the two instances of the structure are equal; otherwise, the method returns a value of false.
+ The first instance of the structure to compare.
+ The second instance of the structure to compare.
+
+
+ The method converts the structure specified into a string that is equivalent to the address.
+ The instance the structure to convert.
+
+
+ The method converts the string specified into an instance of the structure.
+ The string to convert.
+
+
+ The method compares two specified instances of the structure for inequality.
+ The method returns a value of true if the two instances of the structure are not equal; otherwise, the method returns a value of false.
+ The first instance of the structure to compare.
+ The second instance of the structure to compare.
+
+
+ The method converts the string representation of a Simple Mail Transfer Protocol (SMTP) address to an equivalent instance of the structure.
+ The Simple Mail Transfer Protocol (SMTP) address to convert.
+
+
+ The property gets the domain part of the address.
+ The property returns a string that contains the domain part of the address or null if the address is invalid.
+
+
+ The property gets a value that indicates whether the data is valid as a Simple Mail Transfer Protocol (SMTP) address.
+ The property returns a value of true if the data that is contained in the structure is valid as a Simple Mail Transfer Protocol (SMTP) address; otherwise, the property returns a value of false.
+
+
+ The property gets the local part of the address.
+ The property returns a string that contains the local part of the address or null if the address is invalid.
+
+
+ The structure represents an Simple Mail Transfer Protocol (SMTP) domain to use when you are overriding the default routing for a recipient. This type was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+
+
+ The constructor initializes a new instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The name of the SMTP domain to route to.
+
+
+ The constructor initializes a new instance of the RoutingDomain class to the specified domain and type.
+ The string representation of the domain type such as "Smtp".
+ The domain value.
+ Thrown if the domain is invalid, if the domain is null or empty, if the type parameter is null or empty, or if the type parameter contains invalid characters.
+
+
+ The field contains an empty instance of the structure that contains null for the domain. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+
+
+ The field returns a constant string with the value of "smtp".
+
+
+ The method compares this instance of the structure to the specified object. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns a 32-bit signed integer that indicates the lexical relationship between the two comparands.
+ An object that evaluates to a structure.
+
+
+ The method compares this instance of the structure to the specified instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns a 32-bit signed integer that indicates the lexical relationship between the two comparands.
+ An instance of the structure against which to compare.
+
+
+ The method determines whether this instance of the structure is equal to the object that is specified. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns true if the compared domains are equal; otherwise, the method returns false.
+ The object against which to compare this instance of the structure.
+
+
+ The method determines whether this instance of the structure is equal to the domain that is represented by the specified instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns true if the compared domains are equal; otherwise, the method returns false.
+ The instance of the structure against which to compare this instance of the structure.
+
+
+ The method returns the domain part from the specified instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns an instance of the structure that represents the domain part of the specified instance of the structure if the domain part is valid; otherwise, the method returns the value.
+ The instance of the structure from which to get the domain part.
+
+
+ The method indicates whether the domain is of type Smtp.
+ The method returns true if the domain is of type Smtp; otherwise, it returns false.
+
+
+ The method evaluates the validity of the domain that is represented by this instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns true if the domain is a valid Simple Mail Transfer Protocol (SMTP) domain; otherwise, the method returns false.
+
+
+ The method compares two specified instances of the structure for equality. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns a value of true if the two instances of the structure are equal; otherwise, the method returns a value of false.
+ The first instance of the structure to compare.
+ The second instance of the structure to compare.
+
+
+ The method compares two specified instances of the structure for inequality. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns a value of true if the two instances of the structure are not equal; otherwise, the method returns a value of false.
+ The first instance of the structure to compare.
+ The second instance of the structure to compare.
+
+
+ The method converts the string representation of a Simple Mail Transfer Protocol (SMTP) domain to an equivalent instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns an instance of the structure that represents the specified SMTP domain if the specified domain is valid; otherwise, the method throws a System.FormatException exception.
+ The SMTP domain to convert.
+
+
+ The method converts the string representation of a Simple Mail Transfer Protocol (SMTP) domain to an equivalent instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns a value of true if the specified domain is valid; otherwise, the method returns a value of false.
+ The SMTP domain to convert.
+ When this method returns, the parameter routingDomain contains an instance of the structure that represents the domain that is specified by the domain parameter. This parameter is passed uninitialized.
+
+
+ The property gets the name of the domain that is represented by this instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The property returns a string value that contains the name of the domain or an empty string.
+
+
+ The property gets the domain type.
+ The property returns the domain type as a object.
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ The class overrides the default routing for a recipient.
+
+
+ The constructor initializes a new instance of the class.
+ Defines the domain to use when adding a recipient to a delivery queue.
+ An Simple Mail Transfer Protocol (SMTP) domain to use when overriding the default routing for a recipient.
+
+
+ Returns .
+
+
+ Returns .
+
+
+ The property defines the domain to use when adding a recipient to a delivery queue.
+ One of the enumeration values.
+
+
+ The property gets an Simple Mail Transfer Protocol (SMTP) domain to use when overriding the default routing for a recipient.
+ The property returns a instance that specifies the Simple Mail Transfer Protocol (SMTP) domain to use when overriding the default routing for a recipient.
+
+
+ The class is the base class for classes that represent a Simple Mail Transfer Protocol (SMTP) server.
+
+
+ When overridden in a derived class, the method submits an e-mail message for delivery by this Simple Mail Transfer Protocol (SMTP) server.
+ An instance of the class that represents the e-mail message to submit for delivery.
+
+
+ The enumeration indicates actions that may be taken on a message that has a high spam confidence level.
+
+
+ Delete the message without sending a Delivery Status Notification (DSN) to the sender.
+
+
+ Move the message to quarantine for later review.
+
+
+ Reject the message and send a DSN to the sender.
+
+
+ The namespace contains types that support the extension of Microsoft Exchange Server 2010 delivery agents.
+
+
+ The class provides data for connection closing events.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The event handler represents the method that handles connection close events.
+
+
+ The class provides data for the connection close events.
+
+
+ Initializes a new instance of the class.
+
+
+ The method ends a network connection.
+ The SMTP response from the connection.
+
+
+ The class provides data for mail delivery events.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The property gets a mail item for the queue associated with the request.
+ A instance for the queue associated with the event.
+
+
+ The represents the method that handles mail delivery events.
+
+
+ The class provides data for mail delivery events.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ When overridden in a derived class, the method indicates that a transient error has been encountered during the delivery.
+ The SMTP response to send.
+
+
+ When overridden in a derived class, the method indicates that a permanent failure has occurred during delivery.
+ The SMTP response to send.
+
+
+ When overridden in a derived class, the method acknowledges successful delivery to all recipients of a mail item.
+ The SMTP response to send.
+
+
+ When overridden in a derived class, the method indicates that a transient error has been encountered during the delivery to a specific recipient of a mail item.
+ The SMTP response to send.
+ The recipient of the message with the transient error.
+
+
+ When overridden in a derived class, the method indicates that delivery of a mail item to a specific recipient has failed.
+ The SMTP response to send.
+ The recipient to whom delivery has failed.
+
+
+ When overridden in a derived class, the method indicates that delivery of a mail item to a specific recipient has succeeded.
+ The SMTP response to send.
+ The recipient of the mail message.
+
+
+ When overridden in a derived class, the method causes the remote delivery queue to enter the retry state with the specified SMTP response as the last error.
+ The SMTP response to send as the last error on the delivery queue.
+
+
+ When overridden in a derived class, the method causes the remote delivery queue to enter the retry state with the specified SMTP response as the last error and the specified retry interval.
+ The SMTP response to send as the last error on the delivery queue.
+ The interval between delivery retries.
+
+
+ When overridden in a derived class, the method causes all messages in the remote delivery queue to fail with the specified response.
+ The recipient status to send.
+
+
+ The method ends a network connection and restarts delivery processing.
+ The SMTP response.
+
+
+ The class is the base class for all classes that handle delivery agent events.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The event raised when mail deliver connection is closed.
+
+
+ The event raised when a message is ready to be delivered.
+
+
+ The event raised when the delivery agent is opened for mail delivery.
+
+
+ The class produces instances of the class used to extend transport behavior.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The method creates a new instance for the specified server.
+ A instance.
+ The SMTP mail server that delivery agent handles messages from.
+
+
+ The class manages instances of the class.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The parameter gets the mail protocol supported by the managed delivery agents.
+ The mail protocol supported by the managed delivery agents.
+
+
+ The class provides data for connection open events.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The property gets a mail item for delivery.
+ A instance for the queue associated with the event.
+
+
+ The parameter gets the next domain associated with the event.
+ A instance.
+
+
+ The delegate represents the method that will handle open connection events.
+
+
+ The class provides data for open connection events.
+
+
+ The constructor initializes a new instance of the
+
+
+ When overridden in a derived class, the method causes the remote delivery queue to enter the retry state with the specified last error.
+ The last error to report for the delivery queue.
+
+
+ When overridden in a derived class, the method causes the remote delivery queue to enter the retry state with the specified last error and retry interval.
+ The last error to report for the delivery queue.
+ The retry interval.
+
+
+ The namespace contains types that support creating, reading, writing, and modifying e-mail message..
+
+
+ The type represents an attachment to a object.
+
+
+ The method gets a readable stream that contains the contents of the attachment.
+ The stream from which the decoded part of the content can be read.
+
+
+ The property gets or sets a valid value that specifies whether the attachment is inline with the message contents or a regular attachment.
+ The property returns one of the valid values.
+
+
+ The property gets a value that indicates whether the attachment is an OLE object.
+ The property returns true if the attachment is an OLE object; otherwise, the property returns false.
+
+
+ The property gets the for the attachment.
+ The property returns the for the current instance of the class or null for Transport Neutral Encapsulation Format (TNEF) attachments.
+
+
+ The class represents a collection of objects.
+
+
+ The method adds a new object to the collection by using the file name specified by the fileName parameter.
+ The file name for the attachment to add.
+
+
+ The method adds a new object to the collection by using the file name specified by the fileName parameter and the content type specified by the contentType parameter.
+ The file name for the attachment to add to the collection.
+ The content type for the attachment to add to the collection.
+
+
+ The method removes all elements from the collection.
+
+
+ The method removes an element from the collection based on the object specified by the attachment parameter.
+ The method returns true if the object specified by the attachment parameter existed in the collection and the method successfully removed the attachment from the collection; otherwise, the method returns false.
+ The attachment to remove from the collection.
+
+
+ The property gets or sets the element in the specified index in the collection.
+ The zero-based index of the element in the collection to get or set.
+
+
+ The structure provides properties and methods that enable the enumeration of an instance of the class.
+
+
+ The method releases all resource used by this instance of the class.
+
+
+ The method advances the enumerator to the next element in the collection.
+ The method returns true if the operation was successful; otherwise, the method returns false.
+
+
+ The method sets the enumerator to the first element in the collection.
+
+
+ The property gets the current element in the collection.
+ The method returns an instance of the class.
+
+
+ The enumeration indicates whether an attachment is displayed in line with message content.
+
+
+ An attachment inline with the message content.
+
+
+ An attachment attached to the message.
+
+
+ The type represents the primary content of an e-mail message.
+
+
+ Returns .
+
+
+ The method gets a readable stream that contains the contents of the body without content transfer encoding.
+ The method automatically removes the content transfer encoding from the returned stream.
+
+
+ The method gets a stream into which you can write new content by using the specified character set.
+ The character set to use to encode the new content.
+
+
+ The method gets a readable stream that contains the contents of the body.
+ The stream from which the decoded part of the content can be read.
+
+
+ The enumeration specifies the format for the body of a message.
+
+
+ The body is in HTML format.
+
+
+ The body does not exist.
+
+
+ The body is in Rich Text Format (RTF).
+
+
+ The body is in plaintext format.
+
+
+ The class represents an e-mail message.
+
+
+ The method creates a new instance of the class by using the specified .
+ One of the valid enumeration values that specify the format for the body of the e-mail message.
+
+
+ The method creates a new instance of the class by using the specified .
+ A that contains message data.
+
+
+ The method creates a new instance of the class by using the specified stream.
+ A readable stream that contains message data.
+
+
+ The method creates a new instance of the class by using the specified and createAlternative value.
+ One of the valid enumeration values that specify the format for the body of the e-mail message.
+ A Boolean value that indicates whether alternative body text should be created when the bodyFormat parameter value is set to .
+
+
+ The method creates a new instance of the class by using the specified , createAlternative parameter value, and charsetName parameter value.
+ A string value that indicates the character set to use for the body of the message.
+ One of the valid enumeration values that specify the format for the body of the e-mail message.
+ A Boolean value that indicates whether alternative body text should be created when the bodyFormat parameter value is set to .
+
+
+ The method releases all resources used by the .
+
+
+ The method releases the unmanaged resources used by the and optionally releases the managed resources.
+ True to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method collapses and reorders the Multipurpose Internet Mail Extensions (MIME) hierarchy for the message.
+
+
+ The property gets or sets the date and time that the message is sent.
+ The property returns a coordinated universal time (UTC) DateTime value.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether the message is an interpersonal message.
+ When overridden in a derived class, the property returns true if the message is interpersonal; otherwise, it return false.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether the message is encrypted or encapsulated in a format that the class cannot parse.
+ When overridden in a derived class, the property returns true if the message is encrypted or in a format that the class cannot parse; otherwise, the property returns false.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether the message is a system message.
+ When overridden in a derived class, the property returns true if the message is a system message; otherwise, the property returns false.
+
+
+ When overridden in a derived class, the property gets a value that indicates the type of security for the message.
+ When overridden in a derived class, the property returns one of the enumeration values.
+
+
+ When overridden in a derived class, the property gets the underlying for the message.
+ When overridden in a derived class, the property returns the underlying for the message or null for embedded Multipurpose Internet Mail Extensions (MIME) and Transport Neutral Encapsulation Format (TNEF) messages.
+
+
+ When overriden in a derived class, the property gets the underlying for the message.
+ When overridden in a derived class, the property returns the underlying MimePart for the message or null for embedded Transport Neutral Encapsulation Format (TNEF) messages.
+
+
+ The type represents a single recipient of a class message.
+
+
+ The method initializes a new instance of the class by using the specified values for the display name and the Simple Mail Transfer Protocol (SMTP) address of the recipient.
+ The SMTP address for the recipient.
+ The name to use as the friendly display name for the recipient.
+
+
+ The class represents a collection of objects.
+
+
+ The method adds to the collection the object specified by the recipient parameter.
+ The object to add to the collection.
+
+
+ The method removes all elements from the collection.
+
+
+ The method removes an element from the collection based on the object specified by the recipient parameter.
+ The method returns true if the object specified by the recipient parameter existed in the collection and the method successfully removed the recipient from the collection; otherwise, the method returns false.
+ The attachment to remove from the collection.
+
+
+ The property gets the element at the specified index in the collection.
+ The zero-based index of the element to get in the collection.
+
+
+ The structure provides properties and methods that enable the enumeration of an instance of the class.
+
+
+ The method releases all resources used by this instance of the class.
+
+
+ The method sets the enumerator to the first element in the collection.
+
+
+ The property gets the current element in the collection.
+ The method returns an instance of the class.
+
+
+ The enumeration specifies the importance of a message.
+
+
+ A message of high importance.
+
+
+ A message of low importance.
+
+
+ A message of normal importance.
+
+
+ The enumeration specifies the security category for a message.
+
+
+ Message is signed by using Secure/Multipurpose Internet Mail Extensions (S/MIME) or Pretty Good Privacy (PGP).
+
+
+ Message is encrypted by using S/MIME, PGP, or Microsoft Rights Management Services.
+
+
+ Message is neither signed nor encrypted.
+
+
+ Message is base-64 encoded and signed by using S/MIME.
+
+
+ The enumeration specifies the priority of a message.
+
+
+ Nonurgent priority.
+
+
+ Normal priority (default).
+
+
+ Urgent priority.
+
+
+ The enumeration specifies the sensitivity of a message.
+
+
+ Company confidential sensitivity.
+
+
+ No sensitivity specified (default).
+
+
+ Personal sensitivity.
+
+
+ Private sensitivity.
+
+
+ The namespace contains types that support the extension of the Microsoft Exchange Server 2007 transport routing behavior.
+
+
+ The delegate represents the method that will handle the event of a type that is derived from the class.
+
+
+ The class provides data for the event.
+
+
+ The class provides data for the events.
+
+
+ The class is passed to the and events.
+
+
+ When overridden in a derived class, the method reverts the contents of the current to the original contents and defers processing of the .
+ The minimum time to wait before reprocessing the .
+
+
+ When overridden in a derived class, the method reverts the contents of the current to the original contents and defers processing of the .
+ The reason for deferring the .
+ The minimum time to wait before reprocessing the .
+
+
+ The method deletes the current without sending a Delivery Status Notification (DSN).
+
+
+ When overridden in a derived class, the method splits a into two branches, removing recipients from and adding recipients to one of the copies of the .
+ An array that contains one or more structures that contain the recipient or recipients to remove and the recipient or recipients to add.
+
+
+ The method splits a into two branches.
+ The list of recipients to use in the first branch. All other recipients are split off to the second branch.
+
+
+ The class provides data for the method.
+
+
+ The constructor initializes a new instance of the structure.
+ The to remove and replace with new recipients.
+ The recipients to add.
+
+
+ The constructor initializes a new instance of the structure.
+ The code to use for the operation.
+ The to remove and replace with new recipients.
+ The recipients to add.
+
+
+ The delegate represents the method that will handle the event of a type that is derived from the class. This type was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+
+
+ The class provides data for the event. This type was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+
+
+ The method gets the routing parameters for a specified recipient.
+ Returns .
+ Recipient for which RoutingOverride is to be determined
+
+
+ Returns .
+
+
+ The method sets the routing parameters for a recipient to the specified RoutingOverride.
+ Routing Override parameters. The property corresponds to the routing domain to which mail is redirected, to reset RoutingOverride pass null for the routingOverride.
+ Recipient to which RoutingOverride is applied.
+
+
+ The delegate represents the method that will handle the event of a type derived from the class.
+
+
+ The class provides data for the event.
+
+
+ The class is the base class from which all transport agents derive.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The event occurs after the server performs content conversion, if it is required.
+
+
+ The event occurs after all the recipients of the message have been resolved and before routing is determined. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+
+
+ The event occurs after the server routes the message to the next hop and before it performs content conversion, if it is required.
+
+
+ The event occurs after the message is taken off the submit queue.
+
+
+ The class produces instances of the class that are used to extend transport behavior.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ When overridden in a derived class, the method returns an instance of a routing agent.
+ The server on which the routing agent will operate.
+
+
+ The delegate represents the method that will handle the OnSubmittedMessage event of a type derived from the class.
+
+
+ The class provides data for the event.
+
+
+ The namespace contains types that support the extension of the Microsoft Exchange Server 2007 transport SMTP behavior.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event of a class that derives from the class.
+
+
+ The enumeration indicates the type of authentication that was used for the connection to the remote server.
+
+
+ The authentication type could not be determined. This usually means that the connection is from the Internet.
+
+
+ The remote server authenticated as a server in the organization.
+
+
+ The remote server authenticated as a delegated partner.
+
+
+ The enumeration specifies the type of contents that the body of a message contains.
+
+
+ The body contains binary Multipurpose Internet Mail Extensions (MIME) content.
+
+
+ The body contains eight-bit MIME content.
+
+
+ The type of content in the body is not specified.
+
+
+ The body contains seven-bit content.
+
+
+ The class provides data for the events.
+
+
+ The delegate represents the method that will handle the event of a class that derives from the class.
+
+
+ Classes derived from the class provide data for the event.
+
+
+ When overridden in a derived class, the method rejects the Simple Mail Transfer Protocol (SMTP) connection by using the response specified in the response parameter.
+ The response to send to the client for this disconnection.
+
+
+ The class provides data for the events.
+
+
+ The delegate represents the method that will handle the event of a class that derives from the class.
+
+
+ The class provides data for the event.
+
+
+ The property gets one of the enumeration values that indicates the reason for the disconnection.
+ The property returns one of the valid enumeration values.
+
+
+ The delegate represents the method that will handle the event of a class derived from the class.
+
+
+ Classes derived from the class provide data for the event.
+
+
+ The enumeration indicates why the event fired.
+
+
+ This server or one of its agents requested that the session be disconnected.
+
+
+ The disconnect was initiated locally.
+
+
+ The sender sent the QUIT verb.
+
+
+ The remote connector initiated the disconnect.
+
+
+ The connection to the sender was lost.
+
+
+ The connection to the sender timed out.
+
+
+ Too many protocol or authentication errors occurred.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event of a class that derives from the class.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in classes derived from the class.
+
+
+ Classes derived from the class provide data for the events.
+
+
+ The method rejects the authenticated session by sending a response specified by the response parameter.
+ The response to return to the caller.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event of a class that derives from the class.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in a class that derives from the class.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in classes that derive from the class.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in classes that derive from the class.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in classes that derive from the class.
+
+
+ The class provides data to the event.
+
+
+ The delegate represents the method that will handle the event in classes that derive from the class.
+
+
+ The enumeration specifies values to return when parsing a Simple Mail Transfer Protocol (SMTP) command.
+
+
+ Parsing is complete for the command.
+
+
+ A non-protocol error has occurred.
+
+
+ More data is required to parse the command.
+
+
+ A protocol-level error has occurred.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in a class that derives from the class.
+
+
+ Classes that derive from the class provide data for the event.
+
+
+ The class is the base class for all event source classes.
+
+
+ When overridden in a derived class, the method rejects the Simple Mail Transfer Protocol (SMTP) command by using the response specified by the response parameter.
+ The response to send to the client for this command.
+
+
+ Classes that derive from the class provide data for the events.
+
+
+ The class is the base class for all event source classes.
+
+
+ When overridden in a derived class, the method closes the current connection and cleans up the associated session state.
+
+
+ The class is the base class for classes passed to the receive events.
+
+
+ When overridden in a derived class, the method quarantines the received message for the recipients specified by the recipients parameter by using the reason specified by the quarantineReason parameter.
+ The value to put in the quarantine Delivery Status Notification (DSN) with each quarantined recipient for diagnostic purposes.
+ A collection of objects that specify the list of recipients for which the message should be quarantined.
+
+
+ When overridden in a derived class, the method rejects the complete message by sending a Simple Mail Transfer Protocol (SMTP) response specified by the response parameter.
+ An instance of the class that specifies the response to send to the client for the message.
+
+
+ The class provides data for the event.
+
+
+ The property gets or sets one of the enumeration values that specifies the results of the parsing.
+ The property returns one of the valid enumeration values.
+
+
+ The property gets or sets an instance of the class that is associated with the event to which this instance of the class was passed.
+ The property returns one of the valid enumeration values that specifies the response being returned for the rejected command.
+
+
+ The delegate represents the method that will handle the event in a class that derives from the class.
+
+
+ Classes derived from the class provide data for the event.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in classes that derive from the class.
+
+
+ The class is the base class for agent classes that use Simple Mail Transfer Protocol (SMTP) receive events.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) AUTH command and before the server responds to the command.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) connection.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) DATA command.
+
+
+ The event occurs when a Simple Mail Transfer Protocol (SMTP) connection to the server is closed.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) EHLO command.
+
+
+ The event occurs when the server responds to a Simple Mail Transfer Protocol (SMTP) AUTH command.
+
+
+ The event occurs when the server reaches the end of data for a Simple Mail Transfer Protocol (SMTP) message.
+
+
+ The event occurs when the server reaches the end of the headers for a Simple Mail Transfer Protocol (SMTP) message.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) HELO command.
+
+
+ The occurs when the server receives a Simple Mail Transfer Protocol (SMTP) HELP command.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) MAIL command.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) NOOP command.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) RCPT command.
+
+
+ The event occurs when any other event rejects a command or message.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) RSET command.
+
+
+ The class produces instances of the class that are used to extend Simple Mail Transfer Protocol (SMTP) transport behavior.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ When overridden in a derived class, the method creates an instance of a Simple Mail Transfer Protocol (SMTP) transport agent.
+ The server on which the agent will work.
+
+
+ The structure provides properties and methods for responding to Simple Mail Transfer Protocol (SMTP) requests.
+
+
+ The constructor initializes a new instance of the structure.
+ The status code.
+ The enhanced status code.
+ Reply text to send to the caller.
+
+
+ The field gets an instance of the structure that represents a 550 5.7.1 Anonymous client does not have permission to send as this sender response.
+
+
+ The field gets an instance of the structure that represents a 503 5.5.1 Bad sequence of commands response.
+
+
+ The field gets an instance of the structure that represents a 421 4.3.2 System not accepting network messages response.
+
+
+ The field gets an instance of the structure that represents a 421 4.4.1 Connection timed out response.
+
+
+ The field gets an instance of the structure that represents a 451 4.3.2 System not accepting network messages response.
+
+
+ The field gets an instance of the structure that represents an empty, invalid response.
+
+
+ The field gets an instance of the structure that represents a 452 4.3.1 Insufficient system resources response.
+
+
+ The field gets an instance of the structure that represents a 501 5.1.3 Invalid address (recipient) response.
+
+
+ The field gets an instance of the structure that represents a 501 5.5.4 Invalid arguments response.
+
+
+ The field gets an instance of the structure that represents a 554 5.6.0 Invalid Content response.
+
+
+ The field gets an instance of the structure that represents a 554 5.4.4 Unable to route due to invalid recipient address response.
+
+
+ The field gets an instance of the structure that represents a 421 4.4.0 Remote server response was not RFC conformant response.
+
+
+ The field gets an instance of the structure that represents a 501 5.1.7 Invalid Address (Sender) response.
+
+
+ The field gets an instance of the structure that represents a 250 2.1.0 Sender OK response.
+
+
+ The field gets and instance of the structure that represents a 554 5.6.1 Messages of type message/partial are not supported response.
+
+
+ The field gets an instance of the structure that represents a 552 5.3.4 Message size exceeds fixed maximum message size response.
+
+
+ The field gets an instance of the structure that represents a 250 2.0.0 OK response.
+
+
+ The field gets an instance of the structure that represents a 550 5.1.1 User unknown response.
+
+
+ The field gets an instance of the structure that represents a 250 2.1.5 Recipient OK response.
+
+
+ The field gets an instance of the structure that represents a 250 2.1.5 Recipient Address was Expanded response.
+
+
+ The field gets an instance of the structure that represents a 550 5.7.1 Client does not have permission to send as this sender (Sender) response.
+
+
+ The field gets an instance of the structure that represents a 550 5.7.1 Client does not have permission to send on behalf of the from address (Sender) response.
+
+
+ The field gets an instance of the structure that represents a 421 Service not available, closing transmission channel response.
+
+
+ The field gets an instance of the structure that represents a 550 5.7.1 Client does not have permission to submit to this server (Sender) response.
+
+
+ The field gets an instance of the structure that represents a 250 Success response.
+
+
+ The field gets an instance of the structure that represents a 550 5.3.5 System incorrectly configured response.
+
+
+ The field gets an instance of the structure that represents a 451 Timeout waiting for client input response.
+
+
+ The field gets an instance of the structure that represents a 554 5.4.4 Unable to route response.
+
+
+ The field gets an instance of the structure that represents a 500 5.3.3 Unrecognized command response.
+
+
+ The field gets an instance of the structure that represents a 501 5.5.4 Unrecognized parameter response.
+
+
+ The field gets an instance of the structure that represents a 550 5.7.1 Command not allowed response.
+
+
+ The method compares the current instance of the structure to the object specified by the comparand parameter.
+ The method returns true if the current instance of the structure and the object specified by the comparand parameter are both empty or both have the same status code and enhanced status code; otherwise, the method returns false.
+ The object to compare to this instance of the structure.
+
+
+ The method compares the current instance of the structure to the structure specified by the comparand parameter.
+ The method returns true if the current instance of the structure and the structure specified by the comparand parameter are both empty or both have the same status code and enhanced status code; otherwise, the method returns false.
+ The structure to compare to this instance of the structure.
+
+
+ The field returns an instance of the structure that represents a 250 2.6.0 response that indicates that the mail is queued for delivery.
+ The Internet message ID for the queued message.
+
+
+ The method converts the current instance of the structure to a Unicode string.
+ The method returns the response string represented by the current instance of the structure.
+
+
+ The method gets a value that indicates whether the string specified by the text parameter contains a valid Simple Mail Transfer Protocol (SMTP) response.
+ The method returns true if the string specified by the text parameter contains a valid Simple Mail Transfer Protocol (SMTP) response; otherwise, the method returns false.
+ An instance of the structure that represents the response that is contained in the text parameter. This parameter is passed uninitialized.
+ The string to validate.
+
+
+ The property gets the enhanced status code for the response.
+ The property returns a string value containing the enhanced status code of the response in the form X.Y.Z.
+
+
+ The property gets a value that indicates the classification of the Simple Mail Transfer Protocol (SMTP) response.
+ The property returns one of the valid enumeration values.
+
+
+ The property gets the status code for the response.
+ The property returns a string value that contains the status code for the response.
+
+
+ The property gets a string collection that contains the section of each line of the response that comes after the status code and enhanced status code.
+ The property returns a string collection.
+
+
+ The enumeration indicates the status returned from a Simple Mail Transfer Protocol (SMTP) request.
+
+
+ A 3xx status code.
+
+
+ A 5xx status code.
+
+
+ A 2xx status code.
+
+
+ A 4xx status code.
+
+
+ Unknown status.
+
+
+ The class is the base class for classes that represent a Simple Mail Transfer Protocol (SMTP) session.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether the session is a connection with a partner configured for anti-spam bypass.
+ When overridden in a derived class, the property returns true if the session is a connection with a partner configured for anti-spam bypass; otherwise, the property returns false.
+
+
+ When overridden in a derived class, the property gets a value that indicates how the remote server authenticated for the session.
+ When overridden in a derived class, the property returns one of the valid values.
+
+
+ When overridden in a derived class, the property returns a value that indicates whether the session is currently connected.
+ When overridden in a derived class, the property returns true if the connection is still established; otherwise, the property returns false.
+
+
+ When overridden in a derived class, the property gets or sets a value that indicates whether the connection is with a server outside the organization.
+ When overridden in a derived class, the property returns true if the connection is with a server outside the organization; otherwise, the property returns false.
+
+
+ The property indicates whether the session use Transport Layer Security.
+ The value of the property indicates true if Transport Layer Security is used for the session; otherwise, it indicates false.
+
+
+ When overridden in a derived class, the property gets or sets the Internet Protocol (IP) of the last mail server to process the message before the message entered the organization.
+ When overridden in a derived class, the property returns an instance of the IPAddress class.
+
+
+ When overridden in a derived class, the property gets or sets the Internet Protocol (IP) end point for the local connection.
+ When overridden in a derived class, the property returns an instance of the IPEndPoint class.
+
+
+ When overridden in a derived class, the property gets or sets an indexer for custom session properties.
+ When overridden in a derived class, the property returns a dictionary object.
+
+
+ When overridden in a derived class, the property gets or sets the Internet Protocol (IP) end point for the remote connection.
+ When overridden in a derived class, the property returns an instance of the IPEndPoint class.
+
+
+ When overridden in a derived class, the property gets or sets the ID for the session.
+ When overridden in a derived class, the property returns a Guid value.
+
+
+
\ No newline at end of file
diff --git a/Lib/Exchange 2019 CU9/Microsoft.Exchange.Data.Common.dll b/Lib/Exchange 2019 CU9/Microsoft.Exchange.Data.Common.dll
new file mode 100644
index 00000000..8a4c4111
Binary files /dev/null and b/Lib/Exchange 2019 CU9/Microsoft.Exchange.Data.Common.dll differ
diff --git a/Lib/Exchange 2019 CU9/Microsoft.Exchange.Data.Transport.dll b/Lib/Exchange 2019 CU9/Microsoft.Exchange.Data.Transport.dll
new file mode 100644
index 00000000..0d13fb6e
Binary files /dev/null and b/Lib/Exchange 2019 CU9/Microsoft.Exchange.Data.Transport.dll differ
diff --git a/Lib/Exchange 2019 CU9/microsoft.exchange.data.common.xml b/Lib/Exchange 2019 CU9/microsoft.exchange.data.common.xml
new file mode 100644
index 00000000..a086b7a1
--- /dev/null
+++ b/Lib/Exchange 2019 CU9/microsoft.exchange.data.common.xml
@@ -0,0 +1,9082 @@
+
+
+
+ Microsoft.Exchange.Data.Common
+
+
+
+ The class represents exceptions that are caused by invalid input data.
+
+
+ The constructor creates a new exception with the error message message.
+ The error message for this .
+
+
+ The constructor creates a new serializable object.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new object from an inner exception.
+ The exception that caused this to be thrown.
+ The error message for this object.
+
+
+ The namespace contains classes that support localization and error handling.
+
+
+ The class enables access to the assembly name to aid in constructing localized strings.
+
+
+ The method returns a that accesses resources specified by a given base name and assembly.
+ The assembly containing the resources.
+ The root name of the resources.
+
+
+ The method returns the string identified by the resource ID name.
+ The resource ID of the string to return.
+
+
+ The method returns a string that corresponds to a given culture and resource ID.
+ A object representing the culture of the string to retrieve.
+ The resource ID of the string to return.
+
+
+ The interface defines a contract for localized exceptions.
+
+
+ The class defines a contract for localized strings.
+
+
+ The class uses localized strings for exception messages.
+
+
+ The constructor creates a new with a localized string for the error message.
+ A object to use for this object's message.
+
+
+ The constructor uses a localized error message to create a new object from an inner exception.
+ The error message for this object.
+ The exception that caused this to be thrown.
+
+
+ The constructor creates a new serializable object.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The method uses information in the exception argument e to generate an error code.
+ The exception on which to base the error code.
+
+
+ The method is called when this object is serialized.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ Returns .
+
+
+ Returns .
+
+
+ The structure defines a localizable string.
+
+
+ The constructor creates a new object.
+ The contents of the new object.
+
+
+ The constructor creates a new object.
+ The resource ID of the string with which to initialize this object.
+ The resource manager to use for looking up the string.
+ Strings to be inserted into the message identified by id.
+
+
+ The field is true if this object is empty. Otherwise, the property is false.
+
+
+ The method compares this object with another.
+ The method returns true if the strings are identical. Otherwise it returns false.
+ The object to compare.
+
+
+ The method compares this object to another.
+ The method returns true if the strings are equal. Otherwise it returns false.
+ The object to compare.
+
+
+ The method joins an array of strings together with a separator.
+ The method returns a object containing the objects in value separated by separator.
+ The string that will appear between the string fragments after they are joined into a new object.
+ An array containing objects to be joined as strings.
+
+
+ The operator compares two objects.
+ The operator returns true if s1 and s2 are equal. Otherwise, it returns false.
+ A to compare.
+ A to compare.
+
+
+ The implicit conversion operator from to .
+ The resulting string.
+ The object to convert.
+
+
+ The operator overload compares the magnitude of two objects.
+ The operator returns true if s1 is not equal to s2. Otherwise it returns false.
+ The first to compare.
+ The second to compare.
+
+
+ The method uses the specified object to return a string representation of this object.
+ A format string.
+ A object to use to format format.
+
+
+ The method is called when this object is serialized.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about this object.
+
+
+ The method uses the specified object to return a string representation of this object.
+ A object to use to format this as it is converted to a string.
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ The class represents an exception for an operation that failed because of a temporary condition.
+
+
+ The method creates a new object with a localized message.
+ The message for this object.
+
+
+ The constructor creates a new object from a localized message and an inner exception.
+ The message for this object.
+ The exception that caused this to be thrown.
+
+
+ The constructor creates a serializable object.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The namespace contains types that enable you to read and write iCalendar data.
+
+
+ The enumeration contains values that control how objects behave while reading iCalendar data.
+
+
+ Indicates that the will not throw exceptions for errors in incoming iCalendar data. Instead, the CalendarReader object will set its property.
+
+
+ Indicates that the will throw an exception on any error encountered in incoming iCalendar data. This is the default value of the property.
+
+
+ The enumeration contains values that indicate either that the iCalendar data is compliant with RFC2445, or that indicate the problem that caused the iCalendar data to fail to comply with RFC2445.
+
+
+ The incoming iCalendar data is fully compliant with RFC2445.
+
+
+ An end tag was encountered for a different component than the one that is currently open.
+
+
+ A component name was empty.
+
+
+ A parameter name was empty.
+
+
+ A property name was empty.
+
+
+ An end tag has no corresponding opening tag.
+
+
+ A parameter name contained an invalid character.
+
+
+ Parameter text contained an invalid character.
+
+
+ A property name contained an invalid character.
+
+
+ A property value contained an invalid character.
+
+
+ A quoted string contained an invalid character.
+
+
+ A parameter value was invalid.
+
+
+ A value was formatted incorrectly.
+
+
+ One or more components were not closed properly.
+
+
+ A parameter name is missing.
+
+
+ A component tag contained a parameter.
+
+
+ A property was encountered outside of a component.
+
+
+ A property was truncated.
+
+
+ The iCalendar stream ended unexpectedly.
+
+
+ The class returns information about parameters in an iCalendar stream.
+
+
+ The method reads the next parameter.
+ The method returns true if there was another parameter to read. Otherwise, the method returns false.
+
+
+ The method reads the next value in the current parameter.
+ The method returns true if there was another value to read. Otherwise, the method returns false.
+
+
+ The class represents an RFC2445 Period object.
+
+
+ The constructor creates a new object with the specified start and end times.
+ The end time for this structure.
+ The start time for this structure.
+
+
+ The method creates a new object with the specified start time and duration.
+ The duration for this structure.
+ The start time for this structure.
+
+
+ The method returns a string representation of this structure.
+ If is true, then the returned string contains the start date and end date. If is false, then the returned string contains the start date and duration.
+
+
+ The property gets a Boolean value that indicates whether the end date of this structure is explicitly defined.
+ The property returns true if this structure is defined with a start and end date. If the property returns false if this structure is defined with a start time and a duration.
+
+
+ The structure returns information about properties in an iCalendar data stream.
+
+
+ The method moves to the next property.
+ The method returns true if there was another property to read. Otherwise, the method returns false.
+
+
+ The method moves to the next property value.
+ The method returns true if there was another property value to read. Otherwise, the method returns false.
+
+
+ The method reads a value and returns it as a structure.
+ The property returns a DateTime structure with a DateTimeKind of Coordinated Universal Time (UTC) if the property contains a UTC value; otherwise, the DateTimeKind in the returned DateTime structure is DateTimeKind.Unspecified.
+
+
+ The method reads a value and returns it as a structure.
+ The property returns a DateTime structure with a DateTimeKind of Coordinated Universal Time (UTC) if the property contains a UTC value; otherwise, the DateTimeKind in the returned DateTime structure is DateTimeKind.Unspecified.
+ A enumeration value that specifies how to interpret the value as a structure.
+
+
+ The method returns the current value as a structure.
+ A enumeration value that specifies how to interpret the value as a structure.
+
+
+ The class provides a forward-only non-cached reader for iCalendar data streams.
+
+
+ The constructor creates a new object that reads from the stream parameter.
+ A stream that contains iCalendar data.
+
+
+ The constructor creates a new object.
+ A CalendarComplianceMode enumeration value.
+ A string that describes the encoding of stream.
+ A stream that contains iCalendar data.
+
+
+ The method checks if the specified calendar reader has been disposed.
+ The name of the method calling the method.
+
+
+ The method closes this structure and any resources it used to read iCalendar data.
+
+
+ The method releases all managed and unmanaged resources used by the .
+
+
+ The method releases the unmanaged resources used by the and optionally releases the managed resources.
+ Releasesboth managed and unmanaged resources when set to true; releases only unmanaged resources when set to false.
+
+
+ The method moves to the first child component of the current component.
+ The method returns true if there was a child component. Otherwise, the method returns false.
+
+
+ The method moves to the next component.
+ The method returns true if there was another component. Otherwise, the method returns false.
+
+
+ The method moves to the next component that has the same parent as the current component.
+ The method returns true if there was another child component. Otherwise, the method returns false.
+
+
+ The method resets the of this structure.
+
+
+ The structure represents a TIME value type as defined in RFC2445.
+
+
+ The constructor creates a new structure.
+ A structure to use for initializing the property.
+ A Boolean value indicating whether this structure represents local or Coordinated Universal Time (UTC).
+
+
+ The enumeration indicates the type of an iCalendar value.
+
+
+ Indicates that the value is binary.
+
+
+ Indicates that the value is Boolean.
+
+
+ Indicates that the value is a CalAddress.
+
+
+ Indicates that the value is a Date.
+
+
+ Indicates that the value is a .
+
+
+ Indicates that the value is a Duration.
+
+
+ Indicates that the value is a Float.
+
+
+ Indicates that the value is an Integer.
+
+
+ Indicates that the value is a Period.
+
+
+ Indicates that the value is a Recurrence.
+
+
+ Indicates that the value is text.
+
+
+ Indicates that the value is a Time.
+
+
+ Indicates that the value is an xtype.
+
+
+ Indicates that the value is a URI.
+
+
+ Indicates that the value is a UTC-Offset.
+
+
+ The class writes iCalendar data to an underlying stream and performs limited validation on the data written.
+
+
+ The constructor creates a new object that writes to the stream that is passed in the stream parameter.
+ The object into which to write iCalendar data.
+
+
+ The constructor creates a new object that writes to the stream that is passed in the stream parameter and uses the encoding that is specified by the encodingName parameter.
+ The name of the encoding to use when writing iCalendar data.
+ The object into which to write iCalendar data.
+ The stream parameter or encodingName parameter is null.
+ The stream parameter cannot be written to.
+
+
+ The method closes this object but does not close the underlying stream.
+
+
+ The method releases all managed and unmanaged resources used by the .
+
+
+ The method releases the unmanaged resources used by the and optionally releases the managed resources.
+ Release both managed and unmanaged resources if set to true; releases only unmanaged resources if set to false.
+
+
+ The method ends the current component.
+
+
+ The method flushes all data up to the last closed property to the underlying stream.
+
+
+ The method starts a new component that is identified by the componentId parameter.
+ A enumeration value that indicates the component to start.
+ The componentId parameter value that was passed represents a component that is not allowed within the current component.
+
+
+ The method starts a new component that is identified by the name parameter.
+ The name of the component to start.
+ The name parameter was passed as a null reference (Nothing in Visual Basic).
+ The componentId parameter value that was passed represents a component that is not allowed within the current component.
+
+
+ The method starts a new iCalendar parameter that is identified by the parameterId parameter.
+ A enumeration value that indicates the parameter to start.
+ The parameterId value that was passed represents an iCalendar parameter that is not allowed within the current property.
+
+
+ The method starts a new iCalendar parameter that is identified by the name parameter.
+ The name of the parameter to start.
+ The name parameter was passed as a null reference (Nothing in Visual Basic).
+ The name parameter value that was passed represents an iCalendar parameter that is not allowed within the current property.
+
+
+ The method starts a new iCalendar property that is identified by the propertyId parameter.
+ A enumeration value that indicates the property to start.
+ The propertyId value that was passed represents an iCalendar property that is not allowed within the current component.
+
+
+ The method starts a new property that is identified by the name parameter.
+ A string that indicates the property to start.
+ The name parameter was passed as a null reference (Nothing in Visual Basic).
+ The name parameter value that was passed represents an iCalendar property that is not allowed within the current component.
+
+
+ The method writes a component from a object.
+ A object that is positioned at the start of the component to be written by this object.
+ The reader parameter that was passed is positioned on an iCalendar component that is not allowed within the current component.
+
+
+ The method reads an iCalendar parameter from a structure and writes it to the stream that this object owns.
+ A structure that is positioned at the start of the parameter to be written.
+
+
+ The method writes an iCalendar parameter that is identified by the parameterId parameter that contains the value in the value parameter.
+ The value of the parameter to write.
+ A enumeration value that indicates the type of parameter to write.
+
+
+ The method writes an iCalendar parameter with the name that is specified by the name parameter and the value that is specified by the value parameter.
+ The value of the parameter to write.
+ The name of the parameter to write.
+
+
+ The method writes a parameter value to the stream that this object owns.
+ The parameter value to write.
+
+
+ The method reads a property from a structure and writes it to the stream that this object owns.
+ A structure that is positioned at the start of the property to write.
+
+
+ The method writes an iCalendar property that is identified by the propertyId parameter and that has the value given by the value parameter.
+ A enumeration value that indicates the type of property to write.
+ The value of the property.
+
+
+ The method writes an iCalendar property that has the name that is specified by the name parameter and the value that is specified by the value parameter.
+ The value of the parameter to write.
+ The name of the parameter to write.
+
+
+ The method writes a Boolean value to the current property in the stream that this object owns.
+ The Boolean value to write.
+
+
+ The method writes a value to the current property in the stream that this object owns.
+ A value to write.
+
+
+ The method writes a value to the current property in the stream that this object owns.
+ A value to write.
+
+
+ The method writes a value to the current property in the stream that this object owns.
+ A value to write.
+
+
+ The method writes an integer value to the current property in the stream that this object owns.
+ The integer value to write.
+
+
+ The method writes an as a value to the current property in the stream that this object owns.
+ The to write.
+
+
+ The method writes a value to the current property in the stream that this object owns.
+ The value to write.
+
+
+ The method writes a single precision floating point value to the current property in the stream that this object owns.
+ A single precision floating point value to write.
+
+
+ The method writes a string value to the current property in the stream that this object owns.
+ The value to write.
+
+
+ The method writes a value to the current property in the stream that this object owns.
+ The value to write.
+
+
+ The enumeration contains values that identify the iCalendar components that are specified in RFC 2445
+
+
+ Indicates a daylight sub-component in a VTIMEZONE component.
+
+
+ Indicates that the reader is positioned outside the root component level.
+
+
+ Indicates a standard sub-component in a VTIMEZONE component.
+
+
+ Indicates a custom x-component.
+
+
+ Indicates an alarm component.
+
+
+ Indicates the root-level iCalendar object type.
+
+
+ Indicates an event component.
+
+
+ Indicates a free/busy component.
+
+
+ Indicates a journal component.
+
+
+ Indicates a time zone component.
+
+
+ Indicates a to-do component.
+
+
+ The enumeration contains values that represent recurrence frequencies as defined by RFC2445.
+
+
+ Indicates a recurrence value of Daily.
+
+
+ Indicates a recurrence value of Hourly.
+
+
+ Indicates a recurrence value of Minutely.
+
+
+ Indicates a recurrence value of Monthly.
+
+
+ Indicates a recurrence value of Secondly.
+
+
+ Indicates an error in the recurrence rule.
+
+
+ Indicates a recurrence value of Weekly.
+
+
+ a recurrence value of Yearly.
+
+
+ The class represents an exception that is thrown when iCalendar data is encountered that does not comply with RFC2445.
+
+
+ The constructor creates a new exception.
+ The message for this exception.
+
+
+ The constructor creates a new serializable exception.
+ The StreamingContext object that contains contextual information about the source or destination.
+ The SerializationInfo object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new exception.
+ The inner exception that caused this to be thrown.
+ The message for this object.
+
+
+ The enumeration contains values that identify parameters.
+
+
+ Indicates an altrepparam (alternate text representation)) parameter.
+
+
+ Indicates a cutypeparam (calendar user type)) parameter.
+
+
+ Indicates a cnparam (common name) parameter.
+
+
+ Indicates a deltoparam (delegatee) parameter.
+
+
+ Indicates a delfromparam (delegator) parameter.
+
+
+ Indicates a dirparam (directory entry) parameter.
+
+
+ Indicates an encodingparam (inline encoding) parameter.
+
+
+ Indicates an fmttypeparam (format type) parameter.
+
+
+ Indicates an fbtypeparam (free/busy time type) parameter.
+
+
+ Indicates a languageparam (language for text) parameter.
+
+
+ Indicates a memberparam (group or list membership) parameter.
+
+
+ Indicates a roleparam (participation role) parameter.
+
+
+ Indicates a partstatparam (participation status) parameter.
+
+
+ Indicates a rangeparam (recurrence identifier range) parameter.
+
+
+ Indicates a reltypeparam (relationship type) parameter.
+
+
+ Indicates a rsvpparam (RSVP expectation) parameter.
+
+
+ Indicates a sentbyparam (sent by) parameter.
+
+
+ Indicates a tzidparam (reference to time zone object) parameter.
+
+
+ Indicates a trigrelparam (alarm trigger relationship) parameter.
+
+
+ Indicates an xparam (non-standard unregistered) parameter.
+
+
+ Indicates a valuetypeparam (property value data type) parameter.
+
+
+ The enumeration contains values that identify iCalendar properties.
+
+
+ Indicates an action property.
+
+
+ Indicates an attachment property.
+
+
+ Indicates an attendee property.
+
+
+ Indicates a calendar scale property.
+
+
+ Indicates a categories property.
+
+
+ Indicates a classification property.
+
+
+ Indicates a comment property.
+
+
+ Indicates a date/time completed property.
+
+
+ Indicates a contact property.
+
+
+ Indicates a date/time created property.
+
+
+ Indicates a date/time due property.
+
+
+ Indicates a date/time end property
+
+
+ Indicates a date/time stamp property.
+
+
+ Indicates a date/time start property.
+
+
+ Indicates a description property.
+
+
+ Indicates a duration property.
+
+
+ Indicates an exception date/time property.
+
+
+ Indicates an exception rule property.
+
+
+ Indicates a free/busy property.
+
+
+ Indicates a geographic position property.
+
+
+ Indicates a last modified property.
+
+
+ Indicates a location property.
+
+
+ Indicates a method property.
+
+
+ Indicates an organizer property.
+
+
+ Indicates a percent complete property.
+
+
+ Indicates a priority property.
+
+
+ Indicates a product identifier property.
+
+
+ Indicates a recurrence date/times property.
+
+
+ Indicates a Recurrence ID property.
+
+
+ Indicates a recurrence rule property.
+
+
+ Indicates a related to property.
+
+
+ Indicates a repeat property.
+
+
+ Indicates a request status property.
+
+
+ Indicates a resources property.
+
+
+ Indicates a sequence property.
+
+
+ Indicates a status property.
+
+
+ Indicates a summary property.
+
+
+ Indicates a time zone ID property.
+
+
+ Indicates a time zone name property.
+
+
+ Indicates a time zone offset from property.
+
+
+ Indicates a time zone offset to property.
+
+
+ Indicates a time zone URL property.
+
+
+ Indicates a time transparency property.
+
+
+ Indicates a trigger property.
+
+
+ Indicates a UID property.
+
+
+ Indicates any unrecognized property.
+
+
+ Indicates a URL property.
+
+
+ Indicates an iCal version property.
+
+
+ The class represents an iCalendar recurrence rule value type as defined by RFC 2445.
+
+
+ The constructor creates a new object that has default values.
+
+
+ The constructor creates a new object and initializes it with the recurrence information in the parameter value.
+ A string that contains a correctly formatted iCalendar recurrence rule value type as defined by RFC 2445.
+
+
+ The property gets or sets a that represents the value of the UNTIL property when it is defined with an RFC 2445 date.
+ The property returns a DateTime structure that represents a Coordinated Universal Time (UTC) date.
+
+
+ The property gets or sets a that represents the value of the UNTIL property when it is defined with an RFC 2445 datetime.
+ The property returns a DateTime structure that represents a Coordinated Universal Time (UTC) time.
+
+
+ The structure represents a bydaylist recurrence value.
+
+
+ The constructor creates a new structure that has a given weekday and week number.
+ The number of the week in the year.
+ The day of the week in the numbered week that is specified by occurrenceNumber.
+
+
+ The enumeration contains values that indicate which properties are valid on a object.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that no properties are valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ Indicates that the property is valid.
+
+
+ The namespace contains types that enable you to read and write TNEF data.
+
+
+ The enumeration specifies the level of a Tnef Attribute.
+
+
+ Indicates an Attachment-level attribute.
+
+
+ Indicates a Message-level attribute.
+
+
+ The enumeration contains values that identify TNEF attributes.
+
+
+ Indicates the attAidOwner attribute. This is equivalent to the PR_OWNER_APPT_ID MAPI property.
+
+
+ Indicates theattAttachCreateDate attribute. This is equivalent to the PR_CREATION_TIME MAPI property.
+
+
+ Indicates the attAttachDataattribute attribute. This is equivalent to the PR_ATTACH_DATA_BIN or PR_ATTACH_DATA_OBJ MAPI property.
+
+
+ Indicates the attAttachmentattribute attribute. This is equivalent to the arbitrary attachment MAPI properties
+
+
+ Indicates the attAttachMetaFile attribute attribute. This is equivalent to the PR_ATTACH_RENDERING MAPI property.
+
+
+ Indicates the attAttachModifyDate attribute. This is equivalent to the PR_LAST_MODIFICATION_TIME MAPI property.
+
+
+ Indicates the attAttachRenddata attribute.
+
+
+ Indicates the attAttachTitle attribute. This is equivalent to the PR_ATTACH_FILENAME MAPI property.
+
+
+ Indicates the attAttachTransportFilename attribute. This is equivalent to the PR_ATTACH_TRANSPORT_NAME MAPI property.
+
+
+ Indicates the attBody attribute. This is equivalent to the PR_BODY
+
+
+ Indicates the attConversationId attribute. This is equivalent to the PR_CONVERSATION_KEY MAPI property attribute.
+
+
+ Indicates the attDateEnd attribute. This is equivalent to the PR_END_DATE MAPI property.
+
+
+ Indicates the attDateModified attribute. This is equivalent to the PR_LAST_MODIFICATION_TIME MAPI property.
+
+
+ Indicates the attDateRecd attribute. This is equivalent to the PR_MESSAGE_DELIVERY_TIME MAPI property.
+
+
+ Indicates the attDateSent attribute. This is equivalent to the PR_CLIENT_SUBMIT_TIME MAPI property.
+
+
+ Indicates the attDateStart attribute. This is equivalent to the PR_START_DATE MAPI property.
+
+
+ Indicates the attDelegate attribute. This is equivalent to the PR_RCVD_REPRESENTING_xxx MAPI property.
+
+
+ Indicates the attFrom attribute. This is equivalent to the PR_SENDER_ENTRYID and PR_SENDER_NAME MAPI properties.
+
+
+ Indicates the attMapiProps attribute. This is equivalent to an arbitrary MAPI property list
+
+
+ Indicates the attMessageClass attribute. This is equivalent to the PR_MESSAGE_CLASS MAPI property.
+
+
+ Indicates the attMessageId attribute. This is equivalent to the PR_SEARCH_KEY property.
+
+
+ Indicates the attMessageStatus attribute. This is equivalent to the PR_MESSAGE_FLAGS MAPI property.
+
+
+ Indicates the attNull attribute.
+
+
+ Indicates the attOemCodepage attribute.
+
+
+ Indicates the attOriginalMessageClass attribute. This is equivalent to the PR_ORIG_MESSAGE_CLASS MAPI property.
+
+
+ Indicates the attOwner attribute. This is equivalent to the PR_RCVD_REPRESENTING_xxx or PR_SENT_REPRESENTING_xxx MAPI property.
+
+
+ Indicates the attParentId attribute. This is equivalent to the PR_PARENT_KEY MAPI property.
+
+
+ Indicates the attPriority attribute. This is equivalent to the PR_IMPORTANCE property.
+
+
+ Indicates the attRecipTable attribute. This is equivalent to the PR_MESSAGE_RECIPIENTS MAPI property.
+
+
+ Indicates the attRequestRes attribute. This is equivalent to the PR_RESPONSE_REQUESTED MAPI property.
+
+
+ Indicates the attSentFor attribute. This is equivalent to the PR_SENT_REPRESENTING_xxx
+
+
+ Indicates the attSubject attribute. This is equivalent to the PR_SUBJECT MAPI property.
+
+
+ Indicates the attTnefVersion attribute.
+
+
+ The enumeration contains values that control whether a object will throw exceptions when it encounters errors in incoming Tnef data.
+
+
+ Indicates that the will not throw exceptions for errors in incoming Tnef data.
+
+
+ Indicates that the will throw an exception on any error encountered in incoming Tnef data. This is the default value of the property.
+
+
+ The enumeration contains values that specify whether incoming Tnef data is compliant and, if not, what caused the noncompliance.
+
+
+ The incoming Tnef data contains too many attributes.
+
+
+ The incoming Tnef data is fully compliant.
+
+
+ One or more of the attributes are invalid.
+
+
+ The checksum on one or more attributes is invalid.
+
+
+ The length of one or more attributes is incorrect.
+
+
+ One or more attributes are incorrectly applied to a message or an attachment.
+
+
+ One or more attributes have an invalid value.
+
+
+ The date is invalid.
+
+
+ The message class is invalid.
+
+
+ The codepage is not supported.
+
+
+ The length of one or more properties is invalid.
+
+
+ The row count is invalid.
+
+
+ The signature on the incoming Tnef data is invalid.
+
+
+ The version information in the incoming Tnef data is invalid.
+
+
+ The incoming Tnef data contains parts that are nested too deeply.
+
+
+ The incoming Tnef data is truncated.
+
+
+ One or more properties in the incoming Tnef data are of an unsupported type.
+
+
+ The class represents an exception thrown when noncompliant Tnef data is encountered.
+
+
+ The constructor creates a new object with a message specified by the message parameter.
+ The message for this object.
+
+
+ The constructor creates a new serializable object.
+ The StreamingContext object that contains contextual information about the source or destination.
+ The SerializationInfo object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new outer object from an inner exception.
+ The inner exception that caused this to be thrown.
+ The message for this object.
+
+
+ The structure encapsulates the name or name ID of a named MAPI property.
+
+
+ The constructor creates a new structure from a GUID and an integer.
+ The integer ID to assign to the property.
+ The GUID to assign to the property.
+
+
+ The constructor creates a new structure from a GUID and a string.
+ The GUID to assign to the property.
+ The string to assign to the property.
+
+
+ The property gets the name ID of this structure.
+ The property returns the name ID for this structure.
+
+
+ The enumeration contains values indicating how a name is stored in a structure.
+
+
+ The name is stored as an integer.
+
+
+ The name is stored as a string.
+
+
+ The enumeration contains values that represent MAPI properties applied to a Tnef message.
+
+
+ Indicates the MAPI property PR_AB_DEFAULT_DIR.
+
+
+ Indicates the MAPI property PR_AB_DEFAULT_PAB.
+
+
+ Indicates the MAPI property PR_AB_PROVIDER_ID.
+
+
+ Indicates the MAPI property PR_AB_PROVIDERS.
+
+
+ Indicates the MAPI property PR_AB_SEARCH_PATH.
+
+
+ Indicates the MAPI property PR_AB_SEARCH_PATH_UPDATE.
+
+
+ Indicates the MAPI property PR_ACCESS.
+
+
+ Indicates the MAPI property PR_ACCESS_LEVEL.
+
+
+ Indicates the MAPI property PR_ACCOUNT.
+
+
+ Indicates the MAPI property PR_ACKNOWLEDGEMENT_MODE.
+
+
+ Indicates the MAPI property PR_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_ALTERNATE_RECIPIENT.
+
+
+ Indicates the MAPI property PR_ALTERNATE_RECIPIENT_ALLOWED.
+
+
+ Indicates the MAPI property PR_ANR.
+
+
+ Indicates the MAPI property PR_ASSISTANT.
+
+
+ Indicates the MAPI property PR_ASSISTANT_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_ASSOC_CONTENT_COUNT.
+
+
+ Indicates the MAPI property PR_ATTACH_ADDITIONAL_INFO.
+
+
+ Indicates the MAPI property PR_ATTACH_CONTENT_BASE.
+
+
+ Indicates the MAPI property PR_ATTACH_CONTENT_ID.
+
+
+ Indicates the MAPI property PR_ATTACH_CONTENT_LOCATION.
+
+
+ Indicates the MAPI property PR_ATTACH_DATA_BIN or PR_ATTACH_DATA_OBJ.
+
+
+ Indicates the MAPI property PR_ATTACH_DISPOSITION.
+
+
+ Indicates the MAPI property PR_ATTACH_ENCODING.
+
+
+ Indicates the MAPI property PR_ATTACH_EXTENSION.
+
+
+ Indicates the MAPI property PR_ATTACH_FILENAME.
+
+
+ Indicates the MAPI property PR_ATTACH_FLAGS.
+
+
+ Indicates the MAPI property PR_ATTACHMENT_HIDDEN.
+
+
+ Indicates the MAPI property PR_ATTACH_LONG_FILENAME.
+
+
+ Indicates the MAPI property PR_ATTACH_LONG_PATHNAME.
+
+
+ Indicates the MAPI property PR_ATTACHMENT_FLAGS.
+
+
+ Indicates the MAPI property PR_ATTACHMENT_X400_PARAMETERS.
+
+
+ Indicates the MAPI property PR_ATTACH_METHOD.
+
+
+ Indicates the MAPI property PR_ATTACH_MIME_SEQUENCE.
+
+
+ Indicates the MAPI property PR_ATTACH_MIME_TAG.
+
+
+ Indicates the MAPI property PR_ATTACH_NETSCAPE_MAC_INFO.
+
+
+ Indicates the MAPI property PR_ATTACH_NUM.
+
+
+ Indicates the MAPI property PR_ATTACH_PATHNAME.
+
+
+ Indicates the MAPI property PR_ATTACH_RENDERING.
+
+
+ Indicates the MAPI property PR_ATTACH_SIZE.
+
+
+ Indicates the MAPI property PR_ATTACH_TAG.
+
+
+ Indicates the MAPI property PR_ATTACH_TRANSPORT_NAME.
+
+
+ Indicates the MAPI property PR_AUTHORIZING_USERS.
+
+
+ Indicates the MAPI property PR_AUTO_FORWARD_COMMENT.
+
+
+ Indicates the MAPI property PR_AUTO_FORWARDED.
+
+
+ Indicates the PR_AUTO_RESPONSE_SUPPRESS.
+
+
+ Indicates the MAPI property PR_BEEPER_TELEPHONE_NUMBER_W.
+
+
+ Indicates the MAPI property PR_BIRTHDAY.
+
+
+ Indicates the MAPI property PR_BODY.
+
+
+ Indicates the MAPI property PR_BODY_CONTENT_ID.
+
+
+ Indicates the MAPI property PR_BODY_CONTENT_LOCATION.
+
+
+ Indicates the MAPI property PR_BODY_CRC.
+
+
+ Indicates the MAPI property PR_BODY_HTML with binary data.
+
+
+ Indicates the MAPI property PR_BUSINESS2_TELEPHONE_NUMBER_A.
+
+
+ Indicates the MAPI property PR_BUSINESS_ADDRESS_CITY.
+
+
+ Indicates the MAPI property PR_BUSINESS_ADDRESS_COUNTRY.
+
+
+ Indicates the MAPI property PR_BUSINESS_ADDRESS_POSTAL_CODE.
+
+
+ Indicates the MAPI property PR_BUSINESS_ADDRESS_STREET.
+
+
+ Indicates the MAPI property PR_BUSINESS_FAX_NUMBER.
+
+
+ Indicates the MAPI property PR_BUSINESS_HOME_PAGE.
+
+
+ Indicates the MAPI property PR_CALLBACK_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_CAR_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_CHILDRENS_NAMES.
+
+
+ Indicates the MAPI property PR_CLIENT_SUBMIT_TIME.
+
+
+ Indicates the MAPI property PR_COMMENT.
+
+
+ Indicates the MAPI property PR_COMMON_VIEWS_ENTRYID.
+
+
+ Indicates the MAPI property PR_COMPANY_MAIN_PHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_COMPANY_NAME.
+
+
+ Indicates the MAPI property PR_COMPUTER_NETWORK_NAME.
+
+
+ Indicates the MAPI property PR_CONTACT_ADDRTYPES.
+
+
+ Indicates the MAPI property PR_CONTACT_DEFAULT_ADDRESS_INDEX.
+
+
+ Indicates the MAPI property PR_CONTACT_EMAIL_ADDRESSES.
+
+
+ Indicates the MAPI property PR_CONTACT_ENTRYIDS.
+
+
+ Indicates the MAPI property PR_CONTACT_VERSION.
+
+
+ Indicates the MAPI property PR_CONTAINER_CLASS.
+
+
+ Indicates the MAPI property PR_CONTAINER_CONTENTS.
+
+
+ Indicates the MAPI property PR_CONTAINER_FLAGS.
+
+
+ Indicates the MAPI property PR_CONTAINER_HIERARCHY.
+
+
+ Indicates the MAPI property PR_CONTAINER_MODIFY_VERSION.
+
+
+ Indicates the MAPI property PR_CONTENT_CONFIDENTIALITY_ALGORITHM_ID.
+
+
+ Indicates the MAPI property PR_CONTENT_CORRELATOR.
+
+
+ Indicates the MAPI property PR_CONTENT_COUNT.
+
+
+ Indicates the MAPI property PR_CONTENT_IDENTIFIER.
+
+
+ Indicates the MAPI property PR_CONTENT_INTEGRITY_CHECK.
+
+
+ Indicates the MAPI property PR_CONTENT_LENGTH.
+
+
+ Indicates the MAPI property PR_CONTENT_RETURN_REQUESTED.
+
+
+ Indicates the MAPI property PR_CONTENTS_SORT_ORDER.
+
+
+ Indicates the MAPI property PR_CONTENT_UNREAD.
+
+
+ Indicates the MAPI property PR_CONTROL_FLAGS.
+
+
+ Indicates the MAPI property PR_CONTROL_ID.
+
+
+ Indicates the MAPI property PR_CONTROL_STRUCTURE.
+
+
+ Indicates the MAPI property PR_CONTROL_TYPE.
+
+
+ Indicates the MAPI property PR_CONVERSATION_INDEX.
+
+
+ Indicates the MAPI property PR_CONVERSATION_KEY.
+
+
+ Indicates the MAPI property PR_CONVERSATION_TOPIC.
+
+
+ Indicates the MAPI property PR_CONVERSION_EITS.
+
+
+ Indicates the MAPI property PR_CONVERSION_PROHIBITED.
+
+
+ Indicates the MAPI property PR_CONVERSION_WITH_LOSS_PROHIBITED.
+
+
+ Indicates the MAPI property PR_CONVERTED_EITS.
+
+
+ Indicates the MAPI property PR_CORRELATE.
+
+
+ Indicates the MAPI property PR_CORRELATE_MTSID.
+
+
+ Indicates the MAPI property PR_COUNTRY.
+
+
+ Indicates the MAPI property PR_CREATE_TEMPLATES.
+
+
+ Indicates the MAPI property PR_CREATION_TIME.
+
+
+ Indicates the MAPI property PR_CREATION_VERSION.
+
+
+ Indicates the MAPI property PR_CURRENT_VERSION.
+
+
+ Indicates the MAPI property PR_CUSTOMER_ID.
+
+
+ Indicates the MAPI property PR_DEFAULT_PROFILE.
+
+
+ Indicates the MAPI property PR_DEFAULT_STORE.
+
+
+ Indicates the MAPI property PR_DEFAULT_VIEW_ENTRYID.
+
+
+ Indicates the MAPI property PR_DEF_CREATE_DL.
+
+
+ Indicates the MAPI property PR_DEF_CREATE_MAILUSER.
+
+
+ Indicates the MAPI property PR_DEFERRED_DELIVERY_TIME.
+
+
+ Indicates the MAPI property PR_DELEGATION.
+
+
+ Indicates the MAPI property PR_DELETE_AFTER_SUBMIT.
+
+
+ Indicates the MAPI property PR_DELIVER_TIME.
+
+
+ Indicates the MAPI property PR_DELIVERY_POINT.
+
+
+ Indicates the MAPI property PR_DELTAX.
+
+
+ Indicates the MAPI property PR_DELTAY.
+
+
+ Indicates the MAPI property PR_DEPARTMENT_NAME.
+
+
+ Indicates the MAPI property PR_DEPTH.
+
+
+ Indicates the MAPI property PR_DETAILS_TABLE.
+
+
+ Indicates the MAPI property PR_DISCARD_REASON.
+
+
+ Indicates the MAPI property PR_DISCLOSE_RECIPIENTS.
+
+
+ Indicates the MAPI property PR_DISCLOSURE_OF_RECIPIENTS.
+
+
+ Indicates the MAPI property PR_DISCRETE_VALUES.
+
+
+ Indicates the MAPI property PR_DISC_VAL.
+
+
+ Indicates the MAPI property PR_DISPLAY_BCC.
+
+
+ Indicates the MAPI property PR_DISPLAY_CC.
+
+
+ Indicates the MAPI property PR_DISPLAY_NAME.
+
+
+ Indicates the MAPI property PR_DISPLAY_NAME_PREFIX.
+
+
+ Indicates the MAPI property PR_DISPLAY_TO.
+
+
+ Indicates the MAPI property PR_DISPLAY_TYPE.
+
+
+ Indicates the MAPI property PR_DL_EXPANSION_HISTORY.
+
+
+ Indicates the MAPI property PR_DL_EXPANSION_PROHIBITED.
+
+
+ Indicates the MAPI property PR_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_END_DATE.
+
+
+ Indicates the MAPI property PR_ENTRYID.
+
+
+ Indicates the MAPI property PR_EXPAND_BEGIN_TIME.
+
+
+ Indicates the MAPI property PR_EXPANDED_BEGIN_TIME.
+
+
+ Indicates the MAPI property PR_EXPANDED_END_TIME.
+
+
+ Indicates the MAPI property PR_EXPAND_END_TIME.
+
+
+ Indicates the MAPI property PR_EXPIRY_TIME.
+
+
+ Indicates the MAPI property PR_EXPLICIT_CONVERSION.
+
+
+ Indicates the MAPI property PR_FILTERING_HOOKS.
+
+
+ Indicates the MAPI property PR_FINDER_ENTRYID.
+
+
+ Indicates the MAPI property PR_FOLDER_ASSOCIATED_CONTENTS.
+
+
+ Indicates the MAPI property PR_FOLDER_TYPE.
+
+
+ Indicates the MAPI property PR_FORM_CATEGORY.
+
+
+ Indicates the MAPI property PR_FORM_CATEGORY_SUB.
+
+
+ Indicates the MAPI property PR_FORM_ClsID.
+
+
+ Indicates the MAPI property PR_FORM_CONTACT_NAME.
+
+
+ Indicates the MAPI property PR_FORM_DESIGNER_GUID.
+
+
+ Indicates the MAPI property PR_FORM_DESIGNER_NAME.
+
+
+ Indicates the MAPI property PR_FORM_HIDDEN.
+
+
+ Indicates the MAPI property PR_FORM_HOST_MAP.
+
+
+ Indicates the MAPI property PR_FORM_MESSAGE_BEHAVIOR.
+
+
+ Indicates the MAPI property PR_FORM_VERSION.
+
+
+ Indicates the MAPI property PR_FTP_SITE.
+
+
+ Indicates the MAPI property PR_GENDER.
+
+
+ Indicates the MAPI property PR_GENERATION.
+
+
+ Indicates the MAPI property PR_GIVEN_NAME.
+
+
+ Indicates the MAPI property PR_GOVERNMENT_ID_NUMBER.
+
+
+ Indicates the MAPI property PR_HASATTACH.
+
+
+ Indicates the MAPI property PR_HEADER_FOLDER_ENTRYID.
+
+
+ Indicates the MAPI property PR_HOBBIES.
+
+
+ Indicates the MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_HOME_ADDRESS_CITY.
+
+
+ Indicates the MAPI property PR_HOME_ADDRESS_COUNTRY.
+
+
+ Indicates the MAPI property PR_HOME_ADDRESS_POSTAL_CODE.
+
+
+ Indicates the MAPI property PR_HOME_ADDRESS_POST_OFFICE_BOX.
+
+
+ Indicates the MAPI property PR_HOME_ADDRESS_STATE_OR_PROVINCE.
+
+
+ Indicates the MAPI property PR_HOME_ADDRESS_STREET.
+
+
+ Indicates the MAPI property PR_HOME_FAX_NUMBER.
+
+
+ Indicates the MAPI property PR_HOME_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_ICON.
+
+
+ Indicates the MAPI property PR_IDENTITY_DISPLAY.
+
+
+ Indicates the MAPI property PR_IDENTITY_ENTRYID.
+
+
+ Indicates the MAPI property PR_IDENTITY_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_IMPLICIT_CONVERSION_PROHIBITED.
+
+
+ Indicates the MAPI property PR_IMPORTANCE.
+
+
+ Indicates the MAPI property PR_INCOMPLETE_COPY.
+
+
+ Indicates the Internet Mail Override Charset.
+
+
+ Indicates the Internet Mail Override Format.
+
+
+ Indicates the MAPI property PR_INITIAL_DETAILS_PANE.
+
+
+ Indicates the MAPI property PR_INITIALS.
+
+
+ Indicates the MAPI property PR_IN_REPLY_TO_ID.
+
+
+ Indicates the MAPI property PR_INSTANCE_KEY.
+
+
+ Indicates the MAPI property PR_INTERNET_APPROVED.
+
+
+ Indicates the MAPI property PR_INTERNET_ARTICLE_NUMBER.
+
+
+ Indicates the MAPI property PR_INTERNET_CONTROL.
+
+
+ Indicates the MAPI property PR_INTERNET_CPID.
+
+
+ Indicates the MAPI property PR_INTERNET_DISTRIBUTION.
+
+
+ Indicates the MAPI property PR_INTERNET_FOLLOWUP_TO.
+
+
+ Indicates the MAPI property PR_INTERNET_LINES.
+
+
+ Indicates the MAPI property PR_INTERNET_MESSAGE_ID.
+
+
+ Indicates the MAPI property PR_INTERNET_NEWSGROUPS.
+
+
+ Indicates the MAPI property PR_INTERNET_NNTP_PATH.
+
+
+ Indicates the MAPI property PR_INTERNET_ORGANIZATION.
+
+
+ Indicates the MAPI property PR_INTERNET_PRECEDENCE.
+
+
+ Indicates the MAPI property PR_INTERNET_REFERENCES.
+
+
+ Indicates the MAPI property PR_IPM_ID.
+
+
+ Indicates the MAPI property PR_IPM_OUTBOX_ENTRYID.
+
+
+ Indicates the MAPI property PR_IPM_OUTBOX_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_IPM_RETURN_REQUESTED.
+
+
+ Indicates the MAPI property PR_IPM_SENTMAIL_ENTRYID.
+
+
+ Indicates the MAPI property PR_IPM_SENTMAIL_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_IPM_SUBTREE_ENTRYID.
+
+
+ Indicates the MAPI property PR_IPM_SUBTREE_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_IPM_WASTEBASKET_ENTRYID.
+
+
+ Indicates the MAPI property PR_IPM_WASTEBASKET_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_ISDN_NUMBER.
+
+
+ Indicates the MAPI property PR_KEYWORD.
+
+
+ Indicates the MAPI property PR_LANGUAGE.
+
+
+ Indicates the MAPI property PR_LANGUAGES.
+
+
+ Indicates the MAPI property PR_LAST_MODIFICATION_TIME.
+
+
+ Indicates the MAPI property PR_LATEST_DELIVERY_TIME.
+
+
+ Indicates the MAPI property PR_LIST_HELP.
+
+
+ Indicates the MAPI property PR_LIST_SUBSCRIBE.
+
+
+ Indicates the MAPI property PR_LIST_UNSUBSCRIBE.
+
+
+ Indicates the MAPI property PR_LOCALITY.
+
+
+ Indicates the Store property, ptagLocallyDelivered.
+
+
+ Indicates the MAPI property PR_LOCATION.
+
+
+ Indicates the MAPI property PR_LOCK_BRANCH_ID.
+
+
+ Indicates the MAPI property PR_LOCK_DEPTH.
+
+
+ Indicates the MAPI property PR_LOCK_ENLISTMENT_CONTEXT.
+
+
+ Indicates the MAPI property PR_LOCK_EXPIRY_TIME.
+
+
+ Indicates the MAPI property PR_LOCK_PERSISTENT.
+
+
+ Indicates the MAPI property PR_LOCK_RESOURCE_DID.
+
+
+ Indicates the MAPI property PR_LOCK_RESOURCE_FID.
+
+
+ Indicates the MAPI property PR_LOCK_RESOURCE_MID.
+
+
+ Indicates the MAPI property PR_LOCK_SCOPE.
+
+
+ Indicates the MAPI property PR_LOCK_TIMEOUT.
+
+
+ Indicates the MAPI property PR_LOCK_TYPE.
+
+
+ Indicates the MAPI property PR_MAIL_PERMISSION.
+
+
+ Indicates the MAPI property PR_MANAGER_NAME.
+
+
+ Indicates the MAPI property PR_MAPPING_SIGNATURE.
+
+
+ Indicates the MAPI property PR_MDB_PROVIDER.
+
+
+ Indicates the MAPI property PR_MESSAGE_ATTACHMENTS.
+
+
+ Indicates the MAPI property PR_MESSAGE_CC_ME.
+
+
+ Indicates the MAPI property PR_MESSAGE_CLASS.
+
+
+ Indicates the MAPI property PR_MESSAGE_CODEPAGE.
+
+
+ Indicates the MAPI property PR_MESSAGE_DELIVERY_ID.
+
+
+ Indicates the MAPI property PR_MESSAGE_DELIVERY_TIME.
+
+
+ Indicates the MAPI property PR_MESSAGE_DOWNLOAD_TIME.
+
+
+ Indicates the MAPI property PR_MESSAGE_FLAGS.
+
+
+ Indicates the MAPI property PR_MESSAGE_RECIPIENTS.
+
+
+ Indicates the MAPI property PR_MESSAGE_RECIP_ME.
+
+
+ Indicates the MAPI property PR_MESSAGE_SECURITY_LABEL.
+
+
+ Indicates the MAPI property PR_MESSAGE_SIZE.
+
+
+ Indicates the MAPI property PR_MESSAGE_SUBMISSION_ID.
+
+
+ Indicates the MAPI property PR_MESSAGE_TOKEN.
+
+
+ Indicates the MAPI property PR_MESSAGE_TO_ME.
+
+
+ Indicates the MAPI property PR_MHS_COMMON_NAME.
+
+
+ Indicates the MAPI property PR_MIDDLE_NAME.
+
+
+ Indicates the MAPI property PR_MINI_ICON.
+
+
+ Indicates the MAPI property PR_MOBILE_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_MODIFY_VERSION.
+
+
+ Indicates the MAPI property PR_MSG_STATUS.
+
+
+ Indicates the MAPI property PR_NDR_DIAG_CODE.
+
+
+ Indicates the MAPI property PR_NDR_REASON_CODE.
+
+
+ Indicates the MAPI property PR_NDR_STATUS_CODE.
+
+
+ Indicates the MAPI property PR_NEWSGROUP_NAME.
+
+
+ Indicates the MAPI property PR_NICKNAME.
+
+
+ Indicates the MAPI property PR_NNTP_XREF.
+
+
+ Indicates the MAPI property PR_NON_RECEIPT_NOTIFICATION_REQUESTED.
+
+
+ Indicates the MAPI property PR_NON_RECEIPT_REASON.
+
+
+ Indicates the MAPI property PR_NORMALIZED_SUBJECT.
+
+
+ Indicates the MAPI property PR_NT_SECURITY_DESCRIPTOR.
+
+
+ Indicates the MAPI property PR_NULL.
+
+
+ Indicates the MAPI property PR_Object_TYPE.
+
+
+ Indicates the MAPI property PR_OBSOLETED_IPMS.
+
+
+ Indicates the MAPI property PR_OFFICE2_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_OFFICE_LOCATION.
+
+
+ Indicates the MAPI property PR_OFFICE_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_OOF_REPLY_TYPE.
+
+
+ Indicates the MAPI property PR_ORGANIZATIONAL_ID_NUMBER.
+
+
+ Indicates the MAPI property PR_ORIG_ENTRYID.
+
+
+ Indicates the MAPI property PR_ORIGINAL_AUTHOR_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_ORIGINAL_AUTHOR_ENTRYID.
+
+
+ Indicates the MAPI property PR_ORIGINAL_AUTHOR_NAME.
+
+
+ Indicates the MAPI property PR_ORIGINAL_AUTHOR_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_ORIGINAL_DELIVERY_TIME.
+
+
+ Indicates the MAPI property PR_ORIGINAL_DISPLAY_BCC.
+
+
+ Indicates the MAPI property PR_ORIGINAL_DISPLAY_CC.
+
+
+ Indicates the MAPI property PR_ORIGINAL_DISPLAY_NAME.
+
+
+ Indicates the MAPI property PR_ORIGINAL_DISPLAY_TO.
+
+
+ Indicates the MAPI property PR_ORIGINAL_EITS.
+
+
+ Indicates the MAPI property PR_ORIGINAL_ENTRYID.
+
+
+ Indicates the MAPI property PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_ORIGINALLY_INTENDED_RECIP_ENTRYID.
+
+
+ Indicates the MAPI property PR_ORIGINALLY_INTENDED_RECIPIENT_NAME.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENDER_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENDER_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENDER_ENTRYID.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENDER_NAME.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENDER_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENSITIVITY.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENT_REPRESENTING_ENTRYID.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENT_REPRESENTING_NAME.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SENT_REPRESENTING_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SUBJECT.
+
+
+ Indicates the MAPI property PR_ORIGINAL_SUBMIT_TIME.
+
+
+ Indicates the MAPI property PR_ORIGINATING_MTA_CERTIFICATE.
+
+
+ Indicates the MAPI property PR_ORIGINATOR_AND_DL_EXPANSION_HISTORY.
+
+
+ Indicates the MAPI property PR_ORIGINATOR_CERTIFICATE.
+
+
+ Indicates the MAPI property PR_ORIGINATOR_DELIVERY_REPORT_REQUESTED.
+
+
+ Indicates the MAPI property PR_ORIGINATOR_NON_DELIVERY_REPORT_REQUESTED.
+
+
+ Indicates the MAPI property PR_ORIGINATOR_REQUESTED_ALTERNATE_RECIPIENT.
+
+
+ Indicates the MAPI property PR_ORIGINATOR_RETURN_ADDRESS.
+
+
+ Indicates the MAPI property PR_ORIGIN_CHECK.
+
+
+ Indicates the MAPI property PR_ORIG_MESSAGE_CLASS.
+
+
+ Indicates the MAPI property PR_OTHER_ADDRESS_CITY.
+
+
+ Indicates the MAPI property PR_OTHER_ADDRESS_COUNTRY.
+
+
+ Indicates the MAPI property PR_OTHER_ADDRESS_POSTAL_CODE.
+
+
+ Indicates the MAPI property PR_OTHER_ADDRESS_POST_OFFICE_BOX.
+
+
+ Indicates the MAPI property PR_OTHER_ADDRESS_STATE_OR_PROVINCE.
+
+
+ Indicates the MAPI property PR_OTHER_ADDRESS_STREET.
+
+
+ Indicates the MAPI property PR_OTHER_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_OWNER_APPT_ID.
+
+
+ Indicates the MAPI property PR_OWN_STORE_ENTRYID.
+
+
+ Indicates the MAPI property PR_PAGER_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_PARENT_DISPLAY.
+
+
+ Indicates the MAPI property PR_PARENT_ENTRYID.
+
+
+ Indicates the MAPI property PR_PARENT_KEY.
+
+
+ Indicates the MAPI property PR_PERSONAL_HOME_PAGE.
+
+
+ Indicates the MAPI property PR_PHYSICAL_DELIVERY_BUREAU_FAX_DELIVERY.
+
+
+ Indicates the MAPI property PR_PHYSICAL_DELIVERY_MODE.
+
+
+ Indicates the MAPI property PR_PHYSICAL_DELIVERY_REPORT_REQUEST.
+
+
+ Indicates the MAPI property PR_PHYSICAL_FORWARDING_ADDRESS.
+
+
+ Indicates the MAPI property PR_PHYSICAL_FORWARDING_ADDRESS_REQUESTED.
+
+
+ Indicates the MAPI property PR_PHYSICAL_FORWARDING_PROHIBITED.
+
+
+ Indicates the MAPI property PR_PHYSICAL_RENDITION_ATTRIBUTES.
+
+
+ Indicates the MAPI property PR_POSTAL_ADDRESS.
+
+
+ Indicates the MAPI property PR_POSTAL_CODE.
+
+
+ Indicates the MAPI property PR_POST_FOLDER_ENTRIES.
+
+
+ Indicates the MAPI property PR_POST_FOLDER_NAMES.
+
+
+ Indicates the MAPI property PR_POST_OFFICE_BOX.
+
+
+ Indicates the MAPI property PR_POST_REPLY_DENIED.
+
+
+ Indicates the MAPI property PR_POST_REPLY_FOLDER_ENTRIES.
+
+
+ Indicates the MAPI property PR_POST_REPLY_FOLDER_NAMES.
+
+
+ Indicates the MAPI property PR_PREFERRED_BY_NAME.
+
+
+ Indicates the MAPI property PR_PREPROCESS.
+
+
+ Indicates the MAPI property PR_PRIMARY_CAPABILITY.
+
+
+ Indicates the MAPI property PR_PRIMARY_FAX_NUMBER.
+
+
+ Indicates the MAPI property PR_PRIMARY_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_PRIORITY.
+
+
+ Indicates the MAPI property PR_PROFESSION.
+
+
+ Indicates the MAPI property PR_PROFILE_NAME.
+
+
+ Indicates the MAPI property PR_PROOF_OF_DELIVERY.
+
+
+ Indicates the MAPI property PR_PROOF_OF_DELIVERY_REQUESTED.
+
+
+ Indicates the MAPI property PR_PROOF_OF_SUBMISSION.
+
+
+ Indicates the MAPI property PR_PROOF_OF_SUBMISSION_REQUESTED.
+
+
+ Indicates the MAPI property PROP_ID_SECURE_MAX.
+
+
+ Indicates the MAPI property PROP_ID_SECURE_MIN.
+
+
+ Indicates the MAPI property PR_PROVIDER_DISPLAY.
+
+
+ Indicates the MAPI property PR_PROVIDER_DLL_NAME.
+
+
+ Indicates the MAPI property PR_PROVIDER_ORDINAL.
+
+
+ Indicates the MAPI property PR_PROVIDER_SUBMIT_TIME.
+
+
+ Indicates the MAPI property PR_PROVIDER_UID.
+
+
+ Indicates the MAPI property PR_PUID.
+
+
+ Indicates the MAPI property PR_RADIO_TELEPHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_RCVD_REPRESENTING_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_RCVD_REPRESENTING_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_RCVD_REPRESENTING_ENTRYID.
+
+
+ Indicates the MAPI property PR_RCVD_REPRESENTING_NAME.
+
+
+ Indicates the MAPI property PR_RCVD_REPRESENTING_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_READ_RECEIPT_ENTRYID.
+
+
+ Indicates the MAPI property PR_READ_RECEIPT_REQUESTED.
+
+
+ Indicates the MAPI property PR_READ_RECEIPT_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_RECEIPT_TIME.
+
+
+ Indicates the MAPI property PR_RECEIVED_BY_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_RECEIVED_BY_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_RECEIVED_BY_ENTRYID.
+
+
+ Indicates the MAPI property PR_RECEIVED_BY_NAME.
+
+
+ Indicates the MAPI property PR_RECEIVED_BY_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_RECEIVE_FOLDER_SETTINGS.
+
+
+ Indicates the MAPI property PR_RECIPIENT_CERTIFICATE.
+
+
+ Indicates the MAPI property PR_RECIPIENT_NUMBER_FOR_ADVICE.
+
+
+ Indicates the MAPI property PR_RECIPIENT_REASSIGNMENT_PROHIBITED.
+
+
+ Indicates the MAPI property PR_RECIPIENT_STATUS.
+
+
+ Indicates the MAPI property PR_RECIPIENT_TYPE.
+
+
+ Indicates the MAPI property PR_RECORD_KEY.
+
+
+ Indicates the MAPI property PR_REDIRECTION_HISTORY.
+
+
+ Indicates the MAPI property PR_REFERRED_BY_NAME.
+
+
+ Indicates the MAPI property PR_REGISTERED_MAIL_TYPE.
+
+
+ Indicates the MAPI property PR_RELATED_IPMS.
+
+
+ Indicates the MAPI property PR_REMOTE_PROGRESS.
+
+
+ Indicates the MAPI property PR_REMOTE_PROGRESS_TEXT.
+
+
+ Indicates the MAPI property PR_REMOTE_VALIDATE_OK.
+
+
+ Indicates the MAPI property PR_RENDERING_POSITION.
+
+
+ Indicates the MAPI property PR_REPLY_RECIPIENT_ENTRIES.
+
+
+ Indicates the MAPI property PR_REPLY_RECIPIENT_NAMES.
+
+
+ Indicates the MAPI property PR_REPLY_REQUESTED.
+
+
+ Indicates the MAPI property PR_REPLY_TIME.
+
+
+ Indicates the MAPI property PR_REPORT_ENTRYID.
+
+
+ Indicates the MAPI property PR_REPORTING_DL_NAME.
+
+
+ Indicates the MAPI property PR_REPORTING_MTA_CERTIFICATE.
+
+
+ Indicates the MAPI property PR_REPORT_NAME.
+
+
+ Indicates the MAPI property PR_REPORT_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_REPORT_TAG.
+
+
+ Indicates the MAPI property PR_REPORT_TEXT.
+
+
+ Indicates the MAPI property PR_REPORT_TIME.
+
+
+ Indicates the MAPI property PR_REQUESTED_DELIVERY_METHOD.
+
+
+ Indicates the MAPI property PR_RESOURCE_FLAGS.
+
+
+ Indicates the MAPI property PR_RESOURCE_METHODS.
+
+
+ Indicates the MAPI property PR_RESOURCE_PATH.
+
+
+ Indicates the MAPI property PR_RESOURCE_TYPE.
+
+
+ Indicates the MAPI property PR_RESPONSE_REQUESTED.
+
+
+ Indicates the MAPI property PR_RESPONSIBILITY.
+
+
+ Indicates the MAPI property PR_RETURNED_IPM.
+
+
+ Indicates the MAPI property PR_ROWID.
+
+
+ Indicates the MAPI property PR_ROW_TYPE.
+
+
+ Indicates the MAPI property PR_RTF_COMPRESSED.
+
+
+ Indicates the MAPI property PR_RTF_IN_SYNC.
+
+
+ Indicates the MAPI property PR_RTF_SYNC_BODY_COUNT.
+
+
+ Indicates the MAPI property PR_RTF_SYNC_BODY_CRC.
+
+
+ Indicates the MAPI property PR_RTF_SYNC_BODY_TAG.
+
+
+ Indicates the MAPI property PR_RTF_SYNC_PREFIX_COUNT.
+
+
+ Indicates the MAPI property PR_RTF_SYNC_TRAILING_COUNT.
+
+
+ Indicates the MAPI property PR_SEARCH.
+
+
+ Indicates the MAPI property PR_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_SECURITY.
+
+
+ Indicates the MAPI property PR_SELECTABLE.
+
+
+ Indicates the MAPI property PR_SENDER_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_SENDER_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_SENDER_ENTRYID.
+
+
+ Indicates the MAPI property PR_SENDER_NAME.
+
+
+ Indicates the MAPI property PR_SENDER_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_SEND_INTERNET_ENCODING.
+
+
+ Indicates the property on IPM.Outlook.Recall messages.
+
+
+ Indicates the MAPI property PR_SEND_RICH_INFO.
+
+
+ Indicates the MAPI property PR_SENSITIVITY.
+
+
+ Indicates the MAPI property PR_SENTMAIL_ENTRYID.
+
+
+ Indicates the MAPI property PR_SENT_REPRESENTING_ADDRTYPE.
+
+
+ Indicates the MAPI property PR_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+ Indicates the MAPI property PR_SENT_REPRESENTING_ENTRYID.
+
+
+ Indicates the MAPI property PR_SENT_REPRESENTING_NAME.
+
+
+ Indicates the MAPI property PR_SENT_REPRESENTING_SEARCH_KEY.
+
+
+ Indicates the MAPI property PR_SERVICE_DELETE_FILES.
+
+
+ Indicates the MAPI property PR_SERVICE_DLL_NAME.
+
+
+ Indicates the MAPI property PR_SERVICE_ENTRY_NAME.
+
+
+ Indicates the MAPI property PR_SERVICE_EXTRA_UIDS.
+
+
+ Indicates the MAPI property PR_SERVICE_NAME.
+
+
+ Indicates the MAPI property PR_SERVICES.
+
+
+ Indicates the MAPI property PR_SERVICE_SUPPORT_FILES.
+
+
+ Indicates the MAPI property PR_SERVICE_UID.
+
+
+ Indicates the MAPI property PR_SEVEN_BIT_DISPLAY_NAME.
+
+
+ Indicates the MAPI property PR_SMTP_ADDRESS.
+
+
+ Indicates the MAPI property PR_SPOOLER_STATUS.
+
+
+ Indicates the MAPI property PR_SPOUSE_NAME.
+
+
+ Indicates the MAPI property PR_START_DATE.
+
+
+ Indicates the MAPI property PR_STATE_OR_PROVINCE.
+
+
+ Indicates the MAPI property PR_STATUS.
+
+
+ Indicates the MAPI property PR_STATUS_CODE.
+
+
+ Indicates the MAPI property PR_STATUS_STRING.
+
+
+ Indicates the MAPI property PR_STORE_ENTRYID.
+
+
+ Indicates the MAPI property PR_STORE_PROVIDERS.
+
+
+ Indicates the MAPI property PR_STORE_RECORD_KEY.
+
+
+ Indicates the MAPI property PR_STORE_STATE.
+
+
+ Indicates the MAPI property PR_STORE_SUPPORT_MASK.
+
+
+ Indicates the MAPI property PR_STREET_ADDRESS.
+
+
+ Indicates the MAPI property PR_SUBFOLDERS.
+
+
+ Indicates the MAPI property PR_SUBJECT.
+
+
+ Indicates the MAPI property PR_SUBJECT_IPM.
+
+
+ Indicates the MAPI property PR_SUBJECT_PREFIX.
+
+
+ Indicates the MAPI property PR_SUBMIT_FLAGS.
+
+
+ Indicates the MAPI property PR_SUPERSEDES.
+
+
+ Indicates the MAPI property PR_SUPPLEMENTARY_INFO.
+
+
+ Indicates the MAPI property PR_SURNAME.
+
+
+ Indicates the MAPI property PR_TELEX_NUMBER.
+
+
+ Indicates the MAPI property PR_TEMPLATEID.
+
+
+ Indicates the MAPI property PR_TITLE.
+
+
+ Indicates the MAPI property PR_TNEF_CORRELATION_KEY.
+
+
+ Indicates the MAPI property PR_TRANSMITABLE_DISPLAY_NAME.
+
+
+ Indicates the MAPI property PR_TRANSPORT_KEY.
+
+
+ Indicates the MAPI property PR_TRANSPORT_MESSAGE_HEADERS.
+
+
+ Indicates the MAPI property PR_TRANSPORT_PROVIDERS.
+
+
+ Indicates the MAPI property PR_TRANSPORT_STATUS.
+
+
+ Indicates the MAPI property PR_TTYTDD_PHONE_NUMBER.
+
+
+ Indicates the MAPI property PR_TYPE_OF_MTS_USER.
+
+
+ Indicates the MAPI property PR_USER_CERTIFICATE.
+
+
+ Indicates the MAPI property PR_USER_X509_CERTIFICATE.
+
+
+ Indicates the MAPI property PR_VALID_FOLDER_MASK.
+
+
+ Indicates the MAPI property PR_VIEWS_ENTRYID.
+
+
+ Indicates the MAPI property PR_WEDDING_ANNIVERSARY.
+
+
+ Indicates the MAPI property PR_X400_CONTENT_TYPE.
+
+
+ Indicates the MAPI property PR_X400_DEFERRED_DELIVERY_CANCEL.
+
+
+ Indicates the MAPI property PR_XPOS.
+
+
+ Indicates the MAPI property PR_YPOS.
+
+
+ The class is a nested reader that reads individual properties from a TNEF attribute or a recipient row.
+
+
+ The method moves to the next property.
+ The method returns true if there was another property to which to move. Otherwise, returns false.
+
+
+ The method moves to the next row in the current RecipientTable attribute.
+ The method returns true if there was another row to which to move. Otherwise, returns false.
+
+
+ The method moves to the next value in the current property.
+ The method returns true if there was another value to which to move. Otherwise, returns false.
+
+
+ The method reads the raw value of the current attribute value.
+ The method returns the number of characters read.
+ When this method returns, it contains the specified byte array with the values between index and (offset + count - 1) replaced by the characters read from the current source.
+ The place in buffer at which to begin writing.
+ The maximum number of characters to read. If the end of the stream is reached before count of characters is read into buffer, the current method returns.
+
+
+ The method reads the current attribute value.
+ When this method returns, it contains the specified character array with the values between index and (offset + count - 1) replaced by the characters read from the current source.
+ The place in buffer at which to begin writing.
+ The maximum number of characters to read. If the end of the stream is reached before count of characters is read into buffer, the current method returns.
+
+
+ The structure contains MAPI attribute property identifiers.
+
+
+ The constructor creates a new structure identified by the tag parameter.
+ An integer specifying the type of this structure.
+
+
+ The constructor creates a new structure identified by the parameters id and type.
+ A enumeration value used to identify this structure.
+ A enumeration value indicating whether this structure is for an attachment or a message.
+
+
+ The field represents a PR_AB_DEFAULT_DIR MAPI property.
+
+
+ The field represents a PR_AB_DEFAULT_PAB MAPI property.
+
+
+ The field represents a PR_AB_PROVIDER_ID MAPI property.
+
+
+ The field represents a PR_AB_PROVIDERS MAPI property.
+
+
+ The field represents a PR_AB_SEARCH_PATH MAPI property.
+
+
+ The field represents a PR_AB_SEARCH_PATH_UPDATE MAPI property.
+
+
+ The field represents a PR_ACCESS MAPI property.
+
+
+ The field represents a PR_ACCESS_LEVEL MAPI property.
+
+
+ The field represents a PR_ACCOUNT_A MAPI property.
+
+
+ The field represents a PR_ACCOUNT_W MAPI property.
+
+
+ The field represents a PR_ACKNOWLEDGEMENT_MODE MAPI property.
+
+
+ The field represents a PR_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_ALTERNATE_RECIPIENT MAPI property.
+
+
+ The field represents a PR_ALTERNATE_RECIPIENT_ALLOWED MAPI property.
+
+
+ The field represents a PR_ANR_A MAPI property.
+
+
+ The field represents a PR_ANR_W MAPI property.
+
+
+ The field represents a PR_ASSISTANT_A MAPI property.
+
+
+ The field represents a PR_ASSISTANT_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_ASSISTANT_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_ASSISTANT_W MAPI property.
+
+
+ The field represents a PR_ASSOC_CONTENT_COUNT MAPI property.
+
+
+ The field represents a PR_ATTACH_ADDITIONAL_INFO MAPI property.
+
+
+ The field represents a PR_ATTACH_CONTENT_BASE_A MAPI property.
+
+
+ The field represents a PR_ATTACH_CONTENT_BASE_W MAPI property.
+
+
+ The field represents a PR_ATTACH_CONTENT_ID_A MAPI property.
+
+
+ The field represents a PR_ATTACH_CONTENT_ID_W MAPI property.
+
+
+ The field represents a PR_ATTACH_CONTENT_LOCATION_A MAPI property.
+
+
+ The field represents a PR_ATTACH_CONTENT_LOCATION_W MAPI property.
+
+
+ The field represents a PR_ATTACH_DATA_BIN MAPI property.
+
+
+ The field represents a PR_ATTACH_DATA_OBJ MAPI property.
+
+
+ The field represents a PR_ATTACH_DISPOSITION_A MAPI property.
+
+
+ The field represents a PR_ATTACH_DISPOSITION_W MAPI property.
+
+
+ The field represents a PR_ATTACH_ENCODING MAPI property.
+
+
+ The field represents a PR_ATTACH_EXTENSION_A MAPI property.
+
+
+ The field represents a PR_ATTACH_EXTENSION_W MAPI property.
+
+
+ The field represents a PR_ATTACH_FILENAME_A MAPI property.
+
+
+ The field represents a PR_ATTACH_FILENAME_W MAPI property.
+
+
+ The field represents a PR_ATTACH_FLAGS MAPI property.
+
+
+ The field represents a PR_ATTACHMENT_HIDDEN MAPI property.
+
+
+ The field represents a PR_ATTACH_LONG_FILENAME_A MAPI property.
+
+
+ The field represents a PR_ATTACH_LONG_FILENAME_W MAPI property.
+
+
+ The field represents a PR_ATTACH_LONG_PATHNAME_A MAPI property.
+
+
+ The field represents a PR_ATTACH_LONG_PATHNAME_W MAPI property.
+
+
+ The field represents a PR_ATTACHMENT_FLAGS MAPI property.
+
+
+ The field represents a PR_ATTACHMENT_X400_PARAMETERS MAPI property.
+
+
+ The field represents a PR_ATTACH_METHOD MAPI property.
+
+
+ The field represents a PR_ATTACH_MIME_SEQUENCE MAPI property.
+
+
+ The field represents a PR_ATTACH_MIME_TAG_A MAPI property.
+
+
+ The field represents a PR_ATTACH_MIME_TAG_W MAPI property.
+
+
+ The field represents a PR_ATTACH_NETSCAPE_MAC_INFO MAPI property.
+
+
+ The field represents a PR_ATTACH_NUM MAPI property.
+
+
+ The field represents a PR_ATTACH_PATHNAME_A MAPI property.
+
+
+ The field represents a PR_ATTACH_PATHNAME_W MAPI property.
+
+
+ The field represents a PR_ATTACH_RENDERING MAPI property.
+
+
+ The field represents a PR_ATTACH_SIZE MAPI property.
+
+
+ The field represents a PR_ATTACH_TAG MAPI property.
+
+
+ The field represents a PR_ATTACH_TRANSPORT_NAME_A MAPI property.
+
+
+ The field represents a PR_ATTACH_TRANSPORT_NAME_W MAPI property.
+
+
+ The field represents a PR_AUTHORIZING_USERS MAPI property.
+
+
+ The field represents a PR_AUTO_FORWARD_COMMENT_A MAPI property.
+
+
+ The field represents a PR_AUTO_FORWARD_COMMENT_W MAPI property.
+
+
+ The field represents a PR_AUTO_FORWARDED MAPI property.
+
+
+ The field represents a PR_AUTO_RESPONSE_SUPPRESS MAPI property.
+
+
+ The field represents a PR_BEEPER_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_BEEPER_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_BIRTHDAY MAPI property.
+
+
+ The field represents a PR_BODY_A MAPI property.
+
+
+ The field represents a PR_BODY_CONTENT_ID_A MAPI property.
+
+
+ The field represents a PR_BODY_CONTENT_ID_W MAPI property.
+
+
+ The field represents a PR_BODY_CONTENT_LOCATION_A MAPI property.
+
+
+ The field represents a PR_BODY_CONTENT_LOCATION_W MAPI property.
+
+
+ The field represents a PR_BODY_CRC MAPI property.
+
+
+ The field represents a PR_BODY_HTML_A MAPI property.
+
+
+ The field represents a data MAPI property.
+
+
+ The field represents a PR_BODY_HTML_W MAPI property.
+
+
+ The field represents a PR_BODY_W MAPI property.
+
+
+ The field represents a PR_BUSINESS2_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_BUSINESS2_TELEPHONE_NUMBER_A_MV MAPI property.
+
+
+ The field represents a PR_BUSINESS2_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_BUSINESS2_TELEPHONE_NUMBER_W_MV MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_CITY_A MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_CITY_W MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_COUNTRY_A MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_COUNTRY_W MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_POSTAL_CODE_A MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_POSTAL_CODE_W MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_STREET_A MAPI property.
+
+
+ The field represents a PR_BUSINESS_ADDRESS_STREET_W MAPI property.
+
+
+ The field represents a PR_BUSINESS_FAX_NUMBER_A MAPI property.
+
+
+ The field represents a PR_BUSINESS_FAX_NUMBER_W MAPI property.
+
+
+ The field represents a PR_BUSINESS_HOME_PAGE_A MAPI property.
+
+
+ The field represents a PR_BUSINESS_HOME_PAGE_W MAPI property.
+
+
+ The field represents a PR_CALLBACK_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_CALLBACK_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_CAR_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_CAR_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_CHILDRENS_NAMES_A MAPI property.
+
+
+ The field represents a PR_CHILDRENS_NAMES_W MAPI property.
+
+
+ The field represents a PR_CLIENT_SUBMIT_TIME MAPI property.
+
+
+ The field represents a PR_COMMENT_A MAPI property.
+
+
+ The field represents a PR_COMMENT_W MAPI property.
+
+
+ The field represents a PR_COMMON_VIEWS_ENTRYID MAPI property.
+
+
+ The field represents a PR_COMPANY_MAIN_PHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_COMPANY_MAIN_PHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_COMPANY_NAME_A MAPI property.
+
+
+ The field represents a PR_COMPANY_NAME_W MAPI property.
+
+
+ The field represents a PR_COMPUTER_NETWORK_NAME_A MAPI property.
+
+
+ The field represents a PR_COMPUTER_NETWORK_NAME_W MAPI property.
+
+
+ The field represents a PR_CONTACT_ADDRTYPES_A MAPI property.
+
+
+ The field represents a PR_CONTACT_ADDRTYPES_W MAPI property.
+
+
+ The field represents a PR_CONTACT_DEFAULT_ADDRESS_INDEX MAPI property.
+
+
+ The field represents a PR_CONTACT_EMAIL_ADDRESSES_A MAPI property.
+
+
+ The field represents a PR_CONTACT_EMAIL_ADDRESSES_W MAPI property.
+
+
+ The field represents a PR_CONTACT_ENTRYIDS MAPI property.
+
+
+ The field represents a PR_CONTACT_VERSION MAPI property.
+
+
+ The field represents a PR_CONTAINER_CLASS_A MAPI property.
+
+
+ The field represents a PR_CONTAINER_CLASS_W MAPI property.
+
+
+ The field represents a PR_CONTAINER_CONTENTS MAPI property.
+
+
+ The field represents a PR_CONTAINER_FLAGS MAPI property.
+
+
+ The field represents a PR_CONTAINER_HIERARCHY MAPI property.
+
+
+ The field represents a PR_CONTAINER_MODIFY_VERSION MAPI property.
+
+
+ The field represents a PR_CONTENT_CONFIDENTIALITY_ALGORITHM_ID MAPI property.
+
+
+ The field represents a PR_CONTENT_CORRELATOR MAPI property.
+
+
+ The field represents a PR_CONTENT_COUNT MAPI property.
+
+
+ The field represents a PR_CONTENT_IDENTIFIER_A MAPI property.
+
+
+ The field represents a PR_CONTENT_IDENTIFIER_W MAPI property.
+
+
+ The field represents a PR_CONTENT_INTEGRITY_CHECK MAPI property.
+
+
+ The field represents a PR_CONTENT_LENGTH MAPI property.
+
+
+ The field represents a PR_CONTENT_RETURN_REQUESTED MAPI property.
+
+
+ The field represents a PR_CONTENTS_SORT_ORDER MAPI property.
+
+
+ The field represents a PR_CONTENT_UNREAD MAPI property.
+
+
+ The field represents a PR_CONTROL_FLAGS MAPI property.
+
+
+ The field represents a PR_CONTROL_ID MAPI property.
+
+
+ The field represents a PR_CONTROL_STRUCTURE MAPI property.
+
+
+ The field represents a PR_CONTROL_TYPE MAPI property.
+
+
+ The field represents a PR_CONVERSATION_INDEX MAPI property.
+
+
+ The field represents a PR_CONVERSATION_KEY MAPI property.
+
+
+ The field represents a PR_CONVERSATION_TOPIC_A MAPI property.
+
+
+ The field represents a PR_CONVERSATION_TOPIC_W MAPI property.
+
+
+ The field represents a PR_CONVERSION_EITS MAPI property.
+
+
+ The field represents a PR_CONVERSION_PROHIBITED MAPI property.
+
+
+ The field represents a PR_CONVERSION_WITH_LOSS_PROHIBITED MAPI property.
+
+
+ The field represents a PR_CONVERTED_EITS MAPI property.
+
+
+ The field represents a PR_CORRELATE MAPI property.
+
+
+ The field represents a PR_CORRELATE_MTSID MAPI property.
+
+
+ The field represents a PR_COUNTRY_A MAPI property.
+
+
+ The field represents a PR_COUNTRY_W MAPI property.
+
+
+ The field represents a PR_CREATE_TEMPLATES MAPI property.
+
+
+ The field represents a PR_CREATION_TIME MAPI property.
+
+
+ The field represents a PR_CREATION_VERSION MAPI property.
+
+
+ The field represents a PR_CURRENT_VERSION MAPI property.
+
+
+ The field represents a PR_CUSTOMER_ID_A MAPI property.
+
+
+ The field represents a PR_CUSTOMER_ID_W MAPI property.
+
+
+ The field represents a PR_DEFAULT_PROFILE MAPI property.
+
+
+ The field represents a PR_DEFAULT_STORE MAPI property.
+
+
+ The field represents a PR_DEFAULT_VIEW_ENTRYID MAPI property.
+
+
+ The field represents a PR_DEF_CREATE_DL MAPI property.
+
+
+ The field represents a PR_DEF_CREATE_MAILUSER MAPI property.
+
+
+ The field represents a PR_DEFERRED_DELIVERY_TIME MAPI property.
+
+
+ The field represents a PR_DELEGATION MAPI property.
+
+
+ The field represents a PR_DELETE_AFTER_SUBMIT MAPI property.
+
+
+ The field represents a PR_DELIVER_TIME MAPI property.
+
+
+ The field represents a PR_DELIVERY_POINT MAPI property.
+
+
+ The field represents a PR_DELTAX MAPI property.
+
+
+ The field represents a PR_DELTAY MAPI property.
+
+
+ The field represents a PR_DEPARTMENT_NAME_A MAPI property.
+
+
+ The field represents a PR_DEPARTMENT_NAME_W MAPI property.
+
+
+ The field represents a PR_DEPTH MAPI property.
+
+
+ The field represents a PR_DETAILS_TABLE MAPI property.
+
+
+ The field represents a PR_DISCARD_REASON MAPI property.
+
+
+ The field represents a PR_DISCLOSE_RECIPIENTS MAPI property.
+
+
+ The field represents a PR_DISCLOSURE_OF_RECIPIENTS MAPI property.
+
+
+ The field represents a PR_DISCRETE_VALUES MAPI property.
+
+
+ The field represents a PR_DISC_VAL MAPI property.
+
+
+ The field represents a PR_DISPLAY_BCC_A MAPI property.
+
+
+ The field represents a PR_DISPLAY_BCC_W MAPI property.
+
+
+ The field represents a PR_DISPLAY_CC_A MAPI property.
+
+
+ The field represents a PR_DISPLAY_CC_W MAPI property.
+
+
+ The field represents a PR_DISPLAY_NAME_A MAPI property.
+
+
+ The field represents a PR_DISPLAY_NAME_PREFIX_A MAPI property.
+
+
+ The field represents a PR_DISPLAY_NAME_PREFIX_W MAPI property.
+
+
+ The field represents a PR_DISPLAY_NAME_W MAPI property.
+
+
+ The field represents a PR_DISPLAY_TO_A MAPI property.
+
+
+ The field represents a PR_DISPLAY_TO_W MAPI property.
+
+
+ The field represents a PR_DISPLAY_TYPE MAPI property.
+
+
+ The field represents a PR_DL_EXPANSION_HISTORY MAPI property.
+
+
+ The field represents a PR_DL_EXPANSION_PROHIBITED MAPI property.
+
+
+ The field represents a PR_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_END_DATE MAPI property.
+
+
+ The field represents a PR_ENTRYID MAPI property.
+
+
+ The field represents a PR_EXPAND_BEGIN_TIME MAPI property.
+
+
+ The field represents a PR_EXPANDED_BEGIN_TIME MAPI property.
+
+
+ The field represents a PR_EXPANDED_END_TIME MAPI property.
+
+
+ The field represents a PR_EXPAND_END_TIME MAPI property.
+
+
+ The field represents a PR_EXPIRY_TIME MAPI property.
+
+
+ The field represents a PR_EXPLICIT_CONVERSION MAPI property.
+
+
+ The field represents a PR_FILTERING_HOOKS MAPI property.
+
+
+ The field represents a PR_FINDER_ENTRYID MAPI property.
+
+
+ The field represents a PR_FOLDER_ASSOCIATED_CONTENTS MAPI property.
+
+
+ The field represents a PR_FOLDER_TYPE MAPI property.
+
+
+ The field represents a PR_FORM_CATEGORY_A MAPI property.
+
+
+ The field represents a PR_FORM_CATEGORY_SUB_A MAPI property.
+
+
+ The field represents a PR_FORM_CATEGORY_SUB_W MAPI property.
+
+
+ The field represents a PR_FORM_CATEGORY_W MAPI property.
+
+
+ The field represents a PR_FORM_ClsID MAPI property.
+
+
+ The field represents a PR_FORM_CONTACT_NAME_A MAPI property.
+
+
+ The field represents a PR_FORM_CONTACT_NAME_W MAPI property.
+
+
+ The field represents a PR_FORM_DESIGNER_GUID MAPI property.
+
+
+ The field represents a PR_FORM_DESIGNER_NAME_A MAPI property.
+
+
+ The field represents a PR_FORM_DESIGNER_NAME_W MAPI property.
+
+
+ The field represents a PR_FORM_HIDDEN MAPI property.
+
+
+ The field represents a PR_FORM_HOST_MAP MAPI property.
+
+
+ The field represents a PR_FORM_MESSAGE_BEHAVIOR MAPI property.
+
+
+ The field represents a PR_FORM_VERSION_A MAPI property.
+
+
+ The field represents a PR_FORM_VERSION_W MAPI property.
+
+
+ The field represents a PR_FTP_SITE_A MAPI property.
+
+
+ The field represents a PR_FTP_SITE_W MAPI property.
+
+
+ The field represents a PR_GENDER MAPI property.
+
+
+ The field represents a PR_GENERATION_A MAPI property.
+
+
+ The field represents a PR_GENERATION_W MAPI property.
+
+
+ The field represents a PR_GIVEN_NAME_A MAPI property.
+
+
+ The field represents a PR_GIVEN_NAME_W MAPI property.
+
+
+ The field represents a PR_GOVERNMENT_ID_NUMBER_A MAPI property.
+
+
+ The field represents a PR_GOVERNMENT_ID_NUMBER_W MAPI property.
+
+
+ The field represents a PR_HASATTACH MAPI property.
+
+
+ The field represents a PR_HEADER_FOLDER_ENTRYID MAPI property.
+
+
+ The field represents a PR_HOBBIES_A MAPI property.
+
+
+ The field represents a PR_HOBBIES_W MAPI property.
+
+
+ The field represents a PR_HOME2_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_HOME2_TELEPHONE_NUMBER_A_MV MAPI property.
+
+
+ The field represents a PR_HOME2_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_HOME2_TELEPHONE_NUMBER_W_MV MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_CITY_A MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_CITY_W MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_COUNTRY_A MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_COUNTRY_W MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_POSTAL_CODE_A MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_POSTAL_CODE_W MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_POST_OFFICE_BOX_A MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_POST_OFFICE_BOX_W MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_STATE_OR_PROVINCE_A MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_STATE_OR_PROVINCE_W MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_STREET_A MAPI property.
+
+
+ The field represents a PR_HOME_ADDRESS_STREET_W MAPI property.
+
+
+ The field represents a PR_HOME_FAX_NUMBER_A MAPI property.
+
+
+ The field represents a PR_HOME_FAX_NUMBER_W MAPI property.
+
+
+ The field represents a PR_HOME_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_HOME_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_ICON MAPI property.
+
+
+ The field represents a PR_IDENTITY_DISPLAY_A MAPI property.
+
+
+ The field represents a PR_IDENTITY_DISPLAY_W MAPI property.
+
+
+ The field represents a PR_IDENTITY_ENTRYID MAPI property.
+
+
+ The field represents a PR_IDENTITY_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_IMPLICIT_CONVERSION_PROHIBITED MAPI property.
+
+
+ The field represents a PR_IMPORTANCE MAPI property.
+
+
+ The field represents a PR_INCOMPLETE_COPY MAPI property.
+
+
+ The field represents a Charset MAPI property.
+
+
+ The field represents a Format MAPI property.
+
+
+ The field represents a PR_INITIAL_DETAILS_PANE MAPI property.
+
+
+ The field represents a PR_INITIALS_A MAPI property.
+
+
+ The field represents a PR_INITIALS_W MAPI property.
+
+
+ The field represents a PR_IN_REPLY_TO_ID_A MAPI property.
+
+
+ The field represents a PR_IN_REPLY_TO_ID_W MAPI property.
+
+
+ The field represents a PR_INSTANCE_KEY MAPI property.
+
+
+ The field represents a PR_INTERNET_APPROVED_A MAPI property.
+
+
+ The field represents a PR_INTERNET_APPROVED_W MAPI property.
+
+
+ The field represents a PR_INTERNET_ARTICLE_NUMBER MAPI property.
+
+
+ The field represents a PR_INTERNET_CONTROL_A MAPI property.
+
+
+ The field represents a PR_INTERNET_CONTROL_W MAPI property.
+
+
+ The field represents a PR_INTERNET_CPID MAPI property.
+
+
+ The field represents a PR_INTERNET_DISTRIBUTION_A MAPI property.
+
+
+ The field represents a PR_INTERNET_DISTRIBUTION_W MAPI property.
+
+
+ The field represents a PR_INTERNET_FOLLOWUP_TO_A MAPI property.
+
+
+ The field represents a PR_INTERNET_FOLLOWUP_TO_W MAPI property.
+
+
+ The field represents a PR_INTERNET_LINES MAPI property.
+
+
+ The field represents a PR_INTERNET_MESSAGE_ID_A MAPI property.
+
+
+ The field represents a PR_INTERNET_MESSAGE_ID_W MAPI property.
+
+
+ The field represents a PR_INTERNET_NEWSGROUPS_A MAPI property.
+
+
+ The field represents a PR_INTERNET_NEWSGROUPS_W MAPI property.
+
+
+ The field represents a PR_INTERNET_NNTP_PATH_A MAPI property.
+
+
+ The field represents a PR_INTERNET_NNTP_PATH_W MAPI property.
+
+
+ The field represents a PR_INTERNET_ORGANIZATION_A MAPI property.
+
+
+ The field represents a PR_INTERNET_ORGANIZATION_W MAPI property.
+
+
+ The field represents a PR_INTERNET_PRECEDENCE_A MAPI property.
+
+
+ The field represents a PR_INTERNET_PRECEDENCE_W MAPI property.
+
+
+ The field represents a PR_INTERNET_REFERENCES_A MAPI property.
+
+
+ The field represents a PR_INTERNET_REFERENCES_W MAPI property.
+
+
+ The field represents a PR_IPM_ID MAPI property.
+
+
+ The field represents a PR_IPM_OUTBOX_ENTRYID MAPI property.
+
+
+ The field represents a PR_IPM_OUTBOX_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_IPM_RETURN_REQUESTED MAPI property.
+
+
+ The field represents a PR_IPM_SENTMAIL_ENTRYID MAPI property.
+
+
+ The field represents a PR_IPM_SENTMAIL_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_IPM_SUBTREE_ENTRYID MAPI property.
+
+
+ The field represents a PR_IPM_SUBTREE_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_IPM_WASTEBASKET_ENTRYID MAPI property.
+
+
+ The field represents a PR_IPM_WASTEBASKET_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_ISDN_NUMBER_A MAPI property.
+
+
+ The field represents a PR_ISDN_NUMBER_W MAPI property.
+
+
+ The field represents a PR_KEYWORD_A MAPI property.
+
+
+ The field represents a PR_KEYWORD_W MAPI property.
+
+
+ The field represents a PR_LANGUAGE_A MAPI property.
+
+
+ The field represents a PR_LANGUAGES_A MAPI property.
+
+
+ The field represents a PR_LANGUAGES_W MAPI property.
+
+
+ The field represents a PR_LANGUAGE_W MAPI property.
+
+
+ The field represents a PR_LAST_MODIFICATION_TIME MAPI property.
+
+
+ The field represents a PR_LATEST_DELIVERY_TIME MAPI property.
+
+
+ The field represents a PR_LIST_HELP_A MAPI property.
+
+
+ The field represents a PR_LIST_HELP_W MAPI property.
+
+
+ The field represents a PR_LIST_SUBSCRIBE_A MAPI property.
+
+
+ The field represents a PR_LIST_SUBSCRIBE_W MAPI property.
+
+
+ The field represents a PR_LIST_UNSUBSCRIBE_A MAPI property.
+
+
+ The field represents a PR_LIST_UNSUBSCRIBE_W MAPI property.
+
+
+ The field represents a PR_LOCALITY_A MAPI property.
+
+
+ The field represents a PR_LOCALITY_W MAPI property.
+
+
+ The field represents a PR_LOCATION_A MAPI property.
+
+
+ The field represents a PR_LOCATION_W MAPI property.
+
+
+ The field represents a PR_LOCK_BRANCH_ID MAPI property.
+
+
+ The field represents a PR_LOCK_DEPTH MAPI property.
+
+
+ The field represents a PR_LOCK_ENLISTMENT_CONTEXT MAPI property.
+
+
+ The field represents a PR_LOCK_EXPIRY_TIME MAPI property.
+
+
+ The field represents a PR_LOCK_PERSISTENT MAPI property.
+
+
+ The field represents a PR_LOCK_RESOURCE_DID MAPI property.
+
+
+ The field represents a PR_LOCK_RESOURCE_FID MAPI property.
+
+
+ The field represents a PR_LOCK_RESOURCE_MID MAPI property.
+
+
+ The field represents a PR_LOCK_SCOPE MAPI property.
+
+
+ The field represents a PR_LOCK_TIMEOUT MAPI property.
+
+
+ The field represents a PR_LOCK_TYPE MAPI property.
+
+
+ The field represents a PR_MAIL_PERMISSION MAPI property.
+
+
+ The field represents a PR_MANAGER_NAME_A MAPI property.
+
+
+ The field represents a PR_MANAGER_NAME_W MAPI property.
+
+
+ The field represents a PR_MAPPING_SIGNATURE MAPI property.
+
+
+ The field represents a PR_MDB_PROVIDER MAPI property.
+
+
+ The field represents a PR_MESSAGE_ATTACHMENTS MAPI property.
+
+
+ The field represents a PR_MESSAGE_CC_ME MAPI property.
+
+
+ The field represents a PR_MESSAGE_CLASS_A MAPI property.
+
+
+ The field represents a PR_MESSAGE_CLASS_W MAPI property.
+
+
+ The field represents a PR_MESSAGE_CODEPAGE MAPI property.
+
+
+ The field represents a PR_MESSAGE_DELIVERY_ID MAPI property.
+
+
+ The field represents a PR_MESSAGE_DELIVERY_TIME MAPI property.
+
+
+ The field represents a PR_MESSAGE_DOWNLOAD_TIME MAPI property.
+
+
+ The field represents a PR_MESSAGE_FLAGS MAPI property.
+
+
+ The field represents a PR_MESSAGE_RECIPIENTS MAPI property.
+
+
+ The field represents a PR_MESSAGE_RECIP_ME MAPI property.
+
+
+ The field represents a PR_MESSAGE_SECURITY_LABEL MAPI property.
+
+
+ The field represents a PR_MESSAGE_SIZE MAPI property.
+
+
+ The field represents a PR_MESSAGE_SUBMISSION_ID MAPI property.
+
+
+ The field represents a PR_MESSAGE_TOKEN MAPI property.
+
+
+ The field represents a PR_MESSAGE_TO_ME MAPI property.
+
+
+ The field represents a PR_MHS_COMMON_NAME_A MAPI property.
+
+
+ The field represents a PR_MHS_COMMON_NAME_W MAPI property.
+
+
+ The field represents a PR_MIDDLE_NAME_A MAPI property.
+
+
+ The field represents a PR_MIDDLE_NAME_W MAPI property.
+
+
+ The field represents a PR_MINI_ICON MAPI property.
+
+
+ The field represents a PR_MOBILE_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_MOBILE_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_MODIFY_VERSION MAPI property.
+
+
+ The field represents a PR_MSG_STATUS MAPI property.
+
+
+ The field represents a PR_NDR_DIAG_CODE MAPI property.
+
+
+ The field represents a PR_NDR_REASON_CODE MAPI property.
+
+
+ The field represents a PR_NDR_STATUS_CODE MAPI property.
+
+
+ The field represents a PR_NEWSGROUP_NAME_A MAPI property.
+
+
+ The field represents a PR_NEWSGROUP_NAME_W MAPI property.
+
+
+ The field represents a PR_NICKNAME_A MAPI property.
+
+
+ The field represents a PR_NICKNAME_W MAPI property.
+
+
+ The field represents a PR_NNTP_XREF_A MAPI property.
+
+
+ The field represents a PR_NNTP_XREF_W MAPI property.
+
+
+ The field represents a PR_NON_RECEIPT_NOTIFICATION_REQUESTED MAPI property.
+
+
+ The field represents a PR_NON_RECEIPT_REASON MAPI property.
+
+
+ The field represents a PR_NORMALIZED_SUBJECT_A MAPI property.
+
+
+ The field represents a PR_NORMALIZED_SUBJECT_W MAPI property.
+
+
+ The field represents a PR_NT_SECURITY_DESCRIPTOR MAPI property.
+
+
+ The field represents a PR_NULL MAPI property.
+
+
+ The field represents a PR_Object_TYPE MAPI property.
+
+
+ The field represents a PR_OBSOLETED_IPMS MAPI property.
+
+
+ The field represents a PR_OFFICE2_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_OFFICE2_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_OFFICE_LOCATION_A MAPI property.
+
+
+ The field represents a PR_OFFICE_LOCATION_W MAPI property.
+
+
+ The field represents a PR_OFFICE_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_OFFICE_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_OOF_REPLY_TYPE MAPI property.
+
+
+ The field represents a PR_ORGANIZATIONAL_ID_NUMBER_A MAPI property.
+
+
+ The field represents a PR_ORGANIZATIONAL_ID_NUMBER_W MAPI property.
+
+
+ The field represents a PR_ORIG_ENTRYID MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_ENTRYID MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_NAME_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_NAME_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_AUTHOR_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DELIVERY_TIME MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_BCC_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_BCC_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_CC_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_CC_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_NAME_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_NAME_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_TO_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_DISPLAY_TO_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_EITS MAPI property.
+
+
+ The field represents a PR_ORIGINAL_ENTRYID MAPI property.
+
+
+ The field represents a PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_ORIGINALLY_INTENDED_RECIP_ENTRYID MAPI property.
+
+
+ The field represents a PR_ORIGINALLY_INTENDED_RECIPIENT_NAME MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_ENTRYID MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_NAME_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_NAME_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENDER_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENSITIVITY MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_ENTRYID MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_NAME_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_NAME_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SENT_REPRESENTING_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SUBJECT_A MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SUBJECT_W MAPI property.
+
+
+ The field represents a PR_ORIGINAL_SUBMIT_TIME MAPI property.
+
+
+ The field represents a PR_ORIGINATING_MTA_CERTIFICATE MAPI property.
+
+
+ The field represents a PR_ORIGINATOR_AND_DL_EXPANSION_HISTORY MAPI property.
+
+
+ The field represents a PR_ORIGINATOR_CERTIFICATE MAPI property.
+
+
+ The field represents a PR_ORIGINATOR_DELIVERY_REPORT_REQUESTED MAPI property.
+
+
+ The field represents a PR_ORIGINATOR_NON_DELIVERY_REPORT_REQUESTED MAPI property.
+
+
+ The field represents a PR_ORIGINATOR_REQUESTED_ALTERNATE_RECIPIENT MAPI property.
+
+
+ The field represents a PR_ORIGINATOR_RETURN_ADDRESS MAPI property.
+
+
+ The field represents a PR_ORIGIN_CHECK MAPI property.
+
+
+ The field represents a PR_ORIG_MESSAGE_CLASS_A MAPI property.
+
+
+ The field represents a PR_ORIG_MESSAGE_CLASS_W MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_CITY_A MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_CITY_W MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_COUNTRY_A MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_COUNTRY_W MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_POSTAL_CODE_A MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_POSTAL_CODE_W MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_POST_OFFICE_BOX_A MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_POST_OFFICE_BOX_W MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_STATE_OR_PROVINCE_A MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_STATE_OR_PROVINCE_W MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_STREET_A MAPI property.
+
+
+ The field represents a PR_OTHER_ADDRESS_STREET_W MAPI property.
+
+
+ The field represents a PR_OTHER_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_OTHER_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_OWNER_APPT_ID MAPI property.
+
+
+ The field represents a PR_OWN_STORE_ENTRYID MAPI property.
+
+
+ The field represents a PR_PAGER_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_PAGER_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_PARENT_DISPLAY_A MAPI property.
+
+
+ The field represents a PR_PARENT_DISPLAY_W MAPI property.
+
+
+ The field represents a PR_PARENT_ENTRYID MAPI property.
+
+
+ The field represents a PR_PARENT_KEY MAPI property.
+
+
+ The field represents a PR_PERSONAL_HOME_PAGE_A MAPI property.
+
+
+ The field represents a PR_PERSONAL_HOME_PAGE_W MAPI property.
+
+
+ The field represents a PR_PHYSICAL_DELIVERY_BUREAU_FAX_DELIVERY MAPI property.
+
+
+ The field represents a PR_PHYSICAL_DELIVERY_MODE MAPI property.
+
+
+ The field represents a PR_PHYSICAL_DELIVERY_REPORT_REQUEST MAPI property.
+
+
+ The field represents a PR_PHYSICAL_FORWARDING_ADDRESS MAPI property.
+
+
+ The field represents a PR_PHYSICAL_FORWARDING_ADDRESS_REQUESTED MAPI property.
+
+
+ The field represents a PR_PHYSICAL_FORWARDING_PROHIBITED MAPI property.
+
+
+ The field represents a PR_PHYSICAL_RENDITION_ATTRIBUTES MAPI property.
+
+
+ The field represents a PR_POSTAL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_POSTAL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_POSTAL_CODE_A MAPI property.
+
+
+ The field represents a PR_POSTAL_CODE_W MAPI property.
+
+
+ The field represents a PR_POST_FOLDER_ENTRIES MAPI property.
+
+
+ The field represents a PR_POST_FOLDER_NAMES_A MAPI property.
+
+
+ The field represents a PR_POST_FOLDER_NAMES_W MAPI property.
+
+
+ The field represents a PR_POST_OFFICE_BOX_A MAPI property.
+
+
+ The field represents a PR_POST_OFFICE_BOX_W MAPI property.
+
+
+ The field represents a PR_POST_REPLY_DENIED MAPI property.
+
+
+ The field represents a PR_POST_REPLY_FOLDER_ENTRIES MAPI property.
+
+
+ The field represents a PR_POST_REPLY_FOLDER_NAMES_A MAPI property.
+
+
+ The field represents a PR_POST_REPLY_FOLDER_NAMES_W MAPI property.
+
+
+ The field represents a PR_PREFERRED_BY_NAME_A MAPI property.
+
+
+ The field represents a PR_PREFERRED_BY_NAME_W MAPI property.
+
+
+ The field represents a PR_PREPROCESS MAPI property.
+
+
+ The field represents a PR_PRIMARY_CAPABILITY MAPI property.
+
+
+ The field represents a PR_PRIMARY_FAX_NUMBER_A MAPI property.
+
+
+ The field represents a PR_PRIMARY_FAX_NUMBER_W MAPI property.
+
+
+ The field represents a PR_PRIMARY_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_PRIMARY_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_PRIORITY MAPI property.
+
+
+ The field represents a PR_PROFESSION_A MAPI property.
+
+
+ The field represents a PR_PROFESSION_W MAPI property.
+
+
+ The field represents a PR_PROFILE_NAME_A MAPI property.
+
+
+ The field represents a PR_PROFILE_NAME_W MAPI property.
+
+
+ The field represents a PR_PROOF_OF_DELIVERY MAPI property.
+
+
+ The field represents a PR_PROOF_OF_DELIVERY_REQUESTED MAPI property.
+
+
+ The field represents a PR_PROOF_OF_SUBMISSION MAPI property.
+
+
+ The field represents a PR_PROOF_OF_SUBMISSION_REQUESTED MAPI property.
+
+
+ The field represents a PR_PROVIDER_DISPLAY_A MAPI property.
+
+
+ The field represents a PR_PROVIDER_DISPLAY_W MAPI property.
+
+
+ The field represents a PR_PROVIDER_DLL_NAME_A MAPI property.
+
+
+ The field represents a PR_PROVIDER_DLL_NAME_W MAPI property.
+
+
+ The field represents a PR_PROVIDER_ORDINAL MAPI property.
+
+
+ The field represents a PR_PROVIDER_SUBMIT_TIME MAPI property.
+
+
+ The field represents a PR_PROVIDER_UID MAPI property.
+
+
+ The field represents a PR_PUID_A MAPI property.
+
+
+ The field represents a PR_PUID_W MAPI property.
+
+
+ The field represents a PR_RADIO_TELEPHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_RADIO_TELEPHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_ENTRYID MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_NAME_A MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_NAME_W MAPI property.
+
+
+ The field represents a PR_RCVD_REPRESENTING_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_READ_RECEIPT_ENTRYID MAPI property.
+
+
+ The field represents a PR_READ_RECEIPT_REQUESTED MAPI property.
+
+
+ The field represents a PR_READ_RECEIPT_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_RECEIPT_TIME MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_ENTRYID MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_NAME_A MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_NAME_W MAPI property.
+
+
+ The field represents a PR_RECEIVED_BY_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_RECEIVE_FOLDER_SETTINGS MAPI property.
+
+
+ The field represents a PR_RECIPIENT_CERTIFICATE MAPI property.
+
+
+ The field represents a PR_RECIPIENT_NUMBER_FOR_ADVICE_A MAPI property.
+
+
+ The field represents a PR_RECIPIENT_NUMBER_FOR_ADVICE_W MAPI property.
+
+
+ The field represents a PR_RECIPIENT_REASSIGNMENT_PROHIBITED MAPI property.
+
+
+ The field represents a PR_RECIPIENT_STATUS MAPI property.
+
+
+ The field represents a PR_RECIPIENT_TYPE MAPI property.
+
+
+ The field represents a PR_RECORD_KEY MAPI property.
+
+
+ The field represents a PR_REDIRECTION_HISTORY MAPI property.
+
+
+ The field represents a PR_REFERRED_BY_NAME_A MAPI property.
+
+
+ The field represents a PR_REFERRED_BY_NAME_W MAPI property.
+
+
+ The field represents a PR_REGISTERED_MAIL_TYPE MAPI property.
+
+
+ The field represents a PR_RELATED_IPMS MAPI property.
+
+
+ The field represents a PR_REMOTE_PROGRESS MAPI property.
+
+
+ The field represents a PR_REMOTE_PROGRESS_TEXT_A MAPI property.
+
+
+ The field represents a PR_REMOTE_PROGRESS_TEXT_W MAPI property.
+
+
+ The field represents a PR_REMOTE_VALIDATE_OK MAPI property.
+
+
+ The field represents a PR_RENDERING_POSITION MAPI property.
+
+
+ The field represents a PR_REPLY_RECIPIENT_ENTRIES MAPI property.
+
+
+ The field represents a PR_REPLY_RECIPIENT_NAMES_A MAPI property.
+
+
+ The field represents a PR_REPLY_RECIPIENT_NAMES_W MAPI property.
+
+
+ The field represents a PR_REPLY_REQUESTED MAPI property.
+
+
+ The field represents a PR_REPLY_TIME MAPI property.
+
+
+ The field represents a PR_REPORT_ENTRYID MAPI property.
+
+
+ The field represents a PR_REPORTING_DL_NAME MAPI property.
+
+
+ The field represents a PR_REPORTING_MTA_CERTIFICATE MAPI property.
+
+
+ The field represents a PR_REPORT_NAME_A MAPI property.
+
+
+ The field represents a PR_REPORT_NAME_W MAPI property.
+
+
+ The field represents a PR_REPORT_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_REPORT_TAG MAPI property.
+
+
+ The field represents a PR_REPORT_TEXT_A MAPI property.
+
+
+ The field represents a PR_REPORT_TEXT_W MAPI property.
+
+
+ The field represents a PR_REPORT_TIME MAPI property.
+
+
+ The field represents a PR_REQUESTED_DELIVERY_METHOD MAPI property.
+
+
+ The field represents a PR_RESOURCE_FLAGS MAPI property.
+
+
+ The field represents a PR_RESOURCE_METHODS MAPI property.
+
+
+ The field represents a PR_RESOURCE_PATH_A MAPI property.
+
+
+ The field represents a PR_RESOURCE_PATH_W MAPI property.
+
+
+ The field represents a PR_RESOURCE_TYPE MAPI property.
+
+
+ The field represents a PR_RESPONSE_REQUESTED MAPI property.
+
+
+ The field represents a PR_RESPONSIBILITY MAPI property.
+
+
+ The field represents a PR_RETURNED_IPM MAPI property.
+
+
+ The field represents a PR_ROWID MAPI property.
+
+
+ The field represents a PR_ROW_TYPE MAPI property.
+
+
+ The field represents a PR_RTF_COMPRESSED MAPI property.
+
+
+ The field represents a PR_RTF_IN_SYNC MAPI property.
+
+
+ The field represents a PR_RTF_SYNC_BODY_COUNT MAPI property.
+
+
+ The field represents a PR_RTF_SYNC_BODY_CRC MAPI property.
+
+
+ The field represents a PR_RTF_SYNC_BODY_TAG_A MAPI property.
+
+
+ The field represents a PR_RTF_SYNC_BODY_TAG_W MAPI property.
+
+
+ The field represents a PR_RTF_SYNC_PREFIX_COUNT MAPI property.
+
+
+ The field represents a PR_RTF_SYNC_TRAILING_COUNT MAPI property.
+
+
+ The field represents a PR_SEARCH MAPI property.
+
+
+ The field represents a PR_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_SECURITY MAPI property.
+
+
+ The field represents a PR_SELECTABLE MAPI property.
+
+
+ The field represents a PR_SENDER_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_SENDER_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_SENDER_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_SENDER_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_SENDER_ENTRYID MAPI property.
+
+
+ The field represents a PR_SENDER_NAME_A MAPI property.
+
+
+ The field represents a PR_SENDER_NAME_W MAPI property.
+
+
+ The field represents a PR_SENDER_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_SEND_INTERNET_ENCODING MAPI property.
+
+
+ The field represents a messages MAPI property.
+
+
+ The field represents a PR_SEND_RICH_INFO MAPI property.
+
+
+ The field represents a PR_SENSITIVITY MAPI property.
+
+
+ The field represents a PR_SENTMAIL_ENTRYID MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_ADDRTYPE_A MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_ADDRTYPE_W MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_EMAIL_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_EMAIL_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_ENTRYID MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_NAME_A MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_NAME_W MAPI property.
+
+
+ The field represents a PR_SENT_REPRESENTING_SEARCH_KEY MAPI property.
+
+
+ The field represents a PR_SERVICE_DELETE_FILES_A MAPI property.
+
+
+ The field represents a PR_SERVICE_DELETE_FILES_W MAPI property.
+
+
+ The field represents a PR_SERVICE_DLL_NAME_A MAPI property.
+
+
+ The field represents a PR_SERVICE_DLL_NAME_W MAPI property.
+
+
+ The field represents a PR_SERVICE_ENTRY_NAME MAPI property.
+
+
+ The field represents a PR_SERVICE_EXTRA_UIDS MAPI property.
+
+
+ The field represents a PR_SERVICE_NAME_A MAPI property.
+
+
+ The field represents a PR_SERVICE_NAME_W MAPI property.
+
+
+ The field represents a PR_SERVICES MAPI property.
+
+
+ The field represents a PR_SERVICE_SUPPORT_FILES_A MAPI property.
+
+
+ The field represents a PR_SERVICE_SUPPORT_FILES_W MAPI property.
+
+
+ The field represents a PR_SERVICE_UID MAPI property.
+
+
+ The field represents a PR_SEVEN_BIT_DISPLAY_NAME MAPI property.
+
+
+ The field represents a PR_SMTP_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_SMTP_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_SPOOLER_STATUS MAPI property.
+
+
+ The field represents a PR_SPOUSE_NAME_A MAPI property.
+
+
+ The field represents a PR_SPOUSE_NAME_W MAPI property.
+
+
+ The field represents a PR_START_DATE MAPI property.
+
+
+ The field represents a PR_STATE_OR_PROVINCE_A MAPI property.
+
+
+ The field represents a PR_STATE_OR_PROVINCE_W MAPI property.
+
+
+ The field represents a PR_STATUS MAPI property.
+
+
+ The field represents a PR_STATUS_CODE MAPI property.
+
+
+ The field represents a PR_STATUS_STRING_A MAPI property.
+
+
+ The field represents a PR_STATUS_STRING_W MAPI property.
+
+
+ The field represents a PR_STORE_ENTRYID MAPI property.
+
+
+ The field represents a PR_STORE_PROVIDERS MAPI property.
+
+
+ The field represents a PR_STORE_RECORD_KEY MAPI property.
+
+
+ The field represents a PR_STORE_STATE MAPI property.
+
+
+ The field represents a PR_STORE_SUPPORT_MASK MAPI property.
+
+
+ The field represents a PR_STREET_ADDRESS_A MAPI property.
+
+
+ The field represents a PR_STREET_ADDRESS_W MAPI property.
+
+
+ The field represents a PR_SUBFOLDERS MAPI property.
+
+
+ The field represents a PR_SUBJECT_A MAPI property.
+
+
+ The field represents a PR_SUBJECT_IPM MAPI property.
+
+
+ The field represents a PR_SUBJECT_PREFIX_A MAPI property.
+
+
+ The field represents a PR_SUBJECT_PREFIX_W MAPI property.
+
+
+ The field represents a PR_SUBJECT_W MAPI property.
+
+
+ The field represents a PR_SUBMIT_FLAGS MAPI property.
+
+
+ The field represents a PR_SUPERSEDES_A MAPI property.
+
+
+ The field represents a PR_SUPERSEDES_W MAPI property.
+
+
+ The field represents a PR_SUPPLEMENTARY_INFO_A MAPI property.
+
+
+ The field represents a PR_SUPPLEMENTARY_INFO_W MAPI property.
+
+
+ The field represents a PR_SURNAME_A MAPI property.
+
+
+ The field represents a PR_SURNAME_W MAPI property.
+
+
+ The field represents a PR_TELEX_NUMBER_A MAPI property.
+
+
+ The field represents a PR_TELEX_NUMBER_W MAPI property.
+
+
+ The field represents a PR_TEMPLATEID MAPI property.
+
+
+ The field represents a PR_TITLE_A MAPI property.
+
+
+ The field represents a PR_TITLE_W MAPI property.
+
+
+ The field represents a PR_TNEF_CORRELATION_KEY MAPI property.
+
+
+ The field represents a PR_TRANSMITABLE_DISPLAY_NAME_A MAPI property.
+
+
+ The field represents a PR_TRANSMITABLE_DISPLAY_NAME_W MAPI property.
+
+
+ The field represents a PR_TRANSPORT_KEY MAPI property.
+
+
+ The field represents a PR_TRANSPORT_MESSAGE_HEADERS_A MAPI property.
+
+
+ The field represents a PR_TRANSPORT_MESSAGE_HEADERS_W MAPI property.
+
+
+ The field represents a PR_TRANSPORT_PROVIDERS MAPI property.
+
+
+ The field represents a PR_TRANSPORT_STATUS MAPI property.
+
+
+ The field represents a PR_TTYTDD_PHONE_NUMBER_A MAPI property.
+
+
+ The field represents a PR_TTYTDD_PHONE_NUMBER_W MAPI property.
+
+
+ The field represents a PR_TYPE_OF_MTS_USER MAPI property.
+
+
+ The field represents a PR_USER_CERTIFICATE MAPI property.
+
+
+ The field represents a PR_USER_X509_CERTIFICATE MAPI property.
+
+
+ The field represents a PR_VALID_FOLDER_MASK MAPI property.
+
+
+ The field represents a PR_VIEWS_ENTRYID MAPI property.
+
+
+ The field represents a PR_WEDDING_ANNIVERSARY MAPI property.
+
+
+ The field represents a PR_X400_CONTENT_TYPE MAPI property.
+
+
+ The field represents a PR_X400_DEFERRED_DELIVERY_CANCEL MAPI property.
+
+
+ The field represents a PR_XPOS MAPI property.
+
+
+ The field represents a PR_YPOS MAPI property.
+
+
+ The operator overload performs implicit type conversions from to integer.
+ A representing the converted integer parameter tag.
+ The integer to convert.
+
+
+ The operator overload performs implicit type conversions from integer to .
+ An integer representing the converted parameter tag.
+ The to convert.
+
+
+ The enumeration contains values that specify TNEF property types.
+
+
+ Indicates an application time value.
+
+
+ Indicates a counted byte array.
+
+
+ Indicates a 16-bit Boolean value. '0' is false. Non-zero is true.
+
+
+ Indicates an OLE GUID.
+
+
+ Indicates a signed 64-bit integer that represents a base ten decimal with four digits to the right of the decimal point.
+
+
+ Indicates a floating point double.
+
+
+ Indicates a 32-bit error value.
+
+
+ Indicates a signed 16-bit value.
+
+
+ Indicates the 8-byte signed integer.
+
+
+ Indicates a signed 32-bit value.
+
+
+ Indicates the multivariable flag. The value part of the property contains multiple values.
+
+
+ Indicates the NULL property value.
+
+
+ Indicates the embedded object in a property
+
+
+ Indicates a 4-byte floating point value.
+
+
+ Indicates a null-terminated 8-bit character string.
+
+
+ Indicates a FILETIME 64-bit integer specifying the number of 100ns periods since Jan 1, 1601.
+
+
+ Indicates a null-terminated Unicode string.
+
+
+ Indicates an interface. The caller does not specify the type.
+
+
+ The class enables you to read properties from a TNEF stream in a forward-only manner.
+
+
+ The constructor creates a new object that reads TNEF data from the inputStream argument.
+ A stream containing binary TNEF data.
+
+
+ The constructor creates a new object and sets the input stream, codepage, and compliance mode.
+ An integer indicating the codepage to use when decoding the input stream.
+ A stream containing binary TNEF data.
+ A enumeration value indicating whether to throw exceptions when noncompliant TNEF data is encountered.
+
+
+ The method closes the TNEF stream that this object owns.
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method reads an undecoded attribute value from the TNEF stream that this object owns.
+ When this method returns, it contains the specified character array with the values between index and (index + count - 1) replaced by the characters read from the current source.
+ The place in buffer at which to begin writing.
+ The maximum number of characters to read. If the end of the stream is reached before count of characters is read into buffer, the current method returns.
+
+
+ The method reads the next attribute in the TNEF stream that this object owns.
+ The method returns true if there was another attribute to read. It returns false if there were no more attributes.
+
+
+ The method sets the back to .
+
+
+ Releases all resources used by the .
+
+
+ The class produces a TNEF stream by writing attributes and properties.
+
+
+ The constructor creates a new object with an attachment key specified by the attachmentKey parameter for output to the Stream parameter outputStream.
+ The attachment key for this object.
+ The Stream object to which to write.
+
+
+ The constructor creates a new object.
+ The attachment key for this object.
+ An integer representing the code page to use when writing output to outputStream.
+ The Stream object to which to write.
+
+
+ The constructor creates a new object.
+ The attachment key for this object.
+ A enumeration value.
+ An integer representing the code page to use when writing output to outputStream.
+ The Stream object to which to write.
+
+
+ The method closes this object and the stream that it owns.
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method flushes any buffered data to the stream that this object owns.
+
+
+ The method returns a object that can be used to write an embedded message using the codepage specified by the messageCodePage parameter.
+ An integer representing the code page to use when writing the embedded message.
+
+
+ The method sets the code page used to write to the TNEF stream that this object owns.
+ An integer representing the code page to use when writing.
+
+
+ The method starts a new attribute in the stream that this object owns.
+ A enumeration value indicating the attribute to write.
+ A enumeration value indicating whether the attribute to be written is for a message or for an attachment.
+
+
+ The method starts the property specified by the tag parameter in the TNEF stream that this object owns.
+ A enumeration value identifying the property to start.
+
+
+ The method starts a named property.
+ An integer representing the name of the named property to start.
+ A enumeration value identifying the property to start.
+ The GUID for the property set in which to start a new property.
+
+
+ The method starts a named property in the current attribute or row.
+ A enumeration value identifying the property to start.
+ The name of the named property to start.
+ The GUID for the property set in which to start a new property.
+
+
+ The method starts a property value.
+
+
+ The method starts a new row in a RecipientTable attribute.
+
+
+ Releases all resources used by the .
+
+
+ The method writes all properties in the parameter reader to the output stream owned by this object.
+ A from which to read the properties to write to the output stream owned by this object.
+
+
+ The method writes the current attribute in the parameter reader to the output stream owned by this object.
+ A structure positioned on the attribute to write to the output stream owned by this object.
+
+
+ The method reads a raw value from the byte parameter and writes it to the output stream owned by this object.
+ A byte array containing data to write to the stream that this owns.
+ An integer indicating where in buffer to begin reading data.
+ An integer indicating the number of bytes to write from buffer into the stream that this owns.
+
+
+ The method writes a standard TNEF OemCodePage attribute.
+ An integer representing the code page to write. This value will be used to encode 8-bit string values as they are written.
+
+
+ The method reads the current property from the parameter propertyReader and writes it to the output stream that this object owns.
+ A structure positioned on the property to write.
+
+
+ The method writes a property identified by the tag parameter with the Boolean value specified by the value parameter.
+ The Boolean value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the raw value specified by the value parameter.
+ A byte array containing the value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the DateTime value specified by the value parameter.
+ A DateTime object containing the value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the double value specified by the value parameter.
+ A double precision floating point value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the GUID value specified by the value parameter.
+ A GUID object to write.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the short integer value specified by the value parameter.
+ A short integer value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the integer value specified by the value parameter.
+ An integer value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the long integer value specified by the value parameter.
+ A long integer value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the value specified by the value parameter.
+ An object to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the floating point value specified by the value parameter.
+ A single precision floating point value to write to this property value.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the value contained in the value parameter.
+ A enumeration value specifying the property to write.
+ A stream containing the property value to write to this property.
+
+
+ The method writes a property identified by the tag parameter with the value specified by the value parameter.
+ A string containing the property value to write to this property.
+ A enumeration value specifying the property to write.
+
+
+ The method writes a property identified by the tag parameter with the value contained in the value parameter.
+ A TextReader object positioned on the property value to write to this property.
+ A enumeration value specifying the property to write.
+
+
+ The method writes an object property.
+ A GUID object containing the object IID to write.
+ A enumeration value specifying the property to write.
+ A stream object from which to read the raw data to write.
+
+
+ The method writes a raw property value from a byte array.
+ A byte array containing data to write.
+ An integer indicating where in buffer to begin reading data.
+ An integer indicating the number of bytes to write from buffer.
+
+
+ The method reads a text property value from a character array and writes it to the stream that this object owns.
+ A character array containing data to write.
+ An integer indicating where in buffer to begin reading data.
+ An integer indicating the number of characters to write from buffer.
+
+
+ The method writes a Boolean property value to the stream that this object owns.
+ A Boolean value to write.
+
+
+ The method writes the value contained in the value parameter and then ends it.
+ A byte array containing a value to write.
+
+
+ The method writes a DateTime value and then ends it.
+ A DateTime object to write.
+
+
+ The method writes a double precision floating point value and then ends it.
+ A double precision floating point value to write.
+
+
+ The method writes a GUID value and then ends it.
+ A GUID object to write.
+
+
+ The method writes a short integer value and then ends it.
+ A short integer value to write.
+
+
+ The method writes an integer property value and then ends it.
+ An integer value to write.
+
+
+ The method writes a long integer property value and then ends it.
+ A long integer to write.
+
+
+ The method writes and object as a property value and then ends it.
+ An object to write.
+
+
+ The method writes a single precision floating point value as a property value and then ends it.
+ A single precision floating point value to write.
+
+
+ The method reads bytes from the stream parameter, writes them to the output stream that this object owns, and ends the property value.
+ A stream containing the value to write.
+
+
+ The method writes a string to a property value and then ends it.
+ A string containing a value to write.
+
+
+ The method reads text from the reader parameter, writes it to the TNEF stream that this object owns, and then ends the property value.
+ A TextReader object positioned on the value to write.
+
+
+ The method writes an object property value and ends it.
+ A GUID object identifying the property value to write.
+ A stream containing the value to write.
+
+
+ The method writes the standard preamble TNEF version parameter.
+
+
+ The contains an enumeration value specifying not to overwrite the TnefVersion and OemCodePage attributes in the TNEF stream that this object owns.
+
+
+ Indicates not to overwrite the TnefVersion and OemCodePage attributes.
+
+
+ The namespace contains types that enable you to read and write vCard data.
+
+
+ The enumeration sets the compliance mode for vCard contacts.
+
+
+ Indicates that exceptions should not be thrown for non-compliant vCard contacts.
+
+
+ Indicates that vCard data must follow the vCard 3.0 standard.
+
+
+ The enumeration defines vCard contact compliance errors.
+
+
+ The vCard data complies with the vCard 3.0 standard.
+
+
+ A vCard data component closes with a different component name.
+
+
+ The vCard component name was not specified.
+
+
+ A required vCard data parameter was not supplied.
+
+
+ A required vCard parameter name was not specified.
+
+
+ A vCard data tag was closed without a corresponding beginning tag.
+
+
+ An invalid character is present in the vCard parameter name.
+
+
+ An invalid character is present in a vCard parameter's text.
+
+
+ An invalid character is present in a vCard property name.
+
+
+ An invalid character is present in a vCard property value.
+
+
+ An invalid character is present in a quoted string.
+
+
+ A vCard parameter has an invalid value.
+
+
+ A vCard value is in the wrong format for the value.
+
+
+ Not all vCard components that were opened have been closed.
+
+
+ A vCard parameter name is missing.
+
+
+ A vCard component cannot have an associated parameter.
+
+
+ All vCard properties must be inside a vCard component.
+
+
+ A property ended unexpectedly.
+
+
+ A stream ended unexpectedly.
+
+
+ The class reads contact information from a vCard contact parameter.
+
+
+ The method advances to and reads the next parameter.
+ The method returns true if there is another parameter to read; otherwise, false if there are no more parameters on the current property.
+
+
+ The method returns the next value of a multi-value parameter.
+ The method returns true if there is another value to read; otherwise, false if there are no more values on the current parameter.
+
+
+ The method returns the value of a parameter.
+ The value of the parameter.
+
+
+ The property gets the name of the parameter.
+ The name of the parameter.
+
+
+ The property returns the identifier for the parameter.
+ A instance containing the identity of the parameter.
+
+
+ The class reads the contents of vCard properties.
+
+
+ The method overrides the current character set and/or encoding for the current property value.
+ The decoder to use. Can be null.
+ The character set to use. Can be null.
+
+
+ The method returns the property value as a stream.
+ A instance containing the property value.
+
+
+ The method advances to the next property and reads the value.
+ The method returns true if another property is available; otherwise, false if there are no more properties to read.
+
+
+ The method advances to and reads the next value on a property.
+ The method returns true if there is another value on the property; otherwise, false if there are no more values to return.
+
+
+ The method parses a property value according to its type and returns it as an object.
+ he method returns an instance containing the property value.
+
+
+ The method parses the value according to its type and returns it as an object. Values are separated by the specified separators.
+ The method returns an instance containing the property value.
+ Separators on which reading should stop.
+
+
+ The method reads the property value as a Boolean value.
+ The method returns the property as a value.
+
+
+ The method returns the property value as a Boolean value. Values are separated by the specified separators.
+ The method returns the property as a value.
+ Separators on which reading should stop.
+
+
+ The method returns the property value as a byte array.
+ The method returns an array of bytes.
+
+
+ The method returns the property value as a date and time.
+ The method returns the property value as a instance.
+ One of the enumeration values.
+
+
+ The method return the property value as a date and time. Values are separated by the specified separators.
+ The method returns the property value as a instance.
+ Separators on which reading should stop.
+ One of the enumeration values.
+
+
+ The method returns the property value as a double.
+ The method returns the property value as a instance.
+
+
+ The method returns the property value as a double. Values are separated by the specified separators.
+ The method returns the property value as a instance.
+ Separators on which reading should stop.
+
+
+ The method returns the property value as an integer.
+ The method returns the property value as a instance.
+
+
+ The method returns the property value as an integer. Values are separated by the specified separators.
+ The method returns the property value as a instance.
+ Separators on which reading should stop.
+
+
+ The method returns the property value as a string.
+ The method returns the property value as a instance.
+
+
+ Values are separated by the specified separators.
+ The method returns the property value as a instance.
+ Separators on which reading should stop.
+
+
+ The method returns the property value as a time span.
+ The method returns the property value as a instance.
+
+
+ The method returns the property value as a time span. Values are separated by the specified separators.
+ The method returns the property value as a instance.
+ Separators on which reading should stop.
+
+
+ The property gets the last value separator read.
+ One of the enumeration values.
+
+
+ The property gets the name of the property.
+ The name of the property.
+
+
+ The property gets a parameter reader that reads the property parameters.
+ A instance that reads the property's parameters..
+
+
+ The property gets the identifier for the property.
+ A object containing the property identifier.
+
+
+ The property returns the type of the parameter.
+ One of the enumeration values.
+
+
+ The class isa a forward-only, non-cached reader for vCard data.
+
+
+ The constructor initializes a new instance of the class on the specified stream.
+ A object containing the vCard data.
+
+
+ The constructor initializes a new instance of the class on the specified stream with the specified encoding and compliance mode.
+ A object the specifies the encoding used on the vCard data stream.
+ One of the enumeration values that specifies the compliance level required on the vCard data.
+ A object containing the vCard data.
+
+
+ The method checks if the specified contact reader has been disposed.
+ The name of the method calling the method.
+ The method of the has been called.
+
+
+ The method closes the reader and disposes of any resources.
+
+
+ The method releases resources held by the instance.
+
+
+ The method releases managed resources held by the instance.
+ false if called from the finalizer; otherwise, true.
+
+
+ The method reads the next vCard in the data stream.
+ The method returns true if there is another vCard in the data stream; otherwise, false if the data stream has no more vCard data.
+
+
+ The method resets the vCard compliance requirement to .
+
+
+ The gets the vCard 3.0 standard compliance mode.
+ One of the enumeration values.
+
+
+ The property gets the current status of the vCard data.
+ One of the enumeration values.
+
+
+ The property gets a property read that reads the properties of the current vCard.
+ A for the current vCard data.
+
+
+ The enumeration specifies valid separator characters for vCard data.
+
+
+ The valid separator character is a comma (,).
+
+
+ There is no valid separator character.
+
+
+ The valid separator character is a semicolon (;).
+
+
+ The enumeration specifies the data type of vCard property values.
+
+
+ Contact value is a binary array of bytes.
+
+
+ Contact value is a value.
+
+
+ Contact value is the date portion of a value.
+
+
+ Contact value is a value.
+
+
+ Contact value is a float value.
+
+
+ Contact value is an integer value.
+
+
+ Contact value is a phone number represented as a value.
+
+
+ Contact value is a value.
+
+
+ Contact value is the time portion of a value.
+
+
+ Contact value type is unknown.
+
+
+ Contact value is a URI represented as a value.
+
+
+ Contact value is an offset from UTC represented as a value.
+
+
+ Contact value is an embedded vCard represented as an array of bytes.
+
+
+ The class writes structured vCard information to a stream.
+
+
+ The constructor initializes a new object.
+
+
+ The constructor initializes a new object.
+
+
+ The method closes the object.
+
+
+ The method disposes all resources.
+
+
+ The method disposes all resources.
+
+
+ The ends a vCard entry.
+
+
+ The method flushes all data to the underlying stream.
+
+
+ The method starts a new parameter identified by the parameter identifier.
+
+
+ The method starts a new parameter identified by the parameter name.
+
+
+ The method starts a new property that is identified by the property identifier.
+
+
+ The method starts a new property that is identified by the property name.
+
+
+ The method starts a new vCard entry.
+
+
+ The method writes a vCard that is read from the object.
+
+
+ The method writes a parameter that is read by the object.
+
+
+ The method writes a parameter based on parameter identifier.
+
+
+ The method writes a parameter based on parameter name.
+
+
+ The method writes a parameter value.
+
+
+ The method writes a property that is read by the reader.
+ The reader to get the property from.
+
+
+ The method writes a property.
+
+
+ The method writes a property.
+
+
+ The method writes a Boolean value.
+
+
+ The method writes a byte array.
+
+
+ The method writes a DateTime value.
+
+
+ The property writes a T:System.Double value.
+
+
+ The method writes a 32-bit integer value.
+
+
+ The method writes the property value stored in the Object.
+
+
+ The writes data from the stream into a vCard property value.
+
+
+ The method writes a string value to the vCard.
+
+
+ The method writes a property value with the specified content value separator.
+
+
+ The method writes a DateTime value with a value separator.
+
+
+ The method writes a T:System.Double value with a value separator.
+
+
+ The method writes a 32-bit integer value with a value separator.
+
+
+ The method writes the property value stored in the Object with a value separator.
+
+
+ The method writes a string property value to the vCard with value separators.
+
+
+ The method writes a parameter.
+
+
+ The exception thrown when vCard data parsing errors occur.
+
+
+ The constructor initializes a new instance of the class with the specified error message.
+ The message that describes the error.
+
+
+ The constructor initializes a new instance of the class with the specified serialized data.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor initializes a new instance of the class with the specified error message and a reference to the inner exception that is the cause of this exception.
+ The inner exception reference.
+ The message that describes the error.
+
+
+ The enumeration defines vCard data parameters.
+
+
+ The character set used for the vCard.
+
+
+ The character encoding used for the vCard.
+
+
+ The language used for text in the vCard.
+
+
+ The data type for the vCard data.
+
+
+ Unknown vCard parameter.
+
+
+ The data type of the vCard value.
+
+
+ The enumeration defines vCard contact component properties.
+
+
+ Street address of the contact.
+
+
+ The person acting on behalf of this contact.
+
+
+ The date of birth of the contact.
+
+
+ Categories to which the contact is assigned.
+
+
+ Access classification for the contact.
+
+
+ Full name (FN) of the contact.
+
+
+ E-mail address of the contact.
+
+
+ Geocoded location of the contact.
+
+
+ Job title of the contact.
+
+
+ Public key/certificate associated with the contact.
+
+
+ Postal address label of the contact.
+
+
+ Logo image of the contact.
+
+
+ Electronic mail software used by the contact.
+
+
+ Name of the contact's vCard.
+
+
+ Nickname of the contact.
+
+
+ Notes associated with the contact.
+
+
+ Organization affiliation of the contact.
+
+
+ Phone number of the contact.
+
+
+ Photo of the contact.
+
+
+ Product identifier associated with the contact.
+
+
+ Profile of the contact.
+
+
+ Last change date of the contact.
+
+
+ Role of the contact.
+
+
+ Sort string used when sorting contacts.
+
+
+ Sound information associated with the contact.
+
+
+ Source of the contact information.
+
+
+ Structured name of the contact.
+
+
+ Time zone of the contact's location.
+
+
+ Identifier associated with the contact.
+
+
+ Unknown contact property.
+
+
+ URL of Web resource associated with the contact.
+
+
+ Version of the contact information.
+
+
+ The namespace contains types that enable you to work with cultures and character sets to produce localized content.
+
+
+ The class exposes information about a character set.
+
+
+ The method returns a read-only object that represents the character set specified by the codePage parameter.
+ The code page of the desired character set.
+
+
+ The method returns a read-only object that represents the character set specified by the name parameter.
+ The name of the desired character set.
+
+
+ The method returns an object for the specified code page.
+ The code page for which an encoding is desired.
+ The code page specified by the codePage parameter is invalid or is not installed.
+
+
+ The method returns an object for the specified character set name.
+ The name of the character set for which a is desired.
+ The code page specified by the name parameter is invalid or is not installed.
+
+
+ The method attempts to put a object into the charset out parameter that corresponds to the codePage parameter. does not throw an exception if it fails.
+ The method returns true if it is successful. Otherwise, it returns false.
+ The code page for which to obtain a object.
+ A in which to store the result.
+
+
+ The method attempts to put a object into the charset out parameter that corresponds to the name parameter. does not throw an exception if it fails.
+ The method returns true if it is successful. Otherwise, it returns false.
+ A in which to store the result.
+ The character set name for which to obtain a object.
+
+
+ The attempts to put the for the character set that this object represents into the encoding out parameter. does not throw an exception if it fails.
+ The method returns true if it is successful. Otherwise, it returns false.
+ A object in which to store the result.
+
+
+ The method attempts to put the object for the character set specified by the codePage parameter into the encoding out parameter.
+ The method returns true if it is successful. Otherwise, it returns false.
+ The code page for which to obtain an .
+ A object in which to store the result.
+
+
+ The method attempts to get a object for the character set specified by the name parameter.
+ The method returns true if it is successful. Otherwise, it returns false.
+ A object in which to store the result.
+ The name of the character set to obtain.
+
+
+ The property gets a Boolean value that indicates whether the character set represented by this object can be detected by the class.
+ The property is true if the character set can be detected. Otherwise it is false.
+
+
+ The exception is thrown when a requested character set is not installed.
+
+
+ The constructor creates a new for the code page described by the codePage parameter.
+ The code page that was not installed.
+
+
+ The constructor creates a new for the character set described by the charsetName parameter.
+ The character set that was not installed.
+
+
+ The constructor creates a new exception with a message for a given code page.
+ The code page for which a character set was not installed.
+ The message for this .
+
+
+ The constructor creates a new serializable exception.
+ The StreamingContext object that contains contextual information about the source or destination.
+ The SerializationInfo object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new exception with a message for a given character set.
+ The character set that was not installed.
+ The message for this exception.
+
+
+ The constructor creates a new from an inner exception.
+ The code page for which a character set is not installed.
+ The exception that caused this to be thrown.
+ The message for this exception.
+
+
+ The constructor creates a new from an inner exception.
+ The character set that is not installed.
+ The exception that caused this to be thrown.
+ The message for this exception.
+
+
+ The class represents an e-mail culture.
+
+
+ The method returns a read-only object that represents the culture that corresponds to the locale ID parameter, lcid.
+ The locale ID for which to get a culture.
+
+
+ The method gets a read-only object that represents the culture specified by the name parameter.
+ The name of the culture to get.
+
+
+ attempts to put a object that corresponds to the lcid parameter into the culture out parameter. does not throw an exception if it fails.
+ The locale ID for which to obtain a culture.
+ A object in which to store the result.
+
+
+ attempts to put a object that corresponds to the name parameter into the culture out parameter. does not throw an exception if it fails.
+ A object in which to store the result.
+ The name of the culture to obtain.
+
+
+ The property gets the locale ID of the culture represented by this object.
+ The locale ID of the culture represented by this object. If the property returns zero, there is no standard locale ID for the culture.
+
+
+ The is thrown when an invalid or unknown code page or character set is encountered.
+
+
+ The constructor creates a new .
+ The invalid code page.
+
+
+ The constructor creates a new .
+ The invalid character set.
+
+
+ The constructor creates a new with a message.
+ The invalid code page.
+ The message for this exception.
+
+
+ The constructor creates a new serializable object.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new object with a message.
+ The invalid character set.
+ The message for this object.
+
+
+ The constructor creates a new object from an inner exception.
+ The invalid code page.
+ The exception that caused this to be thrown.
+ The message for this object.
+
+
+ The constructor creates a new from an inner exception.
+ The invalid character set.
+ The exception that caused this to be thrown.
+ The message for this object.
+
+
+ The class detects the best code page to use for encoding specified text.
+
+
+ The constructor creates a new object.
+
+
+ The method adds a character to this object.
+ The character to add.
+
+
+ The method adds text from a character array to this object.
+ The text to add.
+
+
+ The method adds text from a string to this object.
+ The text to add.
+
+
+ The method adds text from a to this object.
+ A containing the text to add.
+
+
+ The method adds a specified amount of text from a to this object.
+ A containing the text to add.
+ The maximum number of characters to add.
+
+
+ The method adds text from a character array to this object.
+ A character array containing text to add.
+ The number of characters to read.
+ The zero-based index of the first character to read.
+
+
+ The method adds text from a to this object.
+ The string from which to add text.
+ The number of characters to read.
+ The zero-based index of the first character to read.
+
+
+ The method takes the preferred character set into account and gets the code page that can best represent the text added to this object.
+ Set to true to allow common fallback exception characters. Otherwise, set to false.
+ The preferred character set for representing the text added to this object.
+
+
+ The method gets the code page that best represents the text added to this object and best fits the preferred culture.
+ Set to true to allow common fallback exception characters. Otherwise, set to false.
+ The preferred culture from which to choose a character set to represent the text added to this object.
+
+
+ The method returns an integer that indicates the percentage of the text added to this object that the specified code page can represent.
+ An integer indicating a code page.
+
+
+ The method gets a list of code pages that will encode the text added to this object, ordered from best to worst, subject to the preference indicated by the preferredCharset parameter..
+ Set to true to allow common fallback exception characters. Otherwise, set to false.
+ The preferred character set for representing the text added to this object.
+
+
+ The method returns a list of code pages that will encode the text added to this object, ordered from best to worst, subject to the preference indicated by the culture parameter.
+ Set to true to allow common fallback exception characters. Otherwise, set to false.
+ The preferred culture in which to choose the character set for the data added to this object.
+
+
+ The method resets this object.
+
+
+ The is thrown when an uninstalled or unrecognized culture is encountered.
+
+
+ The constructor creates a new object.
+ The locale ID that was not recognized.
+
+
+ The constructor creates a new object.
+ The name of the culture that was not recognized.
+
+
+ The constructor creates a new with a message.
+ The locale ID that was not recognized.
+ The message for this exception.
+
+
+ The constructor creates a new serializable object.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new object with a message.
+ The culture name that was not recognized.
+ The message for this exception.
+
+
+ The constructor creates a new from an inner exception.
+ The locale ID that was not recognized.
+ The exception that caused this to be thrown.
+ The message for this exception.
+
+
+ The constructor creates a new from an inner exception.
+ The culture name that was not recognized.
+ The exception that caused this to be thrown.
+ The message for this exception.
+
+
+ The namespace contains types that enable you to read and write MIME data by using either stream-based or DOM-based methods.
+
+
+ The class represents a MIME address header.
+
+
+ The constructor constructs a new object.
+ The display name of the new object.
+
+
+ The method copies the contents of this object into destination.
+ The destination object in which to store a deep copy of this object.
+
+
+ The method indicates whether value is valid for this header.
+ The method returns true if value is valid; otherwise, the method returns false.
+ The value to evaluate.
+
+
+ The static method creates a new with the name specified in name, and the address items specified in value.
+ One of AddressParserFlags: , , or .
+ The address header to put in the returned by .
+ The display name for the returned by .
+
+
+ The class represents a recipient or group of recipients.
+
+
+ The method copies the contents of this object into destination.
+ The destination object in which to store the contents of this object.
+
+
+ The method tries to get the display name of this object.
+ The method returns true if it successfully read the display name. If the encoding of the display name is unsupported, returns false, and displayName is set to null.
+ The string in which to store the display name.
+
+
+ The method tries to get the display name of this object and makes available information about the original encoding of the display name.
+ The converted display name.
+ A structure used to control the decoding.
+ A structure that exposes details about the conversion.
+
+
+ The property gets or sets the display name for the recipient or group of recipients represented by this object.
+ The property returns the display name for this object
+
+
+ The enumeration controls how addresses are parsed.
+
+
+ Square brackets in e-mail addresses are treated like angle brackets.
+
+
+ Comments are ignored and can be used as part of the display name.
+
+
+ Comments are enabled.
+
+
+ The class represents a simple Multipurpose Internet Mail Extensions (MIME) text header
+
+
+ The constructor creates a new instance of the class that has the name that is specified in name and the value that is specified in value.
+ The value of this .
+ The name for this .
+
+
+ The method copies the contents of this object into destination.
+ The destination object in which to store a copy of this object.
+
+
+ The method indicates whether value is valid for the object.
+ The method returns true if value is valid; otherwise the method returns false.
+ The value to evaluate.
+
+
+ The property gets or sets the value of this class.
+ The property returns a string representation of the 7-bit ASCII header.
+
+
+ The enumeration specifies how a stream is cached during loading.
+
+
+ Specifies the creation of a new stream to hold the contents of the original Multipurpose Internet Mail Extensions (MIME) stream. You can close the original MIME stream immediately after it is parsed.
+
+
+ Specifies the use of the source MIME stream as the data store. is not supported when a Stream interface is used. Also, the source stream must support seeking. The source stream should not be closed until all operations on the Document Object Model (DOM) are finished. You must manually close the source stream.
+
+
+ Specifies the use of the source MIME stream as the data store. is not supported when a Stream interface is used. Also, the source stream must support seeking. The source stream should not be closed until all operations on the DOM are finished. You must manually close the source stream. When the is disposed, the source stream is automatically disposed also.
+
+
+ The class represents a structured Multipurpose Internet Mail Extensions (MIME) header with parameters.
+
+
+ The method parses the header.
+
+
+ The property returns the indicated by name.
+ A string that identifies the to get.
+
+
+ The class represents a Content-Disposition header.
+
+
+ The constructor creates a new object.
+
+
+ The constructor constructs a new object that has the value that is specified by value.
+ The value of the Content-Disposition header that is represented by this object. The value parameter must not contain any Multipurpose Internet Mail Extensions (MIME) parameters.
+
+
+ The method puts a deep copy of this object into destination.
+ The destination object in which to store a deep copy of this object.
+
+
+ The method indicates whether value is valid for this header.
+ The method returns true if value is valid; otherwise, the method returns false.
+ The value to evaluate.
+
+
+ The property gets and sets the value of this object.
+ The value of the property is a string that contains the value of this object. This value excludes any comments or folding whitespace, and the trailing semicolon. Header parameters remain intact when is assigned.
+
+
+ The enumeration specifies the supported content transfer encodings.
+
+
+ Each three-byte sequence is encoded in a four-byte, seven-bit sequence. This results in a one-third increase in the message size. This is the most common format applied to attachments.
+
+
+ The data is not line-oriented and may have eight-bit data. The Simple Mail Transfer Protocol (SMTP) that is used to send this Multipurpose Internet Mail Extensions (MIME) part must support the BDAT extension for this encoding to be valid.
+
+
+ The data is encoded in the BinHex format for transport and results in seven-bit data.
+
+
+ Some byte data requires the full eight-bit range of bytes, but the data is still line-oriented. The SMTP must support the BDAT extension for this encoding to be valid.
+
+
+ The data is seven-bit encoded and each character that is not seven-bit will be escaped into a three-byte sequence of characters. This is the most common format applied to bodies that contain mostly seven-bit sequences.
+
+
+ Every byte is seven bits. This is the default transfer encoding.
+
+
+ The content transfer encoding is unknown.
+
+
+ The data is encoded in a variant of Unix-to-Unix encode (UUENCODE) format for transport and results in seven-bit data. The data encoding is line-oriented, and is seven-bit compliant.
+
+
+ The class represents a Multipurpose Internet Mail Extensions (MIME) Content-Type header.
+
+
+ The constructor creates a new object that has default values.
+
+
+ The constructor creates a new object that specifies the type specified by value.
+ The content type value for this object.
+
+
+ The method puts a deep copy of this object into destination.
+ The destination object in which to store a copy of this object.
+
+
+ Returns .
+
+
+ The property gets or sets the media type for this object.
+ The property returns a string that contains the media type for this object.
+
+
+ The property gets or sets the subtype for this object.
+ The returns a string that contains the subtype for the Content-Type header represented by this object.
+
+
+ The property gets or sets the value of the Content-Type header represented by this object.
+ The property returns a string that contains the value of the Content-Type header represented by this object.
+
+
+ The class represents a header that contains structured date and time information.
+
+
+ The constructor creates a new object that has the given name and dateTime.
+ A DateTime object that specifies the Coordinated Universal Time (UTC) or local date and time to use when the new object is created.
+ A string that contains the name of the to be created.
+
+
+ The constructor creates a new object that has the given name, dateTime, and timeZoneOffset.
+ A TimeSpan object that specifies the offset that the new object uses to calculate the local time.
+ A DateTime object that specifyies the universal date and time to use when the object is created.
+ A string that contains the name of the to be created.
+
+
+ The method puts a deep copy of this object into destination.
+ The destination object in which to store a deep copy of this object.
+
+
+ The method indicates whether value is valid for this header.
+ The method returns true if value is valid; otherwise the method returns false.
+ The value to evaluate.
+
+
+ The property gets or sets the date and time represented by this object.
+ The property always returns the local time.
+
+
+ The property gets or sets the value of the Multipurpose Internet Mail Extensions (MIME) date header stored in this object.
+ The property returns an ASCII string that represents the MIME date in this DateHeader object.
+
+
+ The enumeration indicates the encodings to try when you are trying to decode Multipurpose Internet Mail Extensions (MIME) headers.
+
+
+ Try all the other encodings represented by the enumeration.
+
+
+ Pass control characters in the header without fixing them.
+
+
+ Try to decode headers by using DBCS decoding.
+
+
+ Return the raw headers if encoding fails.
+
+
+ Try to decode headers by using Japanese Industrial Standard (JIS) decoding.
+
+
+ Do not try to decode any headers because the value is already converted to Unicode.
+
+
+ Try to decode headers by using the encoding specified in RFC2047.
+
+
+ Try to decode headers by using the encoding specified in RFC2231.
+
+
+ Try to decode headers by using UTF8 decoding.
+
+
+ The structure specifies how to decode incoming headers.
+
+
+ The constructor creates a new structure that has the specified by decodingFlags.
+ The enumeration that specifies the encodings to use when trying to decode incoming headers.
+
+
+ The constructor creates a new structure that has the specified by decodingFlags and the encoding specified by encoding.
+ The System.Text.Encoding object that specifies the encoding for incoming headers if no character set information is specified in the incoming document.
+ The enumeration that specifies the encodings to use when trying to decode incoming headers.
+
+
+ The constructor creates a new structure that has the specified by decodingFlags and the encoding specified by charsetName.
+ A string that specifies the character set for incoming headers and parameters if no character set information is specified in the incoming document.
+ A enumeration that specifies the encodings to use when trying to decode incoming headers and parameters.
+
+
+ The static field is a structure that specifies that all supported encodings should be tried when decoding incoming headers.
+
+
+ The static field is a DecodingOptions structure that specifies that incoming headers will not be decoded.
+
+
+ The property gets the character set that is used for incoming headers.
+ The property returns an Encoding object that represents the encoding assumed for incoming headers when no character set is specified in the incoming document.
+
+
+ The property gets the character set name that is used for incoming headers.
+ The property returns the character set name that is assumed for incoming headers when no character set is specified in the incoming document.
+
+
+ The property returns the that is used for decoding incoming headers.
+ The enumeration returns the enumeration that specifies the encodings to try when trying to decode incoming headers.
+
+
+ The structure indicates whether incoming Multipurpose Internet Mail Extensions (MIME) headers were successfully decoded.
+
+
+ The enumeration provides various instructions related to encoding headers.
+
+
+ Enable RFC2231 encoding for parameters.
+
+
+ Force reencoding of headers with the encoding specified in .
+
+
+ No special encoding instructions are specified.
+
+
+ The class specifies how to encode outgoing headers.
+
+
+ The constructor initializes a new object.
+ A string that contains the name of the character set to use when encoding headers.
+ A string that contains the culture name to use for headers.
+ An enumeration that specifies various encoding instructions.
+
+
+ The enumeration indicates which encoding was detected in the header.
+
+
+ Indicates that unencoded 8-bit data was detected in the header.
+
+
+ Indicates that mislabeled Japanese Industrial Standard (JIS)–encoded data was detected in the header.
+
+
+ Indicates that the header encoding was not recognized.
+
+
+ Indicates that data encoded according to RFC2047 was detected in the header.
+
+
+ Indicates that data encoded according to RFC2231 was detected in the header.
+
+
+ The abstract class represents a general Multipurpose Internet Mail Extensions (MIME) header.
+
+
+ The method puts a deep copy of this object into destination.
+ The destination object in which to put a deep copy of this object.
+
+
+ The method creates a new object of the type specified by headerID.
+ A enumeration that specifies the type of Multipurpose Internet Mail Extensions (MIME) header to create.
+
+
+ The static method creates a new object that has the name that is specified by name.
+ A string that specifies the name of the object to create.
+
+
+ The static method returns the that corresponds to a header name.
+ A string that contains the name for which to return the corresponding .
+
+
+ The method indicates whether name is valid for this header.
+ The method returns true if name is valid; otherwise the method returns false.
+ The name to evaluate.
+
+
+ The method indicates whether value is valid for this header.
+ The method returns true if value is valid; otherwise the method returns false.
+ The value to evaluate.
+
+
+ The static method creates a object by reading a .
+ A object from which to read header information.
+
+
+ The method tries to get the value of this object. does not throw an exception if it fails
+ The method returns false if it is unable to return the value of the current header.
+ A object to fill with the value of the current header.
+
+
+ The property gets or sets the value of this object.
+ The property returns a string representation of the 7-bit ASCII header. You can override this to do RFC 2047 encoding.
+
+
+ The enumeration identifies header types.
+
+
+ Identifies an AdHoc header.
+
+
+ Identifies an ApparentlyTo header.
+
+
+ Identifies an Approved header.
+
+
+ Identifies an Article header.
+
+
+ Identifies a Bcc header.
+
+
+ Identifies a Bytes header.
+
+
+ Identifies a Cc header.
+
+
+ Identifies a Comments header.
+
+
+ Identifies a ContentBase header.
+
+
+ Identifies a ContentClass header.
+
+
+ Identifies a ContentDescription header.
+
+
+ Identifies a ContentDisposition header.
+
+
+ Identifies a ContentId header.
+
+
+ Identifies a ContentLanguage header.
+
+
+ Identifies a ContentLocation header.
+
+
+ Identifies a ContentMD5 header.
+
+
+ Identifies a ContentTransferEncoding header.
+
+
+ Identifies a ContentType header.
+
+
+ Identifies a Control header.
+
+
+ Identifies a Date header.
+
+
+ Identifies a DeferredDelivery header.
+
+
+ Identifies a DispositionNotificationTo header.
+
+
+ Identifies a Distribution header.
+
+
+ Identifies an Encoding header.
+
+
+ Identifies an Encrypted header.
+
+
+ Identifies an Expires header.
+
+
+ Identifies an ExpiryDate header.
+
+
+ Identifies a FollowUpTo header.
+
+
+ Identifies a From header.
+
+
+ Identifies an Importance header.
+
+
+ Identifies an InReplyTo header.
+
+
+ Identifies a Keywords header.
+
+
+ Identifies a Lines header.
+
+
+ Identifies a ListHelp header.
+
+
+ Identifies a ListSubscribe header.
+
+
+ Identifies a ListUnsubscribe header.
+
+
+ Identifies a MessageId header.
+
+
+ Identifies a MimeVersion header.
+
+
+ Identifies a NewsGroups header.
+
+
+ Identifies an NntpPostingHost header.
+
+
+ Identifies an Organization header.
+
+
+ Identifies a Path header.
+
+
+ Identifies a Precedence header.
+
+
+ Identifies a Priority header.
+
+
+ Identifies a Received header.
+
+
+ Identifies a References header.
+
+
+ Identifies a ReplyBy header.
+
+
+ Identifies a ReplyTo header.
+
+
+ Identifies a ResentBcc header.
+
+
+ Identifies a ResentCc header.
+
+
+ Identifies a ResentDate header.
+
+
+ Identifies a ResentFrom header.
+
+
+ Identifies a ResentMessageId header.
+
+
+ Identifies a ResentReplyTo header.
+
+
+ Identifies a ResentSender header.
+
+
+ Identifies a ResentTo header.
+
+
+ Identifies a ReturnPath header.
+
+
+ Identifies a ReturnReceiptTo header.
+
+
+ Identifies a RR header.
+
+
+ Identifies a Sender header.
+
+
+ Identifies a Sensitivity header.
+
+
+ Identifies a Subject header.
+
+
+ Identifies a Summary header.
+
+
+ Identifies a Supercedes header.
+
+
+ Identifies a To header.
+
+
+ Identifies an Unknown header.
+
+
+ Identifies an XMSMailPriority header.
+
+
+ Identifies an XPriority header.
+
+
+ Identifies an XRef header.
+
+
+ The class represents an ordered list of headers.
+
+
+ The method copies the contents of this object into destination.
+ A object in which to store a deep copy of this object.
+
+
+ The method returns an array that contains all objects in this object that are of the name specified by headerId.
+ A enumeration value that specifies the name of object to retrieve.
+
+
+ The method returns an array that contains all objects in this object that have the name specified by name.
+ A string that specifies the name of the objects to return.
+
+
+ The method returns the first object in this object that is of the name specified by headerId.
+ A enumeration value that specifies the name of the object to return.
+
+
+ The method returns the first object in this object that is of the name specified by name.
+ A string that specifies the name of the object to return.
+
+
+ The method returns the next object of the same name as the object that you supply.
+ The object returned is the next one in this object that has the same name as refHeader.
+ A object that specifies the name of the object to return.
+
+
+ The method uses a object to create a object.
+ A object from which to read a list of headers.
+
+
+ The method removes all headers in the current part that have the name specified by headerId.
+ A enumeration value that indicates the name of the headers to remove.
+
+
+ The method removes all headers in the current part that have the name specified by name.
+ A string that indicates the name of the headers to remove.
+
+
+ The method writes the headers in this object to stream.
+ An structure that describes how to encode the data as it is written to the stream.
+ A object that controls the data that is written to the stream.
+ The stream to write to.
+
+
+ The structure returns information about an address header.
+
+
+ The method moves to the next address in the header.
+ The method returns true if it successfully moved to the next address header. The method returns false if no more address headers are present or if the is not currently positioned on an address header.
+
+
+ The method tries to get the display name of the current address header.
+ A string in which to store the display name.
+
+
+ The method tries to get the display name of the current address header and makes available information about the encoding of the display name.
+ A string in which to store the display name.
+ A structure that is used to control the decoding.
+ A structure that exposes details about the decoding.
+
+
+ The enumeration controls the action that will be taken if noncompliant Multipurpose Internet Mail Extensions (MIME) text is encountered.
+
+
+ No exceptions are thrown when noncompliant MIME text is encountered.
+
+
+ Parsing will fail if noncompliant MIME text is encountered.
+
+
+ The enumeration flags report any errors that are found in the incoming Multipurpose Internet Mail Extensions (MIME) content or report that the MIME content is compliant.
+
+
+ A line was found in a MIME part body that was terminated by a bare linefeed.
+
+
+ A line was found in a MIME part header that was terminated by a bare linefeed.
+
+
+ The incoming MIME content was compliant.
+
+
+ A boundary was not of the correct form.
+
+
+ An external body was specified by using an invalid syntax.
+
+
+ A header was not of the correct form.
+
+
+ A composite part contained an invalid transfer-encoding value.
+
+
+ A line was found that was longer than 1000 characters.
+
+
+ A body separator was missing.
+
+
+ A required boundary was missing.
+
+
+ A composite header was missing a boundary parameter.
+
+
+ The class represents a Multipurpose Internet Mail Extensions (MIME) document.
+
+
+ The constructor creates a new blank object.
+
+
+ The constructor creates a new object.
+ A object that limits the allowed complexity of incoming Multipurpose Internet Mail Extensions (MIME) documents.
+ A structure that describes how to decode incoming headers.
+
+
+ The method readies this object for garbage collection.
+
+
+ The method readies this object for garbage collection.
+ Set disposing to true when you are calling from a finalizer. Otherwise, set disposing to false.
+
+
+ The method loads a stream of Multipurpose Internet Mail Extensions (MIME) data into this object.
+ A enumeration value that controls the treatment of the input MIME stream.
+ A stream that contains the MIME data to load into this object.
+
+
+ The method writes the Multipurpose Internet Mail Extensions (MIME) data in the Document Object Model (DOM) to stream.
+ The stream into which to write the MIME data that is contained in this object.
+
+
+ The method writes the Multipurpose Internet Mail Extensions (MIME) data in the Document Object Model (DOM) to stream by using encodingOptions and filter.
+ An class that controls how to encode the MIME data as it is written to stream.
+ A object that controls which headers and what content is written to stream.
+ The stream into which to write the MIME data that is contained in this object.
+
+
+ The callback is called when the end of a root Multipurpose Internet Mail Extensions (MIME) part has been reached.
+
+
+ The class provides information about Multipurpose Internet Mail Extensions (MIME) errors in objects in the namespace.
+
+
+ The constructor creates a new object by using message.
+ A string that contains the error message for this exception.
+
+
+ The constructor creates a new object that can be serialized by using info and context.
+ Describes the source and destination of the serialized stream, and provides an additional caller-defined context.
+ Contains all the data that is needed to serialize or deserialize this object.
+
+
+ The constructor creates a new from message and innerException.
+ The inner exception that triggered this object.
+ A string that contains the error message for this object.
+
+
+ The class represents a MIME address group.
+
+
+ The constructor creates an empty object using default values.
+
+
+ The constructor creates an empty object using the display name displayName.
+ A string containing the display name to use for this object.
+
+
+ The method puts a deep copy of this MimeGroup object into destination.
+ A object in which to store a deep copy of this object.
+
+
+ The structure returns information about Multipurpose Internet Mail Extensions (MIME) headers.
+
+
+ The method moves to the next header.
+ The method returns true if there is another header to read. Otherwise, it returns false.
+
+
+ The method tries to get the value of the current header and put it in value.
+ The method returns true if it was able to decode the header. It returns false, and sets value to null, if it was unable to decode the header.
+ A string in which to store the value of this header.
+
+
+ The method tries to get the value of the current header and put it in value.
+ The method returns true if it was able to decode the header. It returns false, and sets value to null, if it was unable to decode the header.
+ A structure that is used to control the decoding.
+ A string in which to store the value of the header read by this .
+ A structure that exposes details about the decoding.
+
+
+ The class controls the allowed complexity of Multipurpose Internet Mail Extensions (MIME) read by a object or used to create a .
+
+
+ The class is the base class for nodes within a object.
+
+
+ The method puts a object onto the end of the list of children that belong to this object.
+ The object to append to the list of the children of this object.
+
+
+ The method copies this object into destination.
+ The object into which to copy this object.
+
+
+ Returns .
+
+
+ The method inserts a new object after a specified object in the list of the children of this object.
+ The object to insert after.
+ The object to insert.
+
+
+ The method inserts a new object before a specified object in the list of the children of this object.
+ The object to insert before.
+ The object to insert.
+
+
+ The method puts a at the start of the list of the children of this object.
+ The object to insert.
+
+
+ The method removes all children of this object.
+
+
+ The method removes the specified child object from the list of the children of this object.
+ The object to remove.
+
+
+ The method removes this object from its parent.
+
+
+ The method replaces a specified child object with another specified object.
+ The object to replace.
+ The object to insert.
+
+
+ The method throws an exception if the owning is read-only.
+ The name of the calling method.
+
+
+ The method writes the Multipurpose Internet Mail Extensions (MIME) data in this to writer.
+ The into which to write the data in this .
+
+
+ The method writes the Multipurpose Internet Mail Extensions (MIME) data in this to stream.
+ The stream into which to write the data in this object.
+
+
+ The method writes the Multipurpose Internet Mail Extensions (MIME) data in this object into stream by using encodingOptions.
+ The object that controls the encoding that is used when the MIME data is written.
+ The stream into which to write the MIME data.
+
+
+ The property gets a bool value that indicates whether the owning is read-only.
+ The property returns true if the owning is read-only; otherwise the property returns false.
+
+
+ The structure lets you enumerate over the children of a object.
+
+
+ The method releases all resources used by the .
+
+
+ The method moves to the next object.
+ The method returns true if there was another object to move to.
+
+
+ The method returns this to its initial state.
+
+
+ The callback class customizes the way in which Multipurpose Internet Mail Extensions (MIME) data is written.
+
+
+ The constructor creates a .
+
+
+ The method is called after all data in a part are output, before the boundary or next part or end boundary is written.
+ The just written.
+ The Stream that is being written to.
+
+
+ The method is called before a is written.
+ Set the return value to true to suppress the writing of header; set the return value to false to write header.
+ The that will be written.
+ The Stream that is being written to.
+
+
+ The method is called at the beginning of a part, after the part boundary has been written.
+ Set the return value to true to suppress the writing of headerList; set the return value to false to write headerList.
+ The Stream to write to.
+ The object to filter.
+
+
+ The method is called before a part boundary is written.
+ Set the return value to true to suppress the writing of part; set the return value to false to write part.
+ The to filter.
+ The Stream to write to.
+
+
+ The method is called after the Multipurpose Internet Mail Extensions (MIME) part boundary is written.
+ The to filter.
+ The Stream to write to.
+
+
+ The class represents a Multipurpose Internet Mail Extensions (MIME) parameter.
+
+
+ The constructor creates a new object that has the name name.
+ The name of the object to create.
+
+
+ The constructor creates a new MimeParameter object that has the name name and the value value.
+ The value for the object to create.
+ The name of the object to create.
+
+
+ The method puts a deep copy of this object into destination.
+ The object into which to put a copy of this object.
+
+
+ The method puts the value of this object into value, but does not throw an exception if the encoding is unsupported.
+ The method returns true if decoding was successful, in which case value contains the Multipurpose Internet Mail Extensions (MIME) part value. It returns false if the decoding was unsuccessful, in which case value is empty.
+ The string in which to put the value of this MimeParameter object if decoding is successful.
+
+
+ The method puts the value of this object into value, but does not throw an exception if the encoding is unsupported.
+ A structure that is used to control the decoding.
+ A string in which to store the display name.
+ A structure that exposes details about the decoding.
+
+
+ The property gets the value of this object.
+ The value returned is the fully decoded Unicode value of the parameter. For RFC2231-encoded parameters, this value contains all the fragments of the header decoded and combined together. The string returned is never null.
+
+
+ The structure returns information about a object.
+
+
+ The method reads the next parameter.
+ The method returns true if there is another parameter to read.
+
+
+ The method tries to get the value of this parameter, but does not throw an exception if its encoding is not supported.
+ The method returns true if the encoding was understood, in which case value contains the parameter value. Otherwise, the method returns false, in which case value is empty.
+ A string in which to store the value.
+
+
+ The method tries to get the value of this parameter, but does not throw an exception if its encoding is not supported.
+ The method returns true if the encoding was understood, in which case value contains the parameter value. Otherwise, the method returns false, in which case value is empty.
+ A structure that is used to control the decoding.
+ A string in which to store the value.
+ A structure that exposes details about the decoding.
+
+
+ The class represents a Multipurpose Internet Mail Extensions (MIME) part.
+
+
+ The constructor creates a blank object.
+
+
+ The constructor creates a new MimePart object and adds a Content-Type header.
+ A string that represents the Content Type for this header.
+
+
+ The constructor creates a new object, gives it a specified Content-Type header, and sets the content.
+ A stream that contains Multipurpose Internet Mail Extensions (MIME) content to put in this header.
+ A enumeration value that specifies how to treat contentStream.
+ A string that contains the Content-Type header to use.
+ A enumeration value that describes the content transfer encoding to apply to contentType and contentStream.
+
+
+ The method creates a new object, gives it a specified content type, and sets the content.
+ A stream that contains Multipurpose Internet Mail Extensions (MIME) content to put in this header.
+ A enumeration value that specifies how to treat contentStream.
+ A string that contains the Content-Type header to use.
+ A string that describes the content transfer encoding to apply to contentType and contentStream.
+
+
+ The method stores a copy of this object in destination.
+ An object in which to store a copy of this object.
+
+
+ The method releases all resources used by the class.
+
+
+ The method releases the unmanaged resources used by the class and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method returns a stream that will be written to by using the specified content transfer encoding.
+ A ContentTransferEncoding enumeration value that will be set on this object.
+
+
+ The method returns a stream that will be written to by using the specified content transfer encoding.
+ The content transfer encoding to use when writing to this object.
+
+
+ The method sets the content of this object.
+ A stream that contains the content.
+ A enumeration value that specifies how to treat contentStream.
+ A enumeration value that specifies the content transfer encoding to use when setting the content by using contentStream.
+
+
+ The method sets the content of this object.
+ A stream that contains the content.
+ A enumeration value that specifies how to treat contentStream.
+ A string that specifies the content transfer encoding to use when setting the content by using contentStream.
+
+
+ The method gets a stream that can be used to read the content of this object.
+ A stream into which to put the read stream.
+
+
+ The method writes the contents of this object to a stream.
+ An enumeration value that specifies how to encode the data as it is written to stream.
+ A callback object that controls the data as it is written to stream.
+ The stream to write to.
+
+
+ The structure encapsulates an enumerable tree of the parts of this MIME message.
+
+
+ The method returns an enumerator that can be used to iterate over the contents of this structure.
+ A enumeration value that controls what the returned enumerates.
+
+
+ The enumeration controls how a object walks its tree.
+
+
+ Include parts from embedded message content subtrees.
+
+
+ All non-empty multipart or message nodes are visited both before and after its children have been visited. This allows you to do any work required to close a multipart or message node.
+
+
+ The structure provides rich control over the enumeration of the contents of a structure.
+
+
+ The method makes the next MimPart object in this PartSubtree structure the current one.
+ The method returns true if it successfully moved to the next object in this structure. Otherwise, if the is empty or if there are no more objects in it, the method returns false.
+
+
+ The method causes the next call to the method to skip the children of the current object and move to the next available parent object.
+
+
+ The method sets the to null and causes the root object to be returned by the next call to the method.
+
+
+ Releases all resources used by the .
+
+
+ The property gets the depth of the current object within the structure that belongs to this object.
+ The value of the property is zero for the root node of a structure.
+
+
+ The class returns information about a MIME stream.
+
+
+ The constructor creates a new object.
+ A Stream object that contains MIME data.
+
+
+ The constructor creates a new object.
+ A structure that determines the allowed complexity of incoming MIME documents.
+ A structure that is used to control the decoding.
+ A stream that contains MIME data.
+ If there is a missing MIME-Version header, inferMime indicates whether this MimeReader object will infer the presence of MIME content from the presence of a Content-Type or Content-Transfer-Encoding header. See Remarks.
+
+
+ The method closes the current stream and releases any resources (such as sockets and file handles) that are associated with the current stream.
+
+
+ The method copies a whole MIME part, both headers and content, into stream.
+ The stream into which to copy the headers and content for the current part.
+
+
+ The method releases the resources that are used by the .
+
+
+ The method Releases the unmanaged resources used by the and optionally releases the managed resources.
+ Set the value of the disposing parameter to true to release both managed and unmanaged resources. Set the value to false to release only unmanaged resources.
+
+
+ The method makes the unparsed headers available for reading.
+
+
+ The method reads at most count bytes into buffer, starting at offset bytes.
+ The return value for the method is the number of bytes that are actually written. This value may be less than the number of bytes that is specified by count if, for example, there are fewer than count bytes left between the current position and the end of the current part.
+ The byte array to write data into.
+ The number of bytes into buffer to begin writing data.
+ The number of bytes to try to read into buffer.
+
+
+ The method moves to the start of the first child part within the current part.
+ The method returns true if it successfully moved to the start of the first child part. If the current part has no children, the method moves to the end of the current part and returns false.
+
+
+ The method moves to the beginning of the current part, which allows for the reading of the headers for the current part.
+
+
+ The method moves to the next part in the MIME source stream.
+ The method returns true if it successfully moved to the next part. If there are no parts left to move to, the method moves to the end of the MIME message and returns false.
+
+
+ The method moves the current position to the next sibling of the current part.
+ The method returns true if it successfully moved the current position to the next sibling part. If the current part has no siblings, or if there are no more siblings in the current part, the method moves the current position to the end of the current part and returns false.
+
+
+ The method reads at most count bytes into buffer, without decoding them, starting at offset bytes.
+ The return value for the method is the number of bytes that are actually written. This value may be less than the number of bytes that is specified by count if, for example, there are fewer than count bytes left between the current position and the end of the current part.
+ The byte array to write data into.
+ The number of bytes into buffer to begin writing data.
+ The number of bytes to try to read into buffer.
+
+
+ The method resets the of the reader to .
+
+
+ The method gets a stream that contains the content of the current part body.
+ The method returns true if it successfully decoded the MIME content into result. If the content is empty, its encoding is unsupported, or it cannot be decoded for any other reason, the method returns false.
+ The stream that contains the returned content.
+
+
+ The class represents the sender or recipient of a MIME message.
+
+
+ The constructor initializes a new instance of the class with default values.
+
+
+ The constructor initializes a new instance of the class with.
+ A string containing the value to use for initializing the property.
+ A string containing the value to use for initializing the property.
+
+
+ The method copies this method into destination.
+ The object into which to copy this object.
+
+
+ The method indicates whether the specified string is a valid email address for the object.
+ The method returns true if email is a valid email address; otherwise the method returns false.
+ The email address to evaluate.
+
+
+ The method returns a object created from address using the contained in flags.
+ The e-mail address to use when creating the returned object.
+ The enumeration value controlling how address is parsed.
+
+
+ The class writes MIME to a stream.
+
+
+ The constructor creates a new object that will write MIME data to data.
+ A stream into which MIME data will be written.
+
+
+ The constructor creates a new object.
+ A class controlling how the MIME data is encoded as it is written.
+ Set to true to force writing of the Mime-Version tag.
+ A stream into which MIME data will be written.
+
+
+ The method closes the stream to which this object writes.
+
+
+ Releases all resources used by the .
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method closes the stream to which this writes.
+
+
+ The method ends the current group so that other recipients will be added outside of the current group.
+ This exception is thrown if the stream has already been flushed, the current header cannot contain recipients, or the current position does not allow recipients to be written.
+
+
+ The method ends the current part.
+
+
+ The method flushes the data in this object to the underlying stream.
+
+
+ The method returns a stream to which you can write the content of the current part using the current value of Content-Transfer-Encoding header.
+ The method throws this exception if is called twice, if the Content-Transfer-Encoding header has not been written, or if it has been written with a value representing an unrecognized encoding.
+
+
+ The method starts an e-mail group.
+ The name of this e-mail group.
+
+
+ The method starts a header using the header ID value in the headerID parameter.
+ A enumeration value identifying the kind of header to write.
+
+
+ The method starts a header using the name supplied by the name parameter.
+ A string specifying the name of the header to start.
+
+
+ The method begins a new MIME part.
+
+
+ The method writes an address from the specified by the reader parameter.
+ A structure containing the address to write.
+
+
+ The method writes content from a object to the stream that this object owns.
+ A object containing content to write to the output stream.
+
+
+ The method writes content from a source Stream to the stream that this object owns.
+ The stream from which to read MIME content.
+
+
+ The method writes data from a buffer into the stream that this object owns.
+ A byte array containing data to write to the stream that this owns.
+ An integer indicating where in buffer to begin reading data.
+ An integer indicating the number of bytes to write from buffer into the stream that this owns.
+
+
+ The method writes the next header from a object into the stream that this object owns.
+ A object that is positioned on the header to be read into the stream that this owns.
+
+
+ The method writes a header of a specified type and specified value to the stream that this object owns.
+ A string containing the value of the header that will be written.
+ A enumeration value indicating the kind of header to write.
+
+
+ The method writes a header of a specified type and specified value to the stream that this object owns.
+ A string containing the value of the header that will be written.
+ A string containing the name of the header to write.
+
+
+ The method writes a Date-Time value to the current header.
+ The DateTime value to write to the current header in the stream that this object owns.
+
+
+ The method writes a value specified by a string to the stream that this object owns.
+ A string containing the value to write to the stream that this object owns.
+
+
+ The method writes a parameter to the current header in the stream that this object owns.
+ A containing the parameter to write.
+
+
+ The method writes a parameter to the current header in the stream that this object owns.
+ The value of the parameter to write.
+ The name of the parameter to write.
+
+
+ The method writes a part to the stream that this object owns.
+ A MimeReader object positioned at the start of the part to write to the stream that this object owns.
+
+
+ The method writes content from a source stream to the stream that this object owns and does not apply an encoding to the content as it is written.
+ A stream containing the content to be written to the stream that this object owns.
+
+
+ The method writes content from a byte array to the stream that this object owns and does not apply an encoding to the content as it is written.
+ A byte array containing content to write to the stream that this object owns.
+ An integer indicating where in buffer to begin reading.
+ An integer indicating the number of bytes to read from buffer.
+
+
+ The method writes a recipient to the stream that this object owns.
+ The display name of the recipient.
+ The address of the recipient.
+
+
+ The property gets a string containing the part boundary for the current part.
+ When the property is accessed in a multipart document at the start of a part, returns a string containing the part boundary. Otherwise, returns null.
+
+
+ The class represents a "Received" header.
+
+
+ The constructor creates a new object.
+ The value of the TCP-info of the By-domain clause of this object.
+ The value to assign to the By clause. If the by parameter is passed as null, the constructor attempts to get this value from the byTcpInfo parameter.
+ The value of the TCP-info of the From-domain clause of this object.
+ The date the message associated with the Received header represented by this object was processed.
+ The link for the message associated with the Received header represented by this object.
+ The value of the path or mailbox for the Received header represented by this object.
+ The value to assign to the From clause. If the from parameter is passed as null, the constructor attempts to get this value from the fromTcpInfo parameter.
+ The ID of the message associated with the Received header represented by this object.
+ The protocol used to preprocess the Received header represented by this object.
+
+
+ The method copies this object into the destination parameter.
+ The object into which to copy this object.
+
+
+ The method indicates whether value is valid for this header.
+ The method returns true if value is valid; otherwise the method returns false.
+ The value to evaluate.
+
+
+ The class represents a MIME header.
+
+
+ The constructor creates a new object from name and value strings.
+ The name to assign to the header represented by this object.
+ The value to assign to the header represented by this object.
+
+
+ The method puts a copy of this object into the destination parameter.
+ The object into which to copy this object.
+
+
+ The method indicates whether value is valid for this header.
+ The method returns true if value is valid; otherwise the method returns false.
+ The value to evaluate.
+
+
+ The method tries to get the value of this object.
+ A string in which to place the value of this object.
+
+
+ The method tries to get the value of this object and makes available information about the encoding of the header.
+ A string in which to store the value of this object.
+ A structure that exposes details about the decoding.
+ A structure that is used to control the decoding.
+
+
+ The namespace contains types that enable you to easily convert MIME content from one encoding to another.
+
+
+ The class decodes base64-encoded data.
+
+
+ The constructor creates a new object.
+
+
+ The method decodes base64-encoded data.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the binary-encoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully encoded. The completed parameter is set to true when either all the input is consumed but the data is not flushed, or the rest of the input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to convert.
+ Set flush to true if this is the last block of data to be converted. Otherwise, set flush to false.
+ A byte array that contains the base64-encoded data to convert to binary.
+ The zero-based byte offset in input at which to begin reading the data to convert.
+ This exception is thrown if input contains invalid base64-encoded data.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set to true to release both managed and unmanaged resources. Set to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are required to store dataCount bytes of base64-encoded data after it has been decoded.
+ The maximum number of bytes needed to store the dataCount base64-encoded bytes after they have been decoded.
+ The number of bytes of base64-encoded data.
+
+
+ The method resets the internal state of this object.
+
+
+ The class encodes data into the base64 encoding.
+
+
+ The constructor creates a new default object.
+
+
+ The constructor initializes a new instance of the class with the LineLength property that is indicated by the lineLength parameter.
+ A value of 76 enables lines that are 76 characters long to be terminated by using CRLF. A value of 0 disables soft wrapping.
+ The lineLength parameter was neither 0 nor 76.
+
+
+ The method applies base64 encoding to data that is provided in a byte array.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the base64-encoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully encoded. The completed parameter is set to true when either all the input is consumed but the data is not flushed, or the rest of the input was flushed.
+ The zero-based byte offset in output at which to begin writing the encoded data.
+ Set flush to true if this is the last block of data to be converted. Otherwise, set flush to false.
+ A byte array that contains the binary data to encode.
+ The zero-based byte offset in input at which to begin reading the data to convert.
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize are less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set this parameter to true to release both managed and unmanaged resources. Set this parameter to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are required to store dataCount bytes of binary data after it has been encoded.
+ The number of bytes of binary data to encode.
+
+
+ The method resets the internal state of this object.
+
+
+ The property gets or sets a value that controls how the encoded data will be wrapped.
+ The property returns 0 or 76. A value of 0 indicates that no wrapping will be performed. A value of 76 indicates that at most 76 characters will come before a CRLF.
+
+
+ The class decodes BinHex data.
+
+
+ The constructor creates a new object that has default values.
+
+
+ The constructor creates a new object and specifies whether the resource fork is included in the output.
+ Set dataForkOnly to true to exclude the resource fork from the output. Set it to false to include the resource fork.
+
+
+ The method decodes BinHex-encoded data.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the decoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully decoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to decode.
+ Set flush to true if this is the last block of data to be decoded. Otherwise, set flush to false.
+ A byte array that contains the BinHex-encoded data to convert to binary.
+ The zero-based byte offset in input at which to begin reading the data to decode.
+ This exception is thrown if input contains invalid BinHex data.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set to true to release both managed and unmanaged resources. Set to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are needed to store dataCount bytes of BinHex data after it has been decoded.
+ The number of bytes of BinHex data.
+
+
+ The method resets the internal state of this object.
+
+
+ The property gets or sets a Boolean value that determines whether the resource fork is included in the output.
+ The property returns true if only the data fork is to be included in the conversion result. If the resource fork is to be included also, the property returns false.
+
+
+ The property gets a object.
+ The property returns the object that represents the Mac Binary Header in the BinHex-encoded data.
+
+
+ The class applies BinHex encoding.
+
+
+ The constructor creates a new object that has default values.
+
+
+ The constructor creates a new object that will include the Mac Binary Header header in its output.
+ A object that is used to write a Mac Binary Header to the output.
+
+
+ The method applies BinHex encoding.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the BinHex-encoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully encoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to convert.
+ Set flush to true if this is the last block of data to be encoded. Otherwise, set flush to false.
+ A byte array that contains the data to encode.
+ The zero-based byte offset in input at which to begin reading the data to encode.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set the value to true to release both managed and unmanaged resources. Set the value to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are needed to store dataCount bytes of data after it has been BinHex-encoded.
+ The number of bytes to BinHex encode.
+
+
+ The method resets the internal state of this object.
+
+
+ The class is a base class for the encoders and decoders in the namespace.
+
+
+ The constructor creates a new object with default values.
+
+
+ When overridden in a derived class, the method encodes or decodes sourceStream and writes it to destinationStream.
+ The stream that contains the data to encode or decode.
+ The stream that will contain the decoded or encoded results.
+
+
+ When overridden in a derived class, the method encodes or decodes data.
+ The number of bytes to use in output.
+ Set flush to true if this is the last block of data to be encoded or decoded. Otherwise, set flush to false.
+ The number of bytes actually read from input.
+ A byte array that will contain the result of the encoding or decoding.
+ The maximum number of bytes to be read from input.
+ The number of bytes actually written to output.
+ A Boolean value indicating that all data has been successfully encoded or decoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to encode or decode.
+ A byte array containing the data to encode or decode.
+ The zero-based byte offset in input at which to begin reading the data to encode or decode.
+
+
+ Releases the resources used by the .
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method returns a that decodes data encoded with the encoding specified by the name parameter.
+ The type of data the returned decoder will decode. Possible values are:Base64QuotedPrintableUUEncodeBinHex
+ The name parameter was not one of "Base64," "QuotedPrintable," "UUEncode," or "BinHex."
+
+
+ The method returns a object that can encode data by using the encoding specified by the name parameter.
+ The type of data the returned encoder will encode. Possible values are:Base64QuotedPrintableUUEncodeBinHex
+ The name parameter was not one of "Base64," "QuotedPrintable," "UUEncode," or "BinHex."
+
+
+ When overridden in a derived class, the method returns the maximum number of bytes needed to store the result of encoding or decoding dataCount bytes of raw or encoded data, respectively.
+ The number of bytes of data to encode or decode.
+
+
+ When overridden in a derived class, the method resets this object's internal state.
+
+
+ The class provides an exception for internal errors in the namespace.
+
+
+ The constructor creates a new with an informative message.
+ A string that contains the error message for this exception.
+
+
+ The constructor creates a new that can be serialized by using information and context.
+ Describes the source and destination of the serialized stream, and provides an additional caller-defined context.
+ Contains all the data that is needed to serialize or deserialize this object.
+
+
+ The constructor creates a new from an inner exception.
+ A string that contains the error message for this exception.
+ The inner exception that triggered this .
+
+
+ The class uses an object derived from to encode or decode data as it is read or written.
+
+
+ The constructor creates a new that uses encoder to encode or decode data as it is read from or written to stream, depending on the value of access.
+ An object derived from to use for encoding or decoding data as it is read or written.
+ The object to read or write to.
+ An enumeration value specifying whether stream is to be read from or written to.
+
+
+ The method closes the object that this owns.
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method clears all buffers in this object and causes any buffered data to be written.
+ The stream does not support writing.
+ The data source or repository is not open.
+
+
+ The method encodes or decodes data as it reads from the object that this object owns.
+ The method returns the total number of bytes read into the array.
+ An integer indicating where in array to place the data.
+ A byte array that will contain the read data.
+ An integer indicating the number of bytes to attempt to read.
+ array was null.
+ The sum of offset and count is greater than the array length.
+ The sum of offset and count is less than zero.
+ The that this object owns does not support reading.
+
+
+ The method moves the current position.
+ The method returns the current position after the seek operation has completed.
+ The possibly negative number of bytes to move from the position specified by origin.
+ A enumeration value indicating the location used to calculate the final seek position.
+ The requested seek position is less than zero.
+ The stream does not support seeking.
+
+
+ The method sets the length of the stream.
+ A long integer representing the desired length of the stream.
+ The stream does not support both writing and seeking.
+
+
+ The method encodes or decodes data as it writes it to the object that this object owns.
+ An integer indicating where in array to begin reading data.
+ A byte array that contains the source data.
+ An integer indicating the number of bytes to attempt to write.
+ Length of array minus offset is less than count.
+ array is null.
+ The stream does not support writing.
+ Either offset or count is negative, or the sum of offset and count is greater than the array length.
+
+
+ The property gets a Boolean value indicating whether this supports reading.
+ The property returns true if the object that this owns supports reading. Otherwise, if the object that this owns is closed or was opened with write-only privileges, returns false.
+
+
+ The property gets a Boolean value indicating whether the object that this object owns supports seeking.
+ The property returns true if seeking is supported. It returns false if the stream that this object owns is closed or if it was constructed from an operating system handle.
+
+
+ The property gets a Boolean value indicating whether the object that this object owns can be written to.
+ The property returns true if writing is supported. If the object that this object owns is closed or was opened with read-only access, the property returns false.
+
+
+ The property gets or sets a long integer value representing the current position within the object that this object owns.
+ You attempted to assign a value less than zero to the property.
+ The stream does not support seeking.
+
+
+ The enumeration contains values that indicate the access type for a stream.
+
+
+ Indicates read access.
+
+
+ Indicates write access.
+
+
+ The class represents a Mac Binary header in a BinHex data stream.
+
+
+ The constructor creates a new object with default values.
+
+
+ The constructor constructs a new object from a valid Mac Binary header contained in the bytes parameter.
+ A valid Mac Binary header.
+ The length of bytes is not 128.
+ The bytes parameter contains corrupt data.
+
+
+ The property gets the checksum for this .
+ The 16-bit CRC field for this .
+
+
+ The property gets or sets the creation date for this object.
+ The property returns the Coordinated Universal Time (UTC) creation date and time for this instance of the object.
+
+
+ The property gets or sets the Creator field of the Mac Binary Header represented by this object.
+ The property returns an Apple-defined four-byte ASCII sequence identifying the application that created the BinHex stream associated with this object.
+
+
+ The property gets or sets the FileName field of the Mac Binary header that this object represents.
+ The name of the file.
+
+
+ The property gets or sets an integer value representing the Type field in the Mac Binary header that this object represents.
+ An Apple-defined four byte sequence encoding for the file type.
+
+
+ The property gets or sets the FinderFlags field of the Mac Binary header represented by this object.
+ An Apple-defined FinderFlags field value.
+
+
+ The property gets or sets the ModificationDate field of the Mac Binary header that this object owns.
+ The property returns the Coordinated Universal Time (UTC) date and time of the modification date for this instance of the object.
+
+
+ The property gets the old Mac Binary header version, which must be 0.
+ The property returns 0.
+
+
+ The class decodes QuotedPrintable data.
+
+
+ The constructor creates a new object that has default values.
+
+
+ The method decodes QuotedPrintable data.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the decoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully decoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to decode.
+ Set flush to true if this is the last block of data to be decoded. Otherwise, set flush to false.
+ A byte array that contains the data to decode.
+ The zero-based byte offset in input at which to begin reading the data to decode.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if one any of the following sare true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set this to true to release both managed and unmanaged resources. Set this to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are needed to store dataCount bytes of data after it has been decoded.
+ The number of bytes of data to decode.
+
+
+ The method resets the internal state of this object.
+
+
+ The class applies QuotedPrintable encoding.
+
+
+ The constructor creates a new that has default values.
+
+
+ The constructor creates a new object.
+ Set ebcdicDictionary to true to include EBCDIC extensions.
+
+
+ The method applies QuotedPrintable encoding.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the encoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully encoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to encode.
+ Set flush to true if this is the last block of data to be encoded. Otherwise, set flush to false.
+ A byte array that contains the data to encode.
+ The zero-based byte offset in input at which to begin reading the data to encode.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set to true to release both managed and unmanaged resources. Set to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are needed to store dataCount bytes of data after it has been encoded.
+ The number of bytes to encode.
+
+
+ The method resets the internal state of this object.
+
+
+ The property returns a Boolean value that indicates whether EBCDIC extensions are being used.
+ The property returns true if the EBCDIC dictionary is being used. Otherwise, the property returns false.
+
+
+ The class decodes UUCP-encoded data.
+
+
+ The constructor creates a new object that has default values.
+
+
+ The method decodes UUCP data.
+ The number of bytes to use in output.
+ The number of bytes that are actually read from input.
+ A byte array that will contain the decoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully decoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to decode.
+ Set flush to true if this is the last block of data to be decoded. Otherwise, set flush to false.
+ A byte array that contains the data to decode.
+ The zero-based byte offset in input at which to begin reading the data to decode.
+ This exception is thrown if input contains invalid UUCP data.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set the value to true to release both managed and unmanaged resources. Set the value to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are needed to store dataCount bytes of data after it has been decoded.
+ The number of bytes of data to decode.
+
+
+ The method resets the internal state of this object.
+
+
+ The class applies UUCP encoding.
+
+
+ The constructor creates a new that has default values.
+
+
+ The constructor creates a new object.
+ The file name to include in the UUCP prologue.
+
+
+ The method applies UUCP encoding.
+ The number of bytes to use in output.
+ The number of bytes hat are actually read from input.
+ A byte array that will contain the encoded data.
+ The maximum number of bytes to be read from input.
+ The number of bytes that are actually written to output.
+ A Boolean value that indicates that all data has been successfully encoded. The completed parameter is set to true when either all of input is consumed but the data is not flushed, or the rest of input was flushed.
+ The zero-based byte offset in output at which to begin writing the data to encode.
+ Set flush to true if this is the last block of data to be encoded. Otherwise, set flush to false.
+ A byte array that contains the data to encode.
+ The zero-based byte offset in input at which to begin reading the data to encode.
+ This exception is thrown if either input is null (Nothing in Visual Basic) and inputSize is nonzero or output is null (Nothing in Visual Basic).
+ This exception is thrown if any one of the following is true:Either inputSize or outputSize is less than zero.inputSize is greater than the length of input.outputSize is greater than the length of output.The sum of inputSize and inputIndex is greater than the size of input.The sum of outputSize and outputIndex is greater than the size of output.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set this to true to release both managed and unmanaged resources. Set this to false to release only unmanaged resources.
+
+
+ The method returns the maximum number of bytes that are needed to store dataCount bytes of data after it has been encoded.
+ The number of bytes to encode.
+
+
+ The method resets the internal state of this object.
+
+
+ The property gets or sets the file name to include in the UUCP prologue.
+ The property returns the file name of the UUCP prologue.
+
+
+ The namespace contains types that enable you to easily convert data among different formats such as HTML, RTF, enriched text, and plain text.
+
+
+ The type is a read-only, forward-only pull mode converter based on the TextReader class.
+
+
+ The constructor constructs a new that converts sourceStream by using converter.
+ The Stream object containing text to convert.
+ The object that will be used to convert sourceStream.
+
+
+ The constructor constructs a new that converts sourceReader by using converter.
+ The object that will be used to convert data from sourceReader.
+ The object containing data to convert.
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method reads the converted character that will be returned by the next call to .
+
+
+ The method reads the next character from the input stream.
+ If successful, the return value for the method is the character read. Otherwise, -1 is returned.
+
+
+ The method reads count bytes from the input stream, starting at offset, and stores them in buffer.
+ The method returns the number of characters read.
+ The maximum number of characters to read. If the end of the stream is reached before count of characters is read into buffer, the current method returns.
+ When this method returns, it contains the specified character array with the values between index and (index + count - 1) replaced by the characters read from the current source.
+ The place in buffer at which to begin writing.
+
+
+ The class is a stream-based converter that can be configured for reading or writing.
+
+
+ The constructor creates a new read-only object for converting sourceReader by using converter.
+ The object to use for the conversion.
+ The from which to read the unconverted input.
+
+
+ The constructor creates a new object for writing converted content into destinationWriter by using conversion.
+ The to which to write the converted output.
+ The object to use for the conversion.
+
+
+ The constructor creates a new object that uses converter to either read from or write into stream, based on the value supplied by access.
+ The object to use when reading to or writing from stream.
+ The object to read from or write into.
+ The enumeration that specifies whether to read from or write to stream.
+
+
+ The method closes the .
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method clears all buffers for this and causes any buffered data to be written to the destination TextWriter that it owns.
+
+
+ The method reads and converts count bytes from the input stream and stores them in buffer, starting at offset.
+ The return value for the method is the number of characters read.
+ The place in buffer at which to begin writing.
+ The maximum number of characters to read. If the end of the stream is reached before count of characters is read into buffer, the current method returns.
+ When this method returns, it contains the specified character array with the values between index and (index + count - 1) replaced by characters read and converted from the current source.
+
+
+ The method throws a NotSupportedException. The object does not support seeks.
+ This parameter is ignored.
+ This parameter is ignored.
+
+
+ The method throws a NotSupportedException.
+ This parameter is ignored.
+
+
+ The method converts and writes count bytes from buffer, starting at offset, into the destination TextWriter that it owns.
+ The starting index in the buffer.
+ The number of characters to write.
+ The character array to write data from.
+
+
+ The property indicates whether the current stream supports reading.
+
+
+ The property returns false to indicate that the object does not support seeks.
+
+
+ The property indicates whether this can be written to.
+
+
+ The property throws a .
+
+
+ The property throws a . The class does not support seeks.
+
+
+ The type specifies the access mode for a ConverterStream object.
+
+
+ Specifies that the associated ConverterStream is open for reading.
+
+
+ Specifies that the associated ConverterStream is open for writing.
+
+
+ The type is a write-only converter that is derived from the class. Source documents are written into and the output is written into a or object.
+
+
+ The constructor creates a new object that uses converter to write converted output to destinationStream.
+ The to write the converted data to.
+ The to use for the conversion.
+
+
+ The constructor creates a new object that uses converter to write converted output to destinationWriter.
+ The to write the converted data to.
+ The to use for the conversion.
+
+
+ The method releases the unmanaged resources that are used by the and optionally releases the managed resources.
+ Set the value to true to release both managed and unmanaged resources. Set the value to false to release only unmanaged resources.
+
+
+ The method clears all buffers for this object and causes any buffered data to be written to the destination or stream that it owns.
+
+
+ The method writes a single character into the destination or object that it owns.
+ The character to write into the or object that this owns.
+
+
+ The method converts buffer and writes it to the or object that this owns.
+ The character array that contains the text to convert and write.
+
+
+ The method converts value and writes it to the or object that this owns.
+ The string that contains the text to convert and write.
+
+
+ The method converts and writes count characters from buffer, starting at index, into the or that this owns.
+ The number of characters to write.
+ The character array to write data from.
+ The starting index in the buffer.
+
+
+ The method appends a new line to value, converts the resulting string, and writes it to the or object that this owns.
+ The string to convert and write.
+
+
+ The class converts enriched text to HTML.
+
+
+ The constructor creates a new object.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the byte order mark or determined by the property.
+ The property returns true if the byte order mark in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.
+
+
+ The property gets or sets a Boolean value indicating whether the HTML will be stripped of executable scripts.
+ The property returns true if executable scripts will be removed. Otherwise, this property returns false.
+
+
+ The class converts enriched text to plain text.
+
+
+ The constructor creates a new object.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the byte order mark or determined by the property.
+ The property returns true if the byte order mark in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.
+
+
+ The enumeration contains values that determine how headers and footers are interpreted before they are inserted into converted output.
+
+
+ The header or footer contains properly-formatted HTML and will be converted to the output format.
+
+
+ The header or footer contains plain text. If the plain text contains any special characters (for example, '<' or '&'), they will be escaped, when necessary, as they are written to the output.
+
+
+ The enumeration contains values that represent HTML attributes.
+
+
+ The HTML markup Abbr.
+
+
+ The HTML markup Accept.
+
+
+ The HTML markup AcceptCharset.
+
+
+ The HTML markup AccessKey.
+
+
+ The HTML markup Action.
+
+
+ The HTML markup Align.
+
+
+ The HTML markup Alink.
+
+
+ The HTML markup Alt.
+
+
+ The HTML markup Archive.
+
+
+ The HTML markup Axis.
+
+
+ The HTML markup Backgroun.
+
+
+ The HTML markup BGColor.
+
+
+ The HTML markup Border.
+
+
+ The HTML markup CellPaddin.
+
+
+ The HTML markup CellSpacin.
+
+
+ The HTML markup Char.
+
+
+ The HTML markup CharOff.
+
+
+ The HTML markup Charset.
+
+
+ The HTML markup Checked.
+
+
+ The HTML markup Cite.
+
+
+ The HTML markup Class.
+
+
+ The HTML markup ClassId.
+
+
+ The HTML markup Clear.
+
+
+ The HTML markup Code.
+
+
+ The HTML markup CodeBase.
+
+
+ The HTML markup CodeType.
+
+
+ The HTML markup Color.
+
+
+ The HTML markup Cols.
+
+
+ The HTML markup ColSpan.
+
+
+ The HTML markup Compact.
+
+
+ The HTML markup Content.
+
+
+ The HTML markup Coords.
+
+
+ The HTML markup Data.
+
+
+ The HTML markup DateTime.
+
+
+ The HTML markup Declare.
+
+
+ The HTML markup Defer.
+
+
+ The HTML markup Dir.
+
+
+ The HTML markup Disabled.
+
+
+ The HTML markup DynSrc.
+
+
+ The HTML markup EncType.
+
+
+ The HTML markup Face.
+
+
+ The HTML markup For.
+
+
+ The HTML markup Frame.
+
+
+ The HTML markup FrameBorder.
+
+
+ The HTML markup Headers.
+
+
+ The HTML markup Height.
+
+
+ The HTML markup Href.
+
+
+ The HTML markup HrefLang.
+
+
+ The HTML markup Hspace.
+
+
+ The HTML markup HttpEquiv.
+
+
+ The HTML markup Id.
+
+
+ The HTML markup IsMap.
+
+
+ The HTML markup Label.
+
+
+ The HTML markup Lang.
+
+
+ The HTML markup Language.
+
+
+ The HTML markup LeftMargin.
+
+
+ The HTML markup Link.
+
+
+ The HTML markup LongDesc.
+
+
+ The HTML markup LowSrc.
+
+
+ The HTML markup MarginHeight.
+
+
+ The HTML markup MarginWidth.
+
+
+ The HTML markup MaxLength.
+
+
+ The HTML markup Media.
+
+
+ The HTML markup Method.
+
+
+ The HTML markup Multiple.
+
+
+ The HTML markup Name.
+
+
+ The HTML markup NoHref.
+
+
+ The HTML markup NoResize.
+
+
+ The HTML markup NoShade.
+
+
+ The HTML markup NoWrap.
+
+
+ The HTML markup Object.
+
+
+ The HTML markup Profile.
+
+
+ The HTML markup Prompt.
+
+
+ The HTML markup ReadOnly.
+
+
+ The HTML markup Rel.
+
+
+ The HTML markup Rev.
+
+
+ The HTML markup Rows.
+
+
+ The HTML markup RowSpan.
+
+
+ The HTML markup Rules.
+
+
+ The HTML markup Scheme.
+
+
+ The HTML markup Scope.
+
+
+ The HTML markup Scrolling.
+
+
+ The HTML markup Selected.
+
+
+ The HTML markup Shape.
+
+
+ The HTML markup Size.
+
+
+ The HTML markup Span.
+
+
+ The HTML markup Src.
+
+
+ The HTML markup StandBy.
+
+
+ The HTML markup Start.
+
+
+ The HTML markup Style.
+
+
+ The HTML markup Summary.
+
+
+ The HTML markup TabIndex.
+
+
+ The HTML markup Target.
+
+
+ The HTML markup Text.
+
+
+ The HTML markup Title.
+
+
+ The HTML markup TopMargin.
+
+
+ The HTML markup Type.
+
+
+ The HTML markup Unknown.
+
+
+ The HTML markup UseMap.
+
+
+ The HTML markup Valign.
+
+
+ The HTML markup Value.
+
+
+ The HTML markup ValueType.
+
+
+ The HTML markup Version.
+
+
+ The HTML markup Vlink.
+
+
+ The HTML markup Vspace.
+
+
+ The HTML markup Width.
+
+
+ The class provides a reader for attributes inside an HTML tag token.
+
+
+ The method returns the name of the attribute as a string.
+ The name of the attribute as a string.
+
+
+ The method returns an arbitrarily long attribute name in chunks.
+ The method returns the number of characters successfully read.
+ Offset into the attribute name to start reading characters.
+ The maximum number of characters to return.
+ Character array that will receive the attribute name.
+
+
+ The method advances to the next attribute in the tag token.
+ The method returns true if the reader advances to the first or next attribute; otherwise, false to indicate that there are no more attributes to read.
+
+
+ The method returns the attribute value as a string.
+ The method returns the attribute value as a string.
+
+
+ The method reads the current attribute value into a character array.
+ The method returns the number of characters read from the attribute value.
+ The position in the attribute value to begin reading..
+ The number of characters to read from the attribute value.
+ The character array that will receive the attribute value.
+
+
+ The property gets a value indicating whether the current attribute as an associated value.
+ The property returns true if the attribute has a value; otherwise, it returns false.
+
+
+ The property gets the current attribute identifier.
+ The method returns one of the enumeration values identifying the current attribute; or if the attribute is not an identified attribute.
+
+
+ The property gets a value indicating whether the attribute name is longer than 128 characters.
+ The property is true if the attribute name is longer than 128 characters; otherwise the property is false.
+
+
+ The property gets a value indicating whether the attribute value is longer than 128 characters.
+ The property is true if the attribute value is longer than 128 characters; otherwise the property is false.
+
+
+ The class is a forward-only parser for HTML documents.
+
+
+ The constructor initializes a new instance of the class that reads data from the specified text reader.
+ The object that contains the HTML document.
+
+
+ The constructor initializes a new instance of the class that reads data from the specified data stream using the specified encoding.
+ The object that contains the HTML document.
+
+
+ The method closes the instance and releases resources used by the instance.
+
+
+ The method releases resource used by the instance.
+ true if the method is called from the finalizer; otherwise, false.
+
+
+ The method reads an HTML tag without parsing the internal text to HTML tokens.
+ The method returns the number of characters successfully read from the input stream.
+ The starting location in the input data to start reading.
+ The number of characters to read from the input stream.
+ The character array that will receive the incoming characters.
+
+
+ The method advances to the next HTML token.
+ The method returns true if it advances to the next token; otherwise, the method returns false to indicate that there are no more tokens to read.
+
+
+ The method reads an HTML tag name as a string.
+ The method returns a string containing the HTML tag name.
+
+
+ The method returns the HTML tag name as a series of chunks in a character array.
+ The method returns the number of characters successfully read from the input stream.
+ The starting location in the input data to start reading.
+ The number of characters to read from the input stream.
+ The character array that will receive the incoming characters.
+
+
+ The method reads the text of an HTML token.
+ The method returns the number of characters successfully read from the input stream.
+ The starting location in the input data to start reading.
+ The number of characters to read from the input stream.
+ The character array that will receive the incoming characters.
+
+
+ The property gets an attribute reader that will parse the attributes of an HTML tag.
+ The property gets an instance that parses the attributes of an HTML tag.
+
+
+ The property gets the current nesting depth of the HTML document.
+ The returns the current nesting depth of the HTML document.
+
+
+ The property gets or sets a value that indicates whether the byte order mark in the HTML document is used to select the input code page.
+ The property returns true if the byte order mark should be respected; otherwise, the property returns false.
+
+
+ The property gets or sets the character encoding that is used when parsing the input stream.
+ The property gets the object that is used when parsing the input stream.
+
+
+ The parameter gets or sets a value that indicates whether the HTML stream should me normalized.
+ The parameter is true if the input HTML should be normalized; otherwise the property is false.
+
+
+ The property gets the depth delta associated with the OverlappedClose and OverlappedReopen tokens.
+ The property gets the overlapped depth.
+
+
+ The property gets the identifier for the current HTML tag.
+ The property returns one of the enumeration values indicating the identifier of the current tag, or return if the current tag cannot be identified.
+
+
+ The property gets a value indicating whether the current tag was inserted when normalizing the HTML document.
+ The property returns true if the current tag was inserted when normalizing the HTML document; otherwise, the property returns false if the current tag is present in the HTML document.
+
+
+ The property gets a value that indicates whether the current HTML tag is extremely long.
+ The property returns true if the current tag name is extremely long; otherwise, the property returns false.
+
+
+ The property gets the kind of token that the is currently processing.
+ The property returns one of the enumeration values indicating the kind of token that the is currently processing.
+
+
+ The delegate is called to enable custom filtering of specific HTML tags.
+
+
+ The class is passed to the delegate and is used to get information about the tag that caused the callback and to filter the tag as it is written to the output.
+
+
+ The method suppresses the output of the content between the tag that caused the callback to the delegate and its end tag.
+
+
+ The method suppresses the output of the tag that caused the callback to the delegate from the output of the conversion.
+
+
+ The method suppresses the output of the tag that caused the callback to the delegate from the output of the conversion and allows you to control whether output of the end tag is also suppressed.
+ Set this parameter to true to preserve the end tag. Set this parameter to false to suppress the output of both the start tag and the end tag.
+
+
+ The method causes the callback to be called for the current tag's corresponding end tag.
+
+
+ The method writes the tag that caused the callback to the output.
+
+
+ The method writes the tag that caused the callback to the output and optionally controls whether the attributes originally present are written.
+ Set this parameter to true to write the attributes originally present. Otherwise, set this parameter to false to suppress them.
+
+
+ The property gets a Boolean value indicating whether the tag that caused the callback to the delegate is an empty element tag.
+ The property returns true if the current tag is empty. Otherwise, it returns false.
+
+
+ The property gets a Boolean value indicating whether the tag that caused the callback to the delegate is an end tag.
+ The property returns true if the current tag is an end tag. Otherwise it returns false.
+
+
+ The structure is a collection of structures that represent the attributes of the HTML tag that caused the callback to the delegate.
+
+
+ The property gets the structure identified by index.
+ The zero-based index of the structure to get.
+
+
+ The class provides methods that allow you to iterate over a collection of structures.
+
+
+ Releases all resources used by .
+
+
+ The method moves the current position to the next structure.
+ The method returns true if there was another structure to which to move. Otherwise it returns false.
+
+
+ The method resets this structure.
+
+
+ The structure contains information about an attribute in the current HTML tag.
+
+
+ The static field contains a filled with empty values, which do not map to any attribute.
+
+
+ The method reads the attribute value or value part into a character array.
+ The returns the number of characters read into buffer.
+ The place in buffer at which to begin writing.
+ The maximum number of characters to read. If the end of the attribute value is reached before count of characters is read into buffer, the current method returns.
+ When this method returns, it contains the specified character array with the values between index and (index + count - 1) replaced by characters read and converted from the stored attribute value.
+
+
+ The method writes the attribute name and value to the output.
+
+
+ The method writes the attribute name to the output.
+
+
+ The method writes the attribute value to the output.
+
+
+ The enumeration contains values that represent HTML tags.
+
+
+ The HTML markup A.
+
+
+ The HTML markup Abbr.
+
+
+ The HTML markup Acronym.
+
+
+ The HTML markup Address.
+
+
+ The HTML markup Applet.
+
+
+ The HTML markup Area.
+
+
+ The HTML markup B.
+
+
+ The HTML markup Base.
+
+
+ The HTML markup BaseFont.
+
+
+ The HTML markup Bdo.
+
+
+ The HTML markup BGSound.
+
+
+ The HTML markup Big.
+
+
+ The HTML markup Blink.
+
+
+ The HTML markup BlockQuote.
+
+
+ The HTML markup Body.
+
+
+ The HTML markup BR.
+
+
+ The HTML markup Button.
+
+
+ The HTML markup Caption.
+
+
+ The HTML markup Center.
+
+
+ The HTML markup Cite.
+
+
+ The HTML markup Code.
+
+
+ The HTML markup Col.
+
+
+ The HTML markup ColGroup.
+
+
+ The HTML markup Comment.
+
+
+ The HTML markup DD.
+
+
+ The HTML markup Del.
+
+
+ The HTML markup Dfn.
+
+
+ The HTML markup Dir.
+
+
+ The HTML markup Div.
+
+
+ The HTML markup DL.
+
+
+ The HTML markup DT.
+
+
+ The HTML markup EM.
+
+
+ The HTML markup Embed.
+
+
+ The HTML markup FieldSet.
+
+
+ The HTML markup Font.
+
+
+ The HTML markup Form.
+
+
+ The HTML markup Frame.
+
+
+ The HTML markup FrameSet.
+
+
+ The HTML markup H1.
+
+
+ The HTML markup H2.
+
+
+ The HTML markup H3.
+
+
+ The HTML markup H4.
+
+
+ The HTML markup H5.
+
+
+ The HTML markup H6.
+
+
+ The HTML markup Head.
+
+
+ The HTML markup HR.
+
+
+ The HTML markup Html.
+
+
+ The HTML markup I.
+
+
+ The HTML markup Iframe.
+
+
+ The HTML markup Image.
+
+
+ The HTML markup Img.
+
+
+ The HTML markup Input.
+
+
+ The HTML markup Ins.
+
+
+ The HTML markup IsIndex.
+
+
+ The HTML markup Kbd.
+
+
+ The HTML markup Label.
+
+
+ The HTML markup Legend.
+
+
+ The HTML markup LI.
+
+
+ The HTML markup Link.
+
+
+ The HTML markup Listing.
+
+
+ The HTML markup Map.
+
+
+ The HTML markup Marquee.
+
+
+ The HTML markup Menu.
+
+
+ The HTML markup Meta.
+
+
+ The HTML markup NextId.
+
+
+ The HTML markup NoBR.
+
+
+ The HTML markup NoEmbed.
+
+
+ The HTML markup NoFrames.
+
+
+ The HTML markup NoScript.
+
+
+ The HTML markup Object.
+
+
+ The HTML markup OL.
+
+
+ The HTML markup OptGroup.
+
+
+ The HTML markup Option.
+
+
+ The HTML markup P.
+
+
+ The HTML markup Param.
+
+
+ The HTML markup PlainText.
+
+
+ The HTML markup Pre.
+
+
+ The HTML markup Q.
+
+
+ The HTML markup RP.
+
+
+ The HTML markup RT.
+
+
+ The HTML markup Ruby.
+
+
+ The HTML markup S.
+
+
+ The HTML markup Samp.
+
+
+ The HTML markup Script.
+
+
+ The HTML markup Select.
+
+
+ The HTML markup Small.
+
+
+ The HTML markup Span.
+
+
+ The HTML markup Strike.
+
+
+ The HTML markup Strong.
+
+
+ The HTML markup Style.
+
+
+ The HTML markup Sub.
+
+
+ The HTML markup Sup.
+
+
+ The HTML markup Table.
+
+
+ The HTML markup Tbody.
+
+
+ The HTML markup TD.
+
+
+ The HTML markup TextArea.
+
+
+ The HTML markup Tfoot.
+
+
+ The HTML markup TH.
+
+
+ The HTML markup Thead.
+
+
+ The HTML markup Title.
+
+
+ The HTML markup TR.
+
+
+ The HTML markup TT.
+
+
+ The HTML markup U.
+
+
+ The HTML markup UL.
+
+
+ An unknown tag was encountered.
+
+
+ The HTML markup Var.
+
+
+ The HTML markup Wbr.
+
+
+ The HTML markup Xml.
+
+
+ The HTML markup Xmp.
+
+
+ The converts HTML to enriched text.
+
+
+ The constructor creates a new object.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the byte order mark or determined by the property.
+ The property returns true if the byte order mark in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the meta tag or determined by the property.
+ The property returns true if the meta tag in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.
+
+
+ The property gets or sets a enumeration value that indicates whether headers and footers will be interpreted as text or as HTML.
+ If the property is set to , then and are interpreted as HTML and only the text that would be visible in the HTML fragment after it was rendered will be inserted into the output. Otherwise, if the property is set to , then and are interpreted as raw plain text that will be properly escaped and inserted directly into the output.
+
+
+ The conversion object transforms HTML. It is used to normalize and filter HTML, convert HTML to use a different code page, and inject text into HTML.
+
+
+ The constructor creates a new conversion object.
+
+
+ The property gets or sets a Boolean value that indicates whether output HTML will be stripped of executable scripts.
+ The property returns true if executable scripts will be removed. Otherwise, this property returns false.
+
+
+ The enumeration identifies the current token type being processed by an object.
+
+
+ Indicates that the current tag does not contain any elements, such as the <BR> tag.
+
+
+ Indicates that the current tag is the end tag of an element, such as </A>
+
+
+ Indicates that the current tag is an HTML tag inserted by HTML normalization to close an HTML element that is not the most recently opened HTML element.
+
+
+ Indicates that the current tag is an HTML tag inserted by HTML normalization to reopon an HTML element that was closed by an element.
+
+
+ Indicates that the current tag is a special HTML tag, such as a comment.
+
+
+ Indicates that the current tag is the start tag of an HTML element, such as <A>.
+
+
+ Indicates that the current token is text between an HTML start tag and an HTML end tag.
+
+
+ The class converts HTML to RTF.
+
+
+ The constructor creates a new object.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the byte order mark or determined by the property.
+ The property returns true if the byte order mark in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.If the property is set to true, but the byte order mark is not present, then the property will be used to determine the encoding.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the meta tag or determined by the property.
+ The property returns true if the meta tag in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.If the property is set to true, but the meta tag contains no encoding information, then the property will be used to determine the encoding.
+
+
+ The property gets or sets a enumeration value that indicates whether headers and footers will be interpreted as text or as HTML.
+ If the property is set to , then and are interpreted as HTML and only the text that would be visible in the HTML fragment after it was rendered will be inserted into the output. Otherwise, if the property is set to , then and are interpreted as raw plain text that will be properly escaped and inserted directly into the output.
+
+
+ The class converts HTML to plain text.
+
+
+ The constructor creates a new object.
+
+
+ The constructor creates a new object and allows you to specify the text extraction mode.
+ A enumeration value specifying whether or not to preserve formatting in extracted text.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the byte order mark or determined by the property.
+ The property returns true if the byte order mark in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.If the property is set to true, but the byte order mark is not present, then the property is used to determine the encoding.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the meta tag or determined by the property.
+ The property returns true if the meta tag in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.If the property is set to true, but the byte order mark is not present, then the property is used to determine the encoding.
+
+
+ The property gets or sets a enumeration value that indicates whether headers and footers will be interpreted as text or as HTML.
+ If the property is set to , then and are interpreted as HTML and only the text that would be visible in the HTML fragment after it was rendered will be inserted into the output. Otherwise, if the property is set to , then and are interpreted as raw plain text that will be properly escaped and inserted directly into the output.
+
+
+ The class provides methods that allow you to easily write HTML tags, HTML attribute, and text to an output HTML document.
+
+
+ The constructor creates a new object with a specified as the output.
+ The object to which to write HTML.
+
+
+ The constructor creates a new object that outputs to a given object using a given encoding.
+ The object to which to write HTML.
+ The encoding to use when writing to output.
+
+
+ The method closes the instance and releases any resources used by the instance.
+
+
+ The method disposes of the instance.
+ true if the method is not called by the finalizer; otherwise, false.
+
+
+ The method clears all buffers for this and causes any buffered data to be written to the destination object or object that it owns.
+
+
+ The method writes an HTML attribute to the output stream.
+ An that contains the attribute to write.
+
+
+ The writes the attribute specified by an enumeration value.
+ A string containing the value of the attribute to write.
+ A enumeration value identifying the attribute to write.
+
+
+ The method writes an attribute with the specified name and value.
+ The name of the attribute to write.
+ The value of the attribute.
+
+
+ The method reads an attribute value from a buffer and writes it to the output with the name specified by the id parameter.
+ The starting index in buffer.
+ The character array to write the value data from.
+ The number of characters to write.
+ A enumeration value identifying the attribute to write.
+
+
+ The method reads an attribute value from a buffer and writes it to the output with a name specified by the name parameter.
+ The number of characters to write.
+ The character array to write the value data from.
+ The name of the attribute to write.
+ The starting index in buffer.
+
+
+ The method writes the attribute name identified by id to the output.
+ A enumeration value that specifies the attribute name to write to the output.
+
+
+ The method writes an attribute name to the HTML output stream.
+ A object that contains the attribute to write to the output stream.
+
+
+ The method writes the specified attribute name to the output.
+ The attribute name to write.
+
+
+ The method writes an attribute value to the HTML output stream.
+ The object that contains the attribute to write to the HMTL output stream.
+
+
+ The method writes an attribute value to the output.
+ The attribute value to write.
+
+
+ The method reads an attribute value from a buffer and writes it to the output.
+ The number of characters to write.
+ The character array to write data from.
+ The starting index in buffer.
+
+
+ The method writes the empty element tag identified by id to the output.
+ A enumeration value specifying an empty element tag to write.
+
+
+ The method writes an empty element tag to the output.
+ The empty element tag to write.
+
+
+ The method writes the end tag identified by id to the output.
+ A enumeration value that identifies the end tag to write.
+
+
+ The method writes an end tag to the output.
+ The end tag to write.
+
+
+ The method copies the original content of an HTML element and writes it to the HTML output stream.
+ A object containing the text to write to the output stream.
+
+
+ The method writes a string containing HTML markup directly to the output, without escaping special characters.
+ The HTML markup to write.
+
+
+ The method reads HTML from a buffer and writes it directly to the output, without escaping special characters.
+ The number of characters to write.
+ The character array to write data from.
+ The starting index in buffer.
+
+
+ The method writes the start tag identified by id to the output.
+ A enumeration value that identifies the start tag to write.
+
+
+ The method writes a start tag to the output.
+ The start tag to write.
+
+
+ The method copies an HTML element, including attributes, to the HTML output stream.
+ The object that contains the element to write to the HTML output stream.
+
+
+ The method writes the text content of an HTML element to the HTML output stream.
+ The that contains the text to write to the HTML output stream.
+
+
+ The method writes text to the output.
+ The text to write.
+
+
+ The method reads text from a buffer and writes it to the output.
+ The number of characters to write.
+ The character array to write text from.
+ The starting index in buffer.
+
+
+ The enumeration contains values that identify the state of a object.
+
+
+ The object is inside a tag and has started an attribute. The object can append a value to the current attribute, start the next attribute, or write another tag or text.
+
+
+ The object is not inside a tag. The object can write a tag or text.
+
+
+ The object is inside a tag, but has not started an attribute. The object can start an attribute or write another tag or text.
+
+
+ The class extracts compressed Rich Text Format (RTF).
+
+
+ The constructor creates a new object.
+
+
+ The enumeration indicates the kind of compression that will be performed.
+
+
+ The contents of the destination stream will be compressed.
+
+
+ The contents of the destination stream will have a compression header but will not be compressed.
+
+
+ The class implements a conversion from Rich Text Format (RTF) to HTML.
+
+
+ The constructor creates a new object.
+
+
+ The property specifies whether to extract encapsulated HTML present in the input Rich Text Format (RTF) or to ignore encapsulated HTML in the input and perform normal conversion of RTF into HTML.
+ The property returns a Boolean value that indicates whether to extract encapsulated HTML present in the input.
+
+
+ The property gets a Boolean value that indicates whether the source RTF document contains encapsulated HTML.
+ The property returns true if both the property is true and the source RTF document contains encapsulated HTML. Otherwise, if either the property is false or the source RTF document does not contain encapsulated HTML, this property returns false.
+
+
+ The property gets or sets a Boolean value that indicates whether the property will be stripped of executable scripts.
+ The property returns true if executable scripts will be removed. Otherwise, the property returns false.
+
+
+ The class implements a conversion from RTF to RTF.
+
+
+ The constructor creates a new object.
+
+
+ The class implements a conversion that converts from Rich Text Format (RTF) to compressed RTF.
+
+
+ The constructor creates a new object.
+
+
+ The class implements a conversion from Rich Text Format (RTF) to text.
+
+
+ The constructor creates a new object.
+
+
+ The constructor creates a new object and allows you to specify the text extraction mode.
+ A enumeration value specifying whether or not to preserve formatting in extracted text.
+
+
+ The class is an abstract base class representing a transformation of text or other data from one format to another.
+
+
+ The method converts the entire contents of sourceStream from its format to the format specified by this object and stores the result in destinationStream.
+ The stream that contains the data to convert.
+ The stream in which to store the conversion.
+
+
+ The method converts the entire contents of sourceStream from its format to the format of destinationWriter and writes the result to destinationWriter.
+ The destination TextWriter object in which to write the converted data.
+ The Stream object that contains the data to convert.
+
+
+ The method converts the entire contents of sourceReader from its format to the format of destinationStream and stores the result in destinationStream.
+ The Stream object in which to store the converted data.
+ The TextReader object that reads the data to convert.
+
+
+ The method converts the entire contents of sourceReader from its format to the format of destinationWriter and writes the result to destinationWriter.
+ The destination TextWriter object in which to write the converted data.
+ The TextReader object that reads the data to convert.
+
+
+ The property gets or sets the internal input buffer size, in bytes, for stream input.
+ The actual read buffer size in bytes.
+
+
+ The exception is thrown when a data format error causes an unrecoverable error.
+
+
+ The constructor creates a new object with a specified message.
+ The message for this exception.
+
+
+ The constructor creates a new object that can be serialized by using info and context.
+ Describes the source and destination of the serialized stream and provides an additional caller-defined context.
+ Contains all the data that is needed to serialize or deserialize this object.
+
+
+ The constructor creates a new object from message and innerException.
+ A string that contains the error message for this object.
+ The inner exception that triggered this exception.
+
+
+ The enumeration contains values that specify how text will be extracted.
+
+
+ Indicates that the text only is to be extracted. Any formatting will be ignored.
+
+
+ Indicates that formatting will be preserved in extracted text.
+
+
+ The implements a conversion from text to HTML.
+
+
+ The constructor creates a new object.
+
+
+ The property gets or sets a Boolean value that indicates whether the encoding is detected from the byte order mark or determined by the property.
+ The property returns true if the byte order mark in the input is to be used to determine the encoding. This property returns false to indicate that the input encoding is to be determined by the property.
+
+
+ The property gets or sets a Boolean value indicating whether the output HTML will be stripped of executable scripts.
+ The property returns true if executable scripts will be removed from the output HTML. Otherwise, this property returns false.
+
+
+ The object converts from text to RTF.
+
+
+ The constructor creates a new object.
+
+
+ The object converts from text to text.
+
+
+ The constructor creates a new object.
+
+
+ The constructor creates a new object with the specified by mode.
+ A enumeration value that indicates how text will be converted.
+
+
+ The enumeration controls how text will be converted.
+
+
+ Indicates that characters will only be translated from one code page to another. In this mode, wrapping and other transformations cannot be performed. For example, no text injection will occur.
+
+
+ Indicates that input text will be parsed and new line characters will be normalized.
+
+
+
\ No newline at end of file
diff --git a/Lib/Exchange 2019 CU9/microsoft.exchange.data.transport.xml b/Lib/Exchange 2019 CU9/microsoft.exchange.data.transport.xml
new file mode 100644
index 00000000..d75ee16a
--- /dev/null
+++ b/Lib/Exchange 2019 CU9/microsoft.exchange.data.transport.xml
@@ -0,0 +1,1792 @@
+
+
+
+ Microsoft.Exchange.Data.Transport
+
+
+
+ The exception is thrown if a problem is encountered with the configuration of the computer that is running Microsoft Exchange Server 2007.
+
+
+ The constructor creates a new exception with a localized string for the error message.
+ A object to use for the error message for this object.
+
+
+ The constructor creates a new exception with the error message message.
+ The error message for this .
+
+
+ The constructor creates a new object from an inner exception.
+ The exception that caused this to be thrown.
+ A object to use for the error message for this object.
+
+
+ The constructor creates a new serializable object.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor creates a new object from an inner exception.
+ The exception that caused this to be thrown.
+ The error message for this object.
+
+
+ The namespace contains types that support the extension of the Microsoft Exchange Server 2010 transport behavior.
+
+
+ The class is the base class for classes that represent a domain for which the server accepts messages.
+
+
+ When overridden in a derived class, the constructor initializes a new instance of the class derived from the class.
+
+
+ When overridden in a derived class, the property gets a Boolean value that indicates whether the domain represented by the instance of the class derived from the class is in the Active Directory directory service forest of the server.
+ The property returns true if the domain is in the Active Directory forest of the server; otherwise, the property returns false.
+
+
+ The property gets the tenant identifier for the accepted domain.
+ The value of the property is a object.
+
+
+ When overridden in a derived class, the property gets a Boolean value that indicates whether the address book contains all recipients for the domain represented by the instance of the class derived from the class.
+ When overridden in a derived class, the property returns true if the address book contains all the recipients for the domain represented by the instance of the class derived from the class; otherwise, the property returns false.
+
+
+ The class is the base class for derived classes that represent a collection of classes that inherit from the class.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ When overridden in a derived class, the method finds in the collection the instance of the class derived from the class that represents the domain specified by the smtpAddress parameter.
+ When overridden in a derived class, the collection contains an instance of the class that represents the domain specified by the smtpAddress parameter and the method returns that instance of the class derived from the class; otherwise, the method returns null.
+ An instance of the class that represents the domain or domain part to find.
+
+
+ When overridden in a derived class, the method finds in the collection the instance of the class derived from the class that represents the domain specified by the domainName parameter.
+ When overridden in a derived class, the collection contains an instance of the class that represents the domain specified by the domainName parameter and the method returns that instance of the class derived from the class; otherwise, the method returns null.
+ A string value that contains the domain or domain part to find.
+
+
+ When overridden in a derived class, the method returns an enumerator object that represents the collection.
+ The method returns an enumerator object that can be used to iterate through the collection.
+
+
+ The class is the base class for classes that provide top-level access to the Recipient API objects for a virtual server.
+
+
+ When overridden in a derived class, the method indicates whether the address book contains the specified address.
+ The method returns true if the address book contains the address specified by the smtpAddress parameter; otherwise, the method returns false.
+ The proxy or primary address for which the method will look.
+
+
+ When overridden in a derived class, the method finds addresses in the address book that are based on the addresses specified in the recipients parameter.
+ When overridden in a derived class, the method returns an array of objects.
+ An instance of the object that contains proxy addresses, primary addresses, or both.
+
+
+ When overridden in a derived class, the method finds an address in the address book based on the address specified in the smtpAddress parameter.
+ When overridden in a derived class, the method returns an instance of the object that represents the address found.
+ An instance of the object that contains a proxy or primary address.
+
+
+ When overridden in a derived class, the method finds addresses in the address book that are based on the addresses specified in the smtpAddresses parameter.
+ When overridden in a derived class, the method returns an array of objects.
+ An instance of the object that contains proxy addresses or primary addresses, or both.
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ When overridden in a derived class, the method indicates whether the specified recipient belongs to the specified group.
+ When overridden in a derived class, the method returns true if the specified recipient is a member of the specified group; otherwise, the method returns false.
+ The proxy or primary address of the recipient.
+ The proxy or primary address of the group.
+
+
+ When overridden in a derived class, the method indicates whether the specified addresses refer to the same recipient.
+ The method returns true if the specified addresses refer to the same recipient; otherwise, the method returns false.
+ The first recipient address to compare.
+ The second recipient address to compare.
+
+
+ The class is the base class for derived classes that represent a recipient.
+
+
+ When overridden in a derived class, the method returns the Spam Confidence Level (SCL) threshold for the recipient for the action that is specified by the action parameter.
+ The value to return if no custom threshold is specified.
+ One of the valid enumeration values that specifies the action to take for messages that exceed the threshold.
+ The action parameter is not one of the valid enumeration values or the defaultValue parameter is outside the range of 0-9 and is not Int.MaxValue.
+
+
+ The method indicates whether a recipient is a blocked sender.
+ The property returns true if the sender is blocked; otherwise, it returns false.
+ The object that represents the sender's address.
+
+
+ When overridden in a derived class, the method gets a value that indicates whether messages from the recipient that is represented by this instance of the class to the recipient that is specified by the recipientAddress parameter should bypass anti-spam tests.
+ The method returns true if the address for the recipient that is specified by the recipientAddress parameter is in the list of trusted recipients for the recipient that is represented by this instance of the class or if the domain for the recipient that is specified by the recipientAddress parameter is in the list of trusted domains for the recipient that is specified by this instance of the class; otherwise, the method returns false.
+ An instance of the class that represents the recipient to check for anti-spam bypass for messages from the recipient that is represented by this instance of the class.
+
+
+ When overridden in a derived class, the method returns a value that indicates whether a message to the recipient that is specified by the senderAddress parameter to the recipient that is represented by this instance of the class should bypass anti-spam tests.
+ The method returns true if the address for the sender that is specified by the senderAddress parameter is in the list of trusted senders for the recipient that is represented by this instance of the class or if the domain for the sender that is specified by the senderAddress parameter is in the list of trusted domains for the recipient that is specified by this instance of the class; otherwise, the method returns false.
+ An instance of the class that represents the sender to check for anti-spam bypass for messages to the recipient that is represented by this instance of the class.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether the recipient should be bypassed from anti-spam processing.
+ When overridden in a derived class, the property returns true if the recipient should be bypassed from anti-spam processing; otherwise, the property returns false.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether the recipient can only receive messages from authenticated senders.
+ When overridden in a derived class, the property returns true if the recipient can only receive messages from authenticated senders; otherwise, the property returns false.
+
+
+ The property gets a recipient's Windows Live Id.
+ The property returns a that represents the recipient's Windows Live Id.
+
+
+ The exception thrown when a transient error is detected when accessing an address book.
+
+
+ The constructor initializes a new instance of the class with the specified error message.
+ The message that describes the error.
+
+
+ The constructor initializes a new instance of the class with the specified error message.
+ The message that describes the error.
+
+
+ The constructor initializes a new instance of the class with the specified error message and a reference to the inner exception that is the cause of this exception.
+ The message that describes the error.
+ The inner exception reference.
+
+
+ The constructor initializes a new instance of the class with the specified serialized data.
+ The object that contains contextual information about the source or destination.
+ The object that holds the serialized object data about the exception being thrown.
+
+
+ The constructor initializes a new instance of the class with the specified error message and a reference to the inner exception that is the cause of this exception.
+ The message that describes the error.
+ The inner exception reference.
+
+
+ The class is the class from which all agent classes derive.
+
+
+ When overridden in a derived class, the constructor initializes a new instance of the class derived from the class.
+
+
+ When overridden in a derived class, the method gets a object to mark the executing event handler to execute asynchronously.
+ When overridden in a derived class, the method returns a object that is used by an asynchronous event handler.
+
+
+ The class represents an asynchronous state object that is used by asynchronous transport agents.
+
+
+ The method is a callback to indicate that the asynchronous event handler completed execution.
+
+
+ The method initializes the current thread for use by an agent.
+
+
+ The class is the base class from which all transport agent factory classes derive.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ When overridden in a derived class, the method releases all resources used by the derived class.
+
+
+ The class is the base class for all agent managers. Agent managers provide additional properties about an agent.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The class provides a read-only interface to the mail item envelope.
+
+
+ The method returns a stream containing the mail message contents.
+ The method returns a object containing the MIME content of the message.
+
+
+ The method returns the value of an extended property that is an array or list.
+ The method returns true if the specified parameter is found; otherwise, the method returns false.
+ Name of the requested property.
+ If a property with the specified name is found, this parameter is set to a collection wrapper for the actual array or list value. If the property is not found, or if the property type does not match the type specified in the ItemT parameter, or if the actual value is null, this parameter is set to null.
+
+
+ The method returns the value of an extended property.
+ The method returns true if the specified property is found and its type matches the T parameter; otherwise, the method returns false.
+ The name of the requested property.
+ If a property with the specified name is not found or its type does not match the T parameter, this parameter is set to the default value of the type specified by the T parameter. Otherwise, the actual value is returned for immutable types; if the property is of type a cloned instance is returned; a is thrown for collections.
+
+
+ The property gets the date and time that the mail item was received for delivery.
+ The property returns the date and time that the mail item was received for delivery.
+
+
+ The property gets the order or speed at which the message should be sent by the messaging system.
+ One of the enumeration values indicating the priority for the mail item.
+
+
+ The property gets the DSN format requested for this mail message.
+ One of the enumeration values.
+
+
+ The gets the identifier for the message envelope.
+ The property returns the message envelope identifier as a string.
+
+
+ The property gets the routing address of the mail sender.
+ The property returns a object containing the routing address of the mail sender.
+
+
+ The gets the delivery method that this e-mail message comes from.
+ The returns one of the enumeration values.
+
+
+ The property gets the incoming mail message.
+ The property returns a instance containing a read-only copy of the mail message.
+
+
+ The gets the length of the message MIME stream.
+ The returns the length of the MIME data stream.
+
+
+ The property gets a value indicating whether the transport should retry delivery until the message is delivered successfully.
+ The property is true if the transport should retry delivery until the message is delivered successfully; otherwise, the property is false..
+
+
+ The property gets the original AUTH provider for the mail message.
+ The property returns the original AUTH provider as a object.
+
+
+ The property gets the HELO/EHLO string presented to the SMTP server.
+ he property returns the HELO/EHLO string presented to the SMTP server as a object.
+
+
+ The property gets the collection of recipients on the message, including to, cc and bcc recipients.
+ The property returns a instance containing the message recipients.
+
+
+ The property gets the tenant to which the item belongs.
+ he property returns object that identifies the tenant.
+
+
+ The enumeration indicates the direction in which a message is coming or going.
+
+
+ The message is coming from a Delivery Agent.
+
+
+ For an incoming message, the message comes from the pickup directory, the replay directory, a Delivery Status Notification (DSN), or the mail submission API. For an outgoing message, the message is going to a server that is not a Simple Mail Transfer Protocol (SMTP) server or it is an application message on the destination server.
+
+
+ The message is coming from or going to a mailbox.
+
+
+ The message is coming from or going to an SMTP endpoint.
+
+
+ The direction of the message cannot be determined.
+
+
+ The enumeration specifies the delivery priority of an e-mail message.
+
+
+ A higher priority than normal for delivery.
+
+
+ A lower priority than normal for delivery.
+
+
+ A normal priority for delivery.
+
+
+ The enumeration defines the domain to use when adding a recipient to a delivery queue.
+
+
+ Use the routing override domain when adding the recipient to the delivery queue.
+
+
+ Use the e-mail address domain when adding the recipient to the delivery queue.
+
+
+ The enumeration specifies the format used for Delivery Status Notification (DSN) messages.
+
+
+ Include the whole original message.
+
+
+ Include only the headers of the original message.
+
+
+ Use the default DSN format.
+
+
+ The enumeration specifies the type of Delivery Status Notification (DSN) to use.
+
+
+ An expanded DSN is used.
+
+
+ A failure DSN is used.
+
+
+ The enumeration specifies the type of Delivery Status Notification (DSN) requested.
+
+
+ A delay DSN is requested.
+
+
+ A failure DSN is requested.
+
+
+ A never DSN is requested.
+
+
+ A requested DSN type is not specified.
+
+
+ A success DSN is requested.
+
+
+ The class is the base class for derived classes that represent a Simple Mail Transfer Protocol (SMTP) recipient.
+
+
+ When overridden in a derived class, the method sets the property to the instance of the structure that is specified. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The routing domain to which mail is redirected for this recipient.
+
+
+ When overridden in a derived class, the property gets the outbound delivery method to the destination for the for this instance of the class.
+ When overridden in a derived class, the property returns one of the valid enumeration values.
+
+
+ The property gets the recipient's category.
+ The property returns a object that represents the recipient's categories.
+ Thrown when a mail recipient has been deleted.
+
+
+ The class is the base class for derived classes that represent a collection of objects that inherit from the class.
+
+
+ When overridden in a derived class, the method adds the specified object to the collection.
+ The address to add to the collection.
+ The collection is read-only.
+
+
+ When overridden in a derived class, the method removes all items from the collection.
+
+
+ When overridden in a derived class, the method removes a recipient from the collection based on the specified .
+ The method returns true if the recipient specified by the recipient parameter existed in the collection and the method successfully removed the recipient from the collection; otherwise, the method returns false.
+ The recipient to remove.
+
+
+ When overridden in a derived class, the method removes a recipient from the collection based on the specified .
+ The method returns an integer value that represents the number of recipients removed from the collection.
+ The Simple Mail Transfer Protocol (SMTP) address to remove.
+
+
+ When overridden in a derived class, the method removes a recipient from the collection based on the specified .
+ The method returns true if the recipient existed in the collection and the recipient was successfully removed; otherwise, the method returns false.
+ One of the values.
+ One of the values.
+ The recipient to remove.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether recipients can be added to the collection.
+ The property returns true ifthis instance of the class allows the addition new recipients; otherwise, the property returns false.
+
+
+ The structure provides properties and methods for enumerating an instance of the class.
+
+
+ The method releases all resources used by this instance of the class.
+
+
+ The method sets the enumerator to the first element in the collection.
+
+
+ The class is a base class from which classes derive that implement methods and properties for managing the Internet Protocol (IP) Allow/Deny list of the server.
+
+
+ When overridden in a derived class, the method adds a new entry to the Internet Protocol (IP) Allow/Deny list that returns a Deny status.
+ The IP address of the entry.
+ The length of time between when the entry is added and when the entry expires.
+ Optional comments associated with the entry.
+
+
+ When overridden in a derived class, the method determines whether the specified IP address is on the Allow list, the Deny list, or neither list.
+ The method returns one of the valid enumeration values.
+ The IP address to check.
+
+
+ The class is the base class for derived classes that represent the envelope of an e-mail message.
+
+
+ When overridden in a derived class, the method gets a readable stream that contains the Multipurpose Internet Mail Extensions (MIME) content for the derived class.
+ When overridden in a derived class, the method returns a read-only stream.
+
+
+ When overridden in a derived class, the method gets a writeable stream that contains the Multipurpose Internet Mail Extensions (MIME) content for the derived class.
+ When overridden in a derived class, the method returns a write-only stream.
+
+
+ When overridden in a derived class, the method specifies that the message will remain in queue until it is delivered, without expiring or generating a non-delivery report (NDR). Executing the method sets the value of the property to true. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+
+
+ When overridden in a derived class, the method gets a value that indicates the inbound delivery method for this instance of the class.
+ The property returns one of the valid enumeration values.
+
+
+ When overridden in a derived class, the property returns a Boolean value that indicates whether the message is marked for special delivery. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The property returns true if Transport will continue to try to deliver the message until it is successful, without a message expiration or non-delivery report (NDR); otherwise, the property returns false.
+
+
+ Returns .
+
+
+ The property gets the tenant to which the message belongs.
+ The property returns a that represents the tenant identifier. An empty GUID is returned for unscoped mail.
+ Thrown when the MailItem has already been deferred.
+
+
+ The enumeration specifies the lists on which an Internet Protocol (IP) address is found.
+
+
+ The specified IP address is on the Allow list.
+
+
+ The specified IP address is on the Deny list.
+
+
+ The specified IP address is not on the Allow list or the Deny list.
+
+
+ The class is a collection of e-mail recipients.
+
+
+ The method determines if the specified address is in the collection.
+ The method returns true if the specified routing address is present in the collection; otherwise, the method returns false.
+ The routing address to locate in the collection.
+
+
+ The method returns an enumerator that can be used to iterate over the items in the collection.
+ The method returns an instance that can be used to iterate over the items in the collection.
+
+
+ The property gets the number of items in the colleciton.
+ The property the number of items in the collection.
+
+
+ The gets the envelope recipient at the specified index in the collection.
+ The returns the at the specified index.
+ The index of the object to return.
+
+
+ The enumeration defines categories for e-mail recipients.
+
+
+ The e-mail recipient is managed by the server.
+
+
+ The e-mail recipient is in a different organization from the processing server.
+
+
+ The e-mail recipient is in a same organization as the processing server.
+
+
+ The enumeration specifies types of recipients.
+
+
+ The recipient is a contact.
+
+
+ The recipient is a distribution list.
+
+
+ The recipient is a dynamic distribution list.
+
+
+ The recipient is a public folder.
+
+
+ The recipient is of an unknown type.
+
+
+ The recipient is a user.
+
+
+ The class is the base class for derived classes that provide information about remote domains that the administrator has configured.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ Returns .
+
+
+ The class is the base class for derived classes that represent a collection of objects that inherit from the class.
+
+
+ When overriden in a derived class, the constructor creates a new instance of the class that is derived from the class.
+
+
+ When overridden in a derived class, the method returns an instance of the class that represents the domain in the Simple Mail Transfer Protocol (SMTP) address that is specified by the smtpAddress parameter.
+ An instance of the class that contains the domain for which to search.
+
+
+ When overridden in a derived class, the method returns an instance of the class that represents the domain that is specified by the domainName parameter.
+ The Simple Mail Transfer Protocol (SMTP) domain name for which to search.
+
+
+ The structure represents an address that is used to route data.
+
+
+ The method initializes a new instance of the structure by using the specified address.
+ The address value.
+
+
+ The method initializes a new instance of the structure by using the specified local part and domain part of an address.
+ The domain part of the address.
+ The local part of the address.
+
+
+ The field contains an empty instance of the structure that contains null for the address.
+
+
+ The field contains an instance of the structure that represents a null reverse path address.
+
+
+ The method compares this instance of the structure with the specified object.
+ The following table lists the return values for the method.ValueMeaningLess than zeroThe address value of this instance of the structure is less than the address value of the structure specified.ZeroThe address value of this instance of the structure is equal to the address value of the structure specified.Greater than zeroThe address value of this instance of the structure is greater than the address value of the structure specified.
+ An object that evaluates a structure or string.
+
+
+ The method compares this instance of the structure with the specified object.
+ The following table lists the return values for the method.ValueMeaningLess than zeroThe address value of this instance of the structure is less than the address value of the structure specified.ZeroThe address value of this instance of the structure is equal to the address value of the structure specified.Greater than zeroThe address value of this instance of the structure is greater than the address value of the structure specified.
+ An instance of the structure against which to compare.
+
+
+ The method determines whether this instance of the structure is equal to the object specified.
+ The method returns a value of true if the object specified by the address parameter is an instance of the structure and the address is equal to the address in this instance of the structure; otherwise, the method returns a value of false.
+ The object against which to compare this instance of the structure.
+
+
+ The property gets a value that indicates whether the address specified by the address parameter is valid as a Simple Mail Transfer Protocol (SMTP) address.
+ The property returns a value of true if the data that is contained in the structure is valid as a Simple Mail Transfer Protocol (SMTP) address; otherwise, the property returns a value of false.
+ The address to evaluate.
+
+
+ The method compares two specified instances of the structure for equality.
+ The method returns a value of true if the two instances of the structure are equal; otherwise, the method returns a value of false.
+ The first instance of the structure to compare.
+ The second instance of the structure to compare.
+
+
+ The method converts the structure specified into a string that is equivalent to the address.
+ The instance the structure to convert.
+
+
+ The method converts the string specified into an instance of the structure.
+ The string to convert.
+
+
+ The method compares two specified instances of the structure for inequality.
+ The method returns a value of true if the two instances of the structure are not equal; otherwise, the method returns a value of false.
+ The first instance of the structure to compare.
+ The second instance of the structure to compare.
+
+
+ The method converts the string representation of a Simple Mail Transfer Protocol (SMTP) address to an equivalent instance of the structure.
+ The Simple Mail Transfer Protocol (SMTP) address to convert.
+
+
+ The property gets the domain part of the address.
+ The property returns a string that contains the domain part of the address or null if the address is invalid.
+
+
+ The property gets a value that indicates whether the data is valid as a Simple Mail Transfer Protocol (SMTP) address.
+ The property returns a value of true if the data that is contained in the structure is valid as a Simple Mail Transfer Protocol (SMTP) address; otherwise, the property returns a value of false.
+
+
+ The property gets the local part of the address.
+ The property returns a string that contains the local part of the address or null if the address is invalid.
+
+
+ The structure represents an Simple Mail Transfer Protocol (SMTP) domain to use when you are overriding the default routing for a recipient. This type was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+
+
+ The constructor initializes a new instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The name of the SMTP domain to route to.
+
+
+ The constructor initializes a new instance of the RoutingDomain class to the specified domain and type.
+ The string representation of the domain type such as "Smtp".
+ The domain value.
+ Thrown if the domain is invalid, if the domain is null or empty, if the type parameter is null or empty, or if the type parameter contains invalid characters.
+
+
+ The field contains an empty instance of the structure that contains null for the domain. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+
+
+ The field returns a constant string with the value of "smtp".
+
+
+ The method compares this instance of the structure to the specified object. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns a 32-bit signed integer that indicates the lexical relationship between the two comparands.
+ An object that evaluates to a structure.
+
+
+ The method compares this instance of the structure to the specified instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns a 32-bit signed integer that indicates the lexical relationship between the two comparands.
+ An instance of the structure against which to compare.
+
+
+ The method determines whether this instance of the structure is equal to the object that is specified. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns true if the compared domains are equal; otherwise, the method returns false.
+ The object against which to compare this instance of the structure.
+
+
+ The method determines whether this instance of the structure is equal to the domain that is represented by the specified instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns true if the compared domains are equal; otherwise, the method returns false.
+ The instance of the structure against which to compare this instance of the structure.
+
+
+ The method returns the domain part from the specified instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns an instance of the structure that represents the domain part of the specified instance of the structure if the domain part is valid; otherwise, the method returns the value.
+ The instance of the structure from which to get the domain part.
+
+
+ The method indicates whether the domain is of type Smtp.
+ The method returns true if the domain is of type Smtp; otherwise, it returns false.
+
+
+ The method evaluates the validity of the domain that is represented by this instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns true if the domain is a valid Simple Mail Transfer Protocol (SMTP) domain; otherwise, the method returns false.
+
+
+ The method compares two specified instances of the structure for equality. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns a value of true if the two instances of the structure are equal; otherwise, the method returns a value of false.
+ The first instance of the structure to compare.
+ The second instance of the structure to compare.
+
+
+ The method compares two specified instances of the structure for inequality. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns a value of true if the two instances of the structure are not equal; otherwise, the method returns a value of false.
+ The first instance of the structure to compare.
+ The second instance of the structure to compare.
+
+
+ The method converts the string representation of a Simple Mail Transfer Protocol (SMTP) domain to an equivalent instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns an instance of the structure that represents the specified SMTP domain if the specified domain is valid; otherwise, the method throws a System.FormatException exception.
+ The SMTP domain to convert.
+
+
+ The method converts the string representation of a Simple Mail Transfer Protocol (SMTP) domain to an equivalent instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The method returns a value of true if the specified domain is valid; otherwise, the method returns a value of false.
+ The SMTP domain to convert.
+ When this method returns, the parameter routingDomain contains an instance of the structure that represents the domain that is specified by the domain parameter. This parameter is passed uninitialized.
+
+
+ The property gets the name of the domain that is represented by this instance of the structure. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+ The property returns a string value that contains the name of the domain or an empty string.
+
+
+ The property gets the domain type.
+ The property returns the domain type as a object.
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ Returns .
+
+
+ The class overrides the default routing for a recipient.
+
+
+ The constructor initializes a new instance of the class.
+ Defines the domain to use when adding a recipient to a delivery queue.
+ An Simple Mail Transfer Protocol (SMTP) domain to use when overriding the default routing for a recipient.
+
+
+ Returns .
+
+
+ Returns .
+
+
+ The property defines the domain to use when adding a recipient to a delivery queue.
+ One of the enumeration values.
+
+
+ The property gets an Simple Mail Transfer Protocol (SMTP) domain to use when overriding the default routing for a recipient.
+ The property returns a instance that specifies the Simple Mail Transfer Protocol (SMTP) domain to use when overriding the default routing for a recipient.
+
+
+ The class is the base class for classes that represent a Simple Mail Transfer Protocol (SMTP) server.
+
+
+ When overridden in a derived class, the method submits an e-mail message for delivery by this Simple Mail Transfer Protocol (SMTP) server.
+ An instance of the class that represents the e-mail message to submit for delivery.
+
+
+ The enumeration indicates actions that may be taken on a message that has a high spam confidence level.
+
+
+ Delete the message without sending a Delivery Status Notification (DSN) to the sender.
+
+
+ Move the message to quarantine for later review.
+
+
+ Reject the message and send a DSN to the sender.
+
+
+ The namespace contains types that support the extension of Microsoft Exchange Server 2010 delivery agents.
+
+
+ The class provides data for connection closing events.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The event handler represents the method that handles connection close events.
+
+
+ The class provides data for the connection close events.
+
+
+ Initializes a new instance of the class.
+
+
+ The method ends a network connection.
+ The SMTP response from the connection.
+
+
+ The class provides data for mail delivery events.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The property gets a mail item for the queue associated with the request.
+ A instance for the queue associated with the event.
+
+
+ The represents the method that handles mail delivery events.
+
+
+ The class provides data for mail delivery events.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ When overridden in a derived class, the method indicates that a transient error has been encountered during the delivery.
+ The SMTP response to send.
+
+
+ When overridden in a derived class, the method indicates that a permanent failure has occurred during delivery.
+ The SMTP response to send.
+
+
+ When overridden in a derived class, the method acknowledges successful delivery to all recipients of a mail item.
+ The SMTP response to send.
+
+
+ When overridden in a derived class, the method indicates that a transient error has been encountered during the delivery to a specific recipient of a mail item.
+ The SMTP response to send.
+ The recipient of the message with the transient error.
+
+
+ When overridden in a derived class, the method indicates that delivery of a mail item to a specific recipient has failed.
+ The SMTP response to send.
+ The recipient to whom delivery has failed.
+
+
+ When overridden in a derived class, the method indicates that delivery of a mail item to a specific recipient has succeeded.
+ The SMTP response to send.
+ The recipient of the mail message.
+
+
+ When overridden in a derived class, the method causes the remote delivery queue to enter the retry state with the specified SMTP response as the last error.
+ The SMTP response to send as the last error on the delivery queue.
+
+
+ When overridden in a derived class, the method causes the remote delivery queue to enter the retry state with the specified SMTP response as the last error and the specified retry interval.
+ The SMTP response to send as the last error on the delivery queue.
+ The interval between delivery retries.
+
+
+ When overridden in a derived class, the method causes all messages in the remote delivery queue to fail with the specified response.
+ The recipient status to send.
+
+
+ The method ends a network connection and restarts delivery processing.
+ The SMTP response.
+
+
+ The class is the base class for all classes that handle delivery agent events.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The event raised when mail deliver connection is closed.
+
+
+ The event raised when a message is ready to be delivered.
+
+
+ The event raised when the delivery agent is opened for mail delivery.
+
+
+ The class produces instances of the class used to extend transport behavior.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The method creates a new instance for the specified server.
+ A instance.
+ The SMTP mail server that delivery agent handles messages from.
+
+
+ The class manages instances of the class.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The parameter gets the mail protocol supported by the managed delivery agents.
+ The mail protocol supported by the managed delivery agents.
+
+
+ The class provides data for connection open events.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The property gets a mail item for delivery.
+ A instance for the queue associated with the event.
+
+
+ The parameter gets the next domain associated with the event.
+ A instance.
+
+
+ The delegate represents the method that will handle open connection events.
+
+
+ The class provides data for open connection events.
+
+
+ The constructor initializes a new instance of the
+
+
+ When overridden in a derived class, the method causes the remote delivery queue to enter the retry state with the specified last error.
+ The last error to report for the delivery queue.
+
+
+ When overridden in a derived class, the method causes the remote delivery queue to enter the retry state with the specified last error and retry interval.
+ The last error to report for the delivery queue.
+ The retry interval.
+
+
+ The namespace contains types that support creating, reading, writing, and modifying e-mail message..
+
+
+ The type represents an attachment to a object.
+
+
+ The method gets a readable stream that contains the contents of the attachment.
+ The stream from which the decoded part of the content can be read.
+
+
+ The property gets or sets a valid value that specifies whether the attachment is inline with the message contents or a regular attachment.
+ The property returns one of the valid values.
+
+
+ The property gets a value that indicates whether the attachment is an OLE object.
+ The property returns true if the attachment is an OLE object; otherwise, the property returns false.
+
+
+ The property gets the for the attachment.
+ The property returns the for the current instance of the class or null for Transport Neutral Encapsulation Format (TNEF) attachments.
+
+
+ The class represents a collection of objects.
+
+
+ The method adds a new object to the collection by using the file name specified by the fileName parameter.
+ The file name for the attachment to add.
+
+
+ The method adds a new object to the collection by using the file name specified by the fileName parameter and the content type specified by the contentType parameter.
+ The file name for the attachment to add to the collection.
+ The content type for the attachment to add to the collection.
+
+
+ The method removes all elements from the collection.
+
+
+ The method removes an element from the collection based on the object specified by the attachment parameter.
+ The method returns true if the object specified by the attachment parameter existed in the collection and the method successfully removed the attachment from the collection; otherwise, the method returns false.
+ The attachment to remove from the collection.
+
+
+ The property gets or sets the element in the specified index in the collection.
+ The zero-based index of the element in the collection to get or set.
+
+
+ The structure provides properties and methods that enable the enumeration of an instance of the class.
+
+
+ The method releases all resource used by this instance of the class.
+
+
+ The method advances the enumerator to the next element in the collection.
+ The method returns true if the operation was successful; otherwise, the method returns false.
+
+
+ The method sets the enumerator to the first element in the collection.
+
+
+ The property gets the current element in the collection.
+ The method returns an instance of the class.
+
+
+ The enumeration indicates whether an attachment is displayed in line with message content.
+
+
+ An attachment inline with the message content.
+
+
+ An attachment attached to the message.
+
+
+ The type represents the primary content of an e-mail message.
+
+
+ Returns .
+
+
+ The method gets a readable stream that contains the contents of the body without content transfer encoding.
+ The method automatically removes the content transfer encoding from the returned stream.
+
+
+ The method gets a stream into which you can write new content by using the specified character set.
+ The character set to use to encode the new content.
+
+
+ The method gets a readable stream that contains the contents of the body.
+ The stream from which the decoded part of the content can be read.
+
+
+ The enumeration specifies the format for the body of a message.
+
+
+ The body is in HTML format.
+
+
+ The body does not exist.
+
+
+ The body is in Rich Text Format (RTF).
+
+
+ The body is in plaintext format.
+
+
+ The class represents an e-mail message.
+
+
+ The method creates a new instance of the class by using the specified .
+ One of the valid enumeration values that specify the format for the body of the e-mail message.
+
+
+ The method creates a new instance of the class by using the specified .
+ A that contains message data.
+
+
+ The method creates a new instance of the class by using the specified stream.
+ A readable stream that contains message data.
+
+
+ The method creates a new instance of the class by using the specified and createAlternative value.
+ One of the valid enumeration values that specify the format for the body of the e-mail message.
+ A Boolean value that indicates whether alternative body text should be created when the bodyFormat parameter value is set to .
+
+
+ The method creates a new instance of the class by using the specified , createAlternative parameter value, and charsetName parameter value.
+ A string value that indicates the character set to use for the body of the message.
+ One of the valid enumeration values that specify the format for the body of the e-mail message.
+ A Boolean value that indicates whether alternative body text should be created when the bodyFormat parameter value is set to .
+
+
+ The method releases all resources used by the .
+
+
+ The method releases the unmanaged resources used by the and optionally releases the managed resources.
+ True to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ The method collapses and reorders the Multipurpose Internet Mail Extensions (MIME) hierarchy for the message.
+
+
+ The property gets or sets the date and time that the message is sent.
+ The property returns a coordinated universal time (UTC) DateTime value.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether the message is an interpersonal message.
+ When overridden in a derived class, the property returns true if the message is interpersonal; otherwise, it return false.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether the message is encrypted or encapsulated in a format that the class cannot parse.
+ When overridden in a derived class, the property returns true if the message is encrypted or in a format that the class cannot parse; otherwise, the property returns false.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether the message is a system message.
+ When overridden in a derived class, the property returns true if the message is a system message; otherwise, the property returns false.
+
+
+ When overridden in a derived class, the property gets a value that indicates the type of security for the message.
+ When overridden in a derived class, the property returns one of the enumeration values.
+
+
+ When overridden in a derived class, the property gets the underlying for the message.
+ When overridden in a derived class, the property returns the underlying for the message or null for embedded Multipurpose Internet Mail Extensions (MIME) and Transport Neutral Encapsulation Format (TNEF) messages.
+
+
+ When overriden in a derived class, the property gets the underlying for the message.
+ When overridden in a derived class, the property returns the underlying MimePart for the message or null for embedded Transport Neutral Encapsulation Format (TNEF) messages.
+
+
+ The type represents a single recipient of a class message.
+
+
+ The method initializes a new instance of the class by using the specified values for the display name and the Simple Mail Transfer Protocol (SMTP) address of the recipient.
+ The SMTP address for the recipient.
+ The name to use as the friendly display name for the recipient.
+
+
+ The class represents a collection of objects.
+
+
+ The method adds to the collection the object specified by the recipient parameter.
+ The object to add to the collection.
+
+
+ The method removes all elements from the collection.
+
+
+ The method removes an element from the collection based on the object specified by the recipient parameter.
+ The method returns true if the object specified by the recipient parameter existed in the collection and the method successfully removed the recipient from the collection; otherwise, the method returns false.
+ The attachment to remove from the collection.
+
+
+ The property gets the element at the specified index in the collection.
+ The zero-based index of the element to get in the collection.
+
+
+ The structure provides properties and methods that enable the enumeration of an instance of the class.
+
+
+ The method releases all resources used by this instance of the class.
+
+
+ The method sets the enumerator to the first element in the collection.
+
+
+ The property gets the current element in the collection.
+ The method returns an instance of the class.
+
+
+ The enumeration specifies the importance of a message.
+
+
+ A message of high importance.
+
+
+ A message of low importance.
+
+
+ A message of normal importance.
+
+
+ The enumeration specifies the security category for a message.
+
+
+ Message is signed by using Secure/Multipurpose Internet Mail Extensions (S/MIME) or Pretty Good Privacy (PGP).
+
+
+ Message is encrypted by using S/MIME, PGP, or Microsoft Rights Management Services.
+
+
+ Message is neither signed nor encrypted.
+
+
+ Message is base-64 encoded and signed by using S/MIME.
+
+
+ The enumeration specifies the priority of a message.
+
+
+ Nonurgent priority.
+
+
+ Normal priority (default).
+
+
+ Urgent priority.
+
+
+ The enumeration specifies the sensitivity of a message.
+
+
+ Company confidential sensitivity.
+
+
+ No sensitivity specified (default).
+
+
+ Personal sensitivity.
+
+
+ Private sensitivity.
+
+
+ The namespace contains types that support the extension of the Microsoft Exchange Server 2007 transport routing behavior.
+
+
+ The delegate represents the method that will handle the event of a type that is derived from the class.
+
+
+ The class provides data for the event.
+
+
+ The class provides data for the events.
+
+
+ The class is passed to the and events.
+
+
+ When overridden in a derived class, the method reverts the contents of the current to the original contents and defers processing of the .
+ The minimum time to wait before reprocessing the .
+
+
+ When overridden in a derived class, the method reverts the contents of the current to the original contents and defers processing of the .
+ The reason for deferring the .
+ The minimum time to wait before reprocessing the .
+
+
+ The method deletes the current without sending a Delivery Status Notification (DSN).
+
+
+ When overridden in a derived class, the method splits a into two branches, removing recipients from and adding recipients to one of the copies of the .
+ An array that contains one or more structures that contain the recipient or recipients to remove and the recipient or recipients to add.
+
+
+ The method splits a into two branches.
+ The list of recipients to use in the first branch. All other recipients are split off to the second branch.
+
+
+ The class provides data for the method.
+
+
+ The constructor initializes a new instance of the structure.
+ The to remove and replace with new recipients.
+ The recipients to add.
+
+
+ The constructor initializes a new instance of the structure.
+ The code to use for the operation.
+ The to remove and replace with new recipients.
+ The recipients to add.
+
+
+ The delegate represents the method that will handle the event of a type that is derived from the class. This type was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+
+
+ The class provides data for the event. This type was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+
+
+ The method gets the routing parameters for a specified recipient.
+ Returns .
+ Recipient for which RoutingOverride is to be determined
+
+
+ Returns .
+
+
+ The method sets the routing parameters for a recipient to the specified RoutingOverride.
+ Routing Override parameters. The property corresponds to the routing domain to which mail is redirected, to reset RoutingOverride pass null for the routingOverride.
+ Recipient to which RoutingOverride is applied.
+
+
+ The delegate represents the method that will handle the event of a type derived from the class.
+
+
+ The class provides data for the event.
+
+
+ The class is the base class from which all transport agents derive.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The event occurs after the server performs content conversion, if it is required.
+
+
+ The event occurs after all the recipients of the message have been resolved and before routing is determined. This member was introduced in Microsoft Exchange Server 2007 Service Pack 1 (SP1).
+
+
+ The event occurs after the server routes the message to the next hop and before it performs content conversion, if it is required.
+
+
+ The event occurs after the message is taken off the submit queue.
+
+
+ The class produces instances of the class that are used to extend transport behavior.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ When overridden in a derived class, the method returns an instance of a routing agent.
+ The server on which the routing agent will operate.
+
+
+ The delegate represents the method that will handle the OnSubmittedMessage event of a type derived from the class.
+
+
+ The class provides data for the event.
+
+
+ The namespace contains types that support the extension of the Microsoft Exchange Server 2007 transport SMTP behavior.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event of a class that derives from the class.
+
+
+ The enumeration indicates the type of authentication that was used for the connection to the remote server.
+
+
+ The authentication type could not be determined. This usually means that the connection is from the Internet.
+
+
+ The remote server authenticated as a server in the organization.
+
+
+ The remote server authenticated as a delegated partner.
+
+
+ The enumeration specifies the type of contents that the body of a message contains.
+
+
+ The body contains binary Multipurpose Internet Mail Extensions (MIME) content.
+
+
+ The body contains eight-bit MIME content.
+
+
+ The type of content in the body is not specified.
+
+
+ The body contains seven-bit content.
+
+
+ The class provides data for the events.
+
+
+ The delegate represents the method that will handle the event of a class that derives from the class.
+
+
+ Classes derived from the class provide data for the event.
+
+
+ When overridden in a derived class, the method rejects the Simple Mail Transfer Protocol (SMTP) connection by using the response specified in the response parameter.
+ The response to send to the client for this disconnection.
+
+
+ The class provides data for the events.
+
+
+ The delegate represents the method that will handle the event of a class that derives from the class.
+
+
+ The class provides data for the event.
+
+
+ The property gets one of the enumeration values that indicates the reason for the disconnection.
+ The property returns one of the valid enumeration values.
+
+
+ The delegate represents the method that will handle the event of a class derived from the class.
+
+
+ Classes derived from the class provide data for the event.
+
+
+ The enumeration indicates why the event fired.
+
+
+ This server or one of its agents requested that the session be disconnected.
+
+
+ The disconnect was initiated locally.
+
+
+ The sender sent the QUIT verb.
+
+
+ The remote connector initiated the disconnect.
+
+
+ The connection to the sender was lost.
+
+
+ The connection to the sender timed out.
+
+
+ Too many protocol or authentication errors occurred.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event of a class that derives from the class.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in classes derived from the class.
+
+
+ Classes derived from the class provide data for the events.
+
+
+ The method rejects the authenticated session by sending a response specified by the response parameter.
+ The response to return to the caller.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event of a class that derives from the class.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in a class that derives from the class.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in classes that derive from the class.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in classes that derive from the class.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in classes that derive from the class.
+
+
+ The class provides data to the event.
+
+
+ The delegate represents the method that will handle the event in classes that derive from the class.
+
+
+ The enumeration specifies values to return when parsing a Simple Mail Transfer Protocol (SMTP) command.
+
+
+ Parsing is complete for the command.
+
+
+ A non-protocol error has occurred.
+
+
+ More data is required to parse the command.
+
+
+ A protocol-level error has occurred.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in a class that derives from the class.
+
+
+ Classes that derive from the class provide data for the event.
+
+
+ The class is the base class for all event source classes.
+
+
+ When overridden in a derived class, the method rejects the Simple Mail Transfer Protocol (SMTP) command by using the response specified by the response parameter.
+ The response to send to the client for this command.
+
+
+ Classes that derive from the class provide data for the events.
+
+
+ The class is the base class for all event source classes.
+
+
+ When overridden in a derived class, the method closes the current connection and cleans up the associated session state.
+
+
+ The class is the base class for classes passed to the receive events.
+
+
+ When overridden in a derived class, the method quarantines the received message for the recipients specified by the recipients parameter by using the reason specified by the quarantineReason parameter.
+ The value to put in the quarantine Delivery Status Notification (DSN) with each quarantined recipient for diagnostic purposes.
+ A collection of objects that specify the list of recipients for which the message should be quarantined.
+
+
+ When overridden in a derived class, the method rejects the complete message by sending a Simple Mail Transfer Protocol (SMTP) response specified by the response parameter.
+ An instance of the class that specifies the response to send to the client for the message.
+
+
+ The class provides data for the event.
+
+
+ The property gets or sets one of the enumeration values that specifies the results of the parsing.
+ The property returns one of the valid enumeration values.
+
+
+ The property gets or sets an instance of the class that is associated with the event to which this instance of the class was passed.
+ The property returns one of the valid enumeration values that specifies the response being returned for the rejected command.
+
+
+ The delegate represents the method that will handle the event in a class that derives from the class.
+
+
+ Classes derived from the class provide data for the event.
+
+
+ The class provides data for the event.
+
+
+ The delegate represents the method that will handle the event in classes that derive from the class.
+
+
+ The class is the base class for agent classes that use Simple Mail Transfer Protocol (SMTP) receive events.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) AUTH command and before the server responds to the command.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) connection.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) DATA command.
+
+
+ The event occurs when a Simple Mail Transfer Protocol (SMTP) connection to the server is closed.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) EHLO command.
+
+
+ The event occurs when the server responds to a Simple Mail Transfer Protocol (SMTP) AUTH command.
+
+
+ The event occurs when the server reaches the end of data for a Simple Mail Transfer Protocol (SMTP) message.
+
+
+ The event occurs when the server reaches the end of the headers for a Simple Mail Transfer Protocol (SMTP) message.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) HELO command.
+
+
+ The occurs when the server receives a Simple Mail Transfer Protocol (SMTP) HELP command.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) MAIL command.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) NOOP command.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) RCPT command.
+
+
+ The event occurs when any other event rejects a command or message.
+
+
+ The event occurs when the server receives a Simple Mail Transfer Protocol (SMTP) RSET command.
+
+
+ The class produces instances of the class that are used to extend Simple Mail Transfer Protocol (SMTP) transport behavior.
+
+
+ The constructor initializes a new instance of the class.
+
+
+ When overridden in a derived class, the method creates an instance of a Simple Mail Transfer Protocol (SMTP) transport agent.
+ The server on which the agent will work.
+
+
+ The structure provides properties and methods for responding to Simple Mail Transfer Protocol (SMTP) requests.
+
+
+ The constructor initializes a new instance of the structure.
+ The status code.
+ The enhanced status code.
+ Reply text to send to the caller.
+
+
+ The field gets an instance of the structure that represents a 550 5.7.1 Anonymous client does not have permission to send as this sender response.
+
+
+ The field gets an instance of the structure that represents a 503 5.5.1 Bad sequence of commands response.
+
+
+ The field gets an instance of the structure that represents a 421 4.3.2 System not accepting network messages response.
+
+
+ The field gets an instance of the structure that represents a 421 4.4.1 Connection timed out response.
+
+
+ The field gets an instance of the structure that represents a 451 4.3.2 System not accepting network messages response.
+
+
+ The field gets an instance of the structure that represents an empty, invalid response.
+
+
+ The field gets an instance of the structure that represents a 452 4.3.1 Insufficient system resources response.
+
+
+ The field gets an instance of the structure that represents a 501 5.1.3 Invalid address (recipient) response.
+
+
+ The field gets an instance of the structure that represents a 501 5.5.4 Invalid arguments response.
+
+
+ The field gets an instance of the structure that represents a 554 5.6.0 Invalid Content response.
+
+
+ The field gets an instance of the structure that represents a 554 5.4.4 Unable to route due to invalid recipient address response.
+
+
+ The field gets an instance of the structure that represents a 421 4.4.0 Remote server response was not RFC conformant response.
+
+
+ The field gets an instance of the structure that represents a 501 5.1.7 Invalid Address (Sender) response.
+
+
+ The field gets an instance of the structure that represents a 250 2.1.0 Sender OK response.
+
+
+ The field gets and instance of the structure that represents a 554 5.6.1 Messages of type message/partial are not supported response.
+
+
+ The field gets an instance of the structure that represents a 552 5.3.4 Message size exceeds fixed maximum message size response.
+
+
+ The field gets an instance of the structure that represents a 250 2.0.0 OK response.
+
+
+ The field gets an instance of the structure that represents a 550 5.1.1 User unknown response.
+
+
+ The field gets an instance of the structure that represents a 250 2.1.5 Recipient OK response.
+
+
+ The field gets an instance of the structure that represents a 250 2.1.5 Recipient Address was Expanded response.
+
+
+ The field gets an instance of the structure that represents a 550 5.7.1 Client does not have permission to send as this sender (Sender) response.
+
+
+ The field gets an instance of the structure that represents a 550 5.7.1 Client does not have permission to send on behalf of the from address (Sender) response.
+
+
+ The field gets an instance of the structure that represents a 421 Service not available, closing transmission channel response.
+
+
+ The field gets an instance of the structure that represents a 550 5.7.1 Client does not have permission to submit to this server (Sender) response.
+
+
+ The field gets an instance of the structure that represents a 250 Success response.
+
+
+ The field gets an instance of the structure that represents a 550 5.3.5 System incorrectly configured response.
+
+
+ The field gets an instance of the structure that represents a 451 Timeout waiting for client input response.
+
+
+ The field gets an instance of the structure that represents a 554 5.4.4 Unable to route response.
+
+
+ The field gets an instance of the structure that represents a 500 5.3.3 Unrecognized command response.
+
+
+ The field gets an instance of the structure that represents a 501 5.5.4 Unrecognized parameter response.
+
+
+ The field gets an instance of the structure that represents a 550 5.7.1 Command not allowed response.
+
+
+ The method compares the current instance of the structure to the object specified by the comparand parameter.
+ The method returns true if the current instance of the structure and the object specified by the comparand parameter are both empty or both have the same status code and enhanced status code; otherwise, the method returns false.
+ The object to compare to this instance of the structure.
+
+
+ The method compares the current instance of the structure to the structure specified by the comparand parameter.
+ The method returns true if the current instance of the structure and the structure specified by the comparand parameter are both empty or both have the same status code and enhanced status code; otherwise, the method returns false.
+ The structure to compare to this instance of the structure.
+
+
+ The field returns an instance of the structure that represents a 250 2.6.0 response that indicates that the mail is queued for delivery.
+ The Internet message ID for the queued message.
+
+
+ The method converts the current instance of the structure to a Unicode string.
+ The method returns the response string represented by the current instance of the structure.
+
+
+ The method gets a value that indicates whether the string specified by the text parameter contains a valid Simple Mail Transfer Protocol (SMTP) response.
+ The method returns true if the string specified by the text parameter contains a valid Simple Mail Transfer Protocol (SMTP) response; otherwise, the method returns false.
+ An instance of the structure that represents the response that is contained in the text parameter. This parameter is passed uninitialized.
+ The string to validate.
+
+
+ The property gets the enhanced status code for the response.
+ The property returns a string value containing the enhanced status code of the response in the form X.Y.Z.
+
+
+ The property gets a value that indicates the classification of the Simple Mail Transfer Protocol (SMTP) response.
+ The property returns one of the valid enumeration values.
+
+
+ The property gets the status code for the response.
+ The property returns a string value that contains the status code for the response.
+
+
+ The property gets a string collection that contains the section of each line of the response that comes after the status code and enhanced status code.
+ The property returns a string collection.
+
+
+ The enumeration indicates the status returned from a Simple Mail Transfer Protocol (SMTP) request.
+
+
+ A 3xx status code.
+
+
+ A 5xx status code.
+
+
+ A 2xx status code.
+
+
+ A 4xx status code.
+
+
+ Unknown status.
+
+
+ The class is the base class for classes that represent a Simple Mail Transfer Protocol (SMTP) session.
+
+
+ When overridden in a derived class, the property gets a value that indicates whether the session is a connection with a partner configured for anti-spam bypass.
+ When overridden in a derived class, the property returns true if the session is a connection with a partner configured for anti-spam bypass; otherwise, the property returns false.
+
+
+ When overridden in a derived class, the property gets a value that indicates how the remote server authenticated for the session.
+ When overridden in a derived class, the property returns one of the valid values.
+
+
+ When overridden in a derived class, the property returns a value that indicates whether the session is currently connected.
+ When overridden in a derived class, the property returns true if the connection is still established; otherwise, the property returns false.
+
+
+ When overridden in a derived class, the property gets or sets a value that indicates whether the connection is with a server outside the organization.
+ When overridden in a derived class, the property returns true if the connection is with a server outside the organization; otherwise, the property returns false.
+
+
+ The property indicates whether the session use Transport Layer Security.
+ The value of the property indicates true if Transport Layer Security is used for the session; otherwise, it indicates false.
+
+
+ When overridden in a derived class, the property gets or sets the Internet Protocol (IP) of the last mail server to process the message before the message entered the organization.
+ When overridden in a derived class, the property returns an instance of the IPAddress class.
+
+
+ When overridden in a derived class, the property gets or sets the Internet Protocol (IP) end point for the local connection.
+ When overridden in a derived class, the property returns an instance of the IPEndPoint class.
+
+
+ When overridden in a derived class, the property gets or sets an indexer for custom session properties.
+ When overridden in a derived class, the property returns a dictionary object.
+
+
+ When overridden in a derived class, the property gets or sets the Internet Protocol (IP) end point for the remote connection.
+ When overridden in a derived class, the property returns an instance of the IPEndPoint class.
+
+
+ When overridden in a derived class, the property gets or sets the ID for the session.
+ When overridden in a derived class, the property returns a Guid value.
+
+
+
\ No newline at end of file
diff --git a/Src/Configuration.DkimSigner/Constants.cs b/Src/Configuration.DkimSigner/Constants.cs
index 3198a87b..e0206e20 100644
--- a/Src/Configuration.DkimSigner/Constants.cs
+++ b/Src/Configuration.DkimSigner/Constants.cs
@@ -66,26 +66,28 @@ public static string DkimSignerPath
{"15.1.1261.35", "Exchange 2016 CU7"},
{"15.1.1415.2", "Exchange 2016 CU8"},
{"15.1.1466.3", "Exchange 2016 CU9"},
- {"15.1.1531.3", "Exchange 2016 CU10" },
- {"15.1.1591.10", "Exchange 2016 CU11" },
- {"15.1.1713.5", "Exchange 2016 CU12" },
- {"15.1.1779.2", "Exchange 2016 CU13" },
+ {"15.1.1531.3", "Exchange 2016 CU10"},
+ {"15.1.1591.10", "Exchange 2016 CU11"},
+ {"15.1.1713.5", "Exchange 2016 CU12"},
+ {"15.1.1779.2", "Exchange 2016 CU13"},
{"15.1.1847.3", "Exchange 2016 CU14"},
{"15.1.1913.5", "Exchange 2016 CU15"},
{"15.1.1979.3", "Exchange 2016 CU16"},
{"15.1.2044.4", "Exchange 2016 CU17"},
{"15.1.2106.2", "Exchange 2016 CU18"},
{"15.1.2176.2", "Exchange 2016 CU19"},
- {"15.2.196.0", "Exchange 2019 Preview" },
- {"15.2.221.12", "Exchange 2019 RTM" },
- {"15.2.330.5", "Exchange 2019 CU1" },
+ {"15.1.2242.4", "Exchange 2016 CU20"},
+ {"15.2.196.0", "Exchange 2019 Preview"},
+ {"15.2.221.12", "Exchange 2019 RTM"},
+ {"15.2.330.5", "Exchange 2019 CU1"},
{"15.2.397.3", "Exchange 2019 CU2"},
- {"15.2.464.5", "Exchange 2019 CU3"},
+ {"15.2.464.5", "Exchange 2019 CU3"},
{"15.2.529.5", "Exchange 2019 CU4"},
{"15.2.595.3", "Exchange 2019 CU5"},
{"15.2.659.4", "Exchange 2019 CU6"},
{"15.2.721.2", "Exchange 2019 CU7"},
- {"15.2.792.3", "Exchange 2019 CU8"}
+ {"15.2.792.3", "Exchange 2019 CU8"},
+ {"15.2.858.5", "Exchange 2019 CU9"}
};
}
}
diff --git a/Src/Configuration.DkimSigner/Properties/AssemblyInfo.cs b/Src/Configuration.DkimSigner/Properties/AssemblyInfo.cs
index 9b4e7517..50b1db9f 100644
--- a/Src/Configuration.DkimSigner/Properties/AssemblyInfo.cs
+++ b/Src/Configuration.DkimSigner/Properties/AssemblyInfo.cs
@@ -32,5 +32,5 @@
// You can specify all the values or you can default the Build and Revision Numbers
// by using the '*' as shown below:
// [assembly: AssemblyVersion("1.0.*")]
-[assembly: AssemblyVersion("3.3.1")]
-[assembly: AssemblyFileVersion("3.3.1")]
+[assembly: AssemblyVersion("3.3.2")]
+[assembly: AssemblyFileVersion("3.3.2")]
diff --git a/Src/Configuration.DkimSigner/bin/Release/Configuration.DkimSigner.exe b/Src/Configuration.DkimSigner/bin/Release/Configuration.DkimSigner.exe
index c96a27b6..c14b18f4 100644
Binary files a/Src/Configuration.DkimSigner/bin/Release/Configuration.DkimSigner.exe and b/Src/Configuration.DkimSigner/bin/Release/Configuration.DkimSigner.exe differ
diff --git a/Src/Configuration.DkimSigner/bin/Release/Configuration.DkimSigner.pdb b/Src/Configuration.DkimSigner/bin/Release/Configuration.DkimSigner.pdb
index 246ab9a5..8ed383a3 100644
Binary files a/Src/Configuration.DkimSigner/bin/Release/Configuration.DkimSigner.pdb and b/Src/Configuration.DkimSigner/bin/Release/Configuration.DkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/Exchange.DkimSigner.csproj b/Src/Exchange.DkimSigner/Exchange.DkimSigner.csproj
index f6a5df9c..aa61fe18 100644
--- a/Src/Exchange.DkimSigner/Exchange.DkimSigner.csproj
+++ b/Src/Exchange.DkimSigner/Exchange.DkimSigner.csproj
@@ -36,6 +36,7 @@
v4.7.2
v4.7.2
v4.7.2
+ v4.7.2
v4.7.1
v4.7.1
v4.7.1
@@ -46,6 +47,7 @@
v4.7.2
v4.7.2
v4.7.2
+ v4.7.2
v4.5
512
@@ -590,6 +592,16 @@
MinimumRecommendedRules.ruleset
false
+
+ bin\Exchange 2016 CU20\
+ TRACE;EX_2016_CU20
+ true
+ pdbonly
+ AnyCPU
+ prompt
+ MinimumRecommendedRules.ruleset
+ false
+
bin\Exchange 2019 Preview\
TRACE;EX_2019_Preview
@@ -690,6 +702,16 @@
MinimumRecommendedRules.ruleset
false
+
+ bin\Exchange 2019 CU9\
+ TRACE;EX_2019_CU9
+ true
+ pdbonly
+ AnyCPU
+ prompt
+ MinimumRecommendedRules.ruleset
+ false
+
..\..\packages\MimeKit.1.2.21\lib\net40\BouncyCastle.dll
@@ -1026,6 +1048,12 @@
..\..\Lib\Exchange 2016 CU19\Microsoft.Exchange.Data.Transport.dll
+
+ ..\..\Lib\Exchange 2016 CU20\Microsoft.Exchange.Data.Common.dll
+
+
+ ..\..\Lib\Exchange 2016 CU20\Microsoft.Exchange.Data.Transport.dll
+
..\..\Lib\Exchange 2019 Preview\Microsoft.Exchange.Data.Common.dll
@@ -1086,6 +1114,12 @@
..\..\Lib\Exchange 2019 CU8\Microsoft.Exchange.Data.Transport.dll
+
+ ..\..\Lib\Exchange 2019 CU9\Microsoft.Exchange.Data.Common.dll
+
+
+ ..\..\Lib\Exchange 2019 CU9\Microsoft.Exchange.Data.Transport.dll
+
..\..\packages\MimeKit.1.2.21\lib\net40\MimeKit.dll
True
diff --git a/Src/Exchange.DkimSigner/Properties/AssemblyInfo.cs b/Src/Exchange.DkimSigner/Properties/AssemblyInfo.cs
index b5cc82f5..a7862801 100644
--- a/Src/Exchange.DkimSigner/Properties/AssemblyInfo.cs
+++ b/Src/Exchange.DkimSigner/Properties/AssemblyInfo.cs
@@ -21,7 +21,7 @@
[assembly: AssemblyCulture("")]
[assembly: ComVisible(false)]
[assembly: Guid("FA0D7628-702A-445B-9C78-887874B212BA")]
-[assembly: AssemblyVersion("3.3.1")]
+[assembly: AssemblyVersion("3.3.2")]
[assembly: CLSCompliant(false)]
[assembly: NeutralResourcesLanguage("en-US")]
-[assembly: AssemblyFileVersion("3.3.1")]
+[assembly: AssemblyFileVersion("3.3.2")]
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3 RU21/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3 RU21/ExchangeDkimSigner.dll
index efe78c3e..8246ae18 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3 RU21/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3 RU21/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3 RU21/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3 RU21/ExchangeDkimSigner.pdb
index cc66ab97..90fced25 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3 RU21/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3 RU21/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3/ExchangeDkimSigner.dll
index c47e9ebd..7f78cb53 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3/ExchangeDkimSigner.pdb
index 2c942953..f849720e 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP1/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP1/ExchangeDkimSigner.dll
index ba5ecddc..4ca1bdfa 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP1/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP1/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP1/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP1/ExchangeDkimSigner.pdb
index 9e8fc0d3..55ebf1dd 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP1/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP1/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP2/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP2/ExchangeDkimSigner.dll
index 4bc3ea2c..d9b20797 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP2/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP2/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP2/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP2/ExchangeDkimSigner.pdb
index 84ae2d86..734b4d59 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP2/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP2/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP3/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP3/ExchangeDkimSigner.dll
index 83c13094..2a8291f2 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP3/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP3/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP3/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP3/ExchangeDkimSigner.pdb
index d66c8908..5b7ad082 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP3/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP3/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2010/ExchangeDkimSigner.dll
index 1df7af2b..0dbc4a49 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2010/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2010/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2010/ExchangeDkimSigner.pdb
index 34b14769..29b9e77f 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2010/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2010/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU1/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU1/ExchangeDkimSigner.dll
index c570dc76..4ebdb80b 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU1/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU1/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU1/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU1/ExchangeDkimSigner.pdb
index b7949797..c42dc720 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU1/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU1/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU2/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU2/ExchangeDkimSigner.dll
index bccddce2..ef2b2cbf 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU2/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU2/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU2/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU2/ExchangeDkimSigner.pdb
index 2d87500d..de1e5f08 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU2/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU2/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU3/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU3/ExchangeDkimSigner.dll
index 4baa0e5b..037036a7 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU3/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU3/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU3/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU3/ExchangeDkimSigner.pdb
index ee93dc0b..5979639c 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU3/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU3/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU10/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU10/ExchangeDkimSigner.dll
index 7e9c3e55..172f1b7a 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU10/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU10/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU10/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU10/ExchangeDkimSigner.pdb
index 0fee7918..765559a7 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU10/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU10/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU11/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU11/ExchangeDkimSigner.dll
index 03df38d9..ebbf4972 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU11/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU11/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU11/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU11/ExchangeDkimSigner.pdb
index 656ab29e..c688cf77 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU11/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU11/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU12/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU12/ExchangeDkimSigner.dll
index 778cf743..394b6c38 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU12/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU12/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU12/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU12/ExchangeDkimSigner.pdb
index 1ffc35f6..06761887 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU12/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU12/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU13/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU13/ExchangeDkimSigner.dll
index 733810fa..eb8c1a20 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU13/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU13/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU13/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU13/ExchangeDkimSigner.pdb
index 4e7eefbc..49b687dd 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU13/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU13/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU14/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU14/ExchangeDkimSigner.dll
index 17663cff..69b4369d 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU14/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU14/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU14/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU14/ExchangeDkimSigner.pdb
index bd3b8842..faf897fb 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU14/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU14/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU15/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU15/ExchangeDkimSigner.dll
index 75c577ad..a614458f 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU15/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU15/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU15/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU15/ExchangeDkimSigner.pdb
index 60c32d26..1174377f 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU15/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU15/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU16/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU16/ExchangeDkimSigner.dll
index 37a16a65..97e27e54 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU16/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU16/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU16/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU16/ExchangeDkimSigner.pdb
index 33111f71..65955315 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU16/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU16/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU17/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU17/ExchangeDkimSigner.dll
index d972cba6..d3c91cb5 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU17/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU17/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU17/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU17/ExchangeDkimSigner.pdb
index f5d4065e..85ebcb5a 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU17/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU17/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU18/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU18/ExchangeDkimSigner.dll
index 40ceaa14..cb9142af 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU18/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU18/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU18/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU18/ExchangeDkimSigner.pdb
index 7d08ae05..839e3bc1 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU18/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU18/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU19/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU19/ExchangeDkimSigner.dll
index d96bb90d..07b0ffbc 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU19/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU19/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU19/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU19/ExchangeDkimSigner.pdb
index d543e702..c25e38f6 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU19/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU19/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU20/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU20/ExchangeDkimSigner.dll
index 8de3fe78..9974629e 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU20/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU20/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU20/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU20/ExchangeDkimSigner.pdb
index 59ce4c7f..039822cc 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU20/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU20/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU21/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU21/ExchangeDkimSigner.dll
index fcb21afd..7cf7702d 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU21/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU21/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU21/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU21/ExchangeDkimSigner.pdb
index 5a75ddc8..4f2590e6 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU21/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU21/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU22/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU22/ExchangeDkimSigner.dll
index 3fc0e1de..ef752ece 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU22/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU22/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU22/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU22/ExchangeDkimSigner.pdb
index 72084058..facb5833 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU22/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU22/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU23/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU23/ExchangeDkimSigner.dll
index 776f0fa8..6591951d 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU23/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU23/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU23/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU23/ExchangeDkimSigner.pdb
index 92284e71..76b347d0 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU23/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU23/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU4/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU4/ExchangeDkimSigner.dll
index a6268264..3f047efd 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU4/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU4/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU4/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU4/ExchangeDkimSigner.pdb
index 1e2883eb..7d252b42 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU4/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU4/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU5/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU5/ExchangeDkimSigner.dll
index 8eaf2135..cfea568e 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU5/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU5/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU5/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU5/ExchangeDkimSigner.pdb
index 1c55b926..a7de4611 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU5/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU5/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU6/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU6/ExchangeDkimSigner.dll
index c315c7b5..4c5e963d 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU6/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU6/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU6/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU6/ExchangeDkimSigner.pdb
index f6416c9b..e38320fe 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU6/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU6/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU7/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU7/ExchangeDkimSigner.dll
index 8f547c19..5a2d86b7 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU7/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU7/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU7/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU7/ExchangeDkimSigner.pdb
index 7e72d405..894d6544 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU7/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU7/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU8/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU8/ExchangeDkimSigner.dll
index 4315325d..1009b59c 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU8/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU8/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU8/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU8/ExchangeDkimSigner.pdb
index 30028c36..7e1357ef 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU8/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU8/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU9/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU9/ExchangeDkimSigner.dll
index d9abc5cf..ae8feadb 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU9/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU9/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU9/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU9/ExchangeDkimSigner.pdb
index 4c0d3c43..d8dc709c 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU9/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013 SP1 CU9/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013/ExchangeDkimSigner.dll
index 338d5ee0..2804f45c 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2013/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013/ExchangeDkimSigner.pdb
index b12dad9e..ae88538d 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2013/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2013/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU1/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU1/ExchangeDkimSigner.dll
index 6ff3d4e7..667682cf 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU1/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU1/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU1/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU1/ExchangeDkimSigner.pdb
index d8785cf9..0e5557c0 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU1/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU1/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU10/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU10/ExchangeDkimSigner.dll
index 06f4f71e..12cc30cf 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU10/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU10/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU10/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU10/ExchangeDkimSigner.pdb
index 2bf48636..fc7a9178 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU10/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU10/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU11/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU11/ExchangeDkimSigner.dll
index 360b336c..ca625114 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU11/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU11/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU11/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU11/ExchangeDkimSigner.pdb
index ff8d8921..681d141e 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU11/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU11/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU12/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU12/ExchangeDkimSigner.dll
index 707b034f..d9556d76 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU12/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU12/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU12/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU12/ExchangeDkimSigner.pdb
index 3efb50b7..147cf3d2 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU12/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU12/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU13/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU13/ExchangeDkimSigner.dll
index 1b6a6d64..ca48df1f 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU13/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU13/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU13/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU13/ExchangeDkimSigner.pdb
index 8e60284c..a2437523 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU13/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU13/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU14/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU14/ExchangeDkimSigner.dll
index 90c7276d..cec79472 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU14/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU14/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU14/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU14/ExchangeDkimSigner.pdb
index 002d7ca6..41dfcb53 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU14/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU14/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU15/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU15/ExchangeDkimSigner.dll
index 5bbdb98b..979b87b8 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU15/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU15/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU15/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU15/ExchangeDkimSigner.pdb
index a5cda59f..89a9a216 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU15/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU15/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.dll
index 748da58a..7363abef 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.pdb
index 6436bbdf..fd5270f3 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU17/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU17/ExchangeDkimSigner.dll
index 843f313b..85a3062d 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU17/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU17/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU17/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU17/ExchangeDkimSigner.pdb
index cc9debbe..98395592 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU17/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU17/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU18/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU18/ExchangeDkimSigner.dll
index 37c9cc11..b1300350 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU18/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU18/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU18/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU18/ExchangeDkimSigner.pdb
index 8296d2aa..abbbf476 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU18/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU18/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU19/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU19/ExchangeDkimSigner.dll
index 5b202c70..e8aeed7c 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU19/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU19/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU19/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU19/ExchangeDkimSigner.pdb
index 30ceeed1..c4fa6959 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU19/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU19/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU2/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU2/ExchangeDkimSigner.dll
index 8df77a61..ee9e0100 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU2/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU2/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU2/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU2/ExchangeDkimSigner.pdb
index 4a22939c..559af956 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU2/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU2/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/BouncyCastle.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/BouncyCastle.dll
new file mode 100644
index 00000000..17e4744b
Binary files /dev/null and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/BouncyCastle.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/BouncyCastle.xml b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/BouncyCastle.xml
new file mode 100644
index 00000000..d27354a2
--- /dev/null
+++ b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/BouncyCastle.xml
@@ -0,0 +1,24206 @@
+
+
+
+ BouncyCastle
+
+
+
+ Base class for both the compress and decompress classes.
+ Holds common arrays, and static data.
+
+ @author Keiron Liddle
+
+
+ An input stream that decompresses from the BZip2 format (with the file
+ header chars) to be read as any other stream.
+
+ @author Keiron Liddle
+
+ NB: note this class has been modified to read the leading BZ from the
+ start of the BZIP2 stream to make it compatible with other PGP programs.
+
+
+ An output stream that compresses into the BZip2 format (with the file
+ header chars) into another stream.
+
+ @author Keiron Liddle
+
+ TODO: Update to BZip2 1.0.1
+ NB: note this class has been modified to add a leading BZ to the
+ start of the BZIP2 stream to make it compatible with other PGP programs.
+
+
+
+ modified by Oliver Merkel, 010128
+
+
+
+ A simple class the hold and calculate the CRC for sanity checking
+ of the data.
+
+ @author Keiron Liddle
+
+
+ Return the DER encoding of the object, null if the DER encoding can not be made.
+
+ @return a DER byte array, null otherwise.
+
+
+ a general purpose ASN.1 decoder - note: this class differs from the
+ others in that it returns null after it has read the last object in
+ the stream. If an ASN.1 Null is encountered a Der/BER Null object is
+ returned.
+
+
+ Create an ASN1InputStream where no DER object will be longer than limit.
+
+ @param input stream containing ASN.1 encoded data.
+ @param limit maximum size of a DER encoded object.
+
+
+ Create an ASN1InputStream based on the input byte array. The length of DER objects in
+ the stream is automatically limited to the length of the input array.
+
+ @param input array containing ASN.1 encoded data.
+
+
+ build an object given its tag and the number of bytes to construct it from.
+
+
+ A Null object.
+
+
+ Create a base ASN.1 object from a byte array.
+ The byte array to parse.
+ The base ASN.1 object represented by the byte array.
+ If there is a problem parsing the data.
+
+
+ Read a base ASN.1 object from a stream.
+ The stream to parse.
+ The base ASN.1 object represented by the byte array.
+ If there is a problem parsing the data.
+
+
+ return an Octet string from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ return an Octet string from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ @param string the octets making up the octet string.
+
+
+ return an Asn1Sequence from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Return an ASN1 sequence from a tagged object. There is a special
+ case here, if an object appears to have been explicitly tagged on
+ reading but we were expecting it to be implicitly tagged in the
+ normal course of events it indicates that we lost the surrounding
+ sequence - so we need to add it back (this will happen if the tagged
+ object is a sequence that contains other sequences). If you are
+ dealing with implicitly tagged sequences you really should
+ be using this method.
+
+ @param obj the tagged object.
+ @param explicitly true if the object is meant to be explicitly tagged,
+ false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ return the object at the sequence position indicated by index.
+
+ @param index the sequence number (starting at zero) of the object
+ @return the object at the sequence position indicated by index.
+
+
+ return an ASN1Set from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Return an ASN1 set from a tagged object. There is a special
+ case here, if an object appears to have been explicitly tagged on
+ reading but we were expecting it to be implicitly tagged in the
+ normal course of events it indicates that we lost the surrounding
+ set - so we need to add it back (this will happen if the tagged
+ object is a sequence that contains other sequences). If you are
+ dealing with implicitly tagged sets you really should
+ be using this method.
+
+ @param obj the tagged object.
+ @param explicitly true if the object is meant to be explicitly tagged
+ false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ return the object at the set position indicated by index.
+
+ @param index the set number (starting at zero) of the object
+ @return the object at the set position indicated by index.
+
+
+ ASN.1 TaggedObject - in ASN.1 notation this is any object preceded by
+ a [n] where n is some number - these are assumed to follow the construction
+ rules (as with sequences).
+
+
+ @param tagNo the tag number for this object.
+ @param obj the tagged object.
+
+
+ @param explicitly true if the object is explicitly tagged.
+ @param tagNo the tag number for this object.
+ @param obj the tagged object.
+
+
+ return whether or not the object may be explicitly tagged.
+
+ Note: if the object has been read from an input stream, the only
+ time you can be sure if isExplicit is returning the true state of
+ affairs is if it returns false. An implicitly tagged object may appear
+ to be explicitly tagged, so you need to understand the context under
+ which the reading was done as well, see GetObject below.
+
+
+ return whatever was following the tag.
+
+ Note: tagged objects are generally context dependent if you're
+ trying to extract a tagged object you should be going via the
+ appropriate GetInstance method.
+
+
+ Return the object held in this tagged object as a parser assuming it has
+ the type of the passed in tag. If the object doesn't have a parser
+ associated with it, the base object is returned.
+
+
+ A BER Null object.
+
+
+ convert a vector of octet strings into a single byte string
+
+
+ The octets making up the octet string.
+
+
+ return the DER octets that make up this string.
+
+
+ create an empty sequence
+
+
+ create a sequence containing one object
+
+
+ create a sequence containing a vector of objects.
+
+
+ create an empty sequence
+
+
+ create a set containing one object
+
+
+ create a set containing a vector of objects.
+
+
+ BER TaggedObject - in ASN.1 notation this is any object preceded by
+ a [n] where n is some number - these are assumed to follow the construction
+ rules (as with sequences).
+
+
+ @param tagNo the tag number for this object.
+ @param obj the tagged object.
+
+
+ @param explicitly true if an explicitly tagged object.
+ @param tagNo the tag number for this object.
+ @param obj the tagged object.
+
+
+ create an implicitly tagged object that contains a zero
+ length sequence.
+
+
+ Class representing the DER-type External
+
+
+ Creates a new instance of DerExternal
+ See X.690 for more informations about the meaning of these parameters
+ @param directReference The direct reference or null
if not set.
+ @param indirectReference The indirect reference or null
if not set.
+ @param dataValueDescriptor The data value descriptor or null
if not set.
+ @param externalData The external data in its encoded form.
+
+
+ Creates a new instance of DerExternal.
+ See X.690 for more informations about the meaning of these parameters
+ @param directReference The direct reference or null
if not set.
+ @param indirectReference The indirect reference or null
if not set.
+ @param dataValueDescriptor The data value descriptor or null
if not set.
+ @param encoding The encoding to be used for the external data
+ @param externalData The external data
+
+
+ The encoding of the content. Valid values are
+
+ 0
single-ASN1-type
+ 1
OCTET STRING
+ 2
BIT STRING
+
+
+
+ Base class for an application specific object
+
+
+ Return the enclosed object assuming explicit tagging.
+
+ @return the resulting object
+ @throws IOException if reconstruction fails.
+
+
+ Return the enclosed object assuming implicit tagging.
+
+ @param derTagNo the type tag that should be applied to the object's contents.
+ @return the resulting object
+ @throws IOException if reconstruction fails.
+
+
+ Der BMPString object.
+
+
+ return a BMP string from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a BMP string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - byte encoded string.
+
+
+ basic constructor
+
+
+ return a Bit string from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a Bit string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ @param data the octets making up the bit string.
+ @param padBits the number of extra bits at the end of the string.
+
+
+ Return the octets contained in this BIT STRING, checking that this BIT STRING really
+ does represent an octet aligned string. Only use this method when the standard you are
+ following dictates that the BIT STRING will be octet aligned.
+
+ @return a copy of the octet aligned data.
+
+
+ @return the value of the bit string as an int (truncating if necessary)
+
+
+ return a bool from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a DerBoolean from the passed in bool.
+
+
+ return a Boolean from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ return an integer from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an Enumerated from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ Generalized time object.
+
+
+ return a generalized time from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a Generalized Time object from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ The correct format for this is YYYYMMDDHHMMSS[.f]Z, or without the Z
+ for local time, or Z+-HHMM on the end, for difference between local
+ time and UTC time. The fractional second amount f must consist of at
+ least one number with trailing zeroes removed.
+
+ @param time the time string.
+ @exception ArgumentException if string is an illegal format.
+
+
+ base constructor from a local time object
+
+
+ Return the time.
+ @return The time string as it appeared in the encoded object.
+
+
+ return the time - always in the form of
+ YYYYMMDDhhmmssGMT(+hh:mm|-hh:mm).
+
+ Normally in a certificate we would expect "Z" rather than "GMT",
+ however adding the "GMT" means we can just use:
+
+ dateF = new SimpleDateFormat("yyyyMMddHHmmssz");
+
+ To read in the time and Get a date which is compatible with our local
+ time zone.
+
+
+ return a Graphic String from the passed in object
+
+ @param obj a DerGraphicString or an object that can be converted into one.
+ @exception IllegalArgumentException if the object cannot be converted.
+ @return a DerGraphicString instance, or null.
+
+
+ return a Graphic String from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception IllegalArgumentException if the tagged object cannot
+ be converted.
+ @return a DerGraphicString instance, or null.
+
+
+ basic constructor - with bytes.
+ @param string the byte encoding of the characters making up the string.
+
+
+ Der IA5String object - this is an ascii string.
+
+
+ return a IA5 string from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an IA5 string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - with bytes.
+
+
+ basic constructor - without validation.
+
+
+ Constructor with optional validation.
+
+ @param string the base string to wrap.
+ @param validate whether or not to check the string.
+ @throws ArgumentException if validate is true and the string
+ contains characters that should not be in an IA5String.
+
+
+ return true if the passed in String can be represented without
+ loss as an IA5String, false otherwise.
+
+ @return true if in printable set, false otherwise.
+
+
+ return an integer from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an Integer from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param isExplicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ in some cases positive values Get crammed into a space,
+ that's not quite big enough...
+
+
+ A Null object.
+
+
+ Der NumericString object - this is an ascii string of characters {0,1,2,3,4,5,6,7,8,9, }.
+
+
+ return a Numeric string from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an Numeric string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - with bytes.
+
+
+ basic constructor - without validation..
+
+
+ Constructor with optional validation.
+
+ @param string the base string to wrap.
+ @param validate whether or not to check the string.
+ @throws ArgumentException if validate is true and the string
+ contains characters that should not be in a NumericString.
+
+
+ Return true if the string can be represented as a NumericString ('0'..'9', ' ')
+
+ @param str string to validate.
+ @return true if numeric, fale otherwise.
+
+
+ return an Oid from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an object Identifier from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ Return true if this oid is an extension of the passed in branch, stem.
+ @param stem the arc or branch that is a possible parent.
+ @return true if the branch is on the passed in stem, false otherwise.
+
+
+ The octets making up the octet string.
+
+
+ Der PrintableString object.
+
+
+ return a printable string from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a Printable string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - byte encoded string.
+
+
+ basic constructor - this does not validate the string
+
+
+ Constructor with optional validation.
+
+ @param string the base string to wrap.
+ @param validate whether or not to check the string.
+ @throws ArgumentException if validate is true and the string
+ contains characters that should not be in a PrintableString.
+
+
+ return true if the passed in String can be represented without
+ loss as a PrintableString, false otherwise.
+
+ @return true if in printable set, false otherwise.
+
+
+ create an empty sequence
+
+
+ create a sequence containing one object
+
+
+ create a sequence containing a vector of objects.
+
+
+ A Der encoded set object
+
+
+ create an empty set
+
+
+ @param obj - a single object that makes up the set.
+
+
+ @param v - a vector of objects making up the set.
+
+
+ Der T61String (also the teletex string) - 8-bit characters
+
+
+ return a T61 string from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an T61 string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - with bytes.
+
+
+ basic constructor - with string.
+
+
+ DER TaggedObject - in ASN.1 notation this is any object preceded by
+ a [n] where n is some number - these are assumed to follow the construction
+ rules (as with sequences).
+
+
+ @param tagNo the tag number for this object.
+ @param obj the tagged object.
+
+
+ @param explicitly true if an explicitly tagged object.
+ @param tagNo the tag number for this object.
+ @param obj the tagged object.
+
+
+ create an implicitly tagged object that contains a zero
+ length sequence.
+
+
+ UTC time object.
+
+
+ return an UTC Time from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an UTC Time from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ The correct format for this is YYMMDDHHMMSSZ (it used to be that seconds were
+ never encoded. When you're creating one of these objects from scratch, that's
+ what you want to use, otherwise we'll try to deal with whatever Gets read from
+ the input stream... (this is why the input format is different from the GetTime()
+ method output).
+
+ @param time the time string.
+
+
+ base constructor from a DateTime object
+
+
+ return the time as a date based on whatever a 2 digit year will return. For
+ standardised processing use ToAdjustedDateTime().
+
+ @return the resulting date
+ @exception ParseException if the date string cannot be parsed.
+
+
+ return the time as an adjusted date
+ in the range of 1950 - 2049.
+
+ @return a date in the range of 1950 to 2049.
+ @exception ParseException if the date string cannot be parsed.
+
+
+ return the time - always in the form of
+ YYMMDDhhmmssGMT(+hh:mm|-hh:mm).
+
+ Normally in a certificate we would expect "Z" rather than "GMT",
+ however adding the "GMT" means we can just use:
+
+ dateF = new SimpleDateFormat("yyMMddHHmmssz");
+
+ To read in the time and Get a date which is compatible with our local
+ time zone.
+
+ Note: In some cases, due to the local date processing, this
+ may lead to unexpected results. If you want to stick the normal
+ convention of 1950 to 2049 use the GetAdjustedTime() method.
+
+
+
+ Return a time string as an adjusted date with a 4 digit year.
+ This goes in the range of 1950 - 2049.
+
+
+
+ Der UTF8String object.
+
+
+ return an UTF8 string from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an UTF8 string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - byte encoded string.
+
+
+ basic constructor
+
+
+ Der UniversalString object.
+
+
+ return a Universal string from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a Universal string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - byte encoded string.
+
+
+ return a Videotex String from the passed in object
+
+ @param obj a DERVideotexString or an object that can be converted into one.
+ @exception IllegalArgumentException if the object cannot be converted.
+ @return a DERVideotexString instance, or null.
+
+
+ return a Videotex String from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception IllegalArgumentException if the tagged object cannot
+ be converted.
+ @return a DERVideotexString instance, or null.
+
+
+ basic constructor - with bytes.
+ @param string the byte encoding of the characters making up the string.
+
+
+ Der VisibleString object.
+
+
+ return a Visible string from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a Visible string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - byte encoded string.
+
+
+ basic constructor
+
+
+ Marker interface for CHOICE objects - if you implement this in a roll-your-own
+ object, any attempt to tag the object implicitly will convert the tag to an
+ explicit one as the encoding rules require.
+
+ If you use this interface your class should also implement the getInstance
+ pattern which takes a tag object and the tagging mode used.
+
+
+
+ basic interface for Der string objects.
+
+
+ class for breaking up an Oid into it's component tokens, ala
+ java.util.StringTokenizer. We need this class as some of the
+ lightweight Java environment don't support classes like
+ StringTokenizer.
+
+
+ return the X9ECParameters object for the named curve represented by
+ the passed in object identifier. Null if the curve isn't present.
+
+ @param oid an object identifier representing a named curve, if present.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+
+ CAKeyUpdAnnContent ::= SEQUENCE {
+ oldWithNew CmpCertificate, -- old pub signed with new priv
+ newWithOld CmpCertificate, -- new pub signed with old priv
+ newWithNew CmpCertificate -- new pub signed with new priv
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertConfirmContent ::= SEQUENCE OF CertStatus
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertOrEncCert ::= CHOICE {
+ certificate [0] CMPCertificate,
+ encryptedCert [1] EncryptedValue
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertRepMessage ::= SEQUENCE {
+ caPubs [1] SEQUENCE SIZE (1..MAX) OF CMPCertificate
+ OPTIONAL,
+ response SEQUENCE OF CertResponse
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertResponse ::= SEQUENCE {
+ certReqId INTEGER,
+ -- to match this response with corresponding request (a value
+ -- of -1 is to be used if certReqId is not specified in the
+ -- corresponding request)
+ status PKIStatusInfo,
+ certifiedKeyPair CertifiedKeyPair OPTIONAL,
+ rspInfo OCTET STRING OPTIONAL
+ -- analogous to the id-regInfo-utf8Pairs string defined
+ -- for regInfo in CertReqMsg [CRMF]
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertStatus ::= SEQUENCE {
+ certHash OCTET STRING,
+ -- the hash of the certificate, using the same hash algorithm
+ -- as is used to create and verify the certificate signature
+ certReqId INTEGER,
+ -- to match this confirmation with the corresponding req/rep
+ statusInfo PKIStatusInfo OPTIONAL
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertifiedKeyPair ::= SEQUENCE {
+ certOrEncCert CertOrEncCert,
+ privateKey [0] EncryptedValue OPTIONAL,
+ -- see [CRMF] for comment on encoding
+ publicationInfo [1] PKIPublicationInfo OPTIONAL
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ Challenge ::= SEQUENCE {
+ owf AlgorithmIdentifier OPTIONAL,
+
+ -- MUST be present in the first Challenge; MAY be omitted in
+ -- any subsequent Challenge in POPODecKeyChallContent (if
+ -- omitted, then the owf used in the immediately preceding
+ -- Challenge is to be used).
+
+ witness OCTET STRING,
+ -- the result of applying the one-way function (owf) to a
+ -- randomly-generated INTEGER, A. [Note that a different
+ -- INTEGER MUST be used for each Challenge.]
+ challenge OCTET STRING
+ -- the encryption (under the public key for which the cert.
+ -- request is being made) of Rand, where Rand is specified as
+ -- Rand ::= SEQUENCE {
+ -- int INTEGER,
+ -- - the randomly-generated INTEGER A (above)
+ -- sender GeneralName
+ -- - the sender's name (as included in PKIHeader)
+ -- }
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+ Note: the addition of attribute certificates is a BC extension.
+
+
+
+ CMPCertificate ::= CHOICE {
+ x509v3PKCert Certificate
+ x509v2AttrCert [1] AttributeCertificate
+ }
+
+ Note: the addition of attribute certificates is a BC extension.
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CrlAnnContent ::= SEQUENCE OF CertificateList
+
+ @return a basic ASN.1 object representation.
+
+
+
+ ErrorMsgContent ::= SEQUENCE {
+ pKIStatusInfo PKIStatusInfo,
+ errorCode INTEGER OPTIONAL,
+ -- implementation-specific error codes
+ errorDetails PKIFreeText OPTIONAL
+ -- implementation-specific error details
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ GenMsgContent ::= SEQUENCE OF InfoTypeAndValue
+
+ @return a basic ASN.1 object representation.
+
+
+
+ GenRepContent ::= SEQUENCE OF InfoTypeAndValue
+
+ @return a basic ASN.1 object representation.
+
+
+ Example InfoTypeAndValue contents include, but are not limited
+ to, the following (un-comment in this ASN.1 module and use as
+ appropriate for a given environment):
+
+ id-it-caProtEncCert OBJECT IDENTIFIER ::= {id-it 1}
+ CAProtEncCertValue ::= CMPCertificate
+ id-it-signKeyPairTypes OBJECT IDENTIFIER ::= {id-it 2}
+ SignKeyPairTypesValue ::= SEQUENCE OF AlgorithmIdentifier
+ id-it-encKeyPairTypes OBJECT IDENTIFIER ::= {id-it 3}
+ EncKeyPairTypesValue ::= SEQUENCE OF AlgorithmIdentifier
+ id-it-preferredSymmAlg OBJECT IDENTIFIER ::= {id-it 4}
+ PreferredSymmAlgValue ::= AlgorithmIdentifier
+ id-it-caKeyUpdateInfo OBJECT IDENTIFIER ::= {id-it 5}
+ CAKeyUpdateInfoValue ::= CAKeyUpdAnnContent
+ id-it-currentCRL OBJECT IDENTIFIER ::= {id-it 6}
+ CurrentCRLValue ::= CertificateList
+ id-it-unsupportedOIDs OBJECT IDENTIFIER ::= {id-it 7}
+ UnsupportedOIDsValue ::= SEQUENCE OF OBJECT IDENTIFIER
+ id-it-keyPairParamReq OBJECT IDENTIFIER ::= {id-it 10}
+ KeyPairParamReqValue ::= OBJECT IDENTIFIER
+ id-it-keyPairParamRep OBJECT IDENTIFIER ::= {id-it 11}
+ KeyPairParamRepValue ::= AlgorithmIdentifer
+ id-it-revPassphrase OBJECT IDENTIFIER ::= {id-it 12}
+ RevPassphraseValue ::= EncryptedValue
+ id-it-implicitConfirm OBJECT IDENTIFIER ::= {id-it 13}
+ ImplicitConfirmValue ::= NULL
+ id-it-confirmWaitTime OBJECT IDENTIFIER ::= {id-it 14}
+ ConfirmWaitTimeValue ::= GeneralizedTime
+ id-it-origPKIMessage OBJECT IDENTIFIER ::= {id-it 15}
+ OrigPKIMessageValue ::= PKIMessages
+ id-it-suppLangTags OBJECT IDENTIFIER ::= {id-it 16}
+ SuppLangTagsValue ::= SEQUENCE OF UTF8String
+
+ where
+
+ id-pkix OBJECT IDENTIFIER ::= {
+ iso(1) identified-organization(3)
+ dod(6) internet(1) security(5) mechanisms(5) pkix(7)}
+ and
+ id-it OBJECT IDENTIFIER ::= {id-pkix 4}
+
+
+
+
+ InfoTypeAndValue ::= SEQUENCE {
+ infoType OBJECT IDENTIFIER,
+ infoValue ANY DEFINED BY infoType OPTIONAL
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ KeyRecRepContent ::= SEQUENCE {
+ status PKIStatusInfo,
+ newSigCert [0] CMPCertificate OPTIONAL,
+ caCerts [1] SEQUENCE SIZE (1..MAX) OF
+ CMPCertificate OPTIONAL,
+ keyPairHist [2] SEQUENCE SIZE (1..MAX) OF
+ CertifiedKeyPair OPTIONAL
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ OobCertHash ::= SEQUENCE {
+ hashAlg [0] AlgorithmIdentifier OPTIONAL,
+ certId [1] CertId OPTIONAL,
+ hashVal BIT STRING
+ -- hashVal is calculated over the Der encoding of the
+ -- self-signed certificate with the identifier certID.
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+ Creates a new PkiBody.
+ @param type one of the TYPE_* constants
+ @param content message content
+
+
+
+ PkiBody ::= CHOICE { -- message-specific body elements
+ ir [0] CertReqMessages, --Initialization Request
+ ip [1] CertRepMessage, --Initialization Response
+ cr [2] CertReqMessages, --Certification Request
+ cp [3] CertRepMessage, --Certification Response
+ p10cr [4] CertificationRequest, --imported from [PKCS10]
+ popdecc [5] POPODecKeyChallContent, --pop Challenge
+ popdecr [6] POPODecKeyRespContent, --pop Response
+ kur [7] CertReqMessages, --Key Update Request
+ kup [8] CertRepMessage, --Key Update Response
+ krr [9] CertReqMessages, --Key Recovery Request
+ krp [10] KeyRecRepContent, --Key Recovery Response
+ rr [11] RevReqContent, --Revocation Request
+ rp [12] RevRepContent, --Revocation Response
+ ccr [13] CertReqMessages, --Cross-Cert. Request
+ ccp [14] CertRepMessage, --Cross-Cert. Response
+ ckuann [15] CAKeyUpdAnnContent, --CA Key Update Ann.
+ cann [16] CertAnnContent, --Certificate Ann.
+ rann [17] RevAnnContent, --Revocation Ann.
+ crlann [18] CRLAnnContent, --CRL Announcement
+ pkiconf [19] PKIConfirmContent, --Confirmation
+ nested [20] NestedMessageContent, --Nested Message
+ genm [21] GenMsgContent, --General Message
+ genp [22] GenRepContent, --General Response
+ error [23] ErrorMsgContent, --Error Message
+ certConf [24] CertConfirmContent, --Certificate confirm
+ pollReq [25] PollReqContent, --Polling request
+ pollRep [26] PollRepContent --Polling response
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PkiConfirmContent ::= NULL
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PKIFailureInfo ::= BIT STRING {
+ badAlg (0),
+ -- unrecognized or unsupported Algorithm Identifier
+ badMessageCheck (1), -- integrity check failed (e.g., signature did not verify)
+ badRequest (2),
+ -- transaction not permitted or supported
+ badTime (3), -- messageTime was not sufficiently close to the system time, as defined by local policy
+ badCertId (4), -- no certificate could be found matching the provided criteria
+ badDataFormat (5),
+ -- the data submitted has the wrong format
+ wrongAuthority (6), -- the authority indicated in the request is different from the one creating the response token
+ incorrectData (7), -- the requester's data is incorrect (for notary services)
+ missingTimeStamp (8), -- when the timestamp is missing but should be there (by policy)
+ badPOP (9) -- the proof-of-possession failed
+ certRevoked (10),
+ certConfirmed (11),
+ wrongIntegrity (12),
+ badRecipientNonce (13),
+ timeNotAvailable (14),
+ -- the TSA's time source is not available
+ unacceptedPolicy (15),
+ -- the requested TSA policy is not supported by the TSA
+ unacceptedExtension (16),
+ -- the requested extension is not supported by the TSA
+ addInfoNotAvailable (17)
+ -- the additional information requested could not be understood
+ -- or is not available
+ badSenderNonce (18),
+ badCertTemplate (19),
+ signerNotTrusted (20),
+ transactionIdInUse (21),
+ unsupportedVersion (22),
+ notAuthorized (23),
+ systemUnavail (24),
+ systemFailure (25),
+ -- the request cannot be handled due to system failure
+ duplicateCertReq (26)
+
+
+
+ Basic constructor.
+
+
+ Return the number of string elements present.
+
+ @return number of elements present.
+
+
+ Return the UTF8STRING at index.
+
+ @param index index of the string of interest
+ @return the string at index.
+
+
+
+ PkiFreeText ::= SEQUENCE SIZE (1..MAX) OF UTF8String
+
+
+
+ Value for a "null" recipient or sender.
+
+
+
+ PkiHeader ::= SEQUENCE {
+ pvno INTEGER { cmp1999(1), cmp2000(2) },
+ sender GeneralName,
+ -- identifies the sender
+ recipient GeneralName,
+ -- identifies the intended recipient
+ messageTime [0] GeneralizedTime OPTIONAL,
+ -- time of production of this message (used when sender
+ -- believes that the transport will be "suitable"; i.e.,
+ -- that the time will still be meaningful upon receipt)
+ protectionAlg [1] AlgorithmIdentifier OPTIONAL,
+ -- algorithm used for calculation of protection bits
+ senderKID [2] KeyIdentifier OPTIONAL,
+ recipKID [3] KeyIdentifier OPTIONAL,
+ -- to identify specific keys used for protection
+ transactionID [4] OCTET STRING OPTIONAL,
+ -- identifies the transaction; i.e., this will be the same in
+ -- corresponding request, response, certConf, and PKIConf
+ -- messages
+ senderNonce [5] OCTET STRING OPTIONAL,
+ recipNonce [6] OCTET STRING OPTIONAL,
+ -- nonces used to provide replay protection, senderNonce
+ -- is inserted by the creator of this message; recipNonce
+ -- is a nonce previously inserted in a related message by
+ -- the intended recipient of this message
+ freeText [7] PKIFreeText OPTIONAL,
+ -- this may be used to indicate context-specific instructions
+ -- (this field is intended for human consumption)
+ generalInfo [8] SEQUENCE SIZE (1..MAX) OF
+ InfoTypeAndValue OPTIONAL
+ -- this may be used to convey context-specific information
+ -- (this field not primarily intended for human consumption)
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PKIHeader ::= SEQUENCE {
+ pvno INTEGER { cmp1999(1), cmp2000(2) },
+ sender GeneralName,
+ -- identifies the sender
+ recipient GeneralName,
+ -- identifies the intended recipient
+ messageTime [0] GeneralizedTime OPTIONAL,
+ -- time of production of this message (used when sender
+ -- believes that the transport will be "suitable"; i.e.,
+ -- that the time will still be meaningful upon receipt)
+ protectionAlg [1] AlgorithmIdentifier OPTIONAL,
+ -- algorithm used for calculation of protection bits
+ senderKID [2] KeyIdentifier OPTIONAL,
+ recipKID [3] KeyIdentifier OPTIONAL,
+ -- to identify specific keys used for protection
+ transactionID [4] OCTET STRING OPTIONAL,
+ -- identifies the transaction; i.e., this will be the same in
+ -- corresponding request, response, certConf, and PKIConf
+ -- messages
+ senderNonce [5] OCTET STRING OPTIONAL,
+ recipNonce [6] OCTET STRING OPTIONAL,
+ -- nonces used to provide replay protection, senderNonce
+ -- is inserted by the creator of this message; recipNonce
+ -- is a nonce previously inserted in a related message by
+ -- the intended recipient of this message
+ freeText [7] PKIFreeText OPTIONAL,
+ -- this may be used to indicate context-specific instructions
+ -- (this field is intended for human consumption)
+ generalInfo [8] SEQUENCE SIZE (1..MAX) OF
+ InfoTypeAndValue OPTIONAL
+ -- this may be used to convey context-specific information
+ -- (this field not primarily intended for human consumption)
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+ Creates a new PkiMessage.
+
+ @param header message header
+ @param body message body
+ @param protection message protection (may be null)
+ @param extraCerts extra certificates (may be null)
+
+
+
+ PkiMessage ::= SEQUENCE {
+ header PKIHeader,
+ body PKIBody,
+ protection [0] PKIProtection OPTIONAL,
+ extraCerts [1] SEQUENCE SIZE (1..MAX) OF CMPCertificate
+ OPTIONAL
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PkiMessages ::= SEQUENCE SIZE (1..MAX) OF PkiMessage
+
+ @return a basic ASN.1 object representation.
+
+
+ @param status
+
+
+ @param status
+ @param statusString
+
+
+
+ PkiStatusInfo ::= SEQUENCE {
+ status PKIStatus, (INTEGER)
+ statusString PkiFreeText OPTIONAL,
+ failInfo PkiFailureInfo OPTIONAL (BIT STRING)
+ }
+
+ PKIStatus:
+ granted (0), -- you got exactly what you asked for
+ grantedWithMods (1), -- you got something like what you asked for
+ rejection (2), -- you don't get it, more information elsewhere in the message
+ waiting (3), -- the request body part has not yet been processed, expect to hear more later
+ revocationWarning (4), -- this message contains a warning that a revocation is imminent
+ revocationNotification (5), -- notification that a revocation has occurred
+ keyUpdateWarning (6) -- update already done for the oldCertId specified in CertReqMsg
+
+ PkiFailureInfo:
+ badAlg (0), -- unrecognized or unsupported Algorithm Identifier
+ badMessageCheck (1), -- integrity check failed (e.g., signature did not verify)
+ badRequest (2), -- transaction not permitted or supported
+ badTime (3), -- messageTime was not sufficiently close to the system time, as defined by local policy
+ badCertId (4), -- no certificate could be found matching the provided criteria
+ badDataFormat (5), -- the data submitted has the wrong format
+ wrongAuthority (6), -- the authority indicated in the request is different from the one creating the response token
+ incorrectData (7), -- the requester's data is incorrect (for notary services)
+ missingTimeStamp (8), -- when the timestamp is missing but should be there (by policy)
+ badPOP (9) -- the proof-of-possession failed
+
+
+
+
+
+ PbmParameter ::= SEQUENCE {
+ salt OCTET STRING,
+ -- note: implementations MAY wish to limit acceptable sizes
+ -- of this string to values appropriate for their environment
+ -- in order to reduce the risk of denial-of-service attacks
+ owf AlgorithmIdentifier,
+ -- AlgId for a One-Way Function (SHA-1 recommended)
+ iterationCount INTEGER,
+ -- number of times the OWF is applied
+ -- note: implementations MAY wish to limit acceptable sizes
+ -- of this integer to values appropriate for their environment
+ -- in order to reduce the risk of denial-of-service attacks
+ mac AlgorithmIdentifier
+ -- the MAC AlgId (e.g., DES-MAC, Triple-DES-MAC [PKCS11],
+ } -- or HMAC [RFC2104, RFC2202])
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PollRepContent ::= SEQUENCE OF SEQUENCE {
+ certReqId INTEGER,
+ checkAfter INTEGER, -- time in seconds
+ reason PKIFreeText OPTIONAL
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PollReqContent ::= SEQUENCE OF SEQUENCE {
+ certReqId INTEGER
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PopoDecKeyChallContent ::= SEQUENCE OF Challenge
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PopoDecKeyRespContent ::= SEQUENCE OF INTEGER
+
+ @return a basic ASN.1 object representation.
+
+
+
+ ProtectedPart ::= SEQUENCE {
+ header PKIHeader,
+ body PKIBody
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ RevAnnContent ::= SEQUENCE {
+ status PKIStatus,
+ certId CertId,
+ willBeRevokedAt GeneralizedTime,
+ badSinceDate GeneralizedTime,
+ crlDetails Extensions OPTIONAL
+ -- extra CRL details (e.g., crl number, reason, location, etc.)
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ RevDetails ::= SEQUENCE {
+ certDetails CertTemplate,
+ -- allows requester to specify as much as they can about
+ -- the cert. for which revocation is requested
+ -- (e.g., for cases in which serialNumber is not available)
+ crlEntryDetails Extensions OPTIONAL
+ -- requested crlEntryExtensions
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ RevRepContent ::= SEQUENCE {
+ status SEQUENCE SIZE (1..MAX) OF PKIStatusInfo,
+ -- in same order as was sent in RevReqContent
+ revCerts [0] SEQUENCE SIZE (1..MAX) OF CertId OPTIONAL,
+ -- IDs for which revocation was requested
+ -- (same order as status)
+ crls [1] SEQUENCE SIZE (1..MAX) OF CertificateList OPTIONAL
+ -- the resulting CRLs (there may be more than one)
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ RevReqContent ::= SEQUENCE OF RevDetails
+
+ @return a basic ASN.1 object representation.
+
+
+ return an Attribute object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Attribute ::= SEQUENCE {
+ attrType OBJECT IDENTIFIER,
+ attrValues SET OF AttributeValue
+ }
+
+
+
+ Return the first attribute matching the given OBJECT IDENTIFIER
+
+
+ Return all the attributes matching the OBJECT IDENTIFIER oid. The vector will be
+ empty if there are no attributes of the required type present.
+
+ @param oid type of attribute required.
+ @return a vector of all the attributes found of type oid.
+
+
+ Return a new table with the passed in attribute added.
+
+ @param attrType
+ @param attrValue
+ @return
+
+
+
+ Attributes ::=
+ SET SIZE(1..MAX) OF Attribute -- according to RFC 5652
+
+ @return
+
+
+ return an AuthEnvelopedData object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param isExplicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @throws ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an AuthEnvelopedData object from the given object.
+
+ @param obj the object we want converted.
+ @throws ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AuthEnvelopedData ::= SEQUENCE {
+ version CMSVersion,
+ originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+ recipientInfos RecipientInfos,
+ authEncryptedContentInfo EncryptedContentInfo,
+ authAttrs [1] IMPLICIT AuthAttributes OPTIONAL,
+ mac MessageAuthenticationCode,
+ unauthAttrs [2] IMPLICIT UnauthAttributes OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+
+ AuthEnvelopedData ::= SEQUENCE {
+ version CMSVersion,
+ originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+ recipientInfos RecipientInfos,
+ authEncryptedContentInfo EncryptedContentInfo,
+ authAttrs [1] IMPLICIT AuthAttributes OPTIONAL,
+ mac MessageAuthenticationCode,
+ unauthAttrs [2] IMPLICIT UnauthAttributes OPTIONAL }
+
+
+
+ return an AuthenticatedData object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param isExplicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @throws ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an AuthenticatedData object from the given object.
+
+ @param obj the object we want converted.
+ @throws ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AuthenticatedData ::= SEQUENCE {
+ version CMSVersion,
+ originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+ recipientInfos RecipientInfos,
+ macAlgorithm MessageAuthenticationCodeAlgorithm,
+ digestAlgorithm [1] DigestAlgorithmIdentifier OPTIONAL,
+ encapContentInfo EncapsulatedContentInfo,
+ authAttrs [2] IMPLICIT AuthAttributes OPTIONAL,
+ mac MessageAuthenticationCode,
+ unauthAttrs [3] IMPLICIT UnauthAttributes OPTIONAL }
+
+ AuthAttributes ::= SET SIZE (1..MAX) OF Attribute
+
+ UnauthAttributes ::= SET SIZE (1..MAX) OF Attribute
+
+ MessageAuthenticationCode ::= OCTET STRING
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AuthenticatedData ::= SEQUENCE {
+ version CMSVersion,
+ originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+ recipientInfos RecipientInfos,
+ macAlgorithm MessageAuthenticationCodeAlgorithm,
+ digestAlgorithm [1] DigestAlgorithmIdentifier OPTIONAL,
+ encapContentInfo EncapsulatedContentInfo,
+ authAttrs [2] IMPLICIT AuthAttributes OPTIONAL,
+ mac MessageAuthenticationCode,
+ unauthAttrs [3] IMPLICIT UnauthAttributes OPTIONAL }
+
+ AuthAttributes ::= SET SIZE (1..MAX) OF Attribute
+
+ UnauthAttributes ::= SET SIZE (1..MAX) OF Attribute
+
+ MessageAuthenticationCode ::= OCTET STRING
+
+
+
+ The other Revocation Info arc
+ id-ri OBJECT IDENTIFIER ::= { iso(1) identified-organization(3)
+ dod(6) internet(1) security(5) mechanisms(5) pkix(7) ri(16) }
+
+
+ RFC 3274 - CMS Compressed Data.
+
+ CompressedData ::= Sequence {
+ version CMSVersion,
+ compressionAlgorithm CompressionAlgorithmIdentifier,
+ encapContentInfo EncapsulatedContentInfo
+ }
+
+
+
+ return a CompressedData object from a tagged object.
+
+ @param ato the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a CompressedData object from the given object.
+
+ @param _obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ RFC 3274 - CMS Compressed Data.
+
+ CompressedData ::= SEQUENCE {
+ version CMSVersion,
+ compressionAlgorithm CompressionAlgorithmIdentifier,
+ encapContentInfo EncapsulatedContentInfo
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ContentInfo ::= Sequence {
+ contentType ContentType,
+ content
+ [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ContentInfo ::= SEQUENCE {
+ contentType ContentType,
+ content
+ [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL }
+
+
+
+ return an EncryptedContentInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ EncryptedContentInfo ::= Sequence {
+ contentType ContentType,
+ contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,
+ encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL
+ }
+
+
+
+
+ EncryptedContentInfo ::= SEQUENCE {
+ contentType ContentType,
+ contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,
+ encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL
+ }
+
+
+
+
+ EncryptedData ::= SEQUENCE {
+ version CMSVersion,
+ encryptedContentInfo EncryptedContentInfo,
+ unprotectedAttrs [1] IMPLICIT UnprotectedAttributes OPTIONAL }
+
+ @return a basic ASN.1 object representation.
+
+
+ return an EnvelopedData object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an EnvelopedData object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ EnvelopedData ::= Sequence {
+ version CMSVersion,
+ originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+ recipientInfos RecipientInfos,
+ encryptedContentInfo EncryptedContentInfo,
+ unprotectedAttrs [1] IMPLICIT UnprotectedAttributes OPTIONAL
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ EnvelopedData ::= SEQUENCE {
+ version CMSVersion,
+ originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+ recipientInfos RecipientInfos,
+ encryptedContentInfo EncryptedContentInfo,
+ unprotectedAttrs [1] IMPLICIT UnprotectedAttributes OPTIONAL
+ }
+
+
+
+ return a KekIdentifier object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a KekIdentifier object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ KekIdentifier ::= Sequence {
+ keyIdentifier OCTET STRING,
+ date GeneralizedTime OPTIONAL,
+ other OtherKeyAttribute OPTIONAL
+ }
+
+
+
+ return a KekRecipientInfo object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a KekRecipientInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ KekRecipientInfo ::= Sequence {
+ version CMSVersion, -- always set to 4
+ kekID KekIdentifier,
+ keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
+ encryptedKey EncryptedKey
+ }
+
+
+
+ return an KeyAgreeRecipientIdentifier object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param isExplicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an KeyAgreeRecipientIdentifier object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ KeyAgreeRecipientIdentifier ::= CHOICE {
+ issuerAndSerialNumber IssuerAndSerialNumber,
+ rKeyId [0] IMPLICIT RecipientKeyIdentifier
+ }
+
+
+
+ return a KeyAgreeRecipientInfo object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a KeyAgreeRecipientInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ * Produce an object suitable for an Asn1OutputStream.
+ *
+ * KeyAgreeRecipientInfo ::= Sequence {
+ * version CMSVersion, -- always set to 3
+ * originator [0] EXPLICIT OriginatorIdentifierOrKey,
+ * ukm [1] EXPLICIT UserKeyingMaterial OPTIONAL,
+ * keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
+ * recipientEncryptedKeys RecipientEncryptedKeys
+ * }
+ *
+ * UserKeyingMaterial ::= OCTET STRING
+ *
+
+
+ return a KeyTransRecipientInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ KeyTransRecipientInfo ::= Sequence {
+ version CMSVersion, -- always set to 0 or 2
+ rid RecipientIdentifier,
+ keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
+ encryptedKey EncryptedKey
+ }
+
+
+
+
+ MetaData ::= SEQUENCE {
+ hashProtected BOOLEAN,
+ fileName UTF8String OPTIONAL,
+ mediaType IA5String OPTIONAL,
+ otherMetaData Attributes OPTIONAL
+ }
+
+ @return
+
+
+ return an OriginatorIdentifierOrKey object from a tagged object.
+
+ @param o the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an OriginatorIdentifierOrKey object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OriginatorIdentifierOrKey ::= CHOICE {
+ issuerAndSerialNumber IssuerAndSerialNumber,
+ subjectKeyIdentifier [0] SubjectKeyIdentifier,
+ originatorKey [1] OriginatorPublicKey
+ }
+
+ SubjectKeyIdentifier ::= OCTET STRING
+
+
+
+ return an OriginatorInfo object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an OriginatorInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OriginatorInfo ::= Sequence {
+ certs [0] IMPLICIT CertificateSet OPTIONAL,
+ crls [1] IMPLICIT CertificateRevocationLists OPTIONAL
+ }
+
+
+
+ return an OriginatorPublicKey object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an OriginatorPublicKey object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OriginatorPublicKey ::= Sequence {
+ algorithm AlgorithmIdentifier,
+ publicKey BIT STRING
+ }
+
+
+
+ return an OtherKeyAttribute object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OtherKeyAttribute ::= Sequence {
+ keyAttrId OBJECT IDENTIFIER,
+ keyAttr ANY DEFINED BY keyAttrId OPTIONAL
+ }
+
+
+
+ return a OtherRecipientInfo object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a OtherRecipientInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OtherRecipientInfo ::= Sequence {
+ oriType OBJECT IDENTIFIER,
+ oriValue ANY DEFINED BY oriType }
+
+
+
+ return a OtherRevocationInfoFormat object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception IllegalArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a OtherRevocationInfoFormat object from the given object.
+
+ @param obj the object we want converted.
+ @exception IllegalArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an ASN1OutputStream.
+
+ OtherRevocationInfoFormat ::= SEQUENCE {
+ otherRevInfoFormat OBJECT IDENTIFIER,
+ otherRevInfo ANY DEFINED BY otherRevInfoFormat }
+
+
+
+ return a PasswordRecipientInfo object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a PasswordRecipientInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ PasswordRecipientInfo ::= Sequence {
+ version CMSVersion, -- Always set to 0
+ keyDerivationAlgorithm [0] KeyDerivationAlgorithmIdentifier
+ OPTIONAL,
+ keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
+ encryptedKey EncryptedKey }
+
+
+
+ return an RecipientEncryptedKey object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param isExplicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a RecipientEncryptedKey object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ RecipientEncryptedKey ::= SEQUENCE {
+ rid KeyAgreeRecipientIdentifier,
+ encryptedKey EncryptedKey
+ }
+
+
+
+ return a RecipientIdentifier object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ RecipientIdentifier ::= CHOICE {
+ issuerAndSerialNumber IssuerAndSerialNumber,
+ subjectKeyIdentifier [0] SubjectKeyIdentifier
+ }
+
+ SubjectKeyIdentifier ::= OCTET STRING
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ RecipientInfo ::= CHOICE {
+ ktri KeyTransRecipientInfo,
+ kari [1] KeyAgreeRecipientInfo,
+ kekri [2] KekRecipientInfo,
+ pwri [3] PasswordRecipientInfo,
+ ori [4] OtherRecipientInfo }
+
+
+
+ return a RecipientKeyIdentifier object from a tagged object.
+
+ @param _ato the tagged object holding the object we want.
+ @param _explicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a RecipientKeyIdentifier object from the given object.
+
+ @param _obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ RecipientKeyIdentifier ::= Sequence {
+ subjectKeyIdentifier SubjectKeyIdentifier,
+ date GeneralizedTime OPTIONAL,
+ other OtherKeyAttribute OPTIONAL
+ }
+
+ SubjectKeyIdentifier ::= OCTET STRING
+
+
+
+
+ ScvpReqRes ::= SEQUENCE {
+ request [0] EXPLICIT ContentInfo OPTIONAL,
+ response ContentInfo }
+
+ @return the ASN.1 primitive representation.
+
+
+ a signed data object.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SignedData ::= Sequence {
+ version CMSVersion,
+ digestAlgorithms DigestAlgorithmIdentifiers,
+ encapContentInfo EncapsulatedContentInfo,
+ certificates [0] IMPLICIT CertificateSet OPTIONAL,
+ crls [1] IMPLICIT CertificateRevocationLists OPTIONAL,
+ signerInfos SignerInfos
+ }
+
+
+
+
+ SignedData ::= SEQUENCE {
+ version CMSVersion,
+ digestAlgorithms DigestAlgorithmIdentifiers,
+ encapContentInfo EncapsulatedContentInfo,
+ certificates [0] IMPLICIT CertificateSet OPTIONAL,
+ crls [1] IMPLICIT CertificateRevocationLists OPTIONAL,
+ signerInfos SignerInfos
+ }
+
+
+
+ return a SignerIdentifier object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SignerIdentifier ::= CHOICE {
+ issuerAndSerialNumber IssuerAndSerialNumber,
+ subjectKeyIdentifier [0] SubjectKeyIdentifier
+ }
+
+ SubjectKeyIdentifier ::= OCTET STRING
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SignerInfo ::= Sequence {
+ version Version,
+ SignerIdentifier sid,
+ digestAlgorithm DigestAlgorithmIdentifier,
+ authenticatedAttributes [0] IMPLICIT Attributes OPTIONAL,
+ digestEncryptionAlgorithm DigestEncryptionAlgorithmIdentifier,
+ encryptedDigest EncryptedDigest,
+ unauthenticatedAttributes [1] IMPLICIT Attributes OPTIONAL
+ }
+
+ EncryptedDigest ::= OCTET STRING
+
+ DigestAlgorithmIdentifier ::= AlgorithmIdentifier
+
+ DigestEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier
+
+
+
+ creates a time object from a given date - if the date is between 1950
+ and 2049 a UTCTime object is Generated, otherwise a GeneralizedTime
+ is used.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Time ::= CHOICE {
+ utcTime UTCTime,
+ generalTime GeneralizedTime }
+
+
+
+
+ TimeStampAndCRL ::= SEQUENCE {
+ timeStamp TimeStampToken, -- according to RFC 3161
+ crl CertificateList OPTIONAL -- according to RFC 5280
+ }
+
+ @return
+
+
+
+ TimeStampTokenEvidence ::=
+ SEQUENCE SIZE(1..MAX) OF TimeStampAndCrl
+
+ @return
+
+
+
+ TimeStampedData ::= SEQUENCE {
+ version INTEGER { v1(1) },
+ dataUri IA5String OPTIONAL,
+ metaData MetaData OPTIONAL,
+ content OCTET STRING OPTIONAL,
+ temporalEvidence Evidence
+ }
+
+ @return
+
+
+ return an AuthEnvelopedData object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param isExplicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @throws ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an AuthEnvelopedData object from the given object.
+
+ @param obj the object we want converted.
+ @throws ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ MQVuserKeyingMaterial ::= SEQUENCE {
+ ephemeralPublicKey OriginatorPublicKey,
+ addedukm [0] EXPLICIT UserKeyingMaterial OPTIONAL }
+
+
+
+
+ AttributeTypeAndValue ::= SEQUENCE {
+ type OBJECT IDENTIFIER,
+ value ANY DEFINED BY type }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertId ::= SEQUENCE {
+ issuer GeneralName,
+ serialNumber INTEGER }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertReqMessages ::= SEQUENCE SIZE (1..MAX) OF CertReqMsg
+
+ @return a basic ASN.1 object representation.
+
+
+ Creates a new CertReqMsg.
+ @param certReq CertRequest
+ @param popo may be null
+ @param regInfo may be null
+
+
+
+ CertReqMsg ::= SEQUENCE {
+ certReq CertRequest,
+ pop ProofOfPossession OPTIONAL,
+ -- content depends upon key type
+ regInfo SEQUENCE SIZE(1..MAX) OF AttributeTypeAndValue OPTIONAL }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertRequest ::= SEQUENCE {
+ certReqId INTEGER, -- ID for matching request and reply
+ certTemplate CertTemplate, -- Selected fields of cert to be issued
+ controls Controls OPTIONAL } -- Attributes affecting issuance
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertTemplate ::= SEQUENCE {
+ version [0] Version OPTIONAL,
+ serialNumber [1] INTEGER OPTIONAL,
+ signingAlg [2] AlgorithmIdentifier OPTIONAL,
+ issuer [3] Name OPTIONAL,
+ validity [4] OptionalValidity OPTIONAL,
+ subject [5] Name OPTIONAL,
+ publicKey [6] SubjectPublicKeyInfo OPTIONAL,
+ issuerUID [7] UniqueIdentifier OPTIONAL,
+ subjectUID [8] UniqueIdentifier OPTIONAL,
+ extensions [9] Extensions OPTIONAL }
+
+ @return a basic ASN.1 object representation.
+
+
+ Sets the X.509 version. Note: for X509v3, use 2 here.
+
+
+ Sets the issuer unique ID (deprecated in X.509v3)
+
+
+ Sets the subject unique ID (deprecated in X.509v3)
+
+
+
+ CertTemplate ::= SEQUENCE {
+ version [0] Version OPTIONAL,
+ serialNumber [1] INTEGER OPTIONAL,
+ signingAlg [2] AlgorithmIdentifier OPTIONAL,
+ issuer [3] Name OPTIONAL,
+ validity [4] OptionalValidity OPTIONAL,
+ subject [5] Name OPTIONAL,
+ publicKey [6] SubjectPublicKeyInfo OPTIONAL,
+ issuerUID [7] UniqueIdentifier OPTIONAL,
+ subjectUID [8] UniqueIdentifier OPTIONAL,
+ extensions [9] Extensions OPTIONAL }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ Controls ::= SEQUENCE SIZE(1..MAX) OF AttributeTypeAndValue
+
+ @return a basic ASN.1 object representation.
+
+
+
+ EncKeyWithID ::= SEQUENCE {
+ privateKey PrivateKeyInfo,
+ identifier CHOICE {
+ string UTF8String,
+ generalName GeneralName
+ } OPTIONAL
+ }
+
+ @return
+
+
+
+ EncryptedKey ::= CHOICE {
+ encryptedValue EncryptedValue, -- deprecated
+ envelopedData [0] EnvelopedData }
+ -- The encrypted private key MUST be placed in the envelopedData
+ -- encryptedContentInfo encryptedContent OCTET STRING.
+
+
+
+
+ EncryptedValue ::= SEQUENCE {
+ intendedAlg [0] AlgorithmIdentifier OPTIONAL,
+ -- the intended algorithm for which the value will be used
+ symmAlg [1] AlgorithmIdentifier OPTIONAL,
+ -- the symmetric algorithm used to encrypt the value
+ encSymmKey [2] BIT STRING OPTIONAL,
+ -- the (encrypted) symmetric key used to encrypt the value
+ keyAlg [3] AlgorithmIdentifier OPTIONAL,
+ -- algorithm used to encrypt the symmetric key
+ valueHint [4] OCTET STRING OPTIONAL,
+ -- a brief description or identifier of the encValue content
+ -- (may be meaningful only to the sending entity, and used only
+ -- if EncryptedValue might be re-examined by the sending entity
+ -- in the future)
+ encValue BIT STRING }
+ -- the encrypted value itself
+
+ @return a basic ASN.1 object representation.
+
+
+
+ OptionalValidity ::= SEQUENCE {
+ notBefore [0] Time OPTIONAL,
+ notAfter [1] Time OPTIONAL } --at least one MUST be present
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PkiArchiveOptions ::= CHOICE {
+ encryptedPrivKey [0] EncryptedKey,
+ -- the actual value of the private key
+ keyGenParameters [1] KeyGenParameters,
+ -- parameters which allow the private key to be re-generated
+ archiveRemGenPrivKey [2] BOOLEAN }
+ -- set to TRUE if sender wishes receiver to archive the private
+ -- key of a key pair that the receiver generates in response to
+ -- this request; set to FALSE if no archival is desired.
+
+
+
+
+ PkiPublicationInfo ::= SEQUENCE {
+ action INTEGER {
+ dontPublish (0),
+ pleasePublish (1) },
+ pubInfos SEQUENCE SIZE (1..MAX) OF SinglePubInfo OPTIONAL }
+ -- pubInfos MUST NOT be present if action is "dontPublish"
+ -- (if action is "pleasePublish" and pubInfos is omitted,
+ -- "dontCare" is assumed)
+
+ @return a basic ASN.1 object representation.
+
+
+ Password-based MAC value for use with POPOSigningKeyInput.
+
+
+ Creates a new PKMACValue.
+ @param params parameters for password-based MAC
+ @param value MAC of the DER-encoded SubjectPublicKeyInfo
+
+
+ Creates a new PKMACValue.
+ @param aid CMPObjectIdentifiers.passwordBasedMAC, with PBMParameter
+ @param value MAC of the DER-encoded SubjectPublicKeyInfo
+
+
+
+ PKMACValue ::= SEQUENCE {
+ algId AlgorithmIdentifier,
+ -- algorithm value shall be PasswordBasedMac 1.2.840.113533.7.66.13
+ -- parameter value is PBMParameter
+ value BIT STRING }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PopoPrivKey ::= CHOICE {
+ thisMessage [0] BIT STRING, -- Deprecated
+ -- possession is proven in this message (which contains the private
+ -- key itself (encrypted for the CA))
+ subsequentMessage [1] SubsequentMessage,
+ -- possession will be proven in a subsequent message
+ dhMAC [2] BIT STRING, -- Deprecated
+ agreeMAC [3] PKMACValue,
+ encryptedKey [4] EnvelopedData }
+
+
+
+ Creates a new Proof of Possession object for a signing key.
+ @param poposkIn the PopoSigningKeyInput structure, or null if the
+ CertTemplate includes both subject and publicKey values.
+ @param aid the AlgorithmIdentifier used to sign the proof of possession.
+ @param signature a signature over the DER-encoded value of poposkIn,
+ or the DER-encoded value of certReq if poposkIn is null.
+
+
+
+ PopoSigningKey ::= SEQUENCE {
+ poposkInput [0] PopoSigningKeyInput OPTIONAL,
+ algorithmIdentifier AlgorithmIdentifier,
+ signature BIT STRING }
+ -- The signature (using "algorithmIdentifier") is on the
+ -- DER-encoded value of poposkInput. NOTE: If the CertReqMsg
+ -- certReq CertTemplate contains the subject and publicKey values,
+ -- then poposkInput MUST be omitted and the signature MUST be
+ -- computed on the DER-encoded value of CertReqMsg certReq. If
+ -- the CertReqMsg certReq CertTemplate does not contain the public
+ -- key and subject values, then poposkInput MUST be present and
+ -- MUST be signed. This strategy ensures that the public key is
+ -- not present in both the poposkInput and CertReqMsg certReq
+ -- CertTemplate fields.
+
+ @return a basic ASN.1 object representation.
+
+
+ Creates a new PopoSigningKeyInput with sender name as authInfo.
+
+
+ Creates a new PopoSigningKeyInput using password-based MAC.
+
+
+ Returns the sender field, or null if authInfo is publicKeyMac
+
+
+ Returns the publicKeyMac field, or null if authInfo is sender
+
+
+
+ PopoSigningKeyInput ::= SEQUENCE {
+ authInfo CHOICE {
+ sender [0] GeneralName,
+ -- used only if an authenticated identity has been
+ -- established for the sender (e.g., a DN from a
+ -- previously-issued and currently-valid certificate
+ publicKeyMac PKMacValue },
+ -- used if no authenticated GeneralName currently exists for
+ -- the sender; publicKeyMac contains a password-based MAC
+ -- on the DER-encoded value of publicKey
+ publicKey SubjectPublicKeyInfo } -- from CertTemplate
+
+ @return a basic ASN.1 object representation.
+
+
+ Creates a ProofOfPossession with type raVerified.
+
+
+ Creates a ProofOfPossession for a signing key.
+
+
+ Creates a ProofOfPossession for key encipherment or agreement.
+ @param type one of TYPE_KEY_ENCIPHERMENT or TYPE_KEY_AGREEMENT
+
+
+
+ ProofOfPossession ::= CHOICE {
+ raVerified [0] NULL,
+ -- used if the RA has already verified that the requester is in
+ -- possession of the private key
+ signature [1] PopoSigningKey,
+ keyEncipherment [2] PopoPrivKey,
+ keyAgreement [3] PopoPrivKey }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ SinglePubInfo ::= SEQUENCE {
+ pubMethod INTEGER {
+ dontCare (0),
+ x500 (1),
+ web (2),
+ ldap (3) },
+ pubLocation GeneralName OPTIONAL }
+
+ @return a basic ASN.1 object representation.
+
+
+ table of the available named parameters for GOST 3410-2001.
+
+
+ return the ECDomainParameters object for the given OID, null if it
+ isn't present.
+
+ @param oid an object identifier representing a named parameters, if present.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+
+ Gost28147-89-Parameters ::=
+ SEQUENCE {
+ iv Gost28147-89-IV,
+ encryptionParamSet OBJECT IDENTIFIER
+ }
+
+ Gost28147-89-IV ::= OCTET STRING (SIZE (8))
+
+
+
+ table of the available named parameters for GOST 3410-94.
+
+
+ return the GOST3410ParamSetParameters object for the given OID, null if it
+ isn't present.
+
+ @param oid an object identifier representing a named parameters, if present.
+
+
+ returns an enumeration containing the name strings for parameters
+ contained in this structure.
+
+
+
+ RFC 3126: 4.3.1 Certificate Values Attribute Definition
+
+ CertificateValues ::= SEQUENCE OF Certificate
+
+
+
+
+
+ CommitmentTypeIndication ::= SEQUENCE {
+ commitmentTypeId CommitmentTypeIdentifier,
+ commitmentTypeQualifier SEQUENCE SIZE (1..MAX) OF
+ CommitmentTypeQualifier OPTIONAL }
+
+
+
+ Commitment type qualifiers, used in the Commitment-Type-Indication attribute (RFC3126).
+
+
+ CommitmentTypeQualifier ::= SEQUENCE {
+ commitmentTypeIdentifier CommitmentTypeIdentifier,
+ qualifier ANY DEFINED BY commitmentTypeIdentifier OPTIONAL }
+
+
+
+ Creates a new CommitmentTypeQualifier
instance.
+
+ @param commitmentTypeIdentifier a CommitmentTypeIdentifier
value
+
+
+ Creates a new CommitmentTypeQualifier
instance.
+
+ @param commitmentTypeIdentifier a CommitmentTypeIdentifier
value
+ @param qualifier the qualifier, defined by the above field.
+
+
+ Creates a new CommitmentTypeQualifier
instance.
+
+ @param as CommitmentTypeQualifier
structure
+ encoded as an Asn1Sequence.
+
+
+ Returns a DER-encodable representation of this instance.
+
+ @return a Asn1Object
value
+
+
+
+ RFC 3126: 4.2.1 Complete Certificate Refs Attribute Definition
+
+ CompleteCertificateRefs ::= SEQUENCE OF OtherCertID
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ CompleteRevocationRefs ::= SEQUENCE OF CrlOcspRef
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ CrlIdentifier ::= SEQUENCE
+ {
+ crlissuer Name,
+ crlIssuedTime UTCTime,
+ crlNumber INTEGER OPTIONAL
+ }
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ CRLListID ::= SEQUENCE
+ {
+ crls SEQUENCE OF CrlValidatedID
+ }
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ CrlOcspRef ::= SEQUENCE {
+ crlids [0] CRLListID OPTIONAL,
+ ocspids [1] OcspListID OPTIONAL,
+ otherRev [2] OtherRevRefs OPTIONAL
+ }
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ CrlValidatedID ::= SEQUENCE {
+ crlHash OtherHash,
+ crlIdentifier CrlIdentifier OPTIONAL}
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ OcspIdentifier ::= SEQUENCE {
+ ocspResponderID ResponderID,
+ -- As in OCSP response data
+ producedAt GeneralizedTime
+ -- As in OCSP response data
+ }
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ OcspListID ::= SEQUENCE {
+ ocspResponses SEQUENCE OF OcspResponsesID
+ }
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ OcspResponsesID ::= SEQUENCE {
+ ocspIdentifier OcspIdentifier,
+ ocspRepHash OtherHash OPTIONAL
+ }
+
+
+
+
+
+
+ OtherCertID ::= SEQUENCE {
+ otherCertHash OtherHash,
+ issuerSerial IssuerSerial OPTIONAL
+ }
+
+
+
+
+
+
+ OtherHash ::= CHOICE {
+ sha1Hash OtherHashValue, -- This contains a SHA-1 hash
+ otherHash OtherHashAlgAndValue
+ }
+
+ OtherHashValue ::= OCTET STRING
+
+
+
+
+
+ Summary description for OtherHashAlgAndValue.
+
+
+
+ OtherHashAlgAndValue ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ hashValue OtherHashValue
+ }
+
+ OtherHashValue ::= OCTET STRING
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ OtherRevRefs ::= SEQUENCE
+ {
+ otherRevRefType OtherRevRefType,
+ otherRevRefs ANY DEFINED BY otherRevRefType
+ }
+
+ OtherRevRefType ::= OBJECT IDENTIFIER
+
+
+
+
+
+ RFC 3126: 4.3.2 Revocation Values Attribute Definition
+
+ OtherRevVals ::= SEQUENCE
+ {
+ otherRevValType OtherRevValType,
+ otherRevVals ANY DEFINED BY otherRevValType
+ }
+
+ OtherRevValType ::= OBJECT IDENTIFIER
+
+
+
+
+
+
+ OtherSigningCertificate ::= SEQUENCE {
+ certs SEQUENCE OF OtherCertID,
+ policies SEQUENCE OF PolicyInformation OPTIONAL
+ }
+
+
+
+
+
+ RFC 5126: 6.3.4. revocation-values Attribute Definition
+
+ RevocationValues ::= SEQUENCE {
+ crlVals [0] SEQUENCE OF CertificateList OPTIONAL,
+ ocspVals [1] SEQUENCE OF BasicOCSPResponse OPTIONAL,
+ otherRevVals [2] OtherRevVals OPTIONAL
+ }
+
+
+
+
+
+
+ SigPolicyQualifierInfo ::= SEQUENCE {
+ sigPolicyQualifierId SigPolicyQualifierId,
+ sigQualifier ANY DEFINED BY sigPolicyQualifierId
+ }
+
+ SigPolicyQualifierId ::= OBJECT IDENTIFIER
+
+
+
+
+
+
+ SignaturePolicyId ::= SEQUENCE {
+ sigPolicyIdentifier SigPolicyId,
+ sigPolicyHash SigPolicyHash,
+ sigPolicyQualifiers SEQUENCE SIZE (1..MAX) OF SigPolicyQualifierInfo OPTIONAL
+ }
+
+ SigPolicyId ::= OBJECT IDENTIFIER
+
+ SigPolicyHash ::= OtherHashAlgAndValue
+
+
+
+
+
+
+ SignaturePolicyIdentifier ::= CHOICE {
+ SignaturePolicyId SignaturePolicyId,
+ SignaturePolicyImplied SignaturePolicyImplied
+ }
+
+ SignaturePolicyImplied ::= NULL
+
+
+
+
+
+
+ SignerAttribute ::= SEQUENCE OF CHOICE {
+ claimedAttributes [0] ClaimedAttributes,
+ certifiedAttributes [1] CertifiedAttributes }
+
+ ClaimedAttributes ::= SEQUENCE OF Attribute
+ CertifiedAttributes ::= AttributeCertificate -- as defined in RFC 3281: see clause 4.1.
+
+
+
+ Signer-Location attribute (RFC3126).
+
+
+ SignerLocation ::= SEQUENCE {
+ countryName [0] DirectoryString OPTIONAL,
+ localityName [1] DirectoryString OPTIONAL,
+ postalAddress [2] PostalAddress OPTIONAL }
+
+ PostalAddress ::= SEQUENCE SIZE(1..6) OF DirectoryString
+
+
+
+
+ SignerLocation ::= SEQUENCE {
+ countryName [0] DirectoryString OPTIONAL,
+ localityName [1] DirectoryString OPTIONAL,
+ postalAddress [2] PostalAddress OPTIONAL }
+
+ PostalAddress ::= SEQUENCE SIZE(1..6) OF DirectoryString
+
+ DirectoryString ::= CHOICE {
+ teletexString TeletexString (SIZE (1..MAX)),
+ printableString PrintableString (SIZE (1..MAX)),
+ universalString UniversalString (SIZE (1..MAX)),
+ utf8String UTF8String (SIZE (1.. MAX)),
+ bmpString BMPString (SIZE (1..MAX)) }
+
+
+
+ constructor
+
+
+
+ ContentHints ::= SEQUENCE {
+ contentDescription UTF8String (SIZE (1..MAX)) OPTIONAL,
+ contentType ContentType }
+
+
+
+ Create from OCTET STRING whose octets represent the identifier.
+
+
+ Create from byte array representing the identifier.
+
+
+ The definition of ContentIdentifier is
+
+ ContentIdentifier ::= OCTET STRING
+
+ id-aa-contentIdentifier OBJECT IDENTIFIER ::= { iso(1)
+ member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9)
+ smime(16) id-aa(2) 7 }
+
+
+ constructor
+
+
+
+ EssCertID ::= SEQUENCE {
+ certHash Hash,
+ issuerSerial IssuerSerial OPTIONAL }
+
+
+
+
+ EssCertIDv2 ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier
+ DEFAULT {algorithm id-sha256},
+ certHash Hash,
+ issuerSerial IssuerSerial OPTIONAL
+ }
+
+ Hash ::= OCTET STRING
+
+ IssuerSerial ::= SEQUENCE {
+ issuer GeneralNames,
+ serialNumber CertificateSerialNumber
+ }
+
+
+
+ constructor
+
+
+
+ OtherCertID ::= SEQUENCE {
+ otherCertHash OtherHash,
+ issuerSerial IssuerSerial OPTIONAL }
+
+ OtherHash ::= CHOICE {
+ sha1Hash OCTET STRING,
+ otherHash OtherHashAlgAndValue }
+
+ OtherHashAlgAndValue ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ hashValue OCTET STRING }
+
+
+
+
+ constructors
+
+
+ The definition of OtherSigningCertificate is
+
+ OtherSigningCertificate ::= SEQUENCE {
+ certs SEQUENCE OF OtherCertID,
+ policies SEQUENCE OF PolicyInformation OPTIONAL
+ }
+
+ id-aa-ets-otherSigCert OBJECT IDENTIFIER ::= { iso(1)
+ member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9)
+ smime(16) id-aa(2) 19 }
+
+
+ constructors
+
+
+ The definition of SigningCertificate is
+
+ SigningCertificate ::= SEQUENCE {
+ certs SEQUENCE OF EssCertID,
+ policies SEQUENCE OF PolicyInformation OPTIONAL
+ }
+
+ id-aa-signingCertificate OBJECT IDENTIFIER ::= { iso(1)
+ member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9)
+ smime(16) id-aa(2) 12 }
+
+
+ The definition of SigningCertificateV2 is
+
+ SigningCertificateV2 ::= SEQUENCE {
+ certs SEQUENCE OF EssCertIDv2,
+ policies SEQUENCE OF PolicyInformation OPTIONAL
+ }
+
+ id-aa-signingCertificateV2 OBJECT IDENTIFIER ::= { iso(1)
+ member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9)
+ smime(16) id-aa(2) 47 }
+
+
+ The CscaMasterList object. This object can be wrapped in a
+ CMSSignedData to be published in LDAP.
+
+
+ CscaMasterList ::= SEQUENCE {
+ version CscaMasterListVersion,
+ certList SET OF Certificate }
+
+ CscaMasterListVersion :: INTEGER {v0(0)}
+
+
+
+ The DataGroupHash object.
+
+ DataGroupHash ::= SEQUENCE {
+ dataGroupNumber DataGroupNumber,
+ dataGroupHashValue OCTET STRING }
+
+ DataGroupNumber ::= INTEGER {
+ dataGroup1 (1),
+ dataGroup1 (2),
+ dataGroup1 (3),
+ dataGroup1 (4),
+ dataGroup1 (5),
+ dataGroup1 (6),
+ dataGroup1 (7),
+ dataGroup1 (8),
+ dataGroup1 (9),
+ dataGroup1 (10),
+ dataGroup1 (11),
+ dataGroup1 (12),
+ dataGroup1 (13),
+ dataGroup1 (14),
+ dataGroup1 (15),
+ dataGroup1 (16) }
+
+
+
+
+ The LDSSecurityObject object (V1.8).
+
+ LDSSecurityObject ::= SEQUENCE {
+ version LDSSecurityObjectVersion,
+ hashAlgorithm DigestAlgorithmIdentifier,
+ dataGroupHashValues SEQUENCE SIZE (2..ub-DataGroups) OF DataHashGroup,
+ ldsVersionInfo LDSVersionInfo OPTIONAL
+ -- if present, version MUST be v1 }
+
+ DigestAlgorithmIdentifier ::= AlgorithmIdentifier,
+
+ LDSSecurityObjectVersion :: INTEGER {V0(0)}
+
+
+
+
+ LDSVersionInfo ::= SEQUENCE {
+ ldsVersion PRINTABLE STRING
+ unicodeVersion PRINTABLE STRING
+ }
+
+ @return
+
+
+ The id-isismtt-cp-accredited OID indicates that the certificate is a
+ qualified certificate according to Directive 1999/93/EC of the European
+ Parliament and of the Council of 13 December 1999 on a Community
+ Framework for Electronic Signatures, which additionally conforms the
+ special requirements of the SigG and has been issued by an accredited CA.
+
+
+ Certificate extensionDate of certificate generation
+
+
+ DateOfCertGenSyntax ::= GeneralizedTime
+
+
+
+ Attribute to indicate that the certificate holder may sign in the name of
+ a third person. May also be used as extension in a certificate.
+
+
+ Attribute to indicate admissions to certain professions. May be used as
+ attribute in attribute certificate or as extension in a certificate
+
+
+ Monetary limit for transactions. The QcEuMonetaryLimit QC statement MUST
+ be used in new certificates in place of the extension/attribute
+ MonetaryLimit since January 1, 2004. For the sake of backward
+ compatibility with certificates already in use, SigG conforming
+ components MUST support MonetaryLimit (as well as QcEuLimitValue).
+
+
+ A declaration of majority. May be used as attribute in attribute
+ certificate or as extension in a certificate
+
+
+
+ Serial number of the smart card containing the corresponding private key
+
+
+ ICCSNSyntax ::= OCTET STRING (SIZE(8..20))
+
+
+
+
+ Reference for a file of a smartcard that stores the public key of this
+ certificate and that is used as �security anchor�.
+
+
+ PKReferenceSyntax ::= OCTET STRING (SIZE(20))
+
+
+
+ Some other restriction regarding the usage of this certificate. May be
+ used as attribute in attribute certificate or as extension in a
+ certificate.
+
+
+ RestrictionSyntax ::= DirectoryString (SIZE(1..1024))
+
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.Restriction
+
+
+
+ (Single)Request extension: Clients may include this extension in a
+ (single) Request to request the responder to send the certificate in the
+ response message along with the status information. Besides the LDAP
+ service, this extension provides another mechanism for the distribution
+ of certificates, which MAY optionally be provided by certificate
+ repositories.
+
+
+ RetrieveIfAllowed ::= BOOLEAN
+
+
+
+ SingleOCSPResponse extension: The certificate requested by the client by
+ inserting the RetrieveIfAllowed extension in the request, will be
+ returned in this extension.
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.Ocsp.RequestedCertificate
+
+
+ Base ObjectIdentifier for naming authorities
+
+
+ SingleOCSPResponse extension: Date, when certificate has been published
+ in the directory and status information has become available. Currently,
+ accrediting authorities enforce that SigG-conforming OCSP servers include
+ this extension in the responses.
+
+
+ CertInDirSince ::= GeneralizedTime
+
+
+
+ Hash of a certificate in OCSP.
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.Ocsp.CertHash
+
+
+
+ NameAtBirth ::= DirectoryString(SIZE(1..64)
+
+
+ Used in
+ {@link Org.BouncyCastle.Asn1.X509.SubjectDirectoryAttributes SubjectDirectoryAttributes}
+
+
+ Some other information of non-restrictive nature regarding the usage of
+ this certificate. May be used as attribute in atribute certificate or as
+ extension in a certificate.
+
+
+ AdditionalInformationSyntax ::= DirectoryString (SIZE(1..2048))
+
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.AdditionalInformationSyntax
+
+
+ Indicates that an attribute certificate exists, which limits the
+ usability of this public key certificate. Whenever verifying a signature
+ with the help of this certificate, the content of the corresponding
+ attribute certificate should be concerned. This extension MUST be
+ included in a PKC, if a corresponding attribute certificate (having the
+ PKC as base certificate) contains some attribute that restricts the
+ usability of the PKC too. Attribute certificates with restricting content
+ MUST always be included in the signed document.
+
+
+ LiabilityLimitationFlagSyntax ::= BOOLEAN
+
+
+
+ ISIS-MTT PROFILE: The responder may include this extension in a response to
+ send the hash of the requested certificate to the responder. This hash is
+ cryptographically bound to the certificate and serves as evidence that the
+ certificate is known to the responder (i.e. it has been issued and is present
+ in the directory). Hence, this extension is a means to provide a positive
+ statement of availability as described in T8.[8]. As explained in T13.[1],
+ clients may rely on this information to be able to validate signatures after
+ the expiry of the corresponding certificate. Hence, clients MUST support this
+ extension. If a positive statement of availability is to be delivered, this
+ extension syntax and OID MUST be used.
+
+
+
+ CertHash ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ certificateHash OCTET STRING
+ }
+
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type CertHash:
+
+
+ CertHash ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ certificateHash OCTET STRING
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from a given details.
+
+ @param hashAlgorithm The hash algorithm identifier.
+ @param certificateHash The hash of the whole DER encoding of the certificate.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ CertHash ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ certificateHash OCTET STRING
+ }
+
+
+ @return an Asn1Object
+
+
+ ISIS-MTT-Optional: The certificate requested by the client by inserting the
+ RetrieveIfAllowed extension in the request, will be returned in this
+ extension.
+
+ ISIS-MTT-SigG: The signature act allows publishing certificates only then,
+ when the certificate owner gives his isExplicit permission. Accordingly, there
+ may be �nondownloadable� certificates, about which the responder must provide
+ status information, but MUST NOT include them in the response. Clients may
+ get therefore the following three kind of answers on a single request
+ including the RetrieveIfAllowed extension:
+
+ - a) the responder supports the extension and is allowed to publish the
+ certificate: RequestedCertificate returned including the requested
+ certificate
+ - b) the responder supports the extension but is NOT allowed to publish
+ the certificate: RequestedCertificate returned including an empty OCTET
+ STRING
+ - c) the responder does not support the extension: RequestedCertificate is
+ not included in the response
+
+ Clients requesting RetrieveIfAllowed MUST be able to handle these cases. If
+ any of the OCTET STRING options is used, it MUST contain the DER encoding of
+ the requested certificate.
+
+
+ RequestedCertificate ::= CHOICE {
+ Certificate Certificate,
+ publicKeyCertificate [0] EXPLICIT OCTET STRING,
+ attributeCertificate [1] EXPLICIT OCTET STRING
+ }
+
+
+
+ Constructor from a given details.
+
+ Only one parameter can be given. All other must be null
.
+
+ @param certificate Given as Certificate
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ RequestedCertificate ::= CHOICE {
+ Certificate Certificate,
+ publicKeyCertificate [0] EXPLICIT OCTET STRING,
+ attributeCertificate [1] EXPLICIT OCTET STRING
+ }
+
+
+ @return an Asn1Object
+
+
+ Some other information of non-restrictive nature regarding the usage of this
+ certificate.
+
+
+ AdditionalInformationSyntax ::= DirectoryString (SIZE(1..2048))
+
+
+
+ Constructor from a given details.
+
+ @param information The describtion of the information.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ AdditionalInformationSyntax ::= DirectoryString (SIZE(1..2048))
+
+
+ @return an Asn1Object
+
+
+ Attribute to indicate admissions to certain professions.
+
+
+ AdmissionSyntax ::= SEQUENCE
+ {
+ admissionAuthority GeneralName OPTIONAL,
+ contentsOfAdmissions SEQUENCE OF Admissions
+ }
+
+ Admissions ::= SEQUENCE
+ {
+ admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+ namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+ professionInfos SEQUENCE OF ProfessionInfo
+ }
+
+ NamingAuthority ::= SEQUENCE
+ {
+ namingAuthorityId OBJECT IDENTIFIER OPTIONAL,
+ namingAuthorityUrl IA5String OPTIONAL,
+ namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+ }
+
+ ProfessionInfo ::= SEQUENCE
+ {
+ namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+ professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+ professionOIDs SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+ registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+ addProfessionInfo OCTET STRING OPTIONAL
+ }
+
+
+
+ ISIS-MTT PROFILE: The relatively complex structure of AdmissionSyntax
+ supports the following concepts and requirements:
+
+ - External institutions (e.g. professional associations, chambers, unions,
+ administrative bodies, companies, etc.), which are responsible for granting
+ and verifying professional admissions, are indicated by means of the data
+ field admissionAuthority. An admission authority is indicated by a
+ GeneralName object. Here an X.501 directory name (distinguished name) can be
+ indicated in the field directoryName, a URL address can be indicated in the
+ field uniformResourceIdentifier, and an object identifier can be indicated in
+ the field registeredId.
+ - The names of authorities which are responsible for the administration of
+ title registers are indicated in the data field namingAuthority. The name of
+ the authority can be identified by an object identifier in the field
+ namingAuthorityId, by means of a text string in the field
+ namingAuthorityText, by means of a URL address in the field
+ namingAuthorityUrl, or by a combination of them. For example, the text string
+ can contain the name of the authority, the country and the name of the title
+ register. The URL-option refers to a web page which contains lists with
+ officially registered professions (text and possibly OID) as well as
+ further information on these professions. Object identifiers for the
+ component namingAuthorityId are grouped under the OID-branch
+ id-isis-at-namingAuthorities and must be applied for.
+ - See http://www.teletrust.de/anwend.asp?Id=30200&Sprache=E_&HomePG=0
+ for an application form and http://www.teletrust.de/links.asp?id=30220,11
+ for an overview of registered naming authorities.
+ - By means of the data type ProfessionInfo certain professions,
+ specializations, disciplines, fields of activity, etc. are identified. A
+ profession is represented by one or more text strings, resp. profession OIDs
+ in the fields professionItems and professionOIDs and by a registration number
+ in the field registrationNumber. An indication in text form must always be
+ present, whereas the other indications are optional. The component
+ addProfessionInfo may contain additional applicationspecific information in
+ DER-encoded form.
+
+
+ By means of different namingAuthority-OIDs or profession OIDs hierarchies of
+ professions, specializations, disciplines, fields of activity, etc. can be
+ expressed. The issuing admission authority should always be indicated (field
+ admissionAuthority), whenever a registration number is presented. Still,
+ information on admissions can be given without indicating an admission or a
+ naming authority by the exclusive use of the component professionItems. In
+ this case the certification authority is responsible for the verification of
+ the admission information.
+
+
+
+ This attribute is single-valued. Still, several admissions can be captured in
+ the sequence structure of the component contentsOfAdmissions of
+ AdmissionSyntax or in the component professionInfos of Admissions. The
+ component admissionAuthority of AdmissionSyntax serves as default value for
+ the component admissionAuthority of Admissions. Within the latter component
+ the default value can be overwritten, in case that another authority is
+ responsible. The component namingAuthority of Admissions serves as a default
+ value for the component namingAuthority of ProfessionInfo. Within the latter
+ component the default value can be overwritten, in case that another naming
+ authority needs to be recorded.
+
+ The length of the string objects is limited to 128 characters. It is
+ recommended to indicate a namingAuthorityURL in all issued attribute
+ certificates. If a namingAuthorityURL is indicated, the field professionItems
+ of ProfessionInfo should contain only registered titles. If the field
+ professionOIDs exists, it has to contain the OIDs of the professions listed
+ in professionItems in the same order. In general, the field professionInfos
+ should contain only one entry, unless the admissions that are to be listed
+ are logically connected (e.g. they have been issued under the same admission
+ number).
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.Admissions
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.ProfessionInfo
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.NamingAuthority
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type ProcurationSyntax:
+
+
+ AdmissionSyntax ::= SEQUENCE
+ {
+ admissionAuthority GeneralName OPTIONAL,
+ contentsOfAdmissions SEQUENCE OF Admissions
+ }
+
+ Admissions ::= SEQUENCE
+ {
+ admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+ namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+ professionInfos SEQUENCE OF ProfessionInfo
+ }
+
+ NamingAuthority ::= SEQUENCE
+ {
+ namingAuthorityId OBJECT IDENTIFIER OPTIONAL,
+ namingAuthorityUrl IA5String OPTIONAL,
+ namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+ }
+
+ ProfessionInfo ::= SEQUENCE
+ {
+ namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+ professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+ professionOIDs SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+ registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+ addProfessionInfo OCTET STRING OPTIONAL
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from given details.
+
+ @param admissionAuthority The admission authority.
+ @param contentsOfAdmissions The admissions.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ AdmissionSyntax ::= SEQUENCE
+ {
+ admissionAuthority GeneralName OPTIONAL,
+ contentsOfAdmissions SEQUENCE OF Admissions
+ }
+
+ Admissions ::= SEQUENCE
+ {
+ admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+ namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+ professionInfos SEQUENCE OF ProfessionInfo
+ }
+
+ NamingAuthority ::= SEQUENCE
+ {
+ namingAuthorityId OBJECT IDENTIFIER OPTIONAL,
+ namingAuthorityUrl IA5String OPTIONAL,
+ namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+ }
+
+ ProfessionInfo ::= SEQUENCE
+ {
+ namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+ professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+ professionOIDs SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+ registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+ addProfessionInfo OCTET STRING OPTIONAL
+ }
+
+
+ @return an Asn1Object
+
+
+ @return Returns the admissionAuthority if present, null otherwise.
+
+
+ @return Returns the contentsOfAdmissions.
+
+
+ An Admissions structure.
+
+
+ Admissions ::= SEQUENCE
+ {
+ admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+ namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+ professionInfos SEQUENCE OF ProfessionInfo
+ }
+
+
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.AdmissionSyntax
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.ProfessionInfo
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.NamingAuthority
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type ProcurationSyntax:
+
+
+ Admissions ::= SEQUENCE
+ {
+ admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+ namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+ professionInfos SEQUENCE OF ProfessionInfo
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from a given details.
+
+ Parameter professionInfos
is mandatory.
+
+ @param admissionAuthority The admission authority.
+ @param namingAuthority The naming authority.
+ @param professionInfos The profession infos.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ Admissions ::= SEQUENCE
+ {
+ admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+ namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+ professionInfos SEQUENCE OF ProfessionInfo
+ }
+
+
+
+ @return an Asn1Object
+
+
+ A declaration of majority.
+
+
+ DeclarationOfMajoritySyntax ::= CHOICE
+ {
+ notYoungerThan [0] IMPLICIT INTEGER,
+ fullAgeAtCountry [1] IMPLICIT SEQUENCE
+ {
+ fullAge BOOLEAN DEFAULT TRUE,
+ country PrintableString (SIZE(2))
+ }
+ dateOfBirth [2] IMPLICIT GeneralizedTime
+ }
+
+
+ fullAgeAtCountry indicates the majority of the owner with respect to the laws
+ of a specific country.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ DeclarationOfMajoritySyntax ::= CHOICE
+ {
+ notYoungerThan [0] IMPLICIT INTEGER,
+ fullAgeAtCountry [1] IMPLICIT SEQUENCE
+ {
+ fullAge BOOLEAN DEFAULT TRUE,
+ country PrintableString (SIZE(2))
+ }
+ dateOfBirth [2] IMPLICIT GeneralizedTime
+ }
+
+
+ @return an Asn1Object
+
+
+ @return notYoungerThan if that's what we are, -1 otherwise
+
+
+ Monetary limit for transactions. The QcEuMonetaryLimit QC statement MUST be
+ used in new certificates in place of the extension/attribute MonetaryLimit
+ since January 1, 2004. For the sake of backward compatibility with
+ certificates already in use, components SHOULD support MonetaryLimit (as well
+ as QcEuLimitValue).
+
+ Indicates a monetary limit within which the certificate holder is authorized
+ to act. (This value DOES NOT express a limit on the liability of the
+ certification authority).
+
+
+ MonetaryLimitSyntax ::= SEQUENCE
+ {
+ currency PrintableString (SIZE(3)),
+ amount INTEGER,
+ exponent INTEGER
+ }
+
+
+ currency must be the ISO code.
+
+ value = amount�10*exponent
+
+
+ Constructor from a given details.
+
+
+ value = amount�10^exponent
+
+ @param currency The currency. Must be the ISO code.
+ @param amount The amount
+ @param exponent The exponent
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ MonetaryLimitSyntax ::= SEQUENCE
+ {
+ currency PrintableString (SIZE(3)),
+ amount INTEGER,
+ exponent INTEGER
+ }
+
+
+ @return an Asn1Object
+
+
+ Names of authorities which are responsible for the administration of title
+ registers.
+
+
+ NamingAuthority ::= SEQUENCE
+ {
+ namingAuthorityID OBJECT IDENTIFIER OPTIONAL,
+ namingAuthorityUrl IA5String OPTIONAL,
+ namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+ }
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.AdmissionSyntax
+
+
+
+ Profession OIDs should always be defined under the OID branch of the
+ responsible naming authority. At the time of this writing, the work group
+ �Recht, Wirtschaft, Steuern� (�Law, Economy, Taxes�) is registered as the
+ first naming authority under the OID id-isismtt-at-namingAuthorities.
+
+
+ Constructor from Asn1Sequence.
+
+
+
+ NamingAuthority ::= SEQUENCE
+ {
+ namingAuthorityID OBJECT IDENTIFIER OPTIONAL,
+ namingAuthorityUrl IA5String OPTIONAL,
+ namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ @return Returns the namingAuthorityID.
+
+
+ @return Returns the namingAuthorityText.
+
+
+ @return Returns the namingAuthorityUrl.
+
+
+ Constructor from given details.
+
+ All parameters can be combined.
+
+ @param namingAuthorityID ObjectIdentifier for naming authority.
+ @param namingAuthorityUrl URL for naming authority.
+ @param namingAuthorityText Textual representation of naming authority.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ NamingAuthority ::= SEQUENCE
+ {
+ namingAuthorityID OBJECT IDENTIFIER OPTIONAL,
+ namingAuthorityUrl IA5String OPTIONAL,
+ namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+ }
+
+
+ @return an Asn1Object
+
+
+ Attribute to indicate that the certificate holder may sign in the name of a
+ third person.
+
+ ISIS-MTT PROFILE: The corresponding ProcurationSyntax contains either the
+ name of the person who is represented (subcomponent thirdPerson) or a
+ reference to his/her base certificate (in the component signingFor,
+ subcomponent certRef), furthermore the optional components country and
+ typeSubstitution to indicate the country whose laws apply, and respectively
+ the type of procuration (e.g. manager, procuration, custody).
+
+
+ ISIS-MTT PROFILE: The GeneralName MUST be of type directoryName and MAY only
+ contain: - RFC3039 attributes, except pseudonym (countryName, commonName,
+ surname, givenName, serialNumber, organizationName, organizationalUnitName,
+ stateOrProvincename, localityName, postalAddress) and - SubjectDirectoryName
+ attributes (title, dateOfBirth, placeOfBirth, gender, countryOfCitizenship,
+ countryOfResidence and NameAtBirth).
+
+
+ ProcurationSyntax ::= SEQUENCE {
+ country [1] EXPLICIT PrintableString(SIZE(2)) OPTIONAL,
+ typeOfSubstitution [2] EXPLICIT DirectoryString (SIZE(1..128)) OPTIONAL,
+ signingFor [3] EXPLICIT SigningFor
+ }
+
+ SigningFor ::= CHOICE
+ {
+ thirdPerson GeneralName,
+ certRef IssuerSerial
+ }
+
+
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type ProcurationSyntax:
+
+
+ ProcurationSyntax ::= SEQUENCE {
+ country [1] EXPLICIT PrintableString(SIZE(2)) OPTIONAL,
+ typeOfSubstitution [2] EXPLICIT DirectoryString (SIZE(1..128)) OPTIONAL,
+ signingFor [3] EXPLICIT SigningFor
+ }
+
+ SigningFor ::= CHOICE
+ {
+ thirdPerson GeneralName,
+ certRef IssuerSerial
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from a given details.
+
+
+ Either generalName
or certRef
MUST be
+ null
.
+
+ @param country The country code whose laws apply.
+ @param typeOfSubstitution The type of procuration.
+ @param certRef Reference to certificate of the person who is represented.
+
+
+ Constructor from a given details.
+
+
+ Either generalName
or certRef
MUST be
+ null
.
+
+ @param country The country code whose laws apply.
+ @param typeOfSubstitution The type of procuration.
+ @param thirdPerson The GeneralName of the person who is represented.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ ProcurationSyntax ::= SEQUENCE {
+ country [1] EXPLICIT PrintableString(SIZE(2)) OPTIONAL,
+ typeOfSubstitution [2] EXPLICIT DirectoryString (SIZE(1..128)) OPTIONAL,
+ signingFor [3] EXPLICIT SigningFor
+ }
+
+ SigningFor ::= CHOICE
+ {
+ thirdPerson GeneralName,
+ certRef IssuerSerial
+ }
+
+
+ @return an Asn1Object
+
+
+ Professions, specializations, disciplines, fields of activity, etc.
+
+
+ ProfessionInfo ::= SEQUENCE
+ {
+ namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+ professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+ professionOids SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+ registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+ addProfessionInfo OCTET STRING OPTIONAL
+ }
+
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.AdmissionSyntax
+
+
+ Rechtsanw�ltin
+
+
+ Rechtsanwalt
+
+
+ Rechtsbeistand
+
+
+ Steuerberaterin
+
+
+ Steuerberater
+
+
+ Steuerbevollm�chtigte
+
+
+ Steuerbevollm�chtigter
+
+
+ Notarin
+
+
+ Notar
+
+
+ Notarvertreterin
+
+
+ Notarvertreter
+
+
+ Notariatsverwalterin
+
+
+ Notariatsverwalter
+
+
+ Wirtschaftspr�ferin
+
+
+ Wirtschaftspr�fer
+
+
+ Vereidigte Buchpr�ferin
+
+
+ Vereidigter Buchpr�fer
+
+
+ Patentanw�ltin
+
+
+ Patentanwalt
+
+
+ Constructor from Asn1Sequence.
+
+
+
+ ProfessionInfo ::= SEQUENCE
+ {
+ namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+ professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+ professionOids SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+ registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+ addProfessionInfo OCTET STRING OPTIONAL
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from given details.
+
+ professionItems
is mandatory, all other parameters are
+ optional.
+
+ @param namingAuthority The naming authority.
+ @param professionItems Directory strings of the profession.
+ @param professionOids DERObjectIdentfier objects for the
+ profession.
+ @param registrationNumber Registration number.
+ @param addProfessionInfo Additional infos in encoded form.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ ProfessionInfo ::= SEQUENCE
+ {
+ namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+ professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+ professionOids SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+ registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+ addProfessionInfo OCTET STRING OPTIONAL
+ }
+
+
+ @return an Asn1Object
+
+
+ @return Returns the addProfessionInfo.
+
+
+ @return Returns the namingAuthority.
+
+
+ @return Returns the professionItems.
+
+
+ @return Returns the professionOids.
+
+
+ @return Returns the registrationNumber.
+
+
+ Some other restriction regarding the usage of this certificate.
+
+
+ RestrictionSyntax ::= DirectoryString (SIZE(1..1024))
+
+
+
+ Constructor from DirectoryString.
+
+ The DirectoryString is of type RestrictionSyntax:
+
+
+ RestrictionSyntax ::= DirectoryString (SIZE(1..1024))
+
+
+ @param restriction A IAsn1String.
+
+
+ Constructor from a given details.
+
+ @param restriction The description of the restriction.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ RestrictionSyntax ::= DirectoryString (SIZE(1..1024))
+
+
+
+ @return an Asn1Object
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ cast5CBCParameters ::= Sequence {
+ iv OCTET STRING DEFAULT 0,
+ -- Initialization vector
+ keyLength Integer
+ -- Key length, in bits
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ IDEA-CBCPar ::= Sequence {
+ iv OCTET STRING OPTIONAL -- exactly 8 octets
+ }
+
+
+
+ The NetscapeCertType object.
+
+ NetscapeCertType ::= BIT STRING {
+ SSLClient (0),
+ SSLServer (1),
+ S/MIME (2),
+ Object Signing (3),
+ Reserved (4),
+ SSL CA (5),
+ S/MIME CA (6),
+ Object Signing CA (7) }
+
+
+
+ Basic constructor.
+
+ @param usage - the bitwise OR of the Key Usage flags giving the
+ allowed uses for the key.
+ e.g. (X509NetscapeCertType.sslCA | X509NetscapeCertType.smimeCA)
+
+
+ This is designed to parse
+ the PublicKeyAndChallenge created by the KEYGEN tag included by
+ Mozilla based browsers.
+
+ PublicKeyAndChallenge ::= SEQUENCE {
+ spki SubjectPublicKeyInfo,
+ challenge IA5STRING
+ }
+
+
+
+
+ Utility class for fetching curves using their NIST names as published in FIPS-PUB 186-3
+
+
+ return the X9ECParameters object for the named curve represented by
+ the passed in object identifier. Null if the curve isn't present.
+
+ @param oid an object identifier representing a named curve, if present.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+ From RFC 3657
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ BasicOcspResponse ::= Sequence {
+ tbsResponseData ResponseData,
+ signatureAlgorithm AlgorithmIdentifier,
+ signature BIT STRING,
+ certs [0] EXPLICIT Sequence OF Certificate OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ CertID ::= Sequence {
+ hashAlgorithm AlgorithmIdentifier,
+ issuerNameHash OCTET STRING, -- Hash of Issuer's DN
+ issuerKeyHash OCTET STRING, -- Hash of Issuers public key
+ serialNumber CertificateSerialNumber }
+
+
+
+ create a CertStatus object with a tag of zero.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ CertStatus ::= CHOICE {
+ good [0] IMPLICIT Null,
+ revoked [1] IMPLICIT RevokedInfo,
+ unknown [2] IMPLICIT UnknownInfo }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ CrlID ::= Sequence {
+ crlUrl [0] EXPLICIT IA5String OPTIONAL,
+ crlNum [1] EXPLICIT Integer OPTIONAL,
+ crlTime [2] EXPLICIT GeneralizedTime OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OcspRequest ::= Sequence {
+ tbsRequest TBSRequest,
+ optionalSignature [0] EXPLICIT Signature OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OcspResponse ::= Sequence {
+ responseStatus OcspResponseStatus,
+ responseBytes [0] EXPLICIT ResponseBytes OPTIONAL }
+
+
+
+ The OcspResponseStatus enumeration.
+
+ OcspResponseStatus ::= Enumerated {
+ successful (0), --Response has valid confirmations
+ malformedRequest (1), --Illegal confirmation request
+ internalError (2), --Internal error in issuer
+ tryLater (3), --Try again later
+ --(4) is not used
+ sigRequired (5), --Must sign the request
+ unauthorized (6) --Request unauthorized
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Request ::= Sequence {
+ reqCert CertID,
+ singleRequestExtensions [0] EXPLICIT Extensions OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ResponderID ::= CHOICE {
+ byName [1] Name,
+ byKey [2] KeyHash }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ResponseBytes ::= Sequence {
+ responseType OBJECT IDENTIFIER,
+ response OCTET STRING }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ResponseData ::= Sequence {
+ version [0] EXPLICIT Version DEFAULT v1,
+ responderID ResponderID,
+ producedAt GeneralizedTime,
+ responses Sequence OF SingleResponse,
+ responseExtensions [1] EXPLICIT Extensions OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ RevokedInfo ::= Sequence {
+ revocationTime GeneralizedTime,
+ revocationReason [0] EXPLICIT CRLReason OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ServiceLocator ::= Sequence {
+ issuer Name,
+ locator AuthorityInfoAccessSyntax OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Signature ::= Sequence {
+ signatureAlgorithm AlgorithmIdentifier,
+ signature BIT STRING,
+ certs [0] EXPLICIT Sequence OF Certificate OPTIONAL}
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SingleResponse ::= Sequence {
+ certID CertID,
+ certStatus CertStatus,
+ thisUpdate GeneralizedTime,
+ nextUpdate [0] EXPLICIT GeneralizedTime OPTIONAL,
+ singleExtensions [1] EXPLICIT Extensions OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ TBSRequest ::= Sequence {
+ version [0] EXPLICIT Version DEFAULT v1,
+ requestorName [1] EXPLICIT GeneralName OPTIONAL,
+ requestList Sequence OF Request,
+ requestExtensions [2] EXPLICIT Extensions OPTIONAL }
+
+
+
+ return an Attribute object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Attr ::= Sequence {
+ attrType OBJECT IDENTIFIER,
+ attrValues Set OF AttributeValue
+ }
+
+
+
+ Pkcs10 Certfication request object.
+
+ CertificationRequest ::= Sequence {
+ certificationRequestInfo CertificationRequestInfo,
+ signatureAlgorithm AlgorithmIdentifier{{ SignatureAlgorithms }},
+ signature BIT STRING
+ }
+
+
+
+ Pkcs10 CertificationRequestInfo object.
+
+ CertificationRequestInfo ::= Sequence {
+ version Integer { v1(0) } (v1,...),
+ subject Name,
+ subjectPKInfo SubjectPublicKeyInfo{{ PKInfoAlgorithms }},
+ attributes [0] Attributes{{ CRIAttributes }}
+ }
+
+ Attributes { ATTRIBUTE:IOSet } ::= Set OF Attr{{ IOSet }}
+
+ Attr { ATTRIBUTE:IOSet } ::= Sequence {
+ type ATTRIBUTE.&id({IOSet}),
+ values Set SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{\@type})
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ContentInfo ::= Sequence {
+ contentType ContentType,
+ content
+ [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL }
+
+
+
+ The EncryptedData object.
+
+ EncryptedData ::= Sequence {
+ version Version,
+ encryptedContentInfo EncryptedContentInfo
+ }
+
+
+ EncryptedContentInfo ::= Sequence {
+ contentType ContentType,
+ contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,
+ encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL
+ }
+
+ EncryptedContent ::= OCTET STRING
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ EncryptedPrivateKeyInfo ::= Sequence {
+ encryptionAlgorithm AlgorithmIdentifier {{KeyEncryptionAlgorithms}},
+ encryptedData EncryptedData
+ }
+
+ EncryptedData ::= OCTET STRING
+
+ KeyEncryptionAlgorithms ALGORITHM-IDENTIFIER ::= {
+ ... -- For local profiles
+ }
+
+
+
+
+ MacData ::= SEQUENCE {
+ mac DigestInfo,
+ macSalt OCTET STRING,
+ iterations INTEGER DEFAULT 1
+ -- Note: The default is for historic reasons and its use is deprecated. A
+ -- higher value, like 1024 is recommended.
+
+ @return the basic DERObject construction.
+
+
+ the infamous Pfx from Pkcs12
+
+
+ write out an RSA private key with its associated information
+ as described in Pkcs8.
+
+ PrivateKeyInfo ::= Sequence {
+ version Version,
+ privateKeyAlgorithm AlgorithmIdentifier {{PrivateKeyAlgorithms}},
+ privateKey PrivateKey,
+ attributes [0] IMPLICIT Attributes OPTIONAL
+ }
+ Version ::= Integer {v1(0)} (v1,...)
+
+ PrivateKey ::= OCTET STRING
+
+ Attributes ::= Set OF Attr
+
+
+
+ The default version
+
+
+
+ RSAES-OAEP-params ::= SEQUENCE {
+ hashAlgorithm [0] OAEP-PSSDigestAlgorithms DEFAULT sha1,
+ maskGenAlgorithm [1] PKCS1MGFAlgorithms DEFAULT mgf1SHA1,
+ pSourceAlgorithm [2] PKCS1PSourceAlgorithms DEFAULT pSpecifiedEmpty
+ }
+
+ OAEP-PSSDigestAlgorithms ALGORITHM-IDENTIFIER ::= {
+ { OID id-sha1 PARAMETERS NULL }|
+ { OID id-sha256 PARAMETERS NULL }|
+ { OID id-sha384 PARAMETERS NULL }|
+ { OID id-sha512 PARAMETERS NULL },
+ ... -- Allows for future expansion --
+ }
+ PKCS1MGFAlgorithms ALGORITHM-IDENTIFIER ::= {
+ { OID id-mgf1 PARAMETERS OAEP-PSSDigestAlgorithms },
+ ... -- Allows for future expansion --
+ }
+ PKCS1PSourceAlgorithms ALGORITHM-IDENTIFIER ::= {
+ { OID id-pSpecified PARAMETERS OCTET STRING },
+ ... -- Allows for future expansion --
+ }
+
+ @return the asn1 primitive representing the parameters.
+
+
+ This outputs the key in Pkcs1v2 format.
+
+ RsaPrivateKey ::= Sequence {
+ version Version,
+ modulus Integer, -- n
+ publicExponent Integer, -- e
+ privateExponent Integer, -- d
+ prime1 Integer, -- p
+ prime2 Integer, -- q
+ exponent1 Integer, -- d mod (p-1)
+ exponent2 Integer, -- d mod (q-1)
+ coefficient Integer -- (inverse of q) mod p
+ }
+
+ Version ::= Integer
+
+ This routine is written to output Pkcs1 version 0, private keys.
+
+
+ The default version
+
+
+
+ RSASSA-PSS-params ::= SEQUENCE {
+ hashAlgorithm [0] OAEP-PSSDigestAlgorithms DEFAULT sha1,
+ maskGenAlgorithm [1] PKCS1MGFAlgorithms DEFAULT mgf1SHA1,
+ saltLength [2] INTEGER DEFAULT 20,
+ trailerField [3] TrailerField DEFAULT trailerFieldBC
+ }
+
+ OAEP-PSSDigestAlgorithms ALGORITHM-IDENTIFIER ::= {
+ { OID id-sha1 PARAMETERS NULL }|
+ { OID id-sha256 PARAMETERS NULL }|
+ { OID id-sha384 PARAMETERS NULL }|
+ { OID id-sha512 PARAMETERS NULL },
+ ... -- Allows for future expansion --
+ }
+
+ PKCS1MGFAlgorithms ALGORITHM-IDENTIFIER ::= {
+ { OID id-mgf1 PARAMETERS OAEP-PSSDigestAlgorithms },
+ ... -- Allows for future expansion --
+ }
+
+ TrailerField ::= INTEGER { trailerFieldBC(1) }
+
+ @return the asn1 primitive representing the parameters.
+
+
+ a Pkcs#7 signed data object.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SignedData ::= Sequence {
+ version Version,
+ digestAlgorithms DigestAlgorithmIdentifiers,
+ contentInfo ContentInfo,
+ certificates
+ [0] IMPLICIT ExtendedCertificatesAndCertificates
+ OPTIONAL,
+ crls
+ [1] IMPLICIT CertificateRevocationLists OPTIONAL,
+ signerInfos SignerInfos }
+
+
+
+ a Pkcs#7 signer info object.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SignerInfo ::= Sequence {
+ version Version,
+ issuerAndSerialNumber IssuerAndSerialNumber,
+ digestAlgorithm DigestAlgorithmIdentifier,
+ authenticatedAttributes [0] IMPLICIT Attributes OPTIONAL,
+ digestEncryptionAlgorithm DigestEncryptionAlgorithmIdentifier,
+ encryptedDigest EncryptedDigest,
+ unauthenticatedAttributes [1] IMPLICIT Attributes OPTIONAL
+ }
+
+ EncryptedDigest ::= OCTET STRING
+
+ DigestAlgorithmIdentifier ::= AlgorithmIdentifier
+
+ DigestEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier
+
+
+
+ the elliptic curve private key object from SEC 1
+
+
+ ECPrivateKey ::= SEQUENCE {
+ version INTEGER { ecPrivkeyVer1(1) } (ecPrivkeyVer1),
+ privateKey OCTET STRING,
+ parameters [0] Parameters OPTIONAL,
+ publicKey [1] BIT STRING OPTIONAL }
+
+
+ return the X9ECParameters object for the named curve represented by
+ the passed in object identifier. Null if the curve isn't present.
+
+ @param oid an object identifier representing a named curve, if present.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+ EllipticCurve OBJECT IDENTIFIER ::= {
+ iso(1) identified-organization(3) certicom(132) curve(0)
+ }
+
+
+ Handler class for dealing with S/MIME Capabilities
+
+
+ general preferences
+
+
+ encryption algorithms preferences
+
+
+ return an Attr object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ returns an ArrayList with 0 or more objects of all the capabilities
+ matching the passed in capability Oid. If the Oid passed is null the
+ entire set is returned.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SMIMECapabilities ::= Sequence OF SMIMECapability
+
+
+
+ general preferences
+
+
+ encryption algorithms preferences
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SMIMECapability ::= Sequence {
+ capabilityID OBJECT IDENTIFIER,
+ parameters ANY DEFINED BY capabilityID OPTIONAL
+ }
+
+
+
+ Handler for creating a vector S/MIME Capabilities
+
+
+ The SmimeEncryptionKeyPreference object.
+
+ SmimeEncryptionKeyPreference ::= CHOICE {
+ issuerAndSerialNumber [0] IssuerAndSerialNumber,
+ receipentKeyId [1] RecipientKeyIdentifier,
+ subjectAltKeyIdentifier [2] SubjectKeyIdentifier
+ }
+
+
+
+ @param sKeyId the subjectKeyIdentifier value (normally the X.509 one)
+
+
+ elliptic curves defined in "ECC Brainpool Standard Curves and Curve Generation"
+ http://www.ecc-brainpool.org/download/draft_pkix_additional_ecc_dp.txt
+
+
+ return the X9ECParameters object for the named curve represented by
+ the passed in object identifier. Null if the curve isn't present.
+
+ @param oid an object identifier representing a named curve, if present.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+
+ Accuracy ::= SEQUENCE {
+ seconds INTEGER OPTIONAL,
+ millis [0] INTEGER (1..999) OPTIONAL,
+ micros [1] INTEGER (1..999) OPTIONAL
+ }
+
+
+
+ @param o
+ @return a MessageImprint object.
+
+
+
+ MessageImprint ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ hashedMessage OCTET STRING }
+
+
+
+
+
+ TstInfo ::= SEQUENCE {
+ version INTEGER { v1(1) },
+ policy TSAPolicyId,
+ messageImprint MessageImprint,
+ -- MUST have the same value as the similar field in
+ -- TimeStampReq
+ serialNumber INTEGER,
+ -- Time-Stamping users MUST be ready to accommodate integers
+ -- up to 160 bits.
+ genTime GeneralizedTime,
+ accuracy Accuracy OPTIONAL,
+ ordering BOOLEAN DEFAULT FALSE,
+ nonce INTEGER OPTIONAL,
+ -- MUST be present if the similar field was present
+ -- in TimeStampReq. In that case it MUST have the same value.
+ tsa [0] GeneralName OPTIONAL,
+ extensions [1] IMPLICIT Extensions OPTIONAL }
+
+
+
+
+
+ TimeStampReq ::= SEQUENCE {
+ version INTEGER { v1(1) },
+ messageImprint MessageImprint,
+ --a hash algorithm OID and the hash value of the data to be
+ --time-stamped
+ reqPolicy TSAPolicyId OPTIONAL,
+ nonce INTEGER OPTIONAL,
+ certReq BOOLEAN DEFAULT FALSE,
+ extensions [0] IMPLICIT Extensions OPTIONAL
+ }
+
+
+
+
+ TimeStampResp ::= SEQUENCE {
+ status PkiStatusInfo,
+ timeStampToken TimeStampToken OPTIONAL }
+
+
+
+ dump a Der object as a formatted string with indentation
+
+ @param obj the Asn1Object to be dumped out.
+
+
+ dump out a DER object as a formatted string, in non-verbose mode
+
+ @param obj the Asn1Encodable to be dumped out.
+ @return the resulting string.
+
+
+ Dump out the object as a string
+
+ @param obj the Asn1Encodable to be dumped out.
+ @param verbose if true, dump out the contents of octet and bit strings.
+ @return the resulting string.
+
+
+
+ DirectoryString ::= CHOICE {
+ teletexString TeletexString (SIZE (1..MAX)),
+ printableString PrintableString (SIZE (1..MAX)),
+ universalString UniversalString (SIZE (1..MAX)),
+ utf8String UTF8String (SIZE (1..MAX)),
+ bmpString BMPString (SIZE (1..MAX)) }
+
+
+
+ The AccessDescription object.
+
+ AccessDescription ::= SEQUENCE {
+ accessMethod OBJECT IDENTIFIER,
+ accessLocation GeneralName }
+
+
+
+ create an AccessDescription with the oid and location provided.
+
+
+
+ @return the access method.
+
+
+
+ @return the access location
+
+
+
+ Return the OID in the Algorithm entry of this identifier.
+
+
+
+
+ Return the parameters structure in the Parameters entry of this identifier.
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AlgorithmIdentifier ::= Sequence {
+ algorithm OBJECT IDENTIFIER,
+ parameters ANY DEFINED BY algorithm OPTIONAL }
+
+
+
+
+ Don't use this one if you are trying to be RFC 3281 compliant.
+ Use it for v1 attribute certificates only.
+
+ Our GeneralNames structure
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AttCertIssuer ::= CHOICE {
+ v1Form GeneralNames, -- MUST NOT be used in this
+ -- profile
+ v2Form [0] V2Form -- v2 only
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AttCertValidityPeriod ::= Sequence {
+ notBeforeTime GeneralizedTime,
+ notAfterTime GeneralizedTime
+ }
+
+
+
+ return an Attr object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Attr ::= Sequence {
+ attrType OBJECT IDENTIFIER,
+ attrValues Set OF AttributeValue
+ }
+
+
+
+ @param obj
+ @return
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AttributeCertificate ::= Sequence {
+ acinfo AttributeCertificateInfo,
+ signatureAlgorithm AlgorithmIdentifier,
+ signatureValue BIT STRING
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AttributeCertificateInfo ::= Sequence {
+ version AttCertVersion -- version is v2,
+ holder Holder,
+ issuer AttCertIssuer,
+ signature AlgorithmIdentifier,
+ serialNumber CertificateSerialNumber,
+ attrCertValidityPeriod AttCertValidityPeriod,
+ attributes Sequence OF Attr,
+ issuerUniqueID UniqueIdentifier OPTIONAL,
+ extensions Extensions OPTIONAL
+ }
+
+ AttCertVersion ::= Integer { v2(1) }
+
+
+
+ The AuthorityInformationAccess object.
+
+ id-pe-authorityInfoAccess OBJECT IDENTIFIER ::= { id-pe 1 }
+
+ AuthorityInfoAccessSyntax ::=
+ Sequence SIZE (1..MAX) OF AccessDescription
+ AccessDescription ::= Sequence {
+ accessMethod OBJECT IDENTIFIER,
+ accessLocation GeneralName }
+
+ id-ad OBJECT IDENTIFIER ::= { id-pkix 48 }
+ id-ad-caIssuers OBJECT IDENTIFIER ::= { id-ad 2 }
+ id-ad-ocsp OBJECT IDENTIFIER ::= { id-ad 1 }
+
+
+
+ create an AuthorityInformationAccess with the oid and location provided.
+
+
+ The AuthorityKeyIdentifier object.
+
+ id-ce-authorityKeyIdentifier OBJECT IDENTIFIER ::= { id-ce 35 }
+
+ AuthorityKeyIdentifier ::= Sequence {
+ keyIdentifier [0] IMPLICIT KeyIdentifier OPTIONAL,
+ authorityCertIssuer [1] IMPLICIT GeneralNames OPTIONAL,
+ authorityCertSerialNumber [2] IMPLICIT CertificateSerialNumber OPTIONAL }
+
+ KeyIdentifier ::= OCTET STRING
+
+
+
+
+ *
+ * Calulates the keyidentifier using a SHA1 hash over the BIT STRING
+ * from SubjectPublicKeyInfo as defined in RFC2459.
+ *
+ * Example of making a AuthorityKeyIdentifier:
+ *
+ * SubjectPublicKeyInfo apki = new SubjectPublicKeyInfo((ASN1Sequence)new ASN1InputStream(
+ * publicKey.getEncoded()).readObject());
+ * AuthorityKeyIdentifier aki = new AuthorityKeyIdentifier(apki);
+ *
+ *
+ *
+
+
+ create an AuthorityKeyIdentifier with the GeneralNames tag and
+ the serial number provided as well.
+
+
+ create an AuthorityKeyIdentifier with the GeneralNames tag and
+ the serial number provided.
+
+
+ create an AuthorityKeyIdentifier with a precomputed key identifier
+
+
+ create an AuthorityKeyIdentifier with a precomupted key identifier
+ and the GeneralNames tag and the serial number provided as well.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+
+ create a cA=true object for the given path length constraint.
+
+ @param pathLenConstraint
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ BasicConstraints := Sequence {
+ cA Boolean DEFAULT FALSE,
+ pathLenConstraint Integer (0..MAX) OPTIONAL
+ }
+
+
+
+ Return the distribution points making up the sequence.
+
+ @return DistributionPoint[]
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ CrlDistPoint ::= Sequence SIZE {1..MAX} OF DistributionPoint
+
+
+
+ The CRLNumber object.
+
+ CRLNumber::= Integer(0..MAX)
+
+
+
+ The CRLReason enumeration.
+
+ CRLReason ::= Enumerated {
+ unspecified (0),
+ keyCompromise (1),
+ cACompromise (2),
+ affiliationChanged (3),
+ superseded (4),
+ cessationOfOperation (5),
+ certificateHold (6),
+ removeFromCRL (8),
+ privilegeWithdrawn (9),
+ aACompromise (10)
+ }
+
+
+
+ CertPolicyId, used in the CertificatePolicies and PolicyMappings
+ X509V3 Extensions.
+
+
+ CertPolicyId ::= OBJECT IDENTIFIER
+
+
+
+ PKIX RFC-2459
+
+ The X.509 v2 CRL syntax is as follows. For signature calculation,
+ the data that is to be signed is ASN.1 Der encoded.
+
+
+ CertificateList ::= Sequence {
+ tbsCertList TbsCertList,
+ signatureAlgorithm AlgorithmIdentifier,
+ signatureValue BIT STRING }
+
+
+
+ This class helps to support crossCerfificatePairs in a LDAP directory
+ according RFC 2587
+
+
+ crossCertificatePairATTRIBUTE::={
+ WITH SYNTAX CertificatePair
+ EQUALITY MATCHING RULE certificatePairExactMatch
+ ID joint-iso-ccitt(2) ds(5) attributeType(4) crossCertificatePair(40)}
+
+
+ The forward elements of the crossCertificatePair attribute of a
+ CA's directory entry shall be used to store all, except self-issued
+ certificates issued to this CA. Optionally, the reverse elements of the
+ crossCertificatePair attribute, of a CA's directory entry may contain a
+ subset of certificates issued by this CA to other CAs. When both the forward
+ and the reverse elements are present in a single attribute value, issuer name
+ in one certificate shall match the subject name in the other and vice versa,
+ and the subject public key in one certificate shall be capable of verifying
+ the digital signature on the other certificate and vice versa.
+
+ When a reverse element is present, the forward element value and the reverse
+ element value need not be stored in the same attribute value; in other words,
+ they can be stored in either a single attribute value or two attribute
+ values.
+
+
+ CertificatePair ::= SEQUENCE {
+ forward [0] Certificate OPTIONAL,
+ reverse [1] Certificate OPTIONAL,
+ -- at least one of the pair shall be present -- }
+
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type CertificatePair:
+
+
+ CertificatePair ::= SEQUENCE {
+ forward [0] Certificate OPTIONAL,
+ reverse [1] Certificate OPTIONAL,
+ -- at least one of the pair shall be present -- }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from a given details.
+
+ @param forward Certificates issued to this CA.
+ @param reverse Certificates issued by this CA to other CAs.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ CertificatePair ::= SEQUENCE {
+ forward [0] Certificate OPTIONAL,
+ reverse [1] Certificate OPTIONAL,
+ -- at least one of the pair shall be present -- }
+
+
+ @return a DERObject
+
+
+ @return Returns the forward.
+
+
+ @return Returns the reverse.
+
+
+ Construct a CertificatePolicies object containing one PolicyInformation.
+
+ @param name the name to be contained.
+
+
+ Produce an object suitable for an ASN1OutputStream.
+
+ CertificatePolicies ::= SEQUENCE SIZE {1..MAX} OF PolicyInformation
+
+
+
+ The DigestInfo object.
+
+ DigestInfo::=Sequence{
+ digestAlgorithm AlgorithmIdentifier,
+ digest OCTET STRING }
+
+
+
+ DisplayText
class, used in
+ CertificatePolicies
X509 V3 extensions (in policy qualifiers).
+
+ It stores a string in a chosen encoding.
+
+ DisplayText ::= CHOICE {
+ ia5String IA5String (SIZE (1..200)),
+ visibleString VisibleString (SIZE (1..200)),
+ bmpString BMPString (SIZE (1..200)),
+ utf8String UTF8String (SIZE (1..200)) }
+
+ @see PolicyQualifierInfo
+ @see PolicyInformation
+
+
+ Constant corresponding to ia5String encoding.
+
+
+
+ Constant corresponding to bmpString encoding.
+
+
+
+ Constant corresponding to utf8String encoding.
+
+
+
+ Constant corresponding to visibleString encoding.
+
+
+
+ Describe constant DisplayTextMaximumSize
here.
+
+
+
+ Creates a new DisplayText
instance.
+
+ @param type the desired encoding type for the text.
+ @param text the text to store. Strings longer than 200
+ characters are truncated.
+
+
+ Creates a new DisplayText
instance.
+
+ @param text the text to encapsulate. Strings longer than 200
+ characters are truncated.
+
+
+ Creates a new DisplayText
instance.
+ Useful when reading back a DisplayText
class
+ from it's Asn1Encodable form.
+
+ @param contents an Asn1Encodable
instance.
+
+
+ Returns the stored string
object.
+
+ @return the stored text as a string
.
+
+
+ The DistributionPoint object.
+
+ DistributionPoint ::= Sequence {
+ distributionPoint [0] DistributionPointName OPTIONAL,
+ reasons [1] ReasonFlags OPTIONAL,
+ cRLIssuer [2] GeneralNames OPTIONAL
+ }
+
+
+
+ The DistributionPointName object.
+
+ DistributionPointName ::= CHOICE {
+ fullName [0] GeneralNames,
+ nameRelativeToCRLIssuer [1] RDN
+ }
+
+
+
+ The extendedKeyUsage object.
+
+ extendedKeyUsage ::= Sequence SIZE (1..MAX) OF KeyPurposeId
+
+
+
+ Returns all extended key usages.
+ The returned ArrayList contains DerObjectIdentifier instances.
+ @return An ArrayList with all key purposes.
+
+
+ The GeneralName object.
+
+ GeneralName ::= CHOICE {
+ otherName [0] OtherName,
+ rfc822Name [1] IA5String,
+ dNSName [2] IA5String,
+ x400Address [3] ORAddress,
+ directoryName [4] Name,
+ ediPartyName [5] EDIPartyName,
+ uniformResourceIdentifier [6] IA5String,
+ iPAddress [7] OCTET STRING,
+ registeredID [8] OBJECT IDENTIFIER}
+
+ OtherName ::= Sequence {
+ type-id OBJECT IDENTIFIER,
+ value [0] EXPLICIT ANY DEFINED BY type-id }
+
+ EDIPartyName ::= Sequence {
+ nameAssigner [0] DirectoryString OPTIONAL,
+ partyName [1] DirectoryString }
+
+
+
+ When the subjectAltName extension contains an Internet mail address,
+ the address MUST be included as an rfc822Name. The format of an
+ rfc822Name is an "addr-spec" as defined in RFC 822 [RFC 822].
+
+ When the subjectAltName extension contains a domain name service
+ label, the domain name MUST be stored in the dNSName (an IA5String).
+ The name MUST be in the "preferred name syntax," as specified by RFC
+ 1034 [RFC 1034].
+
+ When the subjectAltName extension contains a URI, the name MUST be
+ stored in the uniformResourceIdentifier (an IA5String). The name MUST
+ be a non-relative URL, and MUST follow the URL syntax and encoding
+ rules specified in [RFC 1738]. The name must include both a scheme
+ (e.g., "http" or "ftp") and a scheme-specific-part. The scheme-
+ specific-part must include a fully qualified domain name or IP
+ address as the host.
+
+ When the subjectAltName extension contains a iPAddress, the address
+ MUST be stored in the octet string in "network byte order," as
+ specified in RFC 791 [RFC 791]. The least significant bit (LSB) of
+ each octet is the LSB of the corresponding byte in the network
+ address. For IP Version 4, as specified in RFC 791, the octet string
+ MUST contain exactly four octets. For IP Version 6, as specified in
+ RFC 1883, the octet string MUST contain exactly sixteen octets [RFC
+ 1883].
+
+
+ Create a GeneralName for the given tag from the passed in string.
+
+ This constructor can handle:
+
+ - rfc822Name
+ - iPAddress
+ - directoryName
+ - dNSName
+ - uniformResourceIdentifier
+ - registeredID
+
+ For x400Address, otherName and ediPartyName there is no common string
+ format defined.
+
+ Note: A directory name can be encoded in different ways into a byte
+ representation. Be aware of this if the byte representation is used for
+ comparing results.
+
+
+ @param tag tag number
+ @param name string representation of name
+ @throws ArgumentException if the string encoding is not correct or
+ not supported.
+
+
+ Construct a GeneralNames object containing one GeneralName.
+ The name to be contained.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ GeneralNames ::= Sequence SIZE {1..MAX} OF GeneralName
+
+
+
+ Class for containing a restriction object subtrees in NameConstraints. See
+ RFC 3280.
+
+
+
+ GeneralSubtree ::= SEQUENCE
+ {
+ baseName GeneralName,
+ minimum [0] BaseDistance DEFAULT 0,
+ maximum [1] BaseDistance OPTIONAL
+ }
+
+
+ @see org.bouncycastle.asn1.x509.NameConstraints
+
+
+
+ Constructor from a given details.
+
+ According RFC 3280, the minimum and maximum fields are not used with any
+ name forms, thus minimum MUST be zero, and maximum MUST be absent.
+
+ If minimum is null
, zero is assumed, if
+ maximum is null
, maximum is absent.
+
+ @param baseName
+ A restriction.
+ @param minimum
+ Minimum
+
+ @param maximum
+ Maximum
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ GeneralSubtree ::= SEQUENCE
+ {
+ baseName GeneralName,
+ minimum [0] BaseDistance DEFAULT 0,
+ maximum [1] BaseDistance OPTIONAL
+ }
+
+
+ @return a DERObject
+
+
+ The Holder object.
+
+ For an v2 attribute certificate this is:
+
+
+ Holder ::= SEQUENCE {
+ baseCertificateID [0] IssuerSerial OPTIONAL,
+ -- the issuer and serial number of
+ -- the holder's Public Key Certificate
+ entityName [1] GeneralNames OPTIONAL,
+ -- the name of the claimant or role
+ objectDigestInfo [2] ObjectDigestInfo OPTIONAL
+ -- used to directly authenticate the holder,
+ -- for example, an executable
+ }
+
+
+
+ For an v1 attribute certificate this is:
+
+
+ subject CHOICE {
+ baseCertificateID [0] IssuerSerial,
+ -- associated with a Public Key Certificate
+ subjectName [1] GeneralNames },
+ -- associated with a name
+
+
+
+
+ Constructor for a holder for an v1 attribute certificate.
+
+ @param tagObj The ASN.1 tagged holder object.
+
+
+ Constructor for a holder for an v2 attribute certificate. *
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructs a holder from a IssuerSerial.
+ @param baseCertificateID The IssuerSerial.
+ @param version The version of the attribute certificate.
+
+
+ Returns 1 for v2 attribute certificates or 0 for v1 attribute
+ certificates.
+ @return The version of the attribute certificate.
+
+
+ Constructs a holder with an entityName for v2 attribute certificates or
+ with a subjectName for v1 attribute certificates.
+
+ @param entityName The entity or subject name.
+
+
+ Constructs a holder with an entityName for v2 attribute certificates or
+ with a subjectName for v1 attribute certificates.
+
+ @param entityName The entity or subject name.
+ @param version The version of the attribute certificate.
+
+
+ Constructs a holder from an object digest info.
+
+ @param objectDigestInfo The object digest info object.
+
+
+ Returns the entityName for an v2 attribute certificate or the subjectName
+ for an v1 attribute certificate.
+
+ @return The entityname or subjectname.
+
+
+ The Holder object.
+
+ Holder ::= Sequence {
+ baseCertificateID [0] IssuerSerial OPTIONAL,
+ -- the issuer and serial number of
+ -- the holder's Public Key Certificate
+ entityName [1] GeneralNames OPTIONAL,
+ -- the name of the claimant or role
+ objectDigestInfo [2] ObjectDigestInfo OPTIONAL
+ -- used to directly authenticate the holder,
+ -- for example, an executable
+ }
+
+
+
+ Implementation of IetfAttrSyntax
as specified by RFC3281.
+
+
+
+
+
+
+
+
+ IetfAttrSyntax ::= Sequence {
+ policyAuthority [0] GeneralNames OPTIONAL,
+ values Sequence OF CHOICE {
+ octets OCTET STRING,
+ oid OBJECT IDENTIFIER,
+ string UTF8String
+ }
+ }
+
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ IssuerSerial ::= Sequence {
+ issuer GeneralNames,
+ serial CertificateSerialNumber,
+ issuerUid UniqueIdentifier OPTIONAL
+ }
+
+
+
+
+ IssuingDistributionPoint ::= SEQUENCE {
+ distributionPoint [0] DistributionPointName OPTIONAL,
+ onlyContainsUserCerts [1] BOOLEAN DEFAULT FALSE,
+ onlyContainsCACerts [2] BOOLEAN DEFAULT FALSE,
+ onlySomeReasons [3] ReasonFlags OPTIONAL,
+ indirectCRL [4] BOOLEAN DEFAULT FALSE,
+ onlyContainsAttributeCerts [5] BOOLEAN DEFAULT FALSE }
+
+
+
+ Constructor from given details.
+
+ @param distributionPoint
+ May contain an URI as pointer to most current CRL.
+ @param onlyContainsUserCerts Covers revocation information for end certificates.
+ @param onlyContainsCACerts Covers revocation information for CA certificates.
+
+ @param onlySomeReasons
+ Which revocation reasons does this point cover.
+ @param indirectCRL
+ If true
then the CRL contains revocation
+ information about certificates ssued by other CAs.
+ @param onlyContainsAttributeCerts Covers revocation information for attribute certificates.
+
+
+ Constructor from Asn1Sequence
+
+
+ @return Returns the distributionPoint.
+
+
+ @return Returns the onlySomeReasons.
+
+
+ The KeyPurposeID object.
+
+ KeyPurposeID ::= OBJECT IDENTIFIER
+
+
+
+ The KeyUsage object.
+
+ id-ce-keyUsage OBJECT IDENTIFIER ::= { id-ce 15 }
+
+ KeyUsage ::= BIT STRING {
+ digitalSignature (0),
+ nonRepudiation (1),
+ keyEncipherment (2),
+ dataEncipherment (3),
+ keyAgreement (4),
+ keyCertSign (5),
+ cRLSign (6),
+ encipherOnly (7),
+ decipherOnly (8) }
+
+
+
+ Basic constructor.
+
+ @param usage - the bitwise OR of the Key Usage flags giving the
+ allowed uses for the key.
+ e.g. (KeyUsage.keyEncipherment | KeyUsage.dataEncipherment)
+
+
+ Constructor from a given details.
+
+ permitted and excluded are Vectors of GeneralSubtree objects.
+
+ @param permitted Permitted subtrees
+ @param excluded Excluded subtrees
+
+
+ NoticeReference
class, used in
+ CertificatePolicies
X509 V3 extensions
+ (in policy qualifiers).
+
+
+ NoticeReference ::= Sequence {
+ organization DisplayText,
+ noticeNumbers Sequence OF Integer }
+
+
+
+ @see PolicyQualifierInfo
+ @see PolicyInformation
+
+
+ Creates a new NoticeReference
instance.
+
+ @param organization a String
value
+ @param numbers a Vector
value
+
+
+ Creates a new NoticeReference
instance.
+
+ @param organization a String
value
+ @param noticeNumbers an ASN1EncodableVector
value
+
+
+ Creates a new NoticeReference
instance.
+
+ @param organization displayText
+ @param noticeNumbers an ASN1EncodableVector
value
+
+
+ Creates a new NoticeReference
instance.
+ Useful for reconstructing a NoticeReference
+ instance from its encodable/encoded form.
+
+ @param as an Asn1Sequence
value obtained from either
+ calling @{link ToAsn1Object()} for a NoticeReference
+ instance or from parsing it from a Der-encoded stream.
+
+
+ Describe ToAsn1Object
method here.
+
+ @return a Asn1Object
value
+
+
+ ObjectDigestInfo ASN.1 structure used in v2 attribute certificates.
+
+
+
+ ObjectDigestInfo ::= SEQUENCE {
+ digestedObjectType ENUMERATED {
+ publicKey (0),
+ publicKeyCert (1),
+ otherObjectTypes (2) },
+ -- otherObjectTypes MUST NOT
+ -- be used in this profile
+ otherObjectTypeID OBJECT IDENTIFIER OPTIONAL,
+ digestAlgorithm AlgorithmIdentifier,
+ objectDigest BIT STRING
+ }
+
+
+
+
+
+ The public key is hashed.
+
+
+ The public key certificate is hashed.
+
+
+ An other object is hashed.
+
+
+ Constructor from given details.
+
+ If digestedObjectType
is not {@link #publicKeyCert} or
+ {@link #publicKey} otherObjectTypeID
must be given,
+ otherwise it is ignored.
+
+ @param digestedObjectType The digest object type.
+ @param otherObjectTypeID The object type ID for
+ otherObjectDigest
.
+ @param digestAlgorithm The algorithm identifier for the hash.
+ @param objectDigest The hash value.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+
+
+ ObjectDigestInfo ::= SEQUENCE {
+ digestedObjectType ENUMERATED {
+ publicKey (0),
+ publicKeyCert (1),
+ otherObjectTypes (2) },
+ -- otherObjectTypes MUST NOT
+ -- be used in this profile
+ otherObjectTypeID OBJECT IDENTIFIER OPTIONAL,
+ digestAlgorithm AlgorithmIdentifier,
+ objectDigest BIT STRING
+ }
+
+
+
+
+ PolicyMappings V3 extension, described in RFC3280.
+
+ PolicyMappings ::= Sequence SIZE (1..MAX) OF Sequence {
+ issuerDomainPolicy CertPolicyId,
+ subjectDomainPolicy CertPolicyId }
+
+
+ @see RFC 3280, section 4.2.1.6
+
+
+ Creates a new PolicyMappings
instance.
+
+ @param seq an Asn1Sequence
constructed as specified
+ in RFC 3280
+
+
+ Creates a new PolicyMappings
instance.
+
+ @param mappings a HashMap
value that maps
+ string
oids
+ to other string
oids.
+
+
+ PolicyQualifierId, used in the CertificatePolicies
+ X509V3 extension.
+
+
+ id-qt OBJECT IDENTIFIER ::= { id-pkix 2 }
+ id-qt-cps OBJECT IDENTIFIER ::= { id-qt 1 }
+ id-qt-unotice OBJECT IDENTIFIER ::= { id-qt 2 }
+ PolicyQualifierId ::=
+ OBJECT IDENTIFIER ( id-qt-cps | id-qt-unotice )
+
+
+
+ Policy qualifiers, used in the X509V3 CertificatePolicies
+ extension.
+
+
+ PolicyQualifierInfo ::= Sequence {
+ policyQualifierId PolicyQualifierId,
+ qualifier ANY DEFINED BY policyQualifierId }
+
+
+
+ Creates a new PolicyQualifierInfo
instance.
+
+ @param policyQualifierId a PolicyQualifierId
value
+ @param qualifier the qualifier, defined by the above field.
+
+
+ Creates a new PolicyQualifierInfo
containing a
+ cPSuri qualifier.
+
+ @param cps the CPS (certification practice statement) uri as a
+ string
.
+
+
+ Creates a new PolicyQualifierInfo
instance.
+
+ @param as PolicyQualifierInfo
X509 structure
+ encoded as an Asn1Sequence.
+
+
+ Returns a Der-encodable representation of this instance.
+
+ @return a Asn1Object
value
+
+
+
+
+ PrivateKeyUsagePeriod ::= SEQUENCE
+ {
+ notBefore [0] GeneralizedTime OPTIONAL,
+ notAfter [1] GeneralizedTime OPTIONAL }
+
+
+
+
+ This outputs the key in Pkcs1v2 format.
+
+ RSAPublicKey ::= Sequence {
+ modulus Integer, -- n
+ publicExponent Integer, -- e
+ }
+
+
+
+ The ReasonFlags object.
+
+ ReasonFlags ::= BIT STRING {
+ unused(0),
+ keyCompromise(1),
+ cACompromise(2),
+ affiliationChanged(3),
+ superseded(4),
+ cessationOfOperation(5),
+ certficateHold(6)
+ }
+
+
+
+ @param reasons - the bitwise OR of the Key Reason flags giving the
+ allowed uses for the key.
+
+
+ Implementation of the RoleSyntax object as specified by the RFC3281.
+
+
+ RoleSyntax ::= SEQUENCE {
+ roleAuthority [0] GeneralNames OPTIONAL,
+ roleName [1] GeneralName
+ }
+
+
+
+ RoleSyntax factory method.
+ @param obj the object used to construct an instance of
+ RoleSyntax
. It must be an instance of RoleSyntax
+
or Asn1Sequence
.
+ @return the instance of RoleSyntax
built from the
+ supplied object.
+ @throws java.lang.ArgumentException if the object passed
+ to the factory is not an instance of RoleSyntax
or
+ Asn1Sequence
.
+
+
+ Constructor.
+ @param roleAuthority the role authority of this RoleSyntax.
+ @param roleName the role name of this RoleSyntax.
+
+
+ Constructor. Invoking this constructor is the same as invoking
+ new RoleSyntax(null, roleName)
.
+ @param roleName the role name of this RoleSyntax.
+
+
+ Utility constructor. Takes a string
argument representing
+ the role name, builds a GeneralName
to hold the role name
+ and calls the constructor that takes a GeneralName
.
+ @param roleName
+
+
+ Constructor that builds an instance of RoleSyntax
by
+ extracting the encoded elements from the Asn1Sequence
+ object supplied.
+ @param seq an instance of Asn1Sequence
that holds
+ the encoded elements used to build this RoleSyntax
.
+
+
+ Gets the role authority of this RoleSyntax.
+ @return an instance of GeneralNames
holding the
+ role authority of this RoleSyntax.
+
+
+ Gets the role name of this RoleSyntax.
+ @return an instance of GeneralName
holding the
+ role name of this RoleSyntax.
+
+
+ Gets the role name as a java.lang.string
object.
+ @return the role name of this RoleSyntax represented as a
+ string
object.
+
+
+ Gets the role authority as a string[]
object.
+ @return the role authority of this RoleSyntax represented as a
+ string[]
array.
+
+
+ Implementation of the method ToAsn1Object
as
+ required by the superclass ASN1Encodable
.
+
+
+ RoleSyntax ::= SEQUENCE {
+ roleAuthority [0] GeneralNames OPTIONAL,
+ roleName [1] GeneralName
+ }
+
+
+
+ This extension may contain further X.500 attributes of the subject. See also
+ RFC 3039.
+
+
+ SubjectDirectoryAttributes ::= Attributes
+ Attributes ::= SEQUENCE SIZE (1..MAX) OF Attribute
+ Attribute ::= SEQUENCE
+ {
+ type AttributeType
+ values SET OF AttributeValue
+ }
+
+ AttributeType ::= OBJECT IDENTIFIER
+ AttributeValue ::= ANY DEFINED BY AttributeType
+
+
+ @see org.bouncycastle.asn1.x509.X509Name for AttributeType ObjectIdentifiers.
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type SubjectDirectoryAttributes:
+
+
+ SubjectDirectoryAttributes ::= Attributes
+ Attributes ::= SEQUENCE SIZE (1..MAX) OF Attribute
+ Attribute ::= SEQUENCE
+ {
+ type AttributeType
+ values SET OF AttributeValue
+ }
+
+ AttributeType ::= OBJECT IDENTIFIER
+ AttributeValue ::= ANY DEFINED BY AttributeType
+
+
+ @param seq
+ The ASN.1 sequence.
+
+
+ Constructor from an ArrayList of attributes.
+
+ The ArrayList consists of attributes of type {@link Attribute Attribute}
+
+ @param attributes The attributes.
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ SubjectDirectoryAttributes ::= Attributes
+ Attributes ::= SEQUENCE SIZE (1..MAX) OF Attribute
+ Attribute ::= SEQUENCE
+ {
+ type AttributeType
+ values SET OF AttributeValue
+ }
+
+ AttributeType ::= OBJECT IDENTIFIER
+ AttributeValue ::= ANY DEFINED BY AttributeType
+
+
+ @return a DERObject
+
+
+ @return Returns the attributes.
+
+
+ The SubjectKeyIdentifier object.
+
+ SubjectKeyIdentifier::= OCTET STRING
+
+
+
+ Calculates the keyIdentifier using a SHA1 hash over the BIT STRING
+ from SubjectPublicKeyInfo as defined in RFC3280.
+
+ @param spki the subject public key info.
+
+
+ Return a RFC 3280 type 1 key identifier. As in:
+
+ (1) The keyIdentifier is composed of the 160-bit SHA-1 hash of the
+ value of the BIT STRING subjectPublicKey (excluding the tag,
+ length, and number of unused bits).
+
+ @param keyInfo the key info object containing the subjectPublicKey field.
+ @return the key identifier.
+
+
+ Return a RFC 3280 type 2 key identifier. As in:
+
+ (2) The keyIdentifier is composed of a four bit type field with
+ the value 0100 followed by the least significant 60 bits of the
+ SHA-1 hash of the value of the BIT STRING subjectPublicKey.
+
+ @param keyInfo the key info object containing the subjectPublicKey field.
+ @return the key identifier.
+
+
+ The object that contains the public key stored in a certficate.
+
+ The GetEncoded() method in the public keys in the JCE produces a DER
+ encoded one of these.
+
+
+ for when the public key is an encoded object - if the bitstring
+ can't be decoded this routine raises an IOException.
+
+ @exception IOException - if the bit string doesn't represent a Der
+ encoded object.
+
+
+ for when the public key is raw bits...
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SubjectPublicKeyInfo ::= Sequence {
+ algorithm AlgorithmIdentifier,
+ publicKey BIT STRING }
+
+
+
+ PKIX RFC-2459 - TbsCertList object.
+
+ TbsCertList ::= Sequence {
+ version Version OPTIONAL,
+ -- if present, shall be v2
+ signature AlgorithmIdentifier,
+ issuer Name,
+ thisUpdate Time,
+ nextUpdate Time OPTIONAL,
+ revokedCertificates Sequence OF Sequence {
+ userCertificate CertificateSerialNumber,
+ revocationDate Time,
+ crlEntryExtensions Extensions OPTIONAL
+ -- if present, shall be v2
+ } OPTIONAL,
+ crlExtensions [0] EXPLICIT Extensions OPTIONAL
+ -- if present, shall be v2
+ }
+
+
+
+ The TbsCertificate object.
+
+ TbsCertificate ::= Sequence {
+ version [ 0 ] Version DEFAULT v1(0),
+ serialNumber CertificateSerialNumber,
+ signature AlgorithmIdentifier,
+ issuer Name,
+ validity Validity,
+ subject Name,
+ subjectPublicKeyInfo SubjectPublicKeyInfo,
+ issuerUniqueID [ 1 ] IMPLICIT UniqueIdentifier OPTIONAL,
+ subjectUniqueID [ 2 ] IMPLICIT UniqueIdentifier OPTIONAL,
+ extensions [ 3 ] Extensions OPTIONAL
+ }
+
+
+ Note: issuerUniqueID and subjectUniqueID are both deprecated by the IETF. This class
+ will parse them, but you really shouldn't be creating new ones.
+
+
+ Target structure used in target information extension for attribute
+ certificates from RFC 3281.
+
+
+ Target ::= CHOICE {
+ targetName [0] GeneralName,
+ targetGroup [1] GeneralName,
+ targetCert [2] TargetCert
+ }
+
+
+
+ The targetCert field is currently not supported and must not be used
+ according to RFC 3281.
+
+
+ Creates an instance of a Target from the given object.
+
+ obj
can be a Target or a {@link Asn1TaggedObject}
+
+ @param obj The object.
+ @return A Target instance.
+ @throws ArgumentException if the given object cannot be
+ interpreted as Target.
+
+
+ Constructor from Asn1TaggedObject.
+
+ @param tagObj The tagged object.
+ @throws ArgumentException if the encoding is wrong.
+
+
+ Constructor from given details.
+
+ Exactly one of the parameters must be not null
.
+
+ @param type the choice type to apply to the name.
+ @param name the general name.
+ @throws ArgumentException if type is invalid.
+
+
+ @return Returns the targetGroup.
+
+
+ @return Returns the targetName.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ Target ::= CHOICE {
+ targetName [0] GeneralName,
+ targetGroup [1] GeneralName,
+ targetCert [2] TargetCert
+ }
+
+
+ @return an Asn1Object
+
+
+ Target information extension for attributes certificates according to RFC
+ 3281.
+
+
+ SEQUENCE OF Targets
+
+
+
+
+ Creates an instance of a TargetInformation from the given object.
+
+ obj
can be a TargetInformation or a {@link Asn1Sequence}
+
+ @param obj The object.
+ @return A TargetInformation instance.
+ @throws ArgumentException if the given object cannot be interpreted as TargetInformation.
+
+
+ Constructor from a Asn1Sequence.
+
+ @param seq The Asn1Sequence.
+ @throws ArgumentException if the sequence does not contain
+ correctly encoded Targets elements.
+
+
+ Returns the targets in this target information extension.
+
+ The ArrayList is cloned before it is returned.
+
+ @return Returns the targets.
+
+
+ Constructs a target information from a single targets element.
+ According to RFC 3281 only one targets element must be produced.
+
+ @param targets A Targets instance.
+
+
+ According to RFC 3281 only one targets element must be produced. If
+ multiple targets are given they must be merged in
+ into one targets element.
+
+ @param targets An array with {@link Targets}.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ SEQUENCE OF Targets
+
+
+
+ According to RFC 3281 only one targets element must be produced. If
+ multiple targets are given in the constructor they are merged into one
+ targets element. If this was produced from a
+ {@link Org.BouncyCastle.Asn1.Asn1Sequence} the encoding is kept.
+
+ @return an Asn1Object
+
+
+ Targets structure used in target information extension for attribute
+ certificates from RFC 3281.
+
+
+ Targets ::= SEQUENCE OF Target
+
+ Target ::= CHOICE {
+ targetName [0] GeneralName,
+ targetGroup [1] GeneralName,
+ targetCert [2] TargetCert
+ }
+
+ TargetCert ::= SEQUENCE {
+ targetCertificate IssuerSerial,
+ targetName GeneralName OPTIONAL,
+ certDigestInfo ObjectDigestInfo OPTIONAL
+ }
+
+
+ @see org.bouncycastle.asn1.x509.Target
+ @see org.bouncycastle.asn1.x509.TargetInformation
+
+
+ Creates an instance of a Targets from the given object.
+
+ obj
can be a Targets or a {@link Asn1Sequence}
+
+ @param obj The object.
+ @return A Targets instance.
+ @throws ArgumentException if the given object cannot be interpreted as Target.
+
+
+ Constructor from Asn1Sequence.
+
+ @param targets The ASN.1 SEQUENCE.
+ @throws ArgumentException if the contents of the sequence are
+ invalid.
+
+
+ Constructor from given targets.
+
+ The ArrayList is copied.
+
+ @param targets An ArrayList
of {@link Target}s.
+ @see Target
+ @throws ArgumentException if the ArrayList contains not only Targets.
+
+
+ Returns the targets in an ArrayList
.
+
+ The ArrayList is cloned before it is returned.
+
+ @return Returns the targets.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ Targets ::= SEQUENCE OF Target
+
+
+ @return an Asn1Object
+
+
+ creates a time object from a given date - if the date is between 1950
+ and 2049 a UTCTime object is Generated, otherwise a GeneralizedTime
+ is used.
+
+
+
+ Return our time as DateTime.
+
+ A date time.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Time ::= CHOICE {
+ utcTime UTCTime,
+ generalTime GeneralizedTime }
+
+
+
+ UserNotice
class, used in
+ CertificatePolicies
X509 extensions (in policy
+ qualifiers).
+
+ UserNotice ::= Sequence {
+ noticeRef NoticeReference OPTIONAL,
+ explicitText DisplayText OPTIONAL}
+
+
+
+ @see PolicyQualifierId
+ @see PolicyInformation
+
+
+ Creates a new UserNotice
instance.
+
+ @param noticeRef a NoticeReference
value
+ @param explicitText a DisplayText
value
+
+
+ Creates a new UserNotice
instance.
+
+ @param noticeRef a NoticeReference
value
+ @param str the explicitText field as a string.
+
+
+ Creates a new UserNotice
instance.
+ Useful from reconstructing a UserNotice
instance
+ from its encodable/encoded form.
+
+ @param as an ASN1Sequence
value obtained from either
+ calling @{link toASN1Object()} for a UserNotice
+ instance or from parsing it from a DER-encoded stream.
+
+
+ Generator for Version 1 TbsCertificateStructures.
+
+ TbsCertificate ::= Sequence {
+ version [ 0 ] Version DEFAULT v1(0),
+ serialNumber CertificateSerialNumber,
+ signature AlgorithmIdentifier,
+ issuer Name,
+ validity Validity,
+ subject Name,
+ subjectPublicKeyInfo SubjectPublicKeyInfo,
+ }
+
+
+
+
+ Generator for Version 2 AttributeCertificateInfo
+
+ AttributeCertificateInfo ::= Sequence {
+ version AttCertVersion -- version is v2,
+ holder Holder,
+ issuer AttCertIssuer,
+ signature AlgorithmIdentifier,
+ serialNumber CertificateSerialNumber,
+ attrCertValidityPeriod AttCertValidityPeriod,
+ attributes Sequence OF Attr,
+ issuerUniqueID UniqueIdentifier OPTIONAL,
+ extensions Extensions OPTIONAL
+ }
+
+
+
+
+ @param attribute
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ V2Form ::= Sequence {
+ issuerName GeneralNames OPTIONAL,
+ baseCertificateID [0] IssuerSerial OPTIONAL,
+ objectDigestInfo [1] ObjectDigestInfo OPTIONAL
+ -- issuerName MUST be present in this profile
+ -- baseCertificateID and objectDigestInfo MUST NOT
+ -- be present in this profile
+ }
+
+
+
+ Generator for Version 2 TbsCertList structures.
+
+ TbsCertList ::= Sequence {
+ version Version OPTIONAL,
+ -- if present, shall be v2
+ signature AlgorithmIdentifier,
+ issuer Name,
+ thisUpdate Time,
+ nextUpdate Time OPTIONAL,
+ revokedCertificates Sequence OF Sequence {
+ userCertificate CertificateSerialNumber,
+ revocationDate Time,
+ crlEntryExtensions Extensions OPTIONAL
+ -- if present, shall be v2
+ } OPTIONAL,
+ crlExtensions [0] EXPLICIT Extensions OPTIONAL
+ -- if present, shall be v2
+ }
+
+
+ Note: This class may be subject to change
+
+
+ Generator for Version 3 TbsCertificateStructures.
+
+ TbsCertificate ::= Sequence {
+ version [ 0 ] Version DEFAULT v1(0),
+ serialNumber CertificateSerialNumber,
+ signature AlgorithmIdentifier,
+ issuer Name,
+ validity Validity,
+ subject Name,
+ subjectPublicKeyInfo SubjectPublicKeyInfo,
+ issuerUniqueID [ 1 ] IMPLICIT UniqueIdentifier OPTIONAL,
+ subjectUniqueID [ 2 ] IMPLICIT UniqueIdentifier OPTIONAL,
+ extensions [ 3 ] Extensions OPTIONAL
+ }
+
+
+
+
+ an X509Certificate structure.
+
+ Certificate ::= Sequence {
+ tbsCertificate TbsCertificate,
+ signatureAlgorithm AlgorithmIdentifier,
+ signature BIT STRING
+ }
+
+
+
+ The default converter for X509 DN entries when going from their
+ string value to ASN.1 strings.
+
+
+ Apply default conversion for the given value depending on the oid
+ and the character range of the value.
+
+ @param oid the object identifier for the DN entry
+ @param value the value associated with it
+ @return the ASN.1 equivalent for the string value.
+
+
+ an object for the elements in the X.509 V3 extension block.
+
+
+ Convert the value of the passed in extension to an object.
+ The extension to parse.
+ The object the value string contains.
+ If conversion is not possible.
+
+
+ Subject Directory Attributes
+
+
+ Subject Key Identifier
+
+
+ Key Usage
+
+
+ Private Key Usage Period
+
+
+ Subject Alternative Name
+
+
+ Issuer Alternative Name
+
+
+ Basic Constraints
+
+
+ CRL Number
+
+
+ Reason code
+
+
+ Hold Instruction Code
+
+
+ Invalidity Date
+
+
+ Delta CRL indicator
+
+
+ Issuing Distribution Point
+
+
+ Certificate Issuer
+
+
+ Name Constraints
+
+
+ CRL Distribution Points
+
+
+ Certificate Policies
+
+
+ Policy Mappings
+
+
+ Authority Key Identifier
+
+
+ Policy Constraints
+
+
+ Extended Key Usage
+
+
+ Freshest CRL
+
+
+ Inhibit Any Policy
+
+
+ Authority Info Access
+
+
+ Subject Info Access
+
+
+ Logo Type
+
+
+ BiometricInfo
+
+
+ QCStatements
+
+
+ Audit identity extension in attribute certificates.
+
+
+ NoRevAvail extension in attribute certificates.
+
+
+ TargetInformation extension in attribute certificates.
+
+
+ Constructor from Asn1Sequence.
+
+ the extensions are a list of constructed sequences, either with (Oid, OctetString) or (Oid, Boolean, OctetString)
+
+
+ constructor from a table of extensions.
+
+ it's is assumed the table contains Oid/string pairs.
+
+
+ Constructor from a table of extensions with ordering.
+
+ It's is assumed the table contains Oid/string pairs.
+
+
+ Constructor from two vectors
+
+ @param objectIDs an ArrayList of the object identifiers.
+ @param values an ArrayList of the extension values.
+
+
+ constructor from a table of extensions.
+
+ it's is assumed the table contains Oid/string pairs.
+
+
+ Constructor from a table of extensions with ordering.
+
+ It's is assumed the table contains Oid/string pairs.
+
+
+ Constructor from two vectors
+
+ @param objectIDs an ArrayList of the object identifiers.
+ @param values an ArrayList of the extension values.
+
+
+ return an Enumeration of the extension field's object ids.
+
+
+ return the extension represented by the object identifier
+ passed in.
+
+ @return the extension if it's present, null otherwise.
+
+
+
+ Extensions ::= SEQUENCE SIZE (1..MAX) OF Extension
+
+ Extension ::= SEQUENCE {
+ extnId EXTENSION.&id ({ExtensionSet}),
+ critical BOOLEAN DEFAULT FALSE,
+ extnValue OCTET STRING }
+
+
+
+ Generator for X.509 extensions
+
+
+ Reset the generator
+
+
+
+ Add an extension with the given oid and the passed in value to be included
+ in the OCTET STRING associated with the extension.
+
+ OID for the extension.
+ True if critical, false otherwise.
+ The ASN.1 object to be included in the extension.
+
+
+
+ Add an extension with the given oid and the passed in byte array to be wrapped
+ in the OCTET STRING associated with the extension.
+
+ OID for the extension.
+ True if critical, false otherwise.
+ The byte array to be wrapped.
+
+
+ Return true if there are no extension present in this generator.
+ True if empty, false otherwise
+
+
+ Generate an X509Extensions object based on the current state of the generator.
+ An X509Extensions object
+
+
+
+ RDNSequence ::= SEQUENCE OF RelativeDistinguishedName
+
+ RelativeDistinguishedName ::= SET SIZE (1..MAX) OF AttributeTypeAndValue
+
+ AttributeTypeAndValue ::= SEQUENCE {
+ type OBJECT IDENTIFIER,
+ value ANY }
+
+
+
+ country code - StringType(SIZE(2))
+
+
+ organization - StringType(SIZE(1..64))
+
+
+ organizational unit name - StringType(SIZE(1..64))
+
+
+ Title
+
+
+ common name - StringType(SIZE(1..64))
+
+
+ street - StringType(SIZE(1..64))
+
+
+ device serial number name - StringType(SIZE(1..64))
+
+
+ locality name - StringType(SIZE(1..64))
+
+
+ state, or province name - StringType(SIZE(1..64))
+
+
+ Naming attributes of type X520name
+
+
+ businessCategory - DirectoryString(SIZE(1..128)
+
+
+ postalCode - DirectoryString(SIZE(1..40)
+
+
+ dnQualifier - DirectoryString(SIZE(1..64)
+
+
+ RFC 3039 Pseudonym - DirectoryString(SIZE(1..64)
+
+
+ RFC 3039 DateOfBirth - GeneralizedTime - YYYYMMDD000000Z
+
+
+ RFC 3039 PlaceOfBirth - DirectoryString(SIZE(1..128)
+
+
+ RFC 3039 DateOfBirth - PrintableString (SIZE(1)) -- "M", "F", "m" or "f"
+
+
+ RFC 3039 CountryOfCitizenship - PrintableString (SIZE (2)) -- ISO 3166
+ codes only
+
+
+ RFC 3039 CountryOfCitizenship - PrintableString (SIZE (2)) -- ISO 3166
+ codes only
+
+
+ ISIS-MTT NameAtBirth - DirectoryString(SIZE(1..64)
+
+
+ RFC 3039 PostalAddress - SEQUENCE SIZE (1..6) OF
+ DirectoryString(SIZE(1..30))
+
+
+ RFC 2256 dmdName
+
+
+ id-at-telephoneNumber
+
+
+ id-at-name
+
+
+ Email address (RSA PKCS#9 extension) - IA5String.
+ Note: if you're trying to be ultra orthodox, don't use this! It shouldn't be in here.
+
+
+ more from PKCS#9
+
+
+ email address in Verisign certificates
+
+
+ LDAP User id.
+
+
+ determines whether or not strings should be processed and printed
+ from back to front.
+
+
+ default look up table translating OID values into their common symbols following
+ the convention in RFC 2253 with a few extras
+
+
+ look up table translating OID values into their common symbols following the convention in RFC 2253
+
+
+ look up table translating OID values into their common symbols following the convention in RFC 1779
+
+
+
+ look up table translating common symbols into their OIDS.
+
+
+ Return a X509Name based on the passed in tagged object.
+
+ @param obj tag object holding name.
+ @param explicitly true if explicitly tagged false otherwise.
+ @return the X509Name
+
+
+ Constructor from Asn1Sequence
+
+ the principal will be a list of constructed sets, each containing an (OID, string) pair.
+
+
+ Constructor from a table of attributes with ordering.
+
+ it's is assumed the table contains OID/string pairs, and the contents
+ of the table are copied into an internal table as part of the
+ construction process. The ordering ArrayList should contain the OIDs
+ in the order they are meant to be encoded or printed in ToString.
+
+
+ Constructor from a table of attributes with ordering.
+
+ it's is assumed the table contains OID/string pairs, and the contents
+ of the table are copied into an internal table as part of the
+ construction process. The ordering ArrayList should contain the OIDs
+ in the order they are meant to be encoded or printed in ToString.
+
+ The passed in converter will be used to convert the strings into their
+ ASN.1 counterparts.
+
+
+ Takes two vectors one of the oids and the other of the values.
+
+
+ Takes two vectors one of the oids and the other of the values.
+
+ The passed in converter will be used to convert the strings into their
+ ASN.1 counterparts.
+
+
+ Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or
+ some such, converting it into an ordered set of name attributes.
+
+
+ Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or
+ some such, converting it into an ordered set of name attributes with each
+ string value being converted to its associated ASN.1 type using the passed
+ in converter.
+
+
+ Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or
+ some such, converting it into an ordered set of name attributes. If reverse
+ is true, create the encoded version of the sequence starting from the
+ last element in the string.
+
+
+ Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or
+ some such, converting it into an ordered set of name attributes with each
+ string value being converted to its associated ASN.1 type using the passed
+ in converter. If reverse is true the ASN.1 sequence representing the DN will
+ be built by starting at the end of the string, rather than the start.
+
+
+ Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or
+ some such, converting it into an ordered set of name attributes. lookUp
+ should provide a table of lookups, indexed by lowercase only strings and
+ yielding a DerObjectIdentifier, other than that OID. and numeric oids
+ will be processed automatically.
+
+ If reverse is true, create the encoded version of the sequence
+ starting from the last element in the string.
+ @param reverse true if we should start scanning from the end (RFC 2553).
+ @param lookUp table of names and their oids.
+ @param dirName the X.500 string to be parsed.
+
+
+ Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or
+ some such, converting it into an ordered set of name attributes. lookUp
+ should provide a table of lookups, indexed by lowercase only strings and
+ yielding a DerObjectIdentifier, other than that OID. and numeric oids
+ will be processed automatically. The passed in converter is used to convert the
+ string values to the right of each equals sign to their ASN.1 counterparts.
+
+ @param reverse true if we should start scanning from the end, false otherwise.
+ @param lookUp table of names and oids.
+ @param dirName the string dirName
+ @param converter the converter to convert string values into their ASN.1 equivalents
+
+
+ return an IList of the oids in the name, in the order they were found.
+
+
+ return an IList of the values found in the name, in the order they
+ were found.
+
+
+ return an IList of the values found in the name, in the order they
+ were found, with the DN label corresponding to passed in oid.
+
+
+ The X509Name object to test equivalency against.
+ If true, the order of elements must be the same,
+ as well as the values associated with each element.
+
+
+ test for equivalence - note: case is ignored.
+
+
+ convert the structure to a string - if reverse is true the
+ oids and values are listed out starting with the last element
+ in the sequence (ala RFC 2253), otherwise the string will begin
+ with the first element of the structure. If no string definition
+ for the oid is found in oidSymbols the string value of the oid is
+ added. Two standard symbol tables are provided DefaultSymbols, and
+ RFC2253Symbols as part of this class.
+
+ @param reverse if true start at the end of the sequence and work back.
+ @param oidSymbols look up table strings for oids.
+
+
+ * It turns out that the number of standard ways the fields in a DN should be
+ * encoded into their ASN.1 counterparts is rapidly approaching the
+ * number of machines on the internet. By default the X509Name class
+ * will produce UTF8Strings in line with the current recommendations (RFC 3280).
+ *
+ * An example of an encoder look like below:
+ *
+ * public class X509DirEntryConverter
+ * : X509NameEntryConverter
+ * {
+ * public Asn1Object GetConvertedValue(
+ * DerObjectIdentifier oid,
+ * string value)
+ * {
+ * if (str.Length() != 0 && str.charAt(0) == '#')
+ * {
+ * return ConvertHexEncoded(str, 1);
+ * }
+ * if (oid.Equals(EmailAddress))
+ * {
+ * return new DerIA5String(str);
+ * }
+ * else if (CanBePrintable(str))
+ * {
+ * return new DerPrintableString(str);
+ * }
+ * else if (CanBeUTF8(str))
+ * {
+ * return new DerUtf8String(str);
+ * }
+ * else
+ * {
+ * return new DerBmpString(str);
+ * }
+ * }
+ * }
+ *
+ *
+
+
+ Convert an inline encoded hex string rendition of an ASN.1
+ object back into its corresponding ASN.1 object.
+
+ @param str the hex encoded object
+ @param off the index at which the encoding starts
+ @return the decoded object
+
+
+ return true if the passed in string can be represented without
+ loss as a PrintableString, false otherwise.
+
+
+ Convert the passed in string value into the appropriate ASN.1
+ encoded object.
+
+ @param oid the oid associated with the value in the DN.
+ @param value the value of the particular DN component.
+ @return the ASN.1 equivalent for the value.
+
+
+ class for breaking up an X500 Name into it's component tokens, ala
+ java.util.StringTokenizer. We need this class as some of the
+ lightweight Java environment don't support classes like
+ StringTokenizer.
+
+
+ The BiometricData object.
+
+ BiometricData ::= SEQUENCE {
+ typeOfBiometricData TypeOfBiometricData,
+ hashAlgorithm AlgorithmIdentifier,
+ biometricDataHash OCTET STRING,
+ sourceDataUri IA5String OPTIONAL }
+
+
+
+ The Iso4217CurrencyCode object.
+
+ Iso4217CurrencyCode ::= CHOICE {
+ alphabetic PrintableString (SIZE 3), --Recommended
+ numeric INTEGER (1..999) }
+ -- Alphabetic or numeric currency code as defined in ISO 4217
+ -- It is recommended that the Alphabetic form is used
+
+
+
+ The MonetaryValue object.
+
+ MonetaryValue ::= SEQUENCE {
+ currency Iso4217CurrencyCode,
+ amount INTEGER,
+ exponent INTEGER }
+ -- value = amount * 10^exponent
+
+
+
+ The QCStatement object.
+
+ QCStatement ::= SEQUENCE {
+ statementId OBJECT IDENTIFIER,
+ statementInfo ANY DEFINED BY statementId OPTIONAL}
+
+
+
+ The SemanticsInformation object.
+
+ SemanticsInformation ::= SEQUENCE {
+ semanticsIdentifier OBJECT IDENTIFIER OPTIONAL,
+ nameRegistrationAuthorities NameRegistrationAuthorities
+ OPTIONAL }
+ (WITH COMPONENTS {..., semanticsIdentifier PRESENT}|
+ WITH COMPONENTS {..., nameRegistrationAuthorities PRESENT})
+
+ NameRegistrationAuthorities ::= SEQUENCE SIZE (1..MAX) OF
+ GeneralName
+
+
+
+ The TypeOfBiometricData object.
+
+ TypeOfBiometricData ::= CHOICE {
+ predefinedBiometricType PredefinedBiometricType,
+ biometricDataOid OBJECT IDENTIFIER }
+
+ PredefinedBiometricType ::= INTEGER {
+ picture(0),handwritten-signature(1)}
+ (picture|handwritten-signature)
+
+
+
+ Structure for a name or pseudonym.
+
+
+ NameOrPseudonym ::= CHOICE {
+ surAndGivenName SEQUENCE {
+ surName DirectoryString,
+ givenName SEQUENCE OF DirectoryString
+ },
+ pseudonym DirectoryString
+ }
+
+
+ @see org.bouncycastle.asn1.x509.sigi.PersonalData
+
+
+
+ Constructor from DERString.
+
+ The sequence is of type NameOrPseudonym:
+
+
+ NameOrPseudonym ::= CHOICE {
+ surAndGivenName SEQUENCE {
+ surName DirectoryString,
+ givenName SEQUENCE OF DirectoryString
+ },
+ pseudonym DirectoryString
+ }
+
+ @param pseudonym pseudonym value to use.
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type NameOrPseudonym:
+
+
+ NameOrPseudonym ::= CHOICE {
+ surAndGivenName SEQUENCE {
+ surName DirectoryString,
+ givenName SEQUENCE OF DirectoryString
+ },
+ pseudonym DirectoryString
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from a given details.
+
+ @param pseudonym The pseudonym.
+
+
+ Constructor from a given details.
+
+ @param surname The surname.
+ @param givenName A sequence of directory strings making up the givenName
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ NameOrPseudonym ::= CHOICE {
+ surAndGivenName SEQUENCE {
+ surName DirectoryString,
+ givenName SEQUENCE OF DirectoryString
+ },
+ pseudonym DirectoryString
+ }
+
+
+ @return an Asn1Object
+
+
+ Contains personal data for the otherName field in the subjectAltNames
+ extension.
+
+
+ PersonalData ::= SEQUENCE {
+ nameOrPseudonym NameOrPseudonym,
+ nameDistinguisher [0] INTEGER OPTIONAL,
+ dateOfBirth [1] GeneralizedTime OPTIONAL,
+ placeOfBirth [2] DirectoryString OPTIONAL,
+ gender [3] PrintableString OPTIONAL,
+ postalAddress [4] DirectoryString OPTIONAL
+ }
+
+
+ @see org.bouncycastle.asn1.x509.sigi.NameOrPseudonym
+ @see org.bouncycastle.asn1.x509.sigi.SigIObjectIdentifiers
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type NameOrPseudonym:
+
+
+ PersonalData ::= SEQUENCE {
+ nameOrPseudonym NameOrPseudonym,
+ nameDistinguisher [0] INTEGER OPTIONAL,
+ dateOfBirth [1] GeneralizedTime OPTIONAL,
+ placeOfBirth [2] DirectoryString OPTIONAL,
+ gender [3] PrintableString OPTIONAL,
+ postalAddress [4] DirectoryString OPTIONAL
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from a given details.
+
+ @param nameOrPseudonym Name or pseudonym.
+ @param nameDistinguisher Name distinguisher.
+ @param dateOfBirth Date of birth.
+ @param placeOfBirth Place of birth.
+ @param gender Gender.
+ @param postalAddress Postal Address.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ PersonalData ::= SEQUENCE {
+ nameOrPseudonym NameOrPseudonym,
+ nameDistinguisher [0] INTEGER OPTIONAL,
+ dateOfBirth [1] GeneralizedTime OPTIONAL,
+ placeOfBirth [2] DirectoryString OPTIONAL,
+ gender [3] PrintableString OPTIONAL,
+ postalAddress [4] DirectoryString OPTIONAL
+ }
+
+
+ @return an Asn1Object
+
+
+ Object Identifiers of SigI specifciation (German Signature Law
+ Interoperability specification).
+
+
+ Key purpose IDs for German SigI (Signature Interoperability
+ Specification)
+
+
+ Certificate policy IDs for German SigI (Signature Interoperability
+ Specification)
+
+
+ Other Name IDs for German SigI (Signature Interoperability Specification)
+
+
+ To be used for for the generation of directory service certificates.
+
+
+ ID for PersonalData
+
+
+ Certificate is conform to german signature law.
+
+
+ A general class that reads all X9.62 style EC curve tables.
+
+
+ return a X9ECParameters object representing the passed in named
+ curve. The routine returns null if the curve is not present.
+
+ @param name the name of the curve requested
+ @return an X9ECParameters object or null if the curve is not available.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return a X9ECParameters object representing the passed in named
+ curve.
+
+ @param oid the object id of the curve requested
+ @return an X9ECParameters object or null if the curve is not available.
+
+
+ return an enumeration of the names of the available curves.
+
+ @return an enumeration of the names of the available curves.
+
+
+ ASN.1 def for Diffie-Hellman key exchange KeySpecificInfo structure. See
+ RFC 2631, or X9.42, for further details.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ KeySpecificInfo ::= Sequence {
+ algorithm OBJECT IDENTIFIER,
+ counter OCTET STRING SIZE (4..4)
+ }
+
+
+
+ ANS.1 def for Diffie-Hellman key exchange OtherInfo structure. See
+ RFC 2631, or X9.42, for further details.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OtherInfo ::= Sequence {
+ keyInfo KeySpecificInfo,
+ partyAInfo [0] OCTET STRING OPTIONAL,
+ suppPubInfo [2] OCTET STRING
+ }
+
+
+
+ table of the current named curves defined in X.962 EC-DSA.
+
+
+ return the X9ECParameters object for the named curve represented by
+ the passed in object identifier. Null if the curve isn't present.
+
+ @param oid an object identifier representing a named curve, if present.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Parameters ::= CHOICE {
+ ecParameters ECParameters,
+ namedCurve CURVES.&id({CurveNames}),
+ implicitlyCA Null
+ }
+
+
+
+ ASN.1 def for Elliptic-Curve Curve structure. See
+ X9.62, for further details.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Curve ::= Sequence {
+ a FieldElement,
+ b FieldElement,
+ seed BIT STRING OPTIONAL
+ }
+
+
+
+ ASN.1 def for Elliptic-Curve ECParameters structure. See
+ X9.62, for further details.
+
+
+ Return the ASN.1 entry representing the Curve.
+
+ @return the X9Curve for the curve in these parameters.
+
+
+ Return the ASN.1 entry representing the FieldID.
+
+ @return the X9FieldID for the FieldID in these parameters.
+
+
+ Return the ASN.1 entry representing the base point G.
+
+ @return the X9ECPoint for the base point in these parameters.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ECParameters ::= Sequence {
+ version Integer { ecpVer1(1) } (ecpVer1),
+ fieldID FieldID {{FieldTypes}},
+ curve X9Curve,
+ base X9ECPoint,
+ order Integer,
+ cofactor Integer OPTIONAL
+ }
+
+
+
+ class for describing an ECPoint as a Der object.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ECPoint ::= OCTET STRING
+
+
+ Octet string produced using ECPoint.GetEncoded().
+
+
+ Class for processing an ECFieldElement as a DER object.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ FieldElement ::= OCTET STRING
+
+
+
+ - if q is an odd prime then the field element is
+ processed as an Integer and converted to an octet string
+ according to x 9.62 4.3.1.
+ - if q is 2m then the bit string
+ contained in the field element is converted into an octet
+ string with the same ordering padded at the front if necessary.
+
+
+
+
+
+ ASN.1 def for Elliptic-Curve Field ID structure. See
+ X9.62, for further details.
+
+
+ Constructor for elliptic curves over prime fields
+ F2
.
+ @param primeP The prime p
defining the prime field.
+
+
+ Constructor for elliptic curves over binary fields
+ F2m
.
+ @param m The exponent m
of
+ F2m
.
+ @param k1 The integer k1
where xm +
+ xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ Constructor for elliptic curves over binary fields
+ F2m
.
+ @param m The exponent m
of
+ F2m
.
+ @param k1 The integer k1
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k2 The integer k2
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k3 The integer k3
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
..
+
+
+ Produce a Der encoding of the following structure.
+
+ FieldID ::= Sequence {
+ fieldType FIELD-ID.&id({IOSet}),
+ parameters FIELD-ID.&Type({IOSet}{@fieldType})
+ }
+
+
+
+ id-dsa-with-sha1 OBJECT IDENTIFIER ::= { iso(1) member-body(2)
+ us(840) x9-57 (10040) x9cm(4) 3 }
+
+
+ X9.63
+
+
+ X9.42
+
+
+ reader for Base64 armored objects - read the headers and then start returning
+ bytes when the data is reached. An IOException is thrown if the CRC check
+ fails.
+
+
+ decode the base 64 encoded input data.
+
+ @return the offset the data starts in out.
+
+
+ Create a stream for reading a PGP armoured message, parsing up to a header
+ and then reading the data that follows.
+
+ @param input
+
+
+ Create an armoured input stream which will assume the data starts
+ straight away, or parse for headers first depending on the value of
+ hasHeaders.
+
+ @param input
+ @param hasHeaders true if headers are to be looked for, false otherwise.
+
+
+ @return true if we are inside the clear text section of a PGP
+ signed message.
+
+
+ @return true if the stream is actually at end of file.
+
+
+ Return the armor header line (if there is one)
+ @return the armor header line, null if none present.
+
+
+ Return the armor headers (the lines after the armor header line),
+ @return an array of armor headers, null if there aren't any.
+
+
+ Basic output stream.
+
+
+ encode the input data producing a base 64 encoded byte array.
+
+
+ Set an additional header entry.
+
+ @param name the name of the header entry.
+ @param v the value of the header entry.
+
+
+ Reset the headers to only contain a Version string.
+
+
+ Start a clear text signed message.
+ @param hashAlgorithm
+
+
+ Note: Close() does not close the underlying stream. So it is possible to write
+ multiple objects using armoring to a single stream.
+
+
+ Reader for PGP objects.
+
+
+ Returns the next packet tag in the stream.
+
+
+
+ A stream that overlays our input stream, allowing the user to only read a segment of it.
+ NB: dataLength will be negative if the segment length is in the upper range above 2**31.
+
+
+
+ Base class for a PGP object.
+
+
+ Basic output stream.
+
+
+ Create a stream representing a general packet.
+ Output stream to write to.
+
+
+ Create a stream representing an old style partial object.
+ Output stream to write to.
+ The packet tag for the object.
+
+
+ Create a stream representing a general packet.
+ Output stream to write to.
+ Packet tag.
+ Size of chunks making up the packet.
+ If true, the header is written out in old format.
+
+
+ Create a new style partial input stream buffered into chunks.
+ Output stream to write to.
+ Packet tag.
+ Size of chunks making up the packet.
+
+
+ Create a new style partial input stream buffered into chunks.
+ Output stream to write to.
+ Packet tag.
+ Buffer to use for collecting chunks.
+
+
+ Flush the underlying stream.
+
+
+ Finish writing out the current packet without closing the underlying stream.
+
+
+ Generic compressed data object.
+
+
+ The algorithm tag value.
+
+
+ Basic tags for compression algorithms.
+
+
+ Basic type for a PGP packet.
+
+
+ Base class for a DSA public key.
+
+
+ The stream to read the packet from.
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ Base class for a DSA secret key.
+
+
+ @param in
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ @return x
+
+
+ Base class for an ECDH Public Key.
+
+
+ The stream to read the packet from.
+
+
+ Base class for an ECDSA Public Key.
+
+
+ The stream to read the packet from.
+
+
+ Base class for an EC Public Key.
+
+
+ The stream to read the packet from.
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ Base class for an EC Secret Key.
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ Base class for an ElGamal public key.
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ Base class for an ElGamal secret key.
+
+
+ @param in
+
+
+ @param x
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ Basic packet for an experimental packet.
+
+
+ Basic tags for hash algorithms.
+
+
+ Base interface for a PGP key.
+
+
+
+ The base format for this key - in the case of the symmetric keys it will generally
+ be raw indicating that the key is just a straight byte representation, for an asymmetric
+ key the format will be PGP, indicating the key is a string of MPIs encoded in PGP format.
+
+ "RAW" or "PGP".
+
+
+ Note: you can only read from this once...
+
+
+ Generic literal data packet.
+
+
+ The format tag value.
+
+
+ The modification time of the file in milli-seconds (since Jan 1, 1970 UTC)
+
+
+ A multiple precision integer
+
+
+ Basic type for a marker packet.
+
+
+ Basic packet for a modification detection code packet.
+
+
+ Generic signature object
+
+
+ The encryption algorithm tag.
+
+
+ The hash algorithm tag.
+
+
+ Basic PGP packet tag types.
+
+
+ Public Key Algorithm tag numbers.
+
+
+ Basic packet for a PGP public key.
+
+
+ Basic packet for a PGP public key.
+
+
+ Construct a version 4 public key packet.
+
+
+ Basic packet for a PGP public subkey
+
+
+ Construct a version 4 public subkey packet.
+
+
+ Base class for an RSA public key.
+
+
+ Construct an RSA public key from the passed in stream.
+
+
+ The modulus.
+ The public exponent.
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ Base class for an RSA secret (or priate) key.
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ The string to key specifier class.
+
+
+ The hash algorithm.
+
+
+ The IV for the key generation algorithm.
+
+
+ The iteration count
+
+
+ The protection mode - only if GnuDummyS2K
+
+
+ Basic packet for a PGP secret key.
+
+
+ Basic packet for a PGP secret key.
+
+
+ Generic signature packet.
+
+
+ Generate a version 4 signature packet.
+
+ @param signatureType
+ @param keyAlgorithm
+ @param hashAlgorithm
+ @param hashedData
+ @param unhashedData
+ @param fingerprint
+ @param signature
+
+
+ Generate a version 2/3 signature packet.
+
+ @param signatureType
+ @param keyAlgorithm
+ @param hashAlgorithm
+ @param fingerprint
+ @param signature
+
+
+ return the keyId
+ @return the keyId that created the signature.
+
+
+ return the signature trailer that must be included with the data
+ to reconstruct the signature
+
+ @return byte[]
+
+
+ * return the signature as a set of integers - note this is normalised to be the
+ * ASN.1 encoding of what appears in the signature packet.
+
+
+ Return the byte encoding of the signature section.
+ @return uninterpreted signature bytes.
+
+
+ Return the creation time in milliseconds since 1 Jan., 1970 UTC.
+
+
+ Basic type for a PGP Signature sub-packet.
+
+
+ Return the generic data making up the packet.
+
+
+ Basic PGP signature sub-packet tag types.
+
+
+ reader for signature sub-packets
+
+
+ Basic type for a symmetric key encrypted packet.
+
+
+ Basic tags for symmetric key algorithms
+
+
+ Basic type for a symmetric encrypted session key packet
+
+
+ @return int
+
+
+ @return S2k
+
+
+ @return byte[]
+
+
+ @return int
+
+
+ Basic type for a trust packet.
+
+
+ Basic type for a user attribute packet.
+
+
+ Basic type for a user attribute sub-packet.
+
+
+ return the generic data making up the packet.
+
+
+ Basic PGP user attribute sub-packet tag types.
+
+
+ reader for user attribute sub-packets
+
+
+ Basic type for a user ID packet.
+
+
+ Basic type for a image attribute packet.
+
+
+ Packet embedded signature
+
+
+ packet giving signature creation time.
+
+
+ packet giving signature expiration time.
+
+
+ Identifier for the modification detection feature
+
+
+ Returns if modification detection is supported.
+
+
+ Returns if a particular feature is supported.
+
+
+ Sets support for a particular feature.
+
+
+ packet giving signature creation time.
+
+
+ packet giving time after creation at which the key expires.
+
+
+ Return the number of seconds after creation time a key is valid for.
+
+ @return second count for key validity.
+
+
+ Packet holding the key flag values.
+
+
+
+ Return the flag values contained in the first 4 octets (note: at the moment
+ the standard only uses the first one).
+
+
+
+ Class provided a NotationData object according to
+ RFC2440, Chapter 5.2.3.15. Notation Data
+
+
+ packet giving signature creation time.
+
+
+ packet giving whether or not the signature is signed using the primary user ID for the key.
+
+
+ packet giving whether or not is revocable.
+
+
+ packet giving signature creation time.
+
+
+ packet giving signature expiration time.
+
+
+ return time in seconds before signature expires after creation time.
+
+
+ packet giving the User ID of the signer.
+
+
+ packet giving trust.
+
+
+
+ Represents revocation key OpenPGP signature sub packet.
+
+
+
+
+ Represents revocation reason OpenPGP signature sub packet.
+
+
+
+ Compressed data objects
+
+
+ The algorithm used for compression
+
+
+ Get the raw input stream contained in the object.
+
+
+ Return an uncompressed input stream which allows reading of the compressed data.
+
+
+ Class for producing compressed data packets.
+
+
+
+
+ Return an output stream which will save the data being written to
+ the compressed object.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+ Stream to be used for output.
+ A Stream for output of the compressed data.
+
+
+
+
+
+
+
+ Return an output stream which will compress the data as it is written to it.
+ The stream will be written out in chunks according to the size of the passed in buffer.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+ Note: if the buffer is not a power of 2 in length only the largest power of 2
+ bytes worth of the buffer will be used.
+
+
+ Note: using this may break compatibility with RFC 1991 compliant tools.
+ Only recent OpenPGP implementations are capable of accepting these streams.
+
+
+ Stream to be used for output.
+ The buffer to use.
+ A Stream for output of the compressed data.
+
+
+
+
+
+
+ Close the compressed object.summary>
+
+
+
+ Thrown if the IV at the start of a data stream indicates the wrong key is being used.
+
+
+
+ Return the raw input stream for the data stream.
+
+
+ Return true if the message is integrity protected.
+ True, if there is a modification detection code namespace associated
+ with this stream.
+
+
+ Note: This can only be called after the message has been read.
+ True, if the message verifies, false otherwise
+
+
+ Generator for encrypted objects.
+
+
+ Existing SecureRandom constructor.
+ The symmetric algorithm to use.
+ Source of randomness.
+
+
+ Creates a cipher stream which will have an integrity packet associated with it.
+
+
+ Base constructor.
+ The symmetric algorithm to use.
+ Source of randomness.
+ PGP 2.6.x compatibility required.
+
+
+
+ Add a PBE encryption method to the encrypted object using the default algorithm (S2K_SHA1).
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+ Add a PBE encryption method to the encrypted object.
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+ Add a PBE encryption method to the encrypted object.
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+
+
+ Add a PBE encryption method to the encrypted object.
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+ Add a public key encrypted session key to the encrypted object.
+
+
+
+
+ If buffer is non null stream assumed to be partial, otherwise the length will be used
+ to output a fixed length packet.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+
+
+
+
+ Return an output stream which will encrypt the data as it is written to it.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+
+
+
+
+ Return an output stream which will encrypt the data as it is written to it.
+ The stream will be written out in chunks according to the size of the passed in buffer.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+ Note: if the buffer is not a power of 2 in length only the largest power of 2
+ bytes worth of the buffer will be used.
+
+
+
+
+
+
+ Close off the encrypted object - this is equivalent to calling Close() on the stream
+ returned by the Open() method.
+
+
+ Note: This does not close the underlying output stream, only the stream on top of
+ it created by the Open() method.
+
+
+
+
+ A holder for a list of PGP encryption method packets.
+
+
+ Generic exception class for PGP encoding/decoding problems.
+
+
+ Key flag values for the KeyFlags subpacket.
+
+
+
+ General class to handle JCA key pairs and convert them into OpenPGP ones.
+
+ A word for the unwary, the KeyId for an OpenPGP public key is calculated from
+ a hash that includes the time of creation, if you pass a different date to the
+ constructor below with the same public private key pair the KeyIs will not be the
+ same as for previous generations of the key, so ideally you only want to do
+ this once.
+
+
+
+
+ Create a key pair from a PgpPrivateKey and a PgpPublicKey.
+ The public key.
+ The private key.
+
+
+ The keyId associated with this key pair.
+
+
+
+ Generator for a PGP master and subkey ring.
+ This class will generate both the secret and public key rings
+
+
+
+
+ Create a new key ring generator using old style checksumming. It is recommended to use
+ SHA1 checksumming where possible.
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+ The passPhrase to be used to protect secret keys.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+
+ Create a new key ring generator.
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+ The passPhrase to be used to protect secret keys.
+ Checksum the secret keys with SHA1 rather than the older 16 bit checksum.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+
+ Create a new key ring generator.
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+
+ If true, conversion of the passphrase to bytes uses Encoding.UTF8.GetBytes(), otherwise the conversion
+ is performed using Convert.ToByte(), which is the historical behaviour of the library (1.7 and earlier).
+
+ The passPhrase to be used to protect secret keys.
+ Checksum the secret keys with SHA1 rather than the older 16 bit checksum.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+
+ Create a new key ring generator.
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+ The passPhrase to be used to protect secret keys.
+ Checksum the secret keys with SHA1 rather than the older 16 bit checksum.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+
+ Create a new key ring generator.
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+ The hash algorithm.
+ The passPhrase to be used to protect secret keys.
+ Checksum the secret keys with SHA1 rather than the older 16 bit checksum.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+
+ Create a new key ring generator.
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+ The hash algorithm.
+
+ If true, conversion of the passphrase to bytes uses Encoding.UTF8.GetBytes(), otherwise the conversion
+ is performed using Convert.ToByte(), which is the historical behaviour of the library (1.7 and earlier).
+
+ The passPhrase to be used to protect secret keys.
+ Checksum the secret keys with SHA1 rather than the older 16 bit checksum.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+
+ Create a new key ring generator.
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+ The hash algorithm.
+ The passPhrase to be used to protect secret keys.
+ Checksum the secret keys with SHA1 rather than the older 16 bit checksum.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+ Add a subkey to the key ring to be generated with default certification.
+
+
+
+ Add a subkey to the key ring to be generated with default certification.
+
+ The key pair.
+ The hash algorithm.
+
+
+
+ Add a subkey with specific hashed and unhashed packets associated with it and
+ default certification.
+
+ Public/private key pair.
+ Hashed packet values to be included in certification.
+ Unhashed packets values to be included in certification.
+
+
+
+
+ Add a subkey with specific hashed and unhashed packets associated with it and
+ default certification.
+
+ Public/private key pair.
+ Hashed packet values to be included in certification.
+ Unhashed packets values to be included in certification.
+ The hash algorithm.
+ exception adding subkey:
+
+
+
+ Return the secret key ring.
+
+
+ Return the public key ring that corresponds to the secret key ring.
+
+
+
+ Thrown if the key checksum is invalid.
+
+
+
+ Class for processing literal data objects.
+
+
+ The special name indicating a "for your eyes only" packet.
+
+
+ The format of the data stream - Binary or Text
+
+
+ The file name that's associated with the data stream.
+
+
+ Return the file name as an unintrepreted byte array.
+
+
+ The modification time for the file.
+
+
+ The raw input stream for the data stream.
+
+
+ The input stream representing the data stream.
+
+
+ Class for producing literal data packets.
+
+
+ The special name indicating a "for your eyes only" packet.
+
+
+
+ Generates literal data objects in the old format.
+ This is important if you need compatibility with PGP 2.6.x.
+
+ If true, uses old format.
+
+
+
+
+ Open a literal data packet, returning a stream to store the data inside the packet.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+ The stream we want the packet in.
+ The format we are using.
+ The name of the 'file'.
+ The length of the data we will write.
+ The time of last modification we want stored.
+
+
+
+
+ Open a literal data packet, returning a stream to store the data inside the packet,
+ as an indefinite length stream. The stream is written out as a series of partial
+ packets with a chunk size determined by the size of the passed in buffer.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+ Note: if the buffer is not a power of 2 in length only the largest power of 2
+ bytes worth of the buffer will be used.
+
+ The stream we want the packet in.
+ The format we are using.
+ The name of the 'file'.
+ The time of last modification we want stored.
+ The buffer to use for collecting data to put into chunks.
+
+
+
+
+ Open a literal data packet for the passed in FileInfo object, returning
+ an output stream for saving the file contents.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+ The stream we want the packet in.
+ The format we are using.
+ The FileInfo object containg the packet details.
+
+
+
+ Close the literal data packet - this is equivalent to calling Close()
+ on the stream returned by the Open() method.
+
+
+
+
+ A PGP marker packet - in general these should be ignored other than where
+ the idea is to preserve the original input stream.
+
+
+
+
+ General class for reading a PGP object stream.
+
+ Note: if this class finds a PgpPublicKey or a PgpSecretKey it
+ will create a PgpPublicKeyRing, or a PgpSecretKeyRing for each
+ key found. If all you are trying to do is read a key ring file use
+ either PgpPublicKeyRingBundle or PgpSecretKeyRingBundle.
+
+
+
+ Return the next object in the stream, or null if the end is reached.
+ On a parse error
+
+
+
+ Return all available objects in a list.
+
+ An IList containing all objects from this factory, in order.
+
+
+ A one pass signature object.
+
+
+ Initialise the signature object for verification.
+
+
+ Verify the calculated signature against the passed in PgpSignature.
+
+
+ Holder for a list of PgpOnePassSignature objects.
+
+
+ Padding functions.
+
+
+ A password based encryption object.
+
+
+ Return the raw input stream for the data stream.
+
+
+ Return the decrypted input stream, using the passed in passphrase.
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+ Return the decrypted input stream, using the passed in passphrase.
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+
+
+ Return the decrypted input stream, using the passed in passphrase.
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+ General class to contain a private key for use with other OpenPGP objects.
+
+
+
+ Create a PgpPrivateKey from a keyID, the associated public data packet, and a regular private key.
+
+ ID of the corresponding public key.
+ the public key data packet to be associated with this private key.
+ the private key data packet to be associated with this private key.
+
+
+ The keyId associated with the contained private key.
+
+
+ The public key packet associated with this private key, if available.
+
+
+ The contained private key.
+
+
+ General class to handle a PGP public key object.
+
+
+
+ Create a PgpPublicKey from the passed in lightweight one.
+
+
+ Note: the time passed in affects the value of the key's keyId, so you probably only want
+ to do this once for a lightweight key, or make sure you keep track of the time you used.
+
+ Asymmetric algorithm type representing the public key.
+ Actual public key to associate.
+ Date of creation.
+ If pubKey is not public.
+ On key creation problem.
+
+
+ Constructor for a sub-key.
+
+
+ Copy constructor.
+ The public key to copy.
+
+
+ The version of this key.
+
+
+ The creation time of this key.
+
+
+ The number of valid days from creation time - zero means no expiry.
+ WARNING: This method will return 1 for keys with version > 3 that expire in less than 1 day
+
+
+ Return the trust data associated with the public key, if present.
+ A byte array with trust data, null otherwise.
+
+
+ The number of valid seconds from creation time - zero means no expiry.
+
+
+ The keyId associated with the public key.
+
+
+ The fingerprint of the key
+
+
+
+ Check if this key has an algorithm type that makes it suitable to use for encryption.
+
+
+ Note: with version 4 keys KeyFlags subpackets should also be considered when present for
+ determining the preferred use of the key.
+
+
+ true if this key algorithm is suitable for encryption.
+
+
+
+ True, if this is a master key.
+
+
+ The algorithm code associated with the public key.
+
+
+ The strength of the key in bits.
+
+
+ The public key contained in the object.
+ A lightweight public key.
+ If the key algorithm is not recognised.
+
+
+ Allows enumeration of any user IDs associated with the key.
+ An IEnumerable of string objects.
+
+
+ Allows enumeration of any user attribute vectors associated with the key.
+ An IEnumerable of PgpUserAttributeSubpacketVector objects.
+
+
+ Allows enumeration of any signatures associated with the passed in id.
+ The ID to be matched.
+ An IEnumerable of PgpSignature objects.
+
+
+ Allows enumeration of signatures associated with the passed in user attributes.
+ The vector of user attributes to be matched.
+ An IEnumerable of PgpSignature objects.
+
+
+ Allows enumeration of signatures of the passed in type that are on this key.
+ The type of the signature to be returned.
+ An IEnumerable of PgpSignature objects.
+
+
+ Allows enumeration of all signatures/certifications associated with this key.
+ An IEnumerable with all signatures/certifications.
+
+
+ Return all signatures/certifications directly associated with this key (ie, not to a user id).
+
+ @return an iterator (possibly empty) with all signatures/certifications.
+
+
+ Check whether this (sub)key has a revocation signature on it.
+ True, if this (sub)key has been revoked.
+
+
+ Add a certification for an id to the given public key.
+ The key the certification is to be added to.
+ The ID the certification is associated with.
+ The new certification.
+ The re-certified key.
+
+
+ Add a certification for the given UserAttributeSubpackets to the given public key.
+ The key the certification is to be added to.
+ The attributes the certification is associated with.
+ The new certification.
+ The re-certified key.
+
+
+
+ Remove any certifications associated with a user attribute subpacket on a key.
+
+ The key the certifications are to be removed from.
+ The attributes to be removed.
+
+ The re-certified key, or null if the user attribute subpacket was not found on the key.
+
+
+
+ Remove any certifications associated with a given ID on a key.
+ The key the certifications are to be removed from.
+ The ID that is to be removed.
+ The re-certified key, or null if the ID was not found on the key.
+
+
+ Remove a certification associated with a given ID on a key.
+ The key the certifications are to be removed from.
+ The ID that the certfication is to be removed from.
+ The certfication to be removed.
+ The re-certified key, or null if the certification was not found.
+
+
+ Remove a certification associated with a given user attributes on a key.
+ The key the certifications are to be removed from.
+ The user attributes that the certfication is to be removed from.
+ The certification to be removed.
+ The re-certified key, or null if the certification was not found.
+
+
+ Add a revocation or some other key certification to a key.
+ The key the revocation is to be added to.
+ The key signature to be added.
+ The new changed public key object.
+
+
+ Remove a certification from the key.
+ The key the certifications are to be removed from.
+ The certfication to be removed.
+ The modified key, null if the certification was not found.
+
+
+ A public key encrypted data object.
+
+
+ The key ID for the key used to encrypt the data.
+
+
+
+ Return the algorithm code for the symmetric algorithm used to encrypt the data.
+
+
+
+ Return the decrypted data stream for the packet.
+
+
+
+ Class to hold a single master public key and its subkeys.
+
+ Often PGP keyring files consist of multiple master keys, if you are trying to process
+ or construct one of these you should use the PgpPublicKeyRingBundle class.
+
+
+
+
+ Return the first public key in the ring.
+
+
+ Return the public key referred to by the passed in key ID if it is present.
+
+
+ Allows enumeration of all the public keys.
+ An IEnumerable of PgpPublicKey objects.
+
+
+
+ Returns a new key ring with the public key passed in either added or
+ replacing an existing one.
+
+ The public key ring to be modified.
+ The public key to be inserted.
+ A new PgpPublicKeyRing
+
+
+ Returns a new key ring with the public key passed in removed from the key ring.
+ The public key ring to be modified.
+ The public key to be removed.
+ A new PgpPublicKeyRing, or null if pubKey is not found.
+
+
+
+ Often a PGP key ring file is made up of a succession of master/sub-key key rings.
+ If you want to read an entire public key file in one hit this is the class for you.
+
+
+
+ Build a PgpPublicKeyRingBundle from the passed in input stream.
+ Input stream containing data.
+ If a problem parsing the stream occurs.
+ If an object is encountered which isn't a PgpPublicKeyRing.
+
+
+ Return the number of key rings in this collection.
+
+
+ Allow enumeration of the public key rings making up this collection.
+
+
+ Allow enumeration of the key rings associated with the passed in userId.
+ The user ID to be matched.
+ An IEnumerable of key rings which matched (possibly none).
+
+
+ Allow enumeration of the key rings associated with the passed in userId.
+ The user ID to be matched.
+ If true, userId need only be a substring of an actual ID string to match.
+ An IEnumerable of key rings which matched (possibly none).
+
+
+ Allow enumeration of the key rings associated with the passed in userId.
+ The user ID to be matched.
+ If true, userId need only be a substring of an actual ID string to match.
+ If true, case is ignored in user ID comparisons.
+ An IEnumerable of key rings which matched (possibly none).
+
+
+ Return the PGP public key associated with the given key id.
+ The ID of the public key to return.
+
+
+ Return the public key ring which contains the key referred to by keyId
+ key ID to match against
+
+
+
+ Return true if a key matching the passed in key ID is present, false otherwise.
+
+ key ID to look for.
+
+
+
+ Return a new bundle containing the contents of the passed in bundle and
+ the passed in public key ring.
+
+ The PgpPublicKeyRingBundle the key ring is to be added to.
+ The key ring to be added.
+ A new PgpPublicKeyRingBundle merging the current one with the passed in key ring.
+ If the keyId for the passed in key ring is already present.
+
+
+
+ Return a new bundle containing the contents of the passed in bundle with
+ the passed in public key ring removed.
+
+ The PgpPublicKeyRingBundle the key ring is to be removed from.
+ The key ring to be removed.
+ A new PgpPublicKeyRingBundle not containing the passed in key ring.
+ If the keyId for the passed in key ring is not present.
+
+
+ General class to handle a PGP secret key object.
+
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ If utf8PassPhrase is true, conversion of the passphrase to bytes uses Encoding.UTF8.GetBytes(), otherwise the conversion
+ is performed using Convert.ToByte(), which is the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ If utf8PassPhrase is true, conversion of the passphrase to bytes uses Encoding.UTF8.GetBytes(), otherwise the conversion
+ is performed using Convert.ToByte(), which is the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+
+ Check if this key has an algorithm type that makes it suitable to use for signing.
+
+
+ Note: with version 4 keys KeyFlags subpackets should also be considered when present for
+ determining the preferred use of the key.
+
+
+ true if this key algorithm is suitable for use with signing.
+
+
+
+ True, if this is a master key.
+
+
+ Detect if the Secret Key's Private Key is empty or not
+
+
+ The algorithm the key is encrypted with.
+
+
+ The key ID of the public key associated with this key.
+
+
+ Return the S2K usage associated with this key.
+
+
+ Return the S2K used to process this key.
+
+
+ The public key associated with this key.
+
+
+ Allows enumeration of any user IDs associated with the key.
+ An IEnumerable of string objects.
+
+
+ Allows enumeration of any user attribute vectors associated with the key.
+ An IEnumerable of string objects.
+
+
+ Extract a PgpPrivateKey from this secret key's encrypted contents.
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+ Extract a PgpPrivateKey from this secret key's encrypted contents.
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+
+
+ Extract a PgpPrivateKey from this secret key's encrypted contents.
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+
+ Return a copy of the passed in secret key, encrypted using a new password
+ and the passed in algorithm.
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+ The PgpSecretKey to be copied.
+ The current password for the key.
+ The new password for the key.
+ The algorithm to be used for the encryption.
+ Source of randomness.
+
+
+
+ Return a copy of the passed in secret key, encrypted using a new password
+ and the passed in algorithm.
+
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+ The PgpSecretKey to be copied.
+ The current password for the key.
+ The new password for the key.
+ The algorithm to be used for the encryption.
+ Source of randomness.
+
+
+
+ Return a copy of the passed in secret key, encrypted using a new password
+ and the passed in algorithm.
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+ The PgpSecretKey to be copied.
+ The current password for the key.
+ The new password for the key.
+ The algorithm to be used for the encryption.
+ Source of randomness.
+
+
+ Replace the passed the public key on the passed in secret key.
+ Secret key to change.
+ New public key.
+ A new secret key.
+ If KeyId's do not match.
+
+
+
+ Parse a secret key from one of the GPG S expression keys associating it with the passed in public key.
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ Parse a secret key from one of the GPG S expression keys associating it with the passed in public key.
+
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+
+
+
+ Parse a secret key from one of the GPG S expression keys associating it with the passed in public key.
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+
+ Parse a secret key from one of the GPG S expression keys.
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ Parse a secret key from one of the GPG S expression keys.
+
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+
+
+
+ Parse a secret key from one of the GPG S expression keys.
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+
+ Parse a secret key from one of the GPG S expression keys.
+
+
+
+
+ Class to hold a single master secret key and its subkeys.
+
+ Often PGP keyring files consist of multiple master keys, if you are trying to process
+ or construct one of these you should use the PgpSecretKeyRingBundle class.
+
+
+
+
+ Return the public key for the master key.
+
+
+ Return the master private key.
+
+
+ Allows enumeration of the secret keys.
+ An IEnumerable of PgpSecretKey objects.
+
+
+
+ Return an iterator of the public keys in the secret key ring that
+ have no matching private key. At the moment only personal certificate data
+ appears in this fashion.
+
+ An IEnumerable of unattached, or extra, public keys.
+
+
+
+ Replace the public key set on the secret ring with the corresponding key off the public ring.
+
+ Secret ring to be changed.
+ Public ring containing the new public key set.
+
+
+
+ Return a copy of the passed in secret key ring, with the master key and sub keys encrypted
+ using a new password and the passed in algorithm.
+
+ The PgpSecretKeyRing to be copied.
+ The current password for key.
+ The new password for the key.
+ The algorithm to be used for the encryption.
+ Source of randomness.
+
+
+
+ Returns a new key ring with the secret key passed in either added or
+ replacing an existing one with the same key ID.
+
+ The secret key ring to be modified.
+ The secret key to be inserted.
+ A new PgpSecretKeyRing
+
+
+ Returns a new key ring with the secret key passed in removed from the key ring.
+ The secret key ring to be modified.
+ The secret key to be removed.
+ A new PgpSecretKeyRing, or null if secKey is not found.
+
+
+
+ Often a PGP key ring file is made up of a succession of master/sub-key key rings.
+ If you want to read an entire secret key file in one hit this is the class for you.
+
+
+
+ Build a PgpSecretKeyRingBundle from the passed in input stream.
+ Input stream containing data.
+ If a problem parsing the stream occurs.
+ If an object is encountered which isn't a PgpSecretKeyRing.
+
+
+ Return the number of rings in this collection.
+
+
+ Allow enumeration of the secret key rings making up this collection.
+
+
+ Allow enumeration of the key rings associated with the passed in userId.
+ The user ID to be matched.
+ An IEnumerable of key rings which matched (possibly none).
+
+
+ Allow enumeration of the key rings associated with the passed in userId.
+ The user ID to be matched.
+ If true, userId need only be a substring of an actual ID string to match.
+ An IEnumerable of key rings which matched (possibly none).
+
+
+ Allow enumeration of the key rings associated with the passed in userId.
+ The user ID to be matched.
+ If true, userId need only be a substring of an actual ID string to match.
+ If true, case is ignored in user ID comparisons.
+ An IEnumerable of key rings which matched (possibly none).
+
+
+ Return the PGP secret key associated with the given key id.
+ The ID of the secret key to return.
+
+
+ Return the secret key ring which contains the key referred to by keyId
+ The ID of the secret key
+
+
+
+ Return true if a key matching the passed in key ID is present, false otherwise.
+
+ key ID to look for.
+
+
+
+ Return a new bundle containing the contents of the passed in bundle and
+ the passed in secret key ring.
+
+ The PgpSecretKeyRingBundle the key ring is to be added to.
+ The key ring to be added.
+ A new PgpSecretKeyRingBundle merging the current one with the passed in key ring.
+ If the keyId for the passed in key ring is already present.
+
+
+
+ Return a new bundle containing the contents of the passed in bundle with
+ the passed in secret key ring removed.
+
+ The PgpSecretKeyRingBundle the key ring is to be removed from.
+ The key ring to be removed.
+ A new PgpSecretKeyRingBundle not containing the passed in key ring.
+ If the keyId for the passed in key ring is not present.
+
+
+ A PGP signature object.
+
+
+ The OpenPGP version number for this signature.
+
+
+ The key algorithm associated with this signature.
+
+
+ The hash algorithm associated with this signature.
+
+
+
+ Verify the signature as certifying the passed in public key as associated
+ with the passed in user attributes.
+
+ User attributes the key was stored under.
+ The key to be verified.
+ True, if the signature matches, false otherwise.
+
+
+
+ Verify the signature as certifying the passed in public key as associated
+ with the passed in ID.
+
+ ID the key was stored under.
+ The key to be verified.
+ True, if the signature matches, false otherwise.
+
+
+ Verify a certification for the passed in key against the passed in master key.
+ The key we are verifying against.
+ The key we are verifying.
+ True, if the certification is valid, false otherwise.
+
+
+ Verify a key certification, such as revocation, for the passed in key.
+ The key we are checking.
+ True, if the certification is valid, false otherwise.
+
+
+ The ID of the key that created the signature.
+
+
+ The creation time of this signature.
+
+
+
+ Return true if the signature has either hashed or unhashed subpackets.
+
+
+
+ Generator for PGP signatures.
+
+
+ Create a generator for the passed in keyAlgorithm and hashAlgorithm codes.
+
+
+ Initialise the generator for signing.
+
+
+ Initialise the generator for signing.
+
+
+ Return the one pass header associated with the current signature.
+
+
+ Return a signature object containing the current signature state.
+
+
+ Generate a certification for the passed in ID and key.
+ The ID we are certifying against the public key.
+ The key we are certifying against the ID.
+ The certification.
+
+
+ Generate a certification for the passed in userAttributes.
+ The ID we are certifying against the public key.
+ The key we are certifying against the ID.
+ The certification.
+
+
+ Generate a certification for the passed in key against the passed in master key.
+ The key we are certifying against.
+ The key we are certifying.
+ The certification.
+
+
+ Generate a certification, such as a revocation, for the passed in key.
+ The key we are certifying.
+ The certification.
+
+
+ A list of PGP signatures - normally in the signature block after literal data.
+
+
+ Generator for signature subpackets.
+
+
+
+ Add a TrustSignature packet to the signature. The values for depth and trust are largely
+ installation dependent but there are some guidelines in RFC 4880 - 5.2.3.13.
+
+ true if the packet is critical.
+ depth level.
+ trust amount.
+
+
+
+ Set the number of seconds a key is valid for after the time of its creation.
+ A value of zero means the key never expires.
+
+ True, if should be treated as critical, false otherwise.
+ The number of seconds the key is valid, or zero if no expiry.
+
+
+
+ Set the number of seconds a signature is valid for after the time of its creation.
+ A value of zero means the signature never expires.
+
+ True, if should be treated as critical, false otherwise.
+ The number of seconds the signature is valid, or zero if no expiry.
+
+
+
+ Set the creation time for the signature.
+
+ Note: this overrides the generation of a creation time when the signature
+ is generated.
+
+
+
+
+ Sets revocation reason sub packet
+
+
+
+
+ Sets revocation key sub packet
+
+
+
+
+ Sets issuer key sub packet
+
+
+
+ Container for a list of signature subpackets.
+
+
+ Return true if a particular subpacket type exists.
+
+ @param type type to look for.
+ @return true if present, false otherwise.
+
+
+ Return all signature subpackets of the passed in type.
+ @param type subpacket type code
+ @return an array of zero or more matching subpackets.
+
+
+
+ Return the number of seconds a signature is valid for after its creation date.
+ A value of zero means the signature never expires.
+
+ Seconds a signature is valid for.
+
+
+
+ Return the number of seconds a key is valid for after its creation date.
+ A value of zero means the key never expires.
+
+ Seconds a signature is valid for.
+
+
+ Return the number of packets this vector contains.
+
+
+ Container for a list of user attribute subpackets.
+
+
+ Basic utility class.
+
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+ Write out the passed in file as a literal data packet.
+
+
+ Write out the passed in file as a literal data packet in partial packet format.
+
+
+
+ Return either an ArmoredInputStream or a BcpgInputStream based on whether
+ the initial characters of the stream are binary PGP encodings or not.
+
+
+
+ Generator for old style PGP V3 Signatures.
+
+
+ Create a generator for the passed in keyAlgorithm and hashAlgorithm codes.
+
+
+ Initialise the generator for signing.
+
+
+ Initialise the generator for signing.
+
+
+ Return the one pass header associated with the current signature.
+
+
+ Return a V3 signature object containing the current signature state.
+
+
+ Utility functions for looking a S-expression keys. This class will move when it finds a better home!
+
+ Format documented here:
+ http://git.gnupg.org/cgi-bin/gitweb.cgi?p=gnupg.git;a=blob;f=agent/keyformat.txt;h=42c4b1f06faf1bbe71ffadc2fee0fad6bec91a97;hb=refs/heads/master
+
+
+
+
+ The 'Signature' parameter is only available when generating unsigned attributes.
+
+
+
+ containing class for an CMS AuthEnveloped Data object
+
+
+ containing class for an CMS Authenticated Data object
+
+
+ return the object identifier for the content MAC algorithm.
+
+
+ return a store of the intended recipients for this message
+
+
+ return the ContentInfo
+
+
+ return a table of the digested attributes indexed by
+ the OID of the attribute.
+
+
+ return a table of the undigested attributes indexed by
+ the OID of the attribute.
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ General class for generating a CMS authenticated-data message.
+
+ A simple example of usage.
+
+
+ CMSAuthenticatedDataGenerator fact = new CMSAuthenticatedDataGenerator();
+
+ fact.addKeyTransRecipient(cert);
+
+ CMSAuthenticatedData data = fact.generate(content, algorithm, "BC");
+
+
+
+ base constructor
+
+
+ constructor allowing specific source of randomness
+ @param rand instance of SecureRandom to use
+
+
+ generate an enveloped object that contains an CMS Enveloped Data
+ object using the given provider and the passed in key generator.
+
+
+ generate an authenticated object that contains an CMS Authenticated Data object
+
+
+ Parsing class for an CMS Authenticated Data object from an input stream.
+
+ Note: that because we are in a streaming mode only one recipient can be tried and it is important
+ that the methods on the parser are called in the appropriate order.
+
+
+ Example of use - assuming the first recipient matches the private key we have.
+
+ CMSAuthenticatedDataParser ad = new CMSAuthenticatedDataParser(inputStream);
+
+ RecipientInformationStore recipients = ad.getRecipientInfos();
+
+ Collection c = recipients.getRecipients();
+ Iterator it = c.iterator();
+
+ if (it.hasNext())
+ {
+ RecipientInformation recipient = (RecipientInformation)it.next();
+
+ CMSTypedStream recData = recipient.getContentStream(privateKey, "BC");
+
+ processDataStream(recData.getContentStream());
+
+ if (!Arrays.equals(ad.getMac(), recipient.getMac())
+ {
+ System.err.println("Data corrupted!!!!");
+ }
+ }
+
+ Note: this class does not introduce buffering - if you are processing large files you should create
+ the parser with:
+
+ CMSAuthenticatedDataParser ep = new CMSAuthenticatedDataParser(new BufferedInputStream(inputStream, bufSize));
+
+ where bufSize is a suitably large buffer size.
+
+
+
+ return the object identifier for the mac algorithm.
+
+
+ return the ASN.1 encoded encryption algorithm parameters, or null if
+ there aren't any.
+
+
+ return a store of the intended recipients for this message
+
+
+ return a table of the unauthenticated attributes indexed by
+ the OID of the attribute.
+ @exception java.io.IOException
+
+
+ return a table of the unauthenticated attributes indexed by
+ the OID of the attribute.
+ @exception java.io.IOException
+
+
+ General class for generating a CMS authenticated-data message stream.
+
+ A simple example of usage.
+
+ CMSAuthenticatedDataStreamGenerator edGen = new CMSAuthenticatedDataStreamGenerator();
+
+ edGen.addKeyTransRecipient(cert);
+
+ ByteArrayOutputStream bOut = new ByteArrayOutputStream();
+
+ OutputStream out = edGen.open(
+ bOut, CMSAuthenticatedDataGenerator.AES128_CBC, "BC");*
+ out.write(data);
+
+ out.close();
+
+
+
+
+ base constructor
+
+
+ constructor allowing specific source of randomness
+ @param rand instance of SecureRandom to use
+
+
+ Set the underlying string size for encapsulated data
+
+ @param bufferSize length of octet strings to buffer the data.
+
+
+ Use a BER Set to store the recipient information
+
+
+ generate an enveloped object that contains an CMS Enveloped Data
+ object using the given provider and the passed in key generator.
+ @throws java.io.IOException
+
+
+ generate an enveloped object that contains an CMS Enveloped Data object
+
+
+ generate an enveloped object that contains an CMS Enveloped Data object
+
+
+ base constructor
+
+
+ constructor allowing specific source of randomness
+
+ @param rand instance of SecureRandom to use
+
+
+ containing class for an CMS Compressed Data object
+
+
+ Return the uncompressed content.
+
+ @return the uncompressed content
+ @throws CmsException if there is an exception uncompressing the data.
+
+
+ Return the uncompressed content, throwing an exception if the data size
+ is greater than the passed in limit. If the content is exceeded getCause()
+ on the CMSException will contain a StreamOverflowException
+
+ @param limit maximum number of bytes to read
+ @return the content read
+ @throws CMSException if there is an exception uncompressing the data.
+
+
+ return the ContentInfo
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ * General class for generating a compressed CMS message.
+ *
+ * A simple example of usage.
+ *
+ *
+ * CMSCompressedDataGenerator fact = new CMSCompressedDataGenerator();
+ * CMSCompressedData data = fact.Generate(content, algorithm);
+ *
+ *
+
+
+ Generate an object that contains an CMS Compressed Data
+
+
+ Class for reading a CMS Compressed Data stream.
+
+ CMSCompressedDataParser cp = new CMSCompressedDataParser(inputStream);
+
+ process(cp.GetContent().GetContentStream());
+
+ Note: this class does not introduce buffering - if you are processing large files you should create
+ the parser with:
+
+ CMSCompressedDataParser ep = new CMSCompressedDataParser(new BufferedInputStream(inputStream, bufSize));
+
+ where bufSize is a suitably large buffer size.
+
+
+ General class for generating a compressed CMS message stream.
+
+ A simple example of usage.
+
+
+ CMSCompressedDataStreamGenerator gen = new CMSCompressedDataStreamGenerator();
+
+ Stream cOut = gen.Open(outputStream, CMSCompressedDataStreamGenerator.ZLIB);
+
+ cOut.Write(data);
+
+ cOut.Close();
+
+
+
+ base constructor
+
+
+ Set the underlying string size for encapsulated data
+
+ @param bufferSize length of octet strings to buffer the data.
+
+
+ Close the underlying data stream.
+ @throws IOException if the close fails.
+
+
+ containing class for an CMS Enveloped Data object
+
+
+ return the object identifier for the content encryption algorithm.
+
+
+ return a store of the intended recipients for this message
+
+
+ return the ContentInfo
+
+
+ return a table of the unprotected attributes indexed by
+ the OID of the attribute.
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+
+ General class for generating a CMS enveloped-data message.
+
+ A simple example of usage.
+
+
+ CmsEnvelopedDataGenerator fact = new CmsEnvelopedDataGenerator();
+
+ fact.AddKeyTransRecipient(cert);
+
+ CmsEnvelopedData data = fact.Generate(content, algorithm);
+
+
+
+
+ Constructor allowing specific source of randomness
+ Instance of SecureRandom to use.
+
+
+
+ Generate an enveloped object that contains a CMS Enveloped Data
+ object using the passed in key generator.
+
+
+
+ Generate an enveloped object that contains an CMS Enveloped Data object.
+
+
+ Generate an enveloped object that contains an CMS Enveloped Data object.
+
+
+ Parsing class for an CMS Enveloped Data object from an input stream.
+
+ Note: that because we are in a streaming mode only one recipient can be tried and it is important
+ that the methods on the parser are called in the appropriate order.
+
+
+ Example of use - assuming the first recipient matches the private key we have.
+
+ CmsEnvelopedDataParser ep = new CmsEnvelopedDataParser(inputStream);
+
+ RecipientInformationStore recipients = ep.GetRecipientInfos();
+
+ Collection c = recipients.getRecipients();
+ Iterator it = c.iterator();
+
+ if (it.hasNext())
+ {
+ RecipientInformation recipient = (RecipientInformation)it.next();
+
+ CMSTypedStream recData = recipient.getContentStream(privateKey);
+
+ processDataStream(recData.getContentStream());
+ }
+
+ Note: this class does not introduce buffering - if you are processing large files you should create
+ the parser with:
+
+ CmsEnvelopedDataParser ep = new CmsEnvelopedDataParser(new BufferedInputStream(inputStream, bufSize));
+
+ where bufSize is a suitably large buffer size.
+
+
+
+ return the object identifier for the content encryption algorithm.
+
+
+ return the ASN.1 encoded encryption algorithm parameters, or null if
+ there aren't any.
+
+
+ return a store of the intended recipients for this message
+
+
+ return a table of the unprotected attributes indexed by
+ the OID of the attribute.
+ @throws IOException
+
+
+ General class for generating a CMS enveloped-data message stream.
+
+ A simple example of usage.
+
+ CmsEnvelopedDataStreamGenerator edGen = new CmsEnvelopedDataStreamGenerator();
+
+ edGen.AddKeyTransRecipient(cert);
+
+ MemoryStream bOut = new MemoryStream();
+
+ Stream out = edGen.Open(
+ bOut, CMSEnvelopedDataGenerator.AES128_CBC);*
+ out.Write(data);
+
+ out.Close();
+
+
+
+
+ Constructor allowing specific source of randomness
+ Instance of SecureRandom to use.
+
+
+ Set the underlying string size for encapsulated data.
+ Length of octet strings to buffer the data.
+
+
+ Use a BER Set to store the recipient information.
+
+
+
+ Generate an enveloped object that contains an CMS Enveloped Data
+ object using the passed in key generator.
+
+
+
+ generate an enveloped object that contains an CMS Enveloped Data object
+ @throws IOException
+
+
+ generate an enveloped object that contains an CMS Enveloped Data object
+ @throws IOException
+
+
+ General class for generating a CMS enveloped-data message.
+
+ A simple example of usage.
+
+
+ CMSEnvelopedDataGenerator fact = new CMSEnvelopedDataGenerator();
+
+ fact.addKeyTransRecipient(cert);
+
+ CMSEnvelopedData data = fact.generate(content, algorithm, "BC");
+
+
+
+ Constructor allowing specific source of randomness
+ Instance of SecureRandom to use.
+
+
+ add a recipient.
+
+ @param cert recipient's public key certificate
+ @exception ArgumentException if there is a problem with the certificate
+
+
+ add a recipient
+
+ @param key the public key used by the recipient
+ @param subKeyId the identifier for the recipient's public key
+ @exception ArgumentException if there is a problem with the key
+
+
+ add a KEK recipient.
+ @param key the secret key to use for wrapping
+ @param keyIdentifier the byte string that identifies the key
+
+
+ add a KEK recipient.
+ @param key the secret key to use for wrapping
+ @param keyIdentifier the byte string that identifies the key
+
+
+ Add a key agreement based recipient.
+
+ @param agreementAlgorithm key agreement algorithm to use.
+ @param senderPrivateKey private key to initialise sender side of agreement with.
+ @param senderPublicKey sender public key to include with message.
+ @param recipientCert recipient's public key certificate.
+ @param cekWrapAlgorithm OID for key wrapping algorithm to use.
+ @exception SecurityUtilityException if the algorithm requested cannot be found
+ @exception InvalidKeyException if the keys are inappropriate for the algorithm specified
+
+
+ Add multiple key agreement based recipients (sharing a single KeyAgreeRecipientInfo structure).
+
+ @param agreementAlgorithm key agreement algorithm to use.
+ @param senderPrivateKey private key to initialise sender side of agreement with.
+ @param senderPublicKey sender public key to include with message.
+ @param recipientCerts recipients' public key certificates.
+ @param cekWrapAlgorithm OID for key wrapping algorithm to use.
+ @exception SecurityUtilityException if the algorithm requested cannot be found
+ @exception InvalidKeyException if the keys are inappropriate for the algorithm specified
+
+
+
+ Generic routine to copy out the data we want processed.
+
+
+ This routine may be called multiple times.
+
+
+
+ a holding class for a byte array of data to be processed.
+
+
+ A clone of the byte array
+
+
+ a holding class for a file of data to be processed.
+
+
+ The file handle
+
+
+ general class for handling a pkcs7-signature message.
+
+ A simple example of usage - note, in the example below the validity of
+ the certificate isn't verified, just the fact that one of the certs
+ matches the given signer...
+
+
+ IX509Store certs = s.GetCertificates();
+ SignerInformationStore signers = s.GetSignerInfos();
+
+ foreach (SignerInformation signer in signers.GetSigners())
+ {
+ ArrayList certList = new ArrayList(certs.GetMatches(signer.SignerID));
+ X509Certificate cert = (X509Certificate) certList[0];
+
+ if (signer.Verify(cert.GetPublicKey()))
+ {
+ verified++;
+ }
+ }
+
+
+
+ Content with detached signature, digests precomputed
+
+ @param hashes a map of precomputed digests for content indexed by name of hash.
+ @param sigBlock the signature object.
+
+
+ base constructor - content with detached signature.
+
+ @param signedContent the content that was signed.
+ @param sigData the signature object.
+
+
+ base constructor - with encapsulated content
+
+
+ Return the version number for this object.
+
+
+ return the collection of signers that are associated with the
+ signatures for the message.
+
+
+ return a X509Store containing the attribute certificates, if any, contained
+ in this message.
+
+ @param type type of store to create
+ @return a store of attribute certificates
+ @exception NoSuchStoreException if the store type isn't available.
+ @exception CmsException if a general exception prevents creation of the X509Store
+
+
+ return a X509Store containing the public key certificates, if any, contained
+ in this message.
+
+ @param type type of store to create
+ @return a store of public key certificates
+ @exception NoSuchStoreException if the store type isn't available.
+ @exception CmsException if a general exception prevents creation of the X509Store
+
+
+ return a X509Store containing CRLs, if any, contained
+ in this message.
+
+ @param type type of store to create
+ @return a store of CRLs
+ @exception NoSuchStoreException if the store type isn't available.
+ @exception CmsException if a general exception prevents creation of the X509Store
+
+
+
+ Return the DerObjectIdentifier associated with the encapsulated
+ content info structure carried in the signed data.
+
+
+
+ return the ContentInfo
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ Replace the signerinformation store associated with this
+ CmsSignedData object with the new one passed in. You would
+ probably only want to do this if you wanted to change the unsigned
+ attributes associated with a signer, or perhaps delete one.
+
+ @param signedData the signed data object to be used as a base.
+ @param signerInformationStore the new signer information store to use.
+ @return a new signed data object.
+
+
+ Replace the certificate and CRL information associated with this
+ CmsSignedData object with the new one passed in.
+
+ @param signedData the signed data object to be used as a base.
+ @param x509Certs the new certificates to be used.
+ @param x509Crls the new CRLs to be used.
+ @return a new signed data object.
+ @exception CmsException if there is an error processing the stores
+
+
+ * general class for generating a pkcs7-signature message.
+ *
+ * A simple example of usage.
+ *
+ *
+ * IX509Store certs...
+ * IX509Store crls...
+ * CmsSignedDataGenerator gen = new CmsSignedDataGenerator();
+ *
+ * gen.AddSigner(privKey, cert, CmsSignedGenerator.DigestSha1);
+ * gen.AddCertificates(certs);
+ * gen.AddCrls(crls);
+ *
+ * CmsSignedData data = gen.Generate(content);
+ *
+ *
+
+
+ Constructor allowing specific source of randomness
+ Instance of SecureRandom to use.
+
+
+ * add a signer - no attributes other than the default ones will be
+ * provided here.
+ *
+ * @param key signing key to use
+ * @param cert certificate containing corresponding public key
+ * @param digestOID digest algorithm OID
+
+
+ add a signer, specifying the digest encryption algorithm to use - no attributes other than the default ones will be
+ provided here.
+
+ @param key signing key to use
+ @param cert certificate containing corresponding public key
+ @param encryptionOID digest encryption algorithm OID
+ @param digestOID digest algorithm OID
+
+
+ add a signer - no attributes other than the default ones will be
+ provided here.
+
+
+ add a signer, specifying the digest encryption algorithm to use - no attributes other than the default ones will be
+ provided here.
+
+
+ * add a signer with extra signed/unsigned attributes.
+ *
+ * @param key signing key to use
+ * @param cert certificate containing corresponding public key
+ * @param digestOID digest algorithm OID
+ * @param signedAttr table of attributes to be included in signature
+ * @param unsignedAttr table of attributes to be included as unsigned
+
+
+ add a signer, specifying the digest encryption algorithm, with extra signed/unsigned attributes.
+
+ @param key signing key to use
+ @param cert certificate containing corresponding public key
+ @param encryptionOID digest encryption algorithm OID
+ @param digestOID digest algorithm OID
+ @param signedAttr table of attributes to be included in signature
+ @param unsignedAttr table of attributes to be included as unsigned
+
+
+ * add a signer with extra signed/unsigned attributes.
+ *
+ * @param key signing key to use
+ * @param subjectKeyID subjectKeyID of corresponding public key
+ * @param digestOID digest algorithm OID
+ * @param signedAttr table of attributes to be included in signature
+ * @param unsignedAttr table of attributes to be included as unsigned
+
+
+ add a signer, specifying the digest encryption algorithm, with extra signed/unsigned attributes.
+
+ @param key signing key to use
+ @param subjectKeyID subjectKeyID of corresponding public key
+ @param encryptionOID digest encryption algorithm OID
+ @param digestOID digest algorithm OID
+ @param signedAttr table of attributes to be included in signature
+ @param unsignedAttr table of attributes to be included as unsigned
+
+
+ add a signer with extra signed/unsigned attributes based on generators.
+
+
+ add a signer, specifying the digest encryption algorithm, with extra signed/unsigned attributes based on generators.
+
+
+ add a signer with extra signed/unsigned attributes based on generators.
+
+
+ add a signer, including digest encryption algorithm, with extra signed/unsigned attributes based on generators.
+
+
+ generate a signed object that for a CMS Signed Data object
+
+
+ generate a signed object that for a CMS Signed Data
+ object - if encapsulate is true a copy
+ of the message will be included in the signature. The content type
+ is set according to the OID represented by the string signedContentType.
+
+
+ generate a signed object that for a CMS Signed Data
+ object - if encapsulate is true a copy
+ of the message will be included in the signature with the
+ default content type "data".
+
+
+ generate a set of one or more SignerInformation objects representing counter signatures on
+ the passed in SignerInformation object.
+
+ @param signer the signer to be countersigned
+ @param sigProvider the provider to be used for counter signing.
+ @return a store containing the signers.
+
+
+ Parsing class for an CMS Signed Data object from an input stream.
+
+ Note: that because we are in a streaming mode only one signer can be tried and it is important
+ that the methods on the parser are called in the appropriate order.
+
+
+ A simple example of usage for an encapsulated signature.
+
+
+ Two notes: first, in the example below the validity of
+ the certificate isn't verified, just the fact that one of the certs
+ matches the given signer, and, second, because we are in a streaming
+ mode the order of the operations is important.
+
+
+ CmsSignedDataParser sp = new CmsSignedDataParser(encapSigData);
+
+ sp.GetSignedContent().Drain();
+
+ IX509Store certs = sp.GetCertificates();
+ SignerInformationStore signers = sp.GetSignerInfos();
+
+ foreach (SignerInformation signer in signers.GetSigners())
+ {
+ ArrayList certList = new ArrayList(certs.GetMatches(signer.SignerID));
+ X509Certificate cert = (X509Certificate) certList[0];
+
+ Console.WriteLine("verify returns: " + signer.Verify(cert));
+ }
+
+ Note also: this class does not introduce buffering - if you are processing large files you should create
+ the parser with:
+
+ CmsSignedDataParser ep = new CmsSignedDataParser(new BufferedInputStream(encapSigData, bufSize));
+
+ where bufSize is a suitably large buffer size.
+
+
+ base constructor - with encapsulated content
+
+
+ base constructor
+
+ @param signedContent the content that was signed.
+ @param sigData the signature object.
+
+
+ Return the version number for the SignedData object
+
+ @return the version number
+
+
+ return the collection of signers that are associated with the
+ signatures for the message.
+ @throws CmsException
+
+
+ return a X509Store containing the attribute certificates, if any, contained
+ in this message.
+
+ @param type type of store to create
+ @return a store of attribute certificates
+ @exception org.bouncycastle.x509.NoSuchStoreException if the store type isn't available.
+ @exception CmsException if a general exception prevents creation of the X509Store
+
+
+ return a X509Store containing the public key certificates, if any, contained
+ in this message.
+
+ @param type type of store to create
+ @return a store of public key certificates
+ @exception NoSuchStoreException if the store type isn't available.
+ @exception CmsException if a general exception prevents creation of the X509Store
+
+
+ return a X509Store containing CRLs, if any, contained
+ in this message.
+
+ @param type type of store to create
+ @return a store of CRLs
+ @exception NoSuchStoreException if the store type isn't available.
+ @exception CmsException if a general exception prevents creation of the X509Store
+
+
+
+ Return the DerObjectIdentifier associated with the encapsulated
+ content info structure carried in the signed data.
+
+
+
+ Replace the signerinformation store associated with the passed
+ in message contained in the stream original with the new one passed in.
+ You would probably only want to do this if you wanted to change the unsigned
+ attributes associated with a signer, or perhaps delete one.
+
+ The output stream is returned unclosed.
+
+ @param original the signed data stream to be used as a base.
+ @param signerInformationStore the new signer information store to use.
+ @param out the stream to Write the new signed data object to.
+ @return out.
+
+
+ Replace the certificate and CRL information associated with this
+ CMSSignedData object with the new one passed in.
+
+ The output stream is returned unclosed.
+
+ @param original the signed data stream to be used as a base.
+ @param certsAndCrls the new certificates and CRLs to be used.
+ @param out the stream to Write the new signed data object to.
+ @return out.
+ @exception CmsException if there is an error processing the CertStore
+
+
+ General class for generating a pkcs7-signature message stream.
+
+ A simple example of usage.
+
+
+ IX509Store certs...
+ CmsSignedDataStreamGenerator gen = new CmsSignedDataStreamGenerator();
+
+ gen.AddSigner(privateKey, cert, CmsSignedDataStreamGenerator.DIGEST_SHA1);
+
+ gen.AddCertificates(certs);
+
+ Stream sigOut = gen.Open(bOut);
+
+ sigOut.Write(Encoding.UTF8.GetBytes("Hello World!"));
+
+ sigOut.Close();
+
+
+
+ Constructor allowing specific source of randomness
+ Instance of SecureRandom to use.
+
+
+ Set the underlying string size for encapsulated data
+
+ @param bufferSize length of octet strings to buffer the data.
+
+
+ add a signer - no attributes other than the default ones will be
+ provided here.
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ add a signer, specifying the digest encryption algorithm - no attributes other than the default ones will be
+ provided here.
+ @throws NoSuchProviderException
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ add a signer with extra signed/unsigned attributes.
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ add a signer with extra signed/unsigned attributes - specifying digest
+ encryption algorithm.
+ @throws NoSuchProviderException
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ add a signer - no attributes other than the default ones will be
+ provided here.
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ add a signer - no attributes other than the default ones will be
+ provided here.
+ @throws NoSuchProviderException
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ add a signer with extra signed/unsigned attributes.
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ generate a signed object that for a CMS Signed Data object
+
+
+ generate a signed object that for a CMS Signed Data
+ object - if encapsulate is true a copy
+ of the message will be included in the signature with the
+ default content type "data".
+
+
+ generate a signed object that for a CMS Signed Data
+ object using the given provider - if encapsulate is true a copy
+ of the message will be included in the signature with the
+ default content type "data". If dataOutputStream is non null the data
+ being signed will be written to the stream as it is processed.
+ @param out stream the CMS object is to be written to.
+ @param encapsulate true if data should be encapsulated.
+ @param dataOutputStream output stream to copy the data being signed to.
+
+
+ generate a signed object that for a CMS Signed Data
+ object - if encapsulate is true a copy
+ of the message will be included in the signature. The content type
+ is set according to the OID represented by the string signedContentType.
+
+
+ generate a signed object that for a CMS Signed Data
+ object using the given provider - if encapsulate is true a copy
+ of the message will be included in the signature. The content type
+ is set according to the OID represented by the string signedContentType.
+ @param out stream the CMS object is to be written to.
+ @param signedContentType OID for data to be signed.
+ @param encapsulate true if data should be encapsulated.
+ @param dataOutputStream output stream to copy the data being signed to.
+
+
+ Default type for the signed data.
+
+
+ Constructor allowing specific source of randomness
+ Instance of SecureRandom to use.
+
+
+ Add the attribute certificates contained in the passed in store to the
+ generator.
+
+ @param store a store of Version 2 attribute certificates
+ @throws CmsException if an error occurse processing the store.
+
+
+ Add a store of precalculated signers to the generator.
+
+ @param signerStore store of signers
+
+
+ Return a map of oids and byte arrays representing the digests calculated on the content during
+ the last generate.
+
+ @return a map of oids (as String objects) and byte[] representing digests.
+
+
+ Return the digest algorithm using one of the standard JCA string
+ representations rather than the algorithm identifier (if possible).
+
+
+ Return the digest encryption algorithm using one of the standard
+ JCA string representations rather than the algorithm identifier (if
+ possible).
+
+
+ Default authenticated attributes generator.
+
+
+ Initialise to use all defaults
+
+
+ Initialise with some extra attributes or overrides.
+
+ @param attributeTable initial attribute table to use.
+
+
+ Create a standard attribute table from the passed in parameters - this will
+ normally include contentType and messageDigest. If the constructor
+ using an AttributeTable was used, entries in it for contentType and
+ messageDigest will override the generated ones.
+
+ @param parameters source parameters for table generation.
+
+ @return a filled in IDictionary of attributes.
+
+
+ @param parameters source parameters
+ @return the populated attribute table
+
+
+ Default signed attributes generator.
+
+
+ Initialise to use all defaults
+
+
+ Initialise with some extra attributes or overrides.
+
+ @param attributeTable initial attribute table to use.
+
+
+ Create a standard attribute table from the passed in parameters - this will
+ normally include contentType, signingTime, and messageDigest. If the constructor
+ using an AttributeTable was used, entries in it for contentType, signingTime, and
+ messageDigest will override the generated ones.
+
+ @param parameters source parameters for table generation.
+
+ @return a filled in Hashtable of attributes.
+
+
+ @param parameters source parameters
+ @return the populated attribute table
+
+
+ the RecipientInfo class for a recipient who has been sent a message
+ encrypted using a secret key known to the other side.
+
+
+ decrypt the content and return an input stream.
+
+
+ the RecipientInfo class for a recipient who has been sent a message
+ encrypted using key agreement.
+
+
+ decrypt the content and return an input stream.
+
+
+ the KeyTransRecipientInformation class for a recipient who has been sent a secret
+ key encrypted using their public key that needs to be used to
+ extract the message.
+
+
+ decrypt the content and return it as a byte array.
+
+
+ a basic index for an originator.
+
+
+ Return the certificates stored in the underlying OriginatorInfo object.
+
+ @return a Store of X509CertificateHolder objects.
+
+
+ Return the CRLs stored in the underlying OriginatorInfo object.
+
+ @return a Store of X509CRLHolder objects.
+
+
+ Return the underlying ASN.1 object defining this SignerInformation object.
+
+ @return a OriginatorInfo.
+
+
+
+ PKCS5 scheme-2 - password converted to bytes assuming ASCII.
+
+
+
+ PKCS5 scheme-2 - password converted to bytes using UTF-8.
+
+
+ the RecipientInfo class for a recipient who has been sent a message
+ encrypted using a password.
+
+
+ return the object identifier for the key derivation algorithm, or null
+ if there is none present.
+
+ @return OID for key derivation algorithm, if present.
+
+
+ decrypt the content and return an input stream.
+
+
+
+ Generate a RecipientInfo object for the given key.
+
+
+ A
+
+
+ A
+
+
+ A
+
+
+
+
+ * return the object identifier for the key encryption algorithm.
+ *
+ * @return OID for key encryption algorithm.
+
+
+ * return the ASN.1 encoded key encryption algorithm parameters, or null if
+ * there aren't any.
+ *
+ * @return ASN.1 encoding of key encryption algorithm parameters.
+
+
+ Return the MAC calculated for the content stream. Note: this call is only meaningful once all
+ the content has been read.
+
+ @return byte array containing the mac.
+
+
+ Return the first RecipientInformation object that matches the
+ passed in selector. Null if there are no matches.
+
+ @param selector to identify a recipient
+ @return a single RecipientInformation object. Null if none matches.
+
+
+ Return the number of recipients in the collection.
+
+ @return number of recipients identified.
+
+
+ Return all recipients in the collection
+
+ @return a collection of recipients.
+
+
+ Return possible empty collection with recipients matching the passed in RecipientID
+
+ @param selector a recipient id to select against.
+ @return a collection of RecipientInformation objects.
+
+
+ a basic index for a signer.
+
+
+ If the passed in flag is true, the signer signature will be based on the data, not
+ a collection of signed attributes, and no signed attributes will be included.
+
+ @return the builder object
+
+
+ Provide a custom signed attribute generator.
+
+ @param signedGen a generator of signed attributes.
+ @return the builder object
+
+
+ Provide a generator of unsigned attributes.
+
+ @param unsignedGen a generator for signed attributes.
+ @return the builder object
+
+
+ Build a generator with the passed in certHolder issuer and serial number as the signerIdentifier.
+
+ @param contentSigner operator for generating the final signature in the SignerInfo with.
+ @param certHolder carrier for the X.509 certificate related to the contentSigner.
+ @return a SignerInfoGenerator
+ @throws OperatorCreationException if the generator cannot be built.
+
+
+ Build a generator with the passed in subjectKeyIdentifier as the signerIdentifier. If used you should
+ try to follow the calculation described in RFC 5280 section 4.2.1.2.
+
+ @param signerFactory operator factory for generating the final signature in the SignerInfo with.
+ @param subjectKeyIdentifier key identifier to identify the public key for verifying the signature.
+ @return a SignerInfoGenerator
+
+
+ an expanded SignerInfo block from a CMS Signed message
+
+
+ return the version number for this objects underlying SignerInfo structure.
+
+
+ return the object identifier for the signature.
+
+
+ return the signature parameters, or null if there aren't any.
+
+
+ return the content digest that was calculated during verification.
+
+
+ return the object identifier for the signature.
+
+
+ return the signature/encryption algorithm parameters, or null if
+ there aren't any.
+
+
+ return a table of the signed attributes - indexed by
+ the OID of the attribute.
+
+
+ return a table of the unsigned attributes indexed by
+ the OID of the attribute.
+
+
+ return the encoded signature
+
+
+ Return a SignerInformationStore containing the counter signatures attached to this
+ signer. If no counter signatures are present an empty store is returned.
+
+
+ return the DER encoding of the signed attributes.
+ @throws IOException if an encoding error occurs.
+
+
+ verify that the given public key successfully handles and confirms the
+ signature associated with this signer.
+
+
+ verify that the given certificate successfully handles and confirms
+ the signature associated with this signer and, if a signingTime
+ attribute is available, that the certificate was valid at the time the
+ signature was generated.
+
+
+ Return the base ASN.1 CMS structure that this object contains.
+
+ @return an object containing a CMS SignerInfo structure.
+
+
+ Return a signer information object with the passed in unsigned
+ attributes replacing the ones that are current associated with
+ the object passed in.
+
+ @param signerInformation the signerInfo to be used as the basis.
+ @param unsignedAttributes the unsigned attributes to add.
+ @return a copy of the original SignerInformationObject with the changed attributes.
+
+
+ Return a signer information object with passed in SignerInformationStore representing counter
+ signatures attached as an unsigned attribute.
+
+ @param signerInformation the signerInfo to be used as the basis.
+ @param counterSigners signer info objects carrying counter signature.
+ @return a copy of the original SignerInformationObject with the changed attributes.
+
+
+ Create a store containing a single SignerInformation object.
+
+ @param signerInfo the signer information to contain.
+
+
+ Create a store containing a collection of SignerInformation objects.
+
+ @param signerInfos a collection signer information objects to contain.
+
+
+ Return the first SignerInformation object that matches the
+ passed in selector. Null if there are no matches.
+
+ @param selector to identify a signer
+ @return a single SignerInformation object. Null if none matches.
+
+
+ The number of signers in the collection.
+
+
+ An ICollection of all signers in the collection
+
+
+ Return possible empty collection with signers matching the passed in SignerID
+
+ @param selector a signer id to select against.
+ @return a collection of SignerInformation objects.
+
+
+ Basic generator that just returns a preconstructed attribute table
+
+
+ a holding class for public/private parameter pairs.
+
+
+ basic constructor.
+
+ @param publicParam a public key parameters object.
+ @param privateParam the corresponding private key parameters.
+
+
+ return the public key parameters.
+
+ @return the public key parameters.
+
+
+ return the private key parameters.
+
+ @return the private key parameters.
+
+
+ The AEAD block ciphers already handle buffering internally, so this class
+ just takes care of implementing IBufferedCipher methods.
+
+
+ initialise the cipher.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the blocksize for the underlying cipher.
+
+ @return the blocksize for the underlying cipher.
+
+
+ return the size of the output buffer required for an update
+ an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to update
+ with len bytes of input.
+
+
+ return the size of the output buffer required for an update plus a
+ doFinal with an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to update and doFinal
+ with len bytes of input.
+
+
+ process a single byte, producing an output block if necessary.
+
+ @param in the input byte.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ process an array of bytes, producing output if necessary.
+
+ @param in the input byte array.
+ @param inOff the offset at which the input data starts.
+ @param len the number of bytes to be copied out of the input array.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ Process the last block in the buffer.
+
+ @param out the array the block currently being held is copied into.
+ @param outOff the offset at which the copying starts.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there is insufficient space in out for
+ the output, or the input is not block size aligned and should be.
+ @exception InvalidOperationException if the underlying cipher is not
+ initialised.
+ @exception InvalidCipherTextException if padding is expected and not found.
+ @exception DataLengthException if the input is not block size
+ aligned.
+
+
+ Reset the buffer and cipher. After resetting the object is in the same
+ state as it was after the last init (if there was one).
+
+
+ a buffer wrapper for an asymmetric block cipher, allowing input
+ to be accumulated in a piecemeal fashion until final processing.
+
+
+ base constructor.
+
+ @param cipher the cipher this buffering object wraps.
+
+
+ return the amount of data sitting in the buffer.
+
+ @return the amount of data sitting in the buffer.
+
+
+ initialise the buffer and the underlying cipher.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+
+
+ process the contents of the buffer using the underlying
+ cipher.
+
+ @return the result of the encryption/decryption process on the
+ buffer.
+ @exception InvalidCipherTextException if we are given a garbage block.
+
+
+ Reset the buffer
+
+
+ A wrapper class that allows block ciphers to be used to process data in
+ a piecemeal fashion. The BufferedBlockCipher outputs a block only when the
+ buffer is full and more data is being added, or on a doFinal.
+
+ Note: in the case where the underlying cipher is either a CFB cipher or an
+ OFB one the last block may not be a multiple of the block size.
+
+
+
+ constructor for subclasses
+
+
+ Create a buffered block cipher without padding.
+
+ @param cipher the underlying block cipher this buffering object wraps.
+ false otherwise.
+
+
+ initialise the cipher.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the blocksize for the underlying cipher.
+
+ @return the blocksize for the underlying cipher.
+
+
+ return the size of the output buffer required for an update
+ an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to update
+ with len bytes of input.
+
+
+ return the size of the output buffer required for an update plus a
+ doFinal with an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to update and doFinal
+ with len bytes of input.
+
+
+ process a single byte, producing an output block if necessary.
+
+ @param in the input byte.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ process an array of bytes, producing output if necessary.
+
+ @param in the input byte array.
+ @param inOff the offset at which the input data starts.
+ @param len the number of bytes to be copied out of the input array.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ Process the last block in the buffer.
+
+ @param out the array the block currently being held is copied into.
+ @param outOff the offset at which the copying starts.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there is insufficient space in out for
+ the output, or the input is not block size aligned and should be.
+ @exception InvalidOperationException if the underlying cipher is not
+ initialised.
+ @exception InvalidCipherTextException if padding is expected and not found.
+ @exception DataLengthException if the input is not block size
+ aligned.
+
+
+ Reset the buffer and cipher. After resetting the object is in the same
+ state as it was after the last init (if there was one).
+
+
+ The base class for symmetric, or secret, cipher key generators.
+
+
+ initialise the key generator.
+
+ @param param the parameters to be used for key generation
+
+
+ Generate a secret key.
+
+ @return a byte array containing the key value.
+
+
+ this exception is thrown if a buffer that is meant to have output
+ copied into it turns out to be too short, or if we've been given
+ insufficient input. In general this exception will Get thrown rather
+ than an ArrayOutOfBounds exception.
+
+
+ base constructor.
+
+
+ create a DataLengthException with the given message.
+
+ @param message the message to be carried with the exception.
+
+
+ Wrapper removes exposure to the IMemoable interface on an IDigest implementation.
+
+
+ Base constructor.
+
+ @param baseDigest underlying digest to use.
+ @exception IllegalArgumentException if baseDigest is null
+
+
+ implementation of GOST R 34.11-94
+
+
+ Standard constructor
+
+
+ Constructor to allow use of a particular sbox with GOST28147
+ @see GOST28147Engine#getSBox(String)
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables to the IV values.
+
+
+ base implementation of MD4 family style digest as outlined in
+ "Handbook of Applied Cryptography", pages 344 - 347.
+
+
+
+ Implementation of Keccak based on following KeccakNISTInterface.c from http://keccak.noekeon.org/
+
+
+ Following the naming conventions used in the C source code to enable easy review of the implementation.
+
+
+
+ Return the size of block that the compression function is applied to in bytes.
+
+ @return internal byte length of a block.
+
+
+ Base class for SHA-384 and SHA-512.
+
+
+ Constructor for variable length word
+
+
+ Copy constructor. We are using copy constructors in place
+ of the object.Clone() interface as this interface is not
+ supported by J2ME.
+
+
+ adjust the byte counts so that byteCount2 represents the
+ upper long (less 3 bits) word of the byte count.
+
+
+ implementation of MD2
+ as outlined in RFC1319 by B.Kaliski from RSA Laboratories April 1992
+
+
+ return the algorithm name
+
+ @return the algorithm name
+
+
+ Close the digest, producing the final digest value. The doFinal
+ call leaves the digest reset.
+
+ @param out the array the digest is to be copied into.
+ @param outOff the offset into the out array the digest is to start at.
+
+
+ reset the digest back to it's initial state.
+
+
+ update the message digest with a single byte.
+
+ @param in the input byte to be entered.
+
+
+ update the message digest with a block of bytes.
+
+ @param in the byte array containing the data.
+ @param inOff the offset into the byte array where the data starts.
+ @param len the length of the data.
+
+
+ implementation of MD4 as RFC 1320 by R. Rivest, MIT Laboratory for
+ Computer Science and RSA Data Security, Inc.
+
+ NOTE: This algorithm is only included for backwards compatibility
+ with legacy applications, it's not secure, don't use it for anything new!
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables to the IV values.
+
+
+ implementation of MD5 as outlined in "Handbook of Applied Cryptography", pages 346 - 347.
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables to the IV values.
+
+
+ implementation of RipeMD128
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables to the IV values.
+
+
+ implementation of RipeMD see,
+ http://www.esat.kuleuven.ac.be/~bosselae/ripemd160.html
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables to the IV values.
+
+
+
+ Implementation of RipeMD256.
+ Note: this algorithm offers the same level of security as RipeMD128.
+
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+
+ reset the chaining variables to the IV values.
+
+
+
+ Implementation of RipeMD 320.
+ Note: this algorithm offers the same level of security as RipeMD160.
+
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+
+ reset the chaining variables to the IV values.
+
+
+
+ Implementation of SHA-3 based on following KeccakNISTInterface.c from http://keccak.noekeon.org/
+
+
+ Following the naming conventions used in the C source code to enable easy review of the implementation.
+
+
+
+
+ Implementation of Chinese SM3 digest as described at
+ http://tools.ietf.org/html/draft-shen-sm3-hash-00
+ and at .... ( Chinese PDF )
+
+
+ The specification says "process a bit stream",
+ but this is written to process bytes in blocks of 4,
+ meaning this will process 32-bit word groups.
+ But so do also most other digest specifications,
+ including the SHA-256 which was a origin for
+ this specification.
+
+
+
+
+ Standard constructor
+
+
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+
+
+ reset the chaining variables
+
+
+
+ implementation of SHA-1 as outlined in "Handbook of Applied Cryptography", pages 346 - 349.
+
+ It is interesting to ponder why the, apart from the extra IV, the other difference here from MD5
+ is the "endianness" of the word processing!
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+ SHA-224 as described in RFC 3874
+
+ block word digest
+ SHA-1 512 32 160
+ SHA-224 512 32 224
+ SHA-256 512 32 256
+ SHA-384 1024 64 384
+ SHA-512 1024 64 512
+
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+ Draft FIPS 180-2 implementation of SHA-256. Note: As this is
+ based on a draft this implementation is subject to change.
+
+
+ block word digest
+ SHA-1 512 32 160
+ SHA-256 512 32 256
+ SHA-384 1024 64 384
+ SHA-512 1024 64 512
+
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+ Draft FIPS 180-2 implementation of SHA-384. Note: As this is
+ based on a draft this implementation is subject to change.
+
+
+ block word digest
+ SHA-1 512 32 160
+ SHA-256 512 32 256
+ SHA-384 1024 64 384
+ SHA-512 1024 64 512
+
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+ Draft FIPS 180-2 implementation of SHA-512. Note: As this is
+ based on a draft this implementation is subject to change.
+
+
+ block word digest
+ SHA-1 512 32 160
+ SHA-256 512 32 256
+ SHA-384 1024 64 384
+ SHA-512 1024 64 512
+
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+ FIPS 180-4 implementation of SHA-512/t
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+
+ Implementation of SHAKE based on following KeccakNISTInterface.c from http://keccak.noekeon.org/
+
+
+ Following the naming conventions used in the C source code to enable easy review of the implementation.
+
+
+
+ Wrapper class that reduces the output length of a particular digest to
+ only the first n bytes of the digest function.
+
+
+ Base constructor.
+
+ @param baseDigest underlying digest to use.
+ @param length length in bytes of the output of doFinal.
+ @exception ArgumentException if baseDigest is null, or length is greater than baseDigest.GetDigestSize().
+
+
+
+ Implementation of the Skein parameterised hash function in 256, 512 and 1024 bit block sizes,
+ based on the Threefish tweakable block cipher.
+
+
+ This is the 1.3 version of Skein defined in the Skein hash function submission to the NIST SHA-3
+ competition in October 2010.
+
+ Skein was designed by Niels Ferguson - Stefan Lucks - Bruce Schneier - Doug Whiting - Mihir
+ Bellare - Tadayoshi Kohno - Jon Callas - Jesse Walker.
+
+
+
+
+
+
+ 256 bit block size - Skein-256
+
+
+
+
+ 512 bit block size - Skein-512
+
+
+
+
+ 1024 bit block size - Skein-1024
+
+
+
+
+ Constructs a Skein digest with an internal state size and output size.
+
+ the internal state size in bits - one of or
+ .
+ the output/digest size to produce in bits, which must be an integral number of
+ bytes.
+
+
+
+ Optionally initialises the Skein digest with the provided parameters.
+
+ See for details on the parameterisation of the Skein hash function.
+ the parameters to apply to this engine, or null
to use no parameters.
+
+
+
+ Implementation of the Skein family of parameterised hash functions in 256, 512 and 1024 bit block
+ sizes, based on the Threefish tweakable block cipher.
+
+
+ This is the 1.3 version of Skein defined in the Skein hash function submission to the NIST SHA-3
+ competition in October 2010.
+
+ Skein was designed by Niels Ferguson - Stefan Lucks - Bruce Schneier - Doug Whiting - Mihir
+ Bellare - Tadayoshi Kohno - Jon Callas - Jesse Walker.
+
+ This implementation is the basis for and , implementing the
+ parameter based configuration system that allows Skein to be adapted to multiple applications.
+ Initialising the engine with allows standard and arbitrary parameters to
+ be applied during the Skein hash function.
+
+ Implemented:
+
+ - 256, 512 and 1024 bit internal states.
+ - Full 96 bit input length.
+ - Parameters defined in the Skein specification, and arbitrary other pre and post message
+ parameters.
+ - Arbitrary output size in 1 byte intervals.
+
+
+ Not implemented:
+
+ - Sub-byte length input (bit padding).
+ - Tree hashing.
+
+
+
+
+
+
+ 256 bit block size - Skein-256
+
+
+
+
+ 512 bit block size - Skein-512
+
+
+
+
+ 1024 bit block size - Skein-1024
+
+
+
+ The parameter type for the Skein key.
+
+
+ The parameter type for the Skein configuration block.
+
+
+ The parameter type for the message.
+
+
+ The parameter type for the output transformation.
+
+
+ Precalculated UBI(CFG) states for common state/output combinations without key or other
+ pre-message params.
+
+
+ Point at which position might overflow long, so switch to add with carry logic
+
+
+ Bit 127 = final
+
+
+ Bit 126 = first
+
+
+ UBI uses a 128 bit tweak
+
+
+ Whether 64 bit position exceeded
+
+
+ Advances the position in the tweak by the specified value.
+
+
+ The Unique Block Iteration chaining mode.
+
+
+ Buffer for the current block of message data
+
+
+ Offset into the current message block
+
+
+ Buffer for message words for feedback into encrypted block
+
+
+ Underlying Threefish tweakable block cipher
+
+
+ Size of the digest output, in bytes
+
+
+ The current chaining/state value
+
+
+ The initial state value
+
+
+ The (optional) key parameter
+
+
+ Parameters to apply prior to the message
+
+
+ Parameters to apply after the message, but prior to output
+
+
+ The current UBI operation
+
+
+ Buffer for single byte update method
+
+
+
+ Constructs a Skein digest with an internal state size and output size.
+
+ the internal state size in bits - one of or
+ .
+ the output/digest size to produce in bits, which must be an integral number of
+ bytes.
+
+
+
+ Creates a SkeinEngine as an exact copy of an existing instance.
+
+
+
+
+ Initialises the Skein engine with the provided parameters. See for
+ details on the parameterisation of the Skein hash function.
+
+ the parameters to apply to this engine, or null
to use no parameters.
+
+
+ Calculate the initial (pre message block) chaining state.
+
+
+
+ Reset the engine to the initial state (with the key and any pre-message parameters , ready to
+ accept message input.
+
+
+
+ implementation of Tiger based on:
+
+ http://www.cs.technion.ac.il/~biham/Reports/Tiger
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+ Implementation of WhirlpoolDigest, based on Java source published by Barreto
+ and Rijmen.
+
+
+
+ Copy constructor. This will copy the state of the provided message
+ digest.
+
+
+ Reset the chaining variables
+
+
+ initialise a Serpent cipher.
+
+ @param encrypting whether or not we are for encryption.
+ @param params the parameters required to set up the cipher.
+ @throws IllegalArgumentException if the params argument is
+ inappropriate.
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @return the number of bytes processed and produced.
+ @throws DataLengthException if there isn't enough data in in, or
+ space in out.
+ @throws IllegalStateException if the cipher isn't initialised.
+
+
+ InvSO - {13, 3,11, 0,10, 6, 5,12, 1,14, 4, 7,15, 9, 8, 2 } - 15 terms.
+
+
+ S1 - {15,12, 2, 7, 9, 0, 5,10, 1,11,14, 8, 6,13, 3, 4 } - 14 terms.
+
+
+ InvS1 - { 5, 8, 2,14,15, 6,12, 3,11, 4, 7, 9, 1,13,10, 0 } - 14 steps.
+
+
+ S2 - { 8, 6, 7, 9, 3,12,10,15,13, 1,14, 4, 0,11, 5, 2 } - 16 terms.
+
+
+ InvS2 - {12, 9,15, 4,11,14, 1, 2, 0, 3, 6,13, 5, 8,10, 7 } - 16 steps.
+
+
+ S3 - { 0,15,11, 8,12, 9, 6, 3,13, 1, 2, 4,10, 7, 5,14 } - 16 terms.
+
+
+ InvS3 - { 0, 9,10, 7,11,14, 6,13, 3, 5,12, 2, 4, 8,15, 1 } - 15 terms
+
+
+ S4 - { 1,15, 8, 3,12, 0,11, 6, 2, 5, 4,10, 9,14, 7,13 } - 15 terms.
+
+
+ InvS4 - { 5, 0, 8, 3,10, 9, 7,14, 2,12,11, 6, 4,15,13, 1 } - 15 terms.
+
+
+ S5 - {15, 5, 2,11, 4,10, 9,12, 0, 3,14, 8,13, 6, 7, 1 } - 16 terms.
+
+
+ InvS5 - { 8,15, 2, 9, 4, 1,13,14,11, 6, 5, 3, 7,12,10, 0 } - 16 terms.
+
+
+ S6 - { 7, 2,12, 5, 8, 4, 6,11,14, 9, 1,15,13, 3,10, 0 } - 15 terms.
+
+
+ InvS6 - {15,10, 1,13, 5, 3, 6, 0, 4, 9,14, 7, 2,12, 8,11 } - 15 terms.
+
+
+ S7 - { 1,13,15, 0,14, 8, 2,11, 7, 4,12,10, 9, 3, 5, 6 } - 16 terms.
+
+
+ InvS7 - { 3, 0, 6,13, 9,14,15, 8, 5,12,11, 7,10, 1, 4, 2 } - 17 terms.
+
+
+ Apply the linear transformation to the register set.
+
+
+ Apply the inverse of the linear transformation to the register set.
+
+
+ Tnepres is a 128-bit 32-round block cipher with variable key lengths,
+ including 128, 192 and 256 bit keys conjectured to be at least as
+ secure as three-key triple-DES.
+
+ Tnepres is based on Serpent which was designed by Ross Anderson, Eli Biham and Lars Knudsen as a
+ candidate algorithm for the NIST AES Quest. Unfortunately there was an endianness issue
+ with test vectors in the AES submission and the resulting confusion lead to the Tnepres cipher
+ as well, which is a byte swapped version of Serpent.
+
+
+ For full details see The Serpent home page
+
+
+
+ Expand a user-supplied key material into a session key.
+
+ @param key The user-key bytes (multiples of 4) to use.
+ @exception ArgumentException
+
+
+ Encrypt one block of plaintext.
+
+ @param input the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param output the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+
+
+ Decrypt one block of ciphertext.
+
+ @param input the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param output the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+
+
+ an implementation of the AES (Rijndael), from FIPS-197.
+
+ For further details see: http://csrc.nist.gov/encryption/aes/.
+
+ This implementation is based on optimizations from Dr. Brian Gladman's paper and C code at
+ http://fp.gladman.plus.com/cryptography_technology/rijndael/
+
+ There are three levels of tradeoff of speed vs memory
+ Because java has no preprocessor, they are written as three separate classes from which to choose
+
+ The fastest uses 8Kbytes of static tables to precompute round calculations, 4 256 word tables for encryption
+ and 4 for decryption.
+
+ The middle performance version uses only one 256 word table for each, for a total of 2Kbytes,
+ adding 12 rotate operations per round to compute the values contained in the other tables from
+ the contents of the first.
+
+ The slowest version uses no static tables at all and computes the values in each round.
+
+
+ This file contains the middle performance version with 2Kbytes of static tables for round precomputation.
+
+
+
+ Calculate the necessary round keys
+ The number of calculations depends on key size and block size
+ AES specified a fixed block size of 128 bits and key sizes 128/192/256 bits
+ This code is written assuming those are the only possible values
+
+
+ default constructor - 128 bit block size.
+
+
+ initialise an AES cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ an implementation of the AES (Rijndael)), from FIPS-197.
+
+ For further details see: http://csrc.nist.gov/encryption/aes/.
+
+ This implementation is based on optimizations from Dr. Brian Gladman's paper and C code at
+ http://fp.gladman.plus.com/cryptography_technology/rijndael/
+
+ There are three levels of tradeoff of speed vs memory
+ Because java has no preprocessor), they are written as three separate classes from which to choose
+
+ The fastest uses 8Kbytes of static tables to precompute round calculations), 4 256 word tables for encryption
+ and 4 for decryption.
+
+ The middle performance version uses only one 256 word table for each), for a total of 2Kbytes),
+ adding 12 rotate operations per round to compute the values contained in the other tables from
+ the contents of the first
+
+ The slowest version uses no static tables at all and computes the values in each round
+
+
+ This file contains the fast version with 8Kbytes of static tables for round precomputation
+
+
+
+ Calculate the necessary round keys
+ The number of calculations depends on key size and block size
+ AES specified a fixed block size of 128 bits and key sizes 128/192/256 bits
+ This code is written assuming those are the only possible values
+
+
+ default constructor - 128 bit block size.
+
+
+ initialise an AES cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ an implementation of the AES (Rijndael), from FIPS-197.
+
+ For further details see: http://csrc.nist.gov/encryption/aes/.
+
+ This implementation is based on optimizations from Dr. Brian Gladman's paper and C code at
+ http://fp.gladman.plus.com/cryptography_technology/rijndael/
+
+ There are three levels of tradeoff of speed vs memory
+ Because java has no preprocessor, they are written as three separate classes from which to choose
+
+ The fastest uses 8Kbytes of static tables to precompute round calculations, 4 256 word tables for encryption
+ and 4 for decryption.
+
+ The middle performance version uses only one 256 word table for each, for a total of 2Kbytes,
+ adding 12 rotate operations per round to compute the values contained in the other tables from
+ the contents of the first
+
+ The slowest version uses no static tables at all and computes the values
+ in each round.
+
+
+ This file contains the slowest performance version with no static tables
+ for round precomputation, but it has the smallest foot print.
+
+
+
+ Calculate the necessary round keys
+ The number of calculations depends on key size and block size
+ AES specified a fixed block size of 128 bits and key sizes 128/192/256 bits
+ This code is written assuming those are the only possible values
+
+
+ default constructor - 128 bit block size.
+
+
+ initialise an AES cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+
+ An implementation of the AES Key Wrapper from the NIST Key Wrap Specification.
+
+ For further details see: http://csrc.nist.gov/encryption/kms/key-wrap.pdf.
+
+
+
+ A class that provides Blowfish key encryption operations,
+ such as encoding data and generating keys.
+ All the algorithms herein are from Applied Cryptography
+ and implement a simplified cryptography interface.
+
+
+ initialise a Blowfish cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ apply the encryption cycle to each value pair in the table.
+
+
+ Encrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+ The input will be an exact multiple of our blocksize.
+
+
+ Decrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+ The input will be an exact multiple of our blocksize.
+
+
+ Camellia - based on RFC 3713.
+
+
+ Camellia - based on RFC 3713, smaller implementation, about half the size of CamelliaEngine.
+
+
+
+ An implementation of the Camellia key wrapper based on RFC 3657/RFC 3394.
+
+ For further details see: http://www.ietf.org/rfc/rfc3657.txt.
+
+
+
+ A class that provides CAST key encryption operations,
+ such as encoding data and generating keys.
+
+ All the algorithms herein are from the Internet RFC's
+
+ RFC2144 - Cast5 (64bit block, 40-128bit key)
+ RFC2612 - CAST6 (128bit block, 128-256bit key)
+
+ and implement a simplified cryptography interface.
+
+
+ initialise a CAST cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Encrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+
+ @param src The plaintext buffer
+ @param srcIndex An offset into src
+ @param dst The ciphertext buffer
+ @param dstIndex An offset into dst
+
+
+ Decrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+
+ @param src The plaintext buffer
+ @param srcIndex An offset into src
+ @param dst The ciphertext buffer
+ @param dstIndex An offset into dst
+
+
+ The first of the three processing functions for the
+ encryption and decryption.
+
+ @param D the input to be processed
+ @param Kmi the mask to be used from Km[n]
+ @param Kri the rotation value to be used
+
+
+
+ The second of the three processing functions for the
+ encryption and decryption.
+
+ @param D the input to be processed
+ @param Kmi the mask to be used from Km[n]
+ @param Kri the rotation value to be used
+
+
+
+ The third of the three processing functions for the
+ encryption and decryption.
+
+ @param D the input to be processed
+ @param Kmi the mask to be used from Km[n]
+ @param Kri the rotation value to be used
+
+
+
+ Does the 16 rounds to encrypt the block.
+
+ @param L0 the LH-32bits of the plaintext block
+ @param R0 the RH-32bits of the plaintext block
+
+
+ A class that provides CAST6 key encryption operations,
+ such as encoding data and generating keys.
+
+ All the algorithms herein are from the Internet RFC
+
+ RFC2612 - CAST6 (128bit block, 128-256bit key)
+
+ and implement a simplified cryptography interface.
+
+
+ Encrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+
+ @param src The plaintext buffer
+ @param srcIndex An offset into src
+ @param dst The ciphertext buffer
+ @param dstIndex An offset into dst
+
+
+ Decrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+
+ @param src The plaintext buffer
+ @param srcIndex An offset into src
+ @param dst The ciphertext buffer
+ @param dstIndex An offset into dst
+
+
+ Does the 12 quad rounds rounds to encrypt the block.
+
+ @param A the 00-31 bits of the plaintext block
+ @param B the 32-63 bits of the plaintext block
+ @param C the 64-95 bits of the plaintext block
+ @param D the 96-127 bits of the plaintext block
+ @param result the resulting ciphertext
+
+
+ Does the 12 quad rounds rounds to decrypt the block.
+
+ @param A the 00-31 bits of the ciphertext block
+ @param B the 32-63 bits of the ciphertext block
+ @param C the 64-95 bits of the ciphertext block
+ @param D the 96-127 bits of the ciphertext block
+ @param result the resulting plaintext
+
+
+
+ Implementation of Daniel J. Bernstein's ChaCha stream cipher.
+
+
+
+
+ Creates a 20 rounds ChaCha engine.
+
+
+
+
+ Creates a ChaCha engine with a specific number of rounds.
+
+ the number of rounds (must be an even number).
+
+
+
+ ChacCha function.
+
+ The number of ChaCha rounds to execute
+ The input words.
+ The ChaCha state to modify.
+
+
+ A class that provides a basic DESede (or Triple DES) engine.
+
+
+ initialise a DESede cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ * Wrap keys according to
+ *
+ * draft-ietf-smime-key-wrap-01.txt.
+ *
+ * Note:
+ *
+ * - this is based on a draft, and as such is subject to change - don't use this class for anything requiring long term storage.
+ * - if you are using this to wrap triple-des keys you need to set the
+ * parity bits on the key and, if it's a two-key triple-des key, pad it
+ * yourself.
+ *
+ *
+
+
+ Field engine
+
+
+ Field param
+
+
+ Field paramPlusIV
+
+
+ Field iv
+
+
+ Field forWrapping
+
+
+ Field IV2
+
+
+ Method init
+
+ @param forWrapping
+ @param param
+
+
+ Method GetAlgorithmName
+
+ @return
+
+
+ Method wrap
+
+ @param in
+ @param inOff
+ @param inLen
+ @return
+
+
+ Method unwrap
+
+ @param in
+ @param inOff
+ @param inLen
+ @return
+ @throws InvalidCipherTextException
+
+
+ Some key wrap algorithms make use of the Key Checksum defined
+ in CMS [CMS-Algorithms]. This is used to provide an integrity
+ check value for the key being wrapped. The algorithm is
+
+ - Compute the 20 octet SHA-1 hash on the key being wrapped.
+ - Use the first 8 octets of this hash as the checksum value.
+
+ @param key
+ @return
+ @throws Exception
+ @see http://www.w3.org/TR/xmlenc-core/#sec-CMSKeyChecksum
+
+
+ @param key
+ @param checksum
+ @return
+ @see http://www.w3.org/TR/xmlenc-core/#sec-CMSKeyChecksum
+
+
+ A class that provides a basic DES engine.
+
+
+ initialise a DES cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ what follows is mainly taken from "Applied Cryptography", by
+ Bruce Schneier, however it also bears great resemblance to Richard
+ Outerbridge's D3DES...
+
+
+ Generate an integer based working key based on our secret key
+ and what we processing we are planning to do.
+
+ Acknowledgements for this routine go to James Gillogly and Phil Karn.
+ (whoever, and wherever they are!).
+
+
+ the DES engine.
+
+
+ this does your basic ElGamal algorithm.
+
+
+ initialise the ElGamal engine.
+
+ @param forEncryption true if we are encrypting, false otherwise.
+ @param param the necessary ElGamal key parameters.
+
+
+ Return the maximum size for an input block to this engine.
+ For ElGamal this is always one byte less than the size of P on
+ encryption, and twice the length as the size of P on decryption.
+
+ @return maximum size for an input block.
+
+
+ Return the maximum size for an output block to this engine.
+ For ElGamal this is always one byte less than the size of P on
+ decryption, and twice the length as the size of P on encryption.
+
+ @return maximum size for an output block.
+
+
+ Process a single block using the basic ElGamal algorithm.
+
+ @param in the input array.
+ @param inOff the offset into the input buffer where the data starts.
+ @param length the length of the data to be processed.
+ @return the result of the ElGamal process.
+ @exception DataLengthException the input block is too large.
+
+
+ implementation of GOST 28147-89
+
+
+ standard constructor.
+
+
+ initialise an Gost28147 cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is inappropriate.
+
+
+ Return the S-Box associated with SBoxName
+ @param sBoxName name of the S-Box
+ @return byte array representing the S-Box
+
+
+ HC-128 is a software-efficient stream cipher created by Hongjun Wu. It
+ generates keystream from a 128-bit secret key and a 128-bit initialization
+ vector.
+
+ http://www.ecrypt.eu.org/stream/p3ciphers/hc/hc128_p3.pdf
+
+ It is a third phase candidate in the eStream contest, and is patent-free.
+ No attacks are known as of today (April 2007). See
+
+ http://www.ecrypt.eu.org/stream/hcp3.html
+
+
+
+ Initialise a HC-128 cipher.
+
+ @param forEncryption whether or not we are for encryption. Irrelevant, as
+ encryption and decryption are the same.
+ @param params the parameters required to set up the cipher.
+ @throws ArgumentException if the params argument is
+ inappropriate (ie. the key is not 128 bit long).
+
+
+ HC-256 is a software-efficient stream cipher created by Hongjun Wu. It
+ generates keystream from a 256-bit secret key and a 256-bit initialization
+ vector.
+
+ http://www.ecrypt.eu.org/stream/p3ciphers/hc/hc256_p3.pdf
+
+ Its brother, HC-128, is a third phase candidate in the eStream contest.
+ The algorithm is patent-free. No attacks are known as of today (April 2007).
+ See
+
+ http://www.ecrypt.eu.org/stream/hcp3.html
+
+
+
+ Initialise a HC-256 cipher.
+
+ @param forEncryption whether or not we are for encryption. Irrelevant, as
+ encryption and decryption are the same.
+ @param params the parameters required to set up the cipher.
+ @throws ArgumentException if the params argument is
+ inappropriate (ie. the key is not 256 bit long).
+
+
+ Implementation of Bob Jenkin's ISAAC (Indirection Shift Accumulate Add and Count).
+ see: http://www.burtleburtle.net/bob/rand/isaacafa.html
+
+
+ initialise an ISAAC cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param params the parameters required to set up the cipher.
+ @exception ArgumentException if the params argument is
+ inappropriate.
+
+
+ A class that provides a basic International Data Encryption Algorithm (IDEA) engine.
+
+ This implementation is based on the "HOWTO: INTERNATIONAL DATA ENCRYPTION ALGORITHM"
+ implementation summary by Fauzan Mirza (F.U.Mirza@sheffield.ac.uk). (baring 1 typo at the
+ end of the mulinv function!).
+
+
+ It can be found at ftp://ftp.funet.fi/pub/crypt/cryptography/symmetric/idea/
+
+
+ Note 1: This algorithm is patented in the USA, Japan, and Europe including
+ at least Austria, France, Germany, Italy, Netherlands, Spain, Sweden, Switzerland
+ and the United Kingdom. Non-commercial use is free, however any commercial
+ products are liable for royalties. Please see
+ www.mediacrypt.com for
+ further details. This announcement has been included at the request of
+ the patent holders.
+
+
+ Note 2: Due to the requests concerning the above, this algorithm is now only
+ included in the extended assembly. It is not included in the default distributions.
+
+
+
+ standard constructor.
+
+
+ initialise an IDEA cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return x = x * y where the multiplication is done modulo
+ 65537 (0x10001) (as defined in the IDEA specification) and
+ a zero input is taken to be 65536 (0x10000).
+
+ @param x the x value
+ @param y the y value
+ @return x = x * y
+
+
+ The following function is used to expand the user key to the encryption
+ subkey. The first 16 bytes are the user key, and the rest of the subkey
+ is calculated by rotating the previous 16 bytes by 25 bits to the left,
+ and so on until the subkey is completed.
+
+
+ This function computes multiplicative inverse using Euclid's Greatest
+ Common Divisor algorithm. Zero and one are self inverse.
+
+ i.e. x * MulInv(x) == 1 (modulo BASE)
+
+
+
+ Return the additive inverse of x.
+
+ i.e. x + AddInv(x) == 0
+
+
+
+ The function to invert the encryption subkey to the decryption subkey.
+ It also involves the multiplicative inverse and the additive inverse functions.
+
+
+ support class for constructing intergrated encryption ciphers
+ for doing basic message exchanges on top of key agreement ciphers
+
+
+ set up for use with stream mode, where the key derivation function
+ is used to provide a stream of bytes to xor with the message.
+
+ @param agree the key agreement used as the basis for the encryption
+ @param kdf the key derivation function used for byte generation
+ @param mac the message authentication code generator for the message
+
+
+ set up for use in conjunction with a block cipher to handle the
+ message.
+
+ @param agree the key agreement used as the basis for the encryption
+ @param kdf the key derivation function used for byte generation
+ @param mac the message authentication code generator for the message
+ @param cipher the cipher to used for encrypting the message
+
+
+ Initialise the encryptor.
+
+ @param forEncryption whether or not this is encryption/decryption.
+ @param privParam our private key parameters
+ @param pubParam the recipient's/sender's public key parameters
+ @param param encoding and derivation parameters.
+
+
+ NaccacheStern Engine. For details on this cipher, please see
+ http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf
+
+
+ Initializes this algorithm. Must be called before all other Functions.
+
+ @see org.bouncycastle.crypto.AsymmetricBlockCipher#init(bool,
+ org.bouncycastle.crypto.CipherParameters)
+
+
+ Returns the input block size of this algorithm.
+
+ @see org.bouncycastle.crypto.AsymmetricBlockCipher#GetInputBlockSize()
+
+
+ Returns the output block size of this algorithm.
+
+ @see org.bouncycastle.crypto.AsymmetricBlockCipher#GetOutputBlockSize()
+
+
+ Process a single Block using the Naccache-Stern algorithm.
+
+ @see org.bouncycastle.crypto.AsymmetricBlockCipher#ProcessBlock(byte[],
+ int, int)
+
+
+ Encrypts a BigInteger aka Plaintext with the public key.
+
+ @param plain
+ The BigInteger to encrypt
+ @return The byte[] representation of the encrypted BigInteger (i.e.
+ crypted.toByteArray())
+
+
+ Adds the contents of two encrypted blocks mod sigma
+
+ @param block1
+ the first encrypted block
+ @param block2
+ the second encrypted block
+ @return encrypt((block1 + block2) mod sigma)
+ @throws InvalidCipherTextException
+
+
+ Convenience Method for data exchange with the cipher.
+
+ Determines blocksize and splits data to blocksize.
+
+ @param data the data to be processed
+ @return the data after it went through the NaccacheSternEngine.
+ @throws InvalidCipherTextException
+
+
+ Computes the integer x that is expressed through the given primes and the
+ congruences with the chinese remainder theorem (CRT).
+
+ @param congruences
+ the congruences c_i
+ @param primes
+ the primes p_i
+ @return an integer x for that x % p_i == c_i
+
+
+ A Noekeon engine, using direct-key mode.
+
+
+ Create an instance of the Noekeon encryption algorithm
+ and set some defaults
+
+
+ initialise
+
+ @param forEncryption whether or not we are for encryption.
+ @param params the parameters required to set up the cipher.
+ @exception ArgumentException if the params argument is
+ inappropriate.
+
+
+ Re-key the cipher.
+
+ @param key the key to be used
+
+
+ The no-op engine that just copies bytes through, irrespective of whether encrypting and decrypting.
+ Provided for the sake of completeness.
+
+
+ an implementation of RC2 as described in RFC 2268
+ "A Description of the RC2(r) Encryption Algorithm" R. Rivest.
+
+
+ initialise a RC2 cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the result rotating the 16 bit number in x left by y
+
+
+ Wrap keys according to RFC 3217 - RC2 mechanism
+
+
+ Field engine
+
+
+ Field param
+
+
+ Field paramPlusIV
+
+
+ Field iv
+
+
+ Field forWrapping
+
+
+ Field IV2
+
+
+ Method init
+
+ @param forWrapping
+ @param param
+
+
+ Method GetAlgorithmName
+
+ @return
+
+
+ Method wrap
+
+ @param in
+ @param inOff
+ @param inLen
+ @return
+
+
+ Method unwrap
+
+ @param in
+ @param inOff
+ @param inLen
+ @return
+ @throws InvalidCipherTextException
+
+
+ Some key wrap algorithms make use of the Key Checksum defined
+ in CMS [CMS-Algorithms]. This is used to provide an integrity
+ check value for the key being wrapped. The algorithm is
+
+ - Compute the 20 octet SHA-1 hash on the key being wrapped.
+ - Use the first 8 octets of this hash as the checksum value.
+
+ @param key
+ @return
+ @throws Exception
+ @see http://www.w3.org/TR/xmlenc-core/#sec-CMSKeyChecksum
+
+
+ @param key
+ @param checksum
+ @return
+ @see http://www.w3.org/TR/xmlenc-core/#sec-CMSKeyChecksum
+
+
+ initialise a RC4 cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ The specification for RC5 came from the RC5 Encryption Algorithm
+ publication in RSA CryptoBytes, Spring of 1995.
+ http://www.rsasecurity.com/rsalabs/cryptobytes.
+
+ This implementation has a word size of 32 bits.
+
+
+ Create an instance of the RC5 encryption algorithm
+ and set some defaults
+
+
+ initialise a RC5-32 cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Re-key the cipher.
+
+ @param key the key to be used
+
+
+ Encrypt the given block starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+
+ @param in in byte buffer containing data to encrypt
+ @param inOff offset into src buffer
+ @param out out buffer where encrypted data is written
+ @param outOff offset into out buffer
+
+
+ Perform a left "spin" of the word. The rotation of the given
+ word x is rotated left by y bits.
+ Only the lg(32) low-order bits of y
+ are used to determine the rotation amount. Here it is
+ assumed that the wordsize used is a power of 2.
+
+ @param x word to rotate
+ @param y number of bits to rotate % 32
+
+
+ Perform a right "spin" of the word. The rotation of the given
+ word x is rotated left by y bits.
+ Only the lg(32) low-order bits of y
+ are used to determine the rotation amount. Here it is
+ assumed that the wordsize used is a power of 2.
+
+ @param x word to rotate
+ @param y number of bits to rotate % 32
+
+
+ The specification for RC5 came from the RC5 Encryption Algorithm
+ publication in RSA CryptoBytes, Spring of 1995.
+ http://www.rsasecurity.com/rsalabs/cryptobytes.
+
+ This implementation is set to work with a 64 bit word size.
+
+
+ Create an instance of the RC5 encryption algorithm
+ and set some defaults
+
+
+ initialise a RC5-64 cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Re-key the cipher.
+
+ @param key the key to be used
+
+
+ Encrypt the given block starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+
+ @param in in byte buffer containing data to encrypt
+ @param inOff offset into src buffer
+ @param out out buffer where encrypted data is written
+ @param outOff offset into out buffer
+
+
+ Perform a left "spin" of the word. The rotation of the given
+ word x is rotated left by y bits.
+ Only the lg(wordSize) low-order bits of y
+ are used to determine the rotation amount. Here it is
+ assumed that the wordsize used is a power of 2.
+
+ @param x word to rotate
+ @param y number of bits to rotate % wordSize
+
+
+ Perform a right "spin" of the word. The rotation of the given
+ word x is rotated left by y bits.
+ Only the lg(wordSize) low-order bits of y
+ are used to determine the rotation amount. Here it is
+ assumed that the wordsize used is a power of 2.
+
+ @param x word to rotate
+ @param y number of bits to rotate % wordSize
+
+
+ An RC6 engine.
+
+
+ Create an instance of the RC6 encryption algorithm
+ and set some defaults
+
+
+ initialise a RC5-32 cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Re-key the cipher.
+
+ @param inKey the key to be used
+
+
+ Perform a left "spin" of the word. The rotation of the given
+ word x is rotated left by y bits.
+ Only the lg(wordSize) low-order bits of y
+ are used to determine the rotation amount. Here it is
+ assumed that the wordsize used is a power of 2.
+
+ @param x word to rotate
+ @param y number of bits to rotate % wordSize
+
+
+ Perform a right "spin" of the word. The rotation of the given
+ word x is rotated left by y bits.
+ Only the lg(wordSize) low-order bits of y
+ are used to determine the rotation amount. Here it is
+ assumed that the wordsize used is a power of 2.
+
+ @param x word to rotate
+ @param y number of bits to rotate % wordSize
+
+
+ an implementation of the RFC 3211 Key Wrap
+ Specification.
+
+
+
+ An implementation of the AES Key Wrapper from the NIST Key Wrap
+ Specification as described in RFC 3394.
+
+ For further details see: http://www.ietf.org/rfc/rfc3394.txt
+ and http://csrc.nist.gov/encryption/kms/key-wrap.pdf.
+
+
+
+ this does your basic RSA algorithm with blinding
+
+
+ initialise the RSA engine.
+
+ @param forEncryption true if we are encrypting, false otherwise.
+ @param param the necessary RSA key parameters.
+
+
+ Return the maximum size for an input block to this engine.
+ For RSA this is always one byte less than the key size on
+ encryption, and the same length as the key size on decryption.
+
+ @return maximum size for an input block.
+
+
+ Return the maximum size for an output block to this engine.
+ For RSA this is always one byte less than the key size on
+ decryption, and the same length as the key size on encryption.
+
+ @return maximum size for an output block.
+
+
+ Process a single block using the basic RSA algorithm.
+
+ @param inBuf the input array.
+ @param inOff the offset into the input buffer where the data starts.
+ @param inLen the length of the data to be processed.
+ @return the result of the RSA process.
+ @exception DataLengthException the input block is too large.
+
+
+ This does your basic RSA Chaum's blinding and unblinding as outlined in
+ "Handbook of Applied Cryptography", page 475. You need to use this if you are
+ trying to get another party to generate signatures without them being aware
+ of the message they are signing.
+
+
+ Initialise the blinding engine.
+
+ @param forEncryption true if we are encrypting (blinding), false otherwise.
+ @param param the necessary RSA key parameters.
+
+
+ Return the maximum size for an input block to this engine.
+ For RSA this is always one byte less than the key size on
+ encryption, and the same length as the key size on decryption.
+
+ @return maximum size for an input block.
+
+
+ Return the maximum size for an output block to this engine.
+ For RSA this is always one byte less than the key size on
+ decryption, and the same length as the key size on encryption.
+
+ @return maximum size for an output block.
+
+
+ Process a single block using the RSA blinding algorithm.
+
+ @param in the input array.
+ @param inOff the offset into the input buffer where the data starts.
+ @param inLen the length of the data to be processed.
+ @return the result of the RSA process.
+ @throws DataLengthException the input block is too large.
+
+
+ this does your basic RSA algorithm.
+
+
+ initialise the RSA engine.
+
+ @param forEncryption true if we are encrypting, false otherwise.
+ @param param the necessary RSA key parameters.
+
+
+ Return the maximum size for an input block to this engine.
+ For RSA this is always one byte less than the key size on
+ encryption, and the same length as the key size on decryption.
+
+ @return maximum size for an input block.
+
+
+ Return the maximum size for an output block to this engine.
+ For RSA this is always one byte less than the key size on
+ decryption, and the same length as the key size on encryption.
+
+ @return maximum size for an output block.
+
+
+ an implementation of Rijndael, based on the documentation and reference implementation
+ by Paulo Barreto, Vincent Rijmen, for v2.0 August '99.
+
+ Note: this implementation is based on information prior to readonly NIST publication.
+
+
+
+ multiply two elements of GF(2^m)
+ needed for MixColumn and InvMixColumn
+
+
+ xor corresponding text input and round key input bytes
+
+
+ Row 0 remains unchanged
+ The other three rows are shifted a variable amount
+
+
+ Replace every byte of the input by the byte at that place
+ in the nonlinear S-box
+
+
+ Mix the bytes of every column in a linear way
+
+
+ Mix the bytes of every column in a linear way
+ This is the opposite operation of Mixcolumn
+
+
+ Calculate the necessary round keys
+ The number of calculations depends on keyBits and blockBits
+
+
+ default constructor - 128 bit block size.
+
+
+ basic constructor - set the cipher up for a given blocksize
+
+ @param blocksize the blocksize in bits, must be 128, 192, or 256.
+
+
+ initialise a Rijndael cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ this does your basic RSA algorithm.
+
+
+ initialise the RSA engine.
+
+ @param forEncryption true if we are encrypting, false otherwise.
+ @param param the necessary RSA key parameters.
+
+
+ Return the maximum size for an input block to this engine.
+ For RSA this is always one byte less than the key size on
+ encryption, and the same length as the key size on decryption.
+
+ @return maximum size for an input block.
+
+
+ Return the maximum size for an output block to this engine.
+ For RSA this is always one byte less than the key size on
+ decryption, and the same length as the key size on encryption.
+
+ @return maximum size for an output block.
+
+
+ Process a single block using the basic RSA algorithm.
+
+ @param inBuf the input array.
+ @param inOff the offset into the input buffer where the data starts.
+ @param inLen the length of the data to be processed.
+ @return the result of the RSA process.
+ @exception DataLengthException the input block is too large.
+
+
+ Implementation of the SEED algorithm as described in RFC 4009
+
+
+
+ An implementation of the SEED key wrapper based on RFC 4010/RFC 3394.
+
+ For further details see: http://www.ietf.org/rfc/rfc4010.txt.
+
+
+
+
+ Implementation of Daniel J. Bernstein's Salsa20 stream cipher, Snuffle 2005
+
+
+
+ Constants
+
+
+
+ Creates a 20 round Salsa20 engine.
+
+
+
+
+ Creates a Salsa20 engine with a specific number of rounds.
+
+ the number of rounds (must be an even number).
+
+
+ Rotate left
+
+ @param x value to rotate
+ @param y amount to rotate x
+
+ @return rotated x
+
+
+ * Serpent is a 128-bit 32-round block cipher with variable key lengths,
+ * including 128, 192 and 256 bit keys conjectured to be at least as
+ * secure as three-key triple-DES.
+ *
+ * Serpent was designed by Ross Anderson, Eli Biham and Lars Knudsen as a
+ * candidate algorithm for the NIST AES Quest.
+ *
+ *
+ * For full details see The Serpent home page
+ *
+
+
+ Expand a user-supplied key material into a session key.
+
+ @param key The user-key bytes (multiples of 4) to use.
+ @exception ArgumentException
+
+
+ Encrypt one block of plaintext.
+
+ @param input the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param output the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+
+
+ Decrypt one block of ciphertext.
+
+ @param input the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param output the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+
+
+ a class that provides a basic SKIPJACK engine.
+
+
+ initialise a SKIPJACK cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ The G permutation
+
+
+ the inverse of the G permutation.
+
+
+ An TEA engine.
+
+
+ Create an instance of the TEA encryption algorithm
+ and set some defaults
+
+
+ initialise
+
+ @param forEncryption whether or not we are for encryption.
+ @param params the parameters required to set up the cipher.
+ @exception ArgumentException if the params argument is
+ inappropriate.
+
+
+ Re-key the cipher.
+
+ @param key the key to be used
+
+
+
+ Implementation of the Threefish tweakable large block cipher in 256, 512 and 1024 bit block
+ sizes.
+
+
+ This is the 1.3 version of Threefish defined in the Skein hash function submission to the NIST
+ SHA-3 competition in October 2010.
+
+ Threefish was designed by Niels Ferguson - Stefan Lucks - Bruce Schneier - Doug Whiting - Mihir
+ Bellare - Tadayoshi Kohno - Jon Callas - Jesse Walker.
+
+ This implementation inlines all round functions, unrolls 8 rounds, and uses 1.2k of static tables
+ to speed up key schedule injection.
+ 2 x block size state is retained by each cipher instance.
+
+
+
+
+ 256 bit block size - Threefish-256
+
+
+
+
+ 512 bit block size - Threefish-512
+
+
+
+
+ 1024 bit block size - Threefish-1024
+
+
+
+ Size of the tweak in bytes (always 128 bit/16 bytes)
+
+
+ Rounds in Threefish-256
+
+
+ Rounds in Threefish-512
+
+
+ Rounds in Threefish-1024
+
+
+ Max rounds of any of the variants
+
+
+ Key schedule parity constant
+
+
+ Block size in bytes
+
+
+ Block size in 64 bit words
+
+
+ Buffer for byte oriented processBytes to call internal word API
+
+
+ Tweak bytes (2 byte t1,t2, calculated t3 and repeat of t1,t2 for modulo free lookup
+
+
+ Key schedule words
+
+
+ The internal cipher implementation (varies by blocksize)
+
+
+
+ Constructs a new Threefish cipher, with a specified block size.
+
+ the block size in bits, one of , ,
+ .
+
+
+
+ Initialise the engine.
+
+ Initialise for encryption if true, for decryption if false.
+ an instance of or (to
+ use a 0 tweak)
+
+
+
+ Initialise the engine, specifying the key and tweak directly.
+
+ the cipher mode.
+ the words of the key, or null
to use the current key.
+ the 2 word (128 bit) tweak, or null
to use the current tweak.
+
+
+
+ Process a block of data represented as 64 bit words.
+
+ the number of 8 byte words processed (which will be the same as the block size).
+ a block sized buffer of words to process.
+ a block sized buffer of words to receive the output of the operation.
+ if either the input or output is not block sized
+ if this engine is not initialised
+
+
+
+ Read a single 64 bit word from input in LSB first order.
+
+
+
+
+ Write a 64 bit word to output in LSB first order.
+
+
+
+ Rotate left + xor part of the mix operation.
+
+
+ Rotate xor + rotate right part of the unmix operation.
+
+
+ The extended + repeated tweak words
+
+
+ The extended + repeated key words
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ A class that provides Twofish encryption operations.
+
+ This Java implementation is based on the Java reference
+ implementation provided by Bruce Schneier and developed
+ by Raif S. Naffah.
+
+
+ Define the fixed p0/p1 permutations used in keyed S-box lookup.
+ By changing the following constant definitions, the S-boxes will
+ automatically Get changed in the Twofish engine.
+
+
+ gSubKeys[] and gSBox[] are eventually used in the
+ encryption and decryption methods.
+
+
+ initialise a Twofish cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Encrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+ The input will be an exact multiple of our blocksize.
+
+ encryptBlock uses the pre-calculated gSBox[] and subKey[]
+ arrays.
+
+
+ Decrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+ The input will be an exact multiple of our blocksize.
+
+
+ Use (12, 8) Reed-Solomon code over GF(256) to produce
+ a key S-box 32-bit entity from 2 key material 32-bit
+ entities.
+
+ @param k0 first 32-bit entity
+ @param k1 second 32-bit entity
+ @return Remainder polynomial Generated using RS code
+
+
+ * Reed-Solomon code parameters: (12,8) reversible code:
+ *
+ *
+ * G(x) = x^4 + (a+1/a)x^3 + ax^2 + (a+1/a)x + 1
+ *
+ * where a = primitive root of field generator 0x14D
+ *
+
+
+ initialise a VMPC cipher.
+
+ @param forEncryption
+ whether or not we are for encryption.
+ @param params
+ the parameters required to set up the cipher.
+ @exception ArgumentException
+ if the params argument is inappropriate.
+
+
+
+ Implementation of Daniel J. Bernstein's XSalsa20 stream cipher - Salsa20 with an extended nonce.
+
+
+ XSalsa20 requires a 256 bit key, and a 192 bit nonce.
+
+
+
+
+ XSalsa20 key generation: process 256 bit input key and 128 bits of the input nonce
+ using a core Salsa20 function without input addition to produce 256 bit working key
+ and use that with the remaining 64 bits of nonce to initialize a standard Salsa20 engine state.
+
+
+
+ An XTEA engine.
+
+
+ Create an instance of the TEA encryption algorithm
+ and set some defaults
+
+
+ initialise
+
+ @param forEncryption whether or not we are for encryption.
+ @param params the parameters required to set up the cipher.
+ @exception ArgumentException if the params argument is
+ inappropriate.
+
+
+ Re-key the cipher.
+
+ @param key the key to be used
+
+
+ Base interface for a public/private key block cipher.
+
+
+ The name of the algorithm this cipher implements.
+
+
+ Initialise the cipher.
+ Initialise for encryption if true, for decryption if false.
+ The key or other data required by the cipher.
+
+
+ The maximum size, in bytes, an input block may be.
+
+
+ The maximum size, in bytes, an output block will be.
+
+
+ Process a block.
+ The input buffer.
+ The offset into inBuf that the input block begins.
+ The length of the input block.
+ Input decrypts improperly.
+ Input is too large for the cipher.
+
+
+ interface that a public/private key pair generator should conform to.
+
+
+ intialise the key pair generator.
+
+ @param the parameters the key pair is to be initialised with.
+
+
+ return an AsymmetricCipherKeyPair containing the Generated keys.
+
+ @return an AsymmetricCipherKeyPair containing the Generated keys.
+
+
+ The basic interface that basic Diffie-Hellman implementations
+ conforms to.
+
+
+ initialise the agreement engine.
+
+
+ return the field size for the agreement algorithm in bytes.
+
+
+ given a public key from a given party calculate the next
+ message in the agreement sequence.
+
+
+ Base interface for a symmetric key block cipher.
+
+
+ The name of the algorithm this cipher implements.
+
+
+ Initialise the cipher.
+ Initialise for encryption if true, for decryption if false.
+ The key or other data required by the cipher.
+
+
+ The block size for this cipher, in bytes.
+
+
+ Indicates whether this cipher can handle partial blocks.
+
+
+ Process a block.
+ The input buffer.
+ The offset into inBuf that the input block begins.
+ The output buffer.
+ The offset into outBuf to write the output block.
+ If input block is wrong size, or outBuf too small.
+ The number of bytes processed and produced.
+
+
+
+ Reset the cipher to the same state as it was after the last init (if there was one).
+
+
+
+
+ Operators that reduce their input to a single block return an object
+ of this type.
+
+
+
+
+ Return the final result of the operation.
+
+ A block of bytes, representing the result of an operation.
+
+
+
+ Store the final result of the operation by copying it into the destination array.
+
+ The number of bytes copied into destination.
+ The byte array to copy the result into.
+ The offset into destination to start copying the result at.
+
+
+ Block cipher engines are expected to conform to this interface.
+
+
+ The name of the algorithm this cipher implements.
+
+
+ Initialise the cipher.
+ If true the cipher is initialised for encryption,
+ if false for decryption.
+ The key and other data required by the cipher.
+
+
+
+ Reset the cipher. After resetting the cipher is in the same state
+ as it was after the last init (if there was one).
+
+
+
+ all parameter classes implement this.
+
+
+ interface for classes implementing the Digital Signature Algorithm
+
+
+ initialise the signer for signature generation or signature
+ verification.
+
+ @param forSigning true if we are generating a signature, false
+ otherwise.
+ @param param key parameters for signature generation.
+
+
+ sign the passed in message (usually the output of a hash function).
+
+ @param message the message to be signed.
+ @return two big integers representing the r and s values respectively.
+
+
+ verify the message message against the signature values r and s.
+
+ @param message the message that was supposed to have been signed.
+ @param r the r signature value.
+ @param s the s signature value.
+
+
+ base interface for general purpose byte derivation functions.
+
+
+ return the message digest used as the basis for the function
+
+
+ Parameters for key/byte stream derivation classes
+
+
+ interface that a message digest conforms to.
+
+
+ return the algorithm name
+
+ @return the algorithm name
+
+
+ return the size, in bytes, of the digest produced by this message digest.
+
+ @return the size, in bytes, of the digest produced by this message digest.
+
+
+ return the size, in bytes, of the internal buffer used by this digest.
+
+ @return the size, in bytes, of the internal buffer used by this digest.
+
+
+ update the message digest with a single byte.
+
+ @param inByte the input byte to be entered.
+
+
+ update the message digest with a block of bytes.
+
+ @param input the byte array containing the data.
+ @param inOff the offset into the byte array where the data starts.
+ @param len the length of the data.
+
+
+ Close the digest, producing the final digest value. The doFinal
+ call leaves the digest reset.
+
+ @param output the array the digest is to be copied into.
+ @param outOff the offset into the out array the digest is to start at.
+
+
+ reset the digest back to it's initial state.
+
+
+
+ Base interface describing an entropy source for a DRBG.
+
+
+
+
+ Return whether or not this entropy source is regarded as prediction resistant.
+
+ true if this instance is prediction resistant; otherwise, false.
+
+
+
+ Return a byte array of entropy.
+
+ The entropy bytes.
+
+
+
+ Return the number of bits of entropy this source can produce.
+
+ The size, in bits, of the return value of getEntropy.
+
+
+
+ Base interface describing a provider of entropy sources.
+
+
+
+
+ Return an entropy source providing a block of entropy.
+
+ The size of the block of entropy required.
+ An entropy source providing bitsRequired blocks of entropy.
+
+
+ The base interface for implementations of message authentication codes (MACs).
+
+
+ Initialise the MAC.
+
+ @param param the key and other data required by the MAC.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Return the name of the algorithm the MAC implements.
+
+ @return the name of the algorithm the MAC implements.
+
+
+ Return the block size for this MAC (in bytes).
+
+ @return the block size for this MAC in bytes.
+
+
+ add a single byte to the mac for processing.
+
+ @param in the byte to be processed.
+ @exception InvalidOperationException if the MAC is not initialised.
+
+
+ @param in the array containing the input.
+ @param inOff the index in the array the data begins at.
+ @param len the length of the input starting at inOff.
+ @exception InvalidOperationException if the MAC is not initialised.
+ @exception DataLengthException if there isn't enough data in in.
+
+
+ Compute the final stage of the MAC writing the output to the out
+ parameter.
+
+ doFinal leaves the MAC in the same state it was after the last init.
+
+ @param out the array the MAC is to be output to.
+ @param outOff the offset into the out buffer the output is to start at.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the MAC is not initialised.
+
+
+ Reset the MAC. At the end of resetting the MAC should be in the
+ in the same state it was after the last init (if there was one).
+
+
+
+ Base interface for operators that serve as stream-based signature calculators.
+
+
+
+ The algorithm details object for this calculator.
+
+
+
+ Create a stream calculator for this signature calculator. The stream
+ calculator is used for the actual operation of entering the data to be signed
+ and producing the signature block.
+
+ A calculator producing an IBlockResult with a signature in it.
+
+
+
+ Base interface for cryptographic operations such as Hashes, MACs, and Signatures which reduce a stream of data
+ to a single value.
+
+
+
+ Return a "sink" stream which only exists to update the implementing object.
+ A stream to write to in order to update the implementing object.
+
+
+
+ Return the result of processing the stream. This value is only available once the stream
+ has been closed.
+
+ The result of processing the stream.
+
+
+ Return the name of the algorithm the signer implements.
+
+ @return the name of the algorithm the signer implements.
+
+
+ Initialise the signer for signing or verification.
+
+ @param forSigning true if for signing, false otherwise
+ @param param necessary parameters.
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ Generate a signature for the message we've been loaded with using
+ the key we were initialised with.
+
+
+ return true if the internal state represents the signature described
+ in the passed in array.
+
+
+ reset the internal state
+
+
+ Signer with message recovery.
+
+
+ Returns true if the signer has recovered the full message as
+ part of signature verification.
+
+ @return true if full message recovered.
+
+
+ Returns a reference to what message was recovered (if any).
+
+ @return full/partial message, null if nothing.
+
+
+ Perform an update with the recovered message before adding any other data. This must
+ be the first update method called, and calling it will result in the signer assuming
+ that further calls to update will include message content past what is recoverable.
+
+ @param signature the signature that we are in the process of verifying.
+ @throws IllegalStateException
+
+
+ The interface stream ciphers conform to.
+
+
+ The name of the algorithm this cipher implements.
+
+
+ Initialise the cipher.
+ If true the cipher is initialised for encryption,
+ if false for decryption.
+ The key and other data required by the cipher.
+
+ If the parameters argument is inappropriate.
+
+
+
+ encrypt/decrypt a single byte returning the result.
+ the byte to be processed.
+ the result of processing the input byte.
+
+
+
+ Process a block of bytes from input putting the result into output.
+
+ The input byte array.
+
+ The offset into input where the data to be processed starts.
+
+ The number of bytes to be processed.
+ The output buffer the processed bytes go into.
+
+ The offset into output the processed data starts at.
+
+ If the output buffer is too small.
+
+
+
+ Reset the cipher to the same state as it was after the last init (if there was one).
+
+
+
+
+ Operators that reduce their input to the validation of a signature produce this type.
+
+
+
+
+ Return true if the passed in data matches what is expected by the verification result.
+
+ The bytes representing the signature.
+ true if the signature verifies, false otherwise.
+
+
+
+ Return true if the length bytes from off in the source array match the signature
+ expected by the verification result.
+
+ Byte array containing the signature.
+ The offset into the source array where the signature starts.
+ The number of bytes in source making up the signature.
+ true if the signature verifies, false otherwise.
+
+
+
+ Base interface for operators that serve as stream-based signature verifiers.
+
+
+
+ The algorithm details object for this verifier.
+
+
+
+ Create a stream calculator for this verifier. The stream
+ calculator is used for the actual operation of entering the data to be verified
+ and producing a result which can be used to verify the original signature.
+
+ A calculator producing an IVerifier which can verify the signature.
+
+
+
+ Base interface for a provider to support the dynamic creation of signature verifiers.
+
+
+
+
+ Return a signature verfier for signature algorithm described in the passed in algorithm details object.
+
+ The details of the signature algorithm verification is required for.
+ A new signature verifier.
+
+
+ The name of the algorithm this cipher implements.
+
+
+
+ With FIPS PUB 202 a new kind of message digest was announced which supported extendable output, or variable digest sizes.
+ This interface provides the extra method required to support variable output on a digest implementation.
+
+
+
+ Output the results of the final calculation for this digest to outLen number of bytes.
+
+ @param out output array to write the output bytes to.
+ @param outOff offset to start writing the bytes at.
+ @param outLen the number of output bytes requested.
+ @return the number of bytes written
+
+
+ this exception is thrown whenever we find something we don't expect in a
+ message.
+
+
+ base constructor.
+
+
+ create a InvalidCipherTextException with the given message.
+
+ @param message the message to be carried with the exception.
+
+
+ The base class for parameters to key generators.
+
+
+ initialise the generator with a source of randomness
+ and a strength (in bits).
+
+ @param random the random byte source.
+ @param strength the size, in bits, of the keys we want to produce.
+
+
+ return the random source associated with this
+ generator.
+
+ @return the generators random source.
+
+
+ return the bit strength for keys produced by this generator,
+
+ @return the strength of the keys this generator produces (in bits).
+
+
+
+ This exception is thrown whenever a cipher requires a change of key, iv
+ or similar after x amount of bytes enciphered
+
+
+
+ super class for all Password Based Encyrption (Pbe) parameter generator classes.
+
+
+ base constructor.
+
+
+ initialise the Pbe generator.
+
+ @param password the password converted into bytes (see below).
+ @param salt the salt to be mixed with the password.
+ @param iterationCount the number of iterations the "mixing" function
+ is to be applied for.
+
+
+ return the password byte array.
+
+ @return the password byte array.
+
+
+ return the salt byte array.
+
+ @return the salt byte array.
+
+
+ return the iteration count.
+
+ @return the iteration count.
+
+
+ Generate derived parameters for a key of length keySize.
+
+ @param keySize the length, in bits, of the key required.
+ @return a parameters object representing a key.
+
+
+ Generate derived parameters for a key of length keySize, and
+ an initialisation vector (IV) of length ivSize.
+
+ @param keySize the length, in bits, of the key required.
+ @param ivSize the length, in bits, of the iv required.
+ @return a parameters object representing a key and an IV.
+
+
+ Generate derived parameters for a key of length keySize, specifically
+ for use with a MAC.
+
+ @param keySize the length, in bits, of the key required.
+ @return a parameters object representing a key.
+
+
+ converts a password to a byte array according to the scheme in
+ Pkcs5 (ascii, no padding)
+
+ @param password a character array representing the password.
+ @return a byte array representing the password.
+
+
+ converts a password to a byte array according to the scheme in
+ PKCS5 (UTF-8, no padding)
+
+ @param password a character array representing the password.
+ @return a byte array representing the password.
+
+
+ converts a password to a byte array according to the scheme in
+ Pkcs12 (unicode, big endian, 2 zero pad bytes at the end).
+
+ @param password a character array representing the password.
+ @return a byte array representing the password.
+
+
+ An EntropySourceProvider where entropy generation is based on a SecureRandom output using SecureRandom.generateSeed().
+
+
+ Create a entropy source provider based on the passed in SecureRandom.
+
+ @param secureRandom the SecureRandom to base EntropySource construction on.
+ @param isPredictionResistant boolean indicating if the SecureRandom is based on prediction resistant entropy or not (true if it is).
+
+
+ Return an entropy source that will create bitsRequired bits of entropy on
+ each invocation of getEntropy().
+
+ @param bitsRequired size (in bits) of entropy to be created by the provided source.
+ @return an EntropySource that generates bitsRequired bits of entropy on each call to its getEntropy() method.
+
+
+ A SP800-90A CTR DRBG.
+
+
+ Construct a SP800-90A CTR DRBG.
+
+ Minimum entropy requirement is the security strength requested.
+
+ @param engine underlying block cipher to use to support DRBG
+ @param keySizeInBits size of the key to use with the block cipher.
+ @param securityStrength security strength required (in bits)
+ @param entropySource source of entropy to use for seeding/reseeding.
+ @param personalizationString personalization string to distinguish this DRBG (may be null).
+ @param nonce nonce to further distinguish this DRBG (may be null).
+
+
+ Return the block size (in bits) of the DRBG.
+
+ @return the number of bits produced on each internal round of the DRBG.
+
+
+ Populate a passed in array with random data.
+
+ @param output output array for generated bits.
+ @param additionalInput additional input to be added to the DRBG in this step.
+ @param predictionResistant true if a reseed should be forced, false otherwise.
+
+ @return number of bits generated, -1 if a reseed required.
+
+
+ Reseed the DRBG.
+
+ @param additionalInput additional input to be added to the DRBG in this step.
+
+
+ Pad out a key for TDEA, setting odd parity for each byte.
+
+ @param keyMaster
+ @param keyOff
+ @param tmp
+ @param tmpOff
+
+
+ Used by both Dual EC and Hash.
+
+
+ A SP800-90A Hash DRBG.
+
+
+ Construct a SP800-90A Hash DRBG.
+
+ Minimum entropy requirement is the security strength requested.
+
+ @param digest source digest to use for DRB stream.
+ @param securityStrength security strength required (in bits)
+ @param entropySource source of entropy to use for seeding/reseeding.
+ @param personalizationString personalization string to distinguish this DRBG (may be null).
+ @param nonce nonce to further distinguish this DRBG (may be null).
+
+
+ Return the block size (in bits) of the DRBG.
+
+ @return the number of bits produced on each internal round of the DRBG.
+
+
+ Populate a passed in array with random data.
+
+ @param output output array for generated bits.
+ @param additionalInput additional input to be added to the DRBG in this step.
+ @param predictionResistant true if a reseed should be forced, false otherwise.
+
+ @return number of bits generated, -1 if a reseed required.
+
+
+ Reseed the DRBG.
+
+ @param additionalInput additional input to be added to the DRBG in this step.
+
+
+ A SP800-90A HMAC DRBG.
+
+
+ Construct a SP800-90A Hash DRBG.
+
+ Minimum entropy requirement is the security strength requested.
+
+ @param hMac Hash MAC to base the DRBG on.
+ @param securityStrength security strength required (in bits)
+ @param entropySource source of entropy to use for seeding/reseeding.
+ @param personalizationString personalization string to distinguish this DRBG (may be null).
+ @param nonce nonce to further distinguish this DRBG (may be null).
+
+
+ Return the block size (in bits) of the DRBG.
+
+ @return the number of bits produced on each round of the DRBG.
+
+
+ Populate a passed in array with random data.
+
+ @param output output array for generated bits.
+ @param additionalInput additional input to be added to the DRBG in this step.
+ @param predictionResistant true if a reseed should be forced, false otherwise.
+
+ @return number of bits generated, -1 if a reseed required.
+
+
+ Reseed the DRBG.
+
+ @param additionalInput additional input to be added to the DRBG in this step.
+
+
+ Interface to SP800-90A deterministic random bit generators.
+
+
+ Return the block size of the DRBG.
+
+ @return the block size (in bits) produced by each round of the DRBG.
+
+
+ Populate a passed in array with random data.
+
+ @param output output array for generated bits.
+ @param additionalInput additional input to be added to the DRBG in this step.
+ @param predictionResistant true if a reseed should be forced, false otherwise.
+
+ @return number of bits generated, -1 if a reseed required.
+
+
+ Reseed the DRBG.
+
+ @param additionalInput additional input to be added to the DRBG in this step.
+
+
+ Generate numBytes worth of entropy from the passed in entropy source.
+
+ @param entropySource the entropy source to request the data from.
+ @param numBytes the number of bytes of entropy requested.
+ @return a byte array populated with the random data.
+
+
+ Builder class for making SecureRandom objects based on SP 800-90A Deterministic Random Bit Generators (DRBG).
+
+
+ Basic constructor, creates a builder using an EntropySourceProvider based on the default SecureRandom with
+ predictionResistant set to false.
+
+ Any SecureRandom created from a builder constructed like this will make use of input passed to SecureRandom.setSeed() if
+ the default SecureRandom does for its generateSeed() call.
+
+
+
+ Construct a builder with an EntropySourceProvider based on the passed in SecureRandom and the passed in value
+ for prediction resistance.
+
+ Any SecureRandom created from a builder constructed like this will make use of input passed to SecureRandom.setSeed() if
+ the passed in SecureRandom does for its generateSeed() call.
+
+ @param entropySource
+ @param predictionResistant
+
+
+ Create a builder which makes creates the SecureRandom objects from a specified entropy source provider.
+
+ Note: If this constructor is used any calls to setSeed() in the resulting SecureRandom will be ignored.
+
+ @param entropySourceProvider a provider of EntropySource objects.
+
+
+ Set the personalization string for DRBG SecureRandoms created by this builder
+ @param personalizationString the personalisation string for the underlying DRBG.
+ @return the current builder.
+
+
+ Set the security strength required for DRBGs used in building SecureRandom objects.
+
+ @param securityStrength the security strength (in bits)
+ @return the current builder.
+
+
+ Set the amount of entropy bits required for seeding and reseeding DRBGs used in building SecureRandom objects.
+
+ @param entropyBitsRequired the number of bits of entropy to be requested from the entropy source on each seed/reseed.
+ @return the current builder.
+
+
+ Build a SecureRandom based on a SP 800-90A Hash DRBG.
+
+ @param digest digest algorithm to use in the DRBG underneath the SecureRandom.
+ @param nonce nonce value to use in DRBG construction.
+ @param predictionResistant specify whether the underlying DRBG in the resulting SecureRandom should reseed on each request for bytes.
+ @return a SecureRandom supported by a Hash DRBG.
+
+
+ Build a SecureRandom based on a SP 800-90A CTR DRBG.
+
+ @param cipher the block cipher to base the DRBG on.
+ @param keySizeInBits key size in bits to be used with the block cipher.
+ @param nonce nonce value to use in DRBG construction.
+ @param predictionResistant specify whether the underlying DRBG in the resulting SecureRandom should reseed on each request for bytes.
+ @return a SecureRandom supported by a CTR DRBG.
+
+
+ Build a SecureRandom based on a SP 800-90A HMAC DRBG.
+
+ @param hMac HMAC algorithm to use in the DRBG underneath the SecureRandom.
+ @param nonce nonce value to use in DRBG construction.
+ @param predictionResistant specify whether the underlying DRBG in the resulting SecureRandom should reseed on each request for bytes.
+ @return a SecureRandom supported by a HMAC DRBG.
+
+
+
+ @param engine
+ @param entropySource
+
+
+ Populate a passed in array with random data.
+
+ @param output output array for generated bits.
+ @param predictionResistant true if a reseed should be forced, false otherwise.
+
+ @return number of bits generated, -1 if a reseed required.
+
+
+ Reseed the RNG.
+
+
+ Basic constructor, creates a builder using an EntropySourceProvider based on the default SecureRandom with
+ predictionResistant set to false.
+
+ Any SecureRandom created from a builder constructed like this will make use of input passed to SecureRandom.setSeed() if
+ the default SecureRandom does for its generateSeed() call.
+
+
+
+ Construct a builder with an EntropySourceProvider based on the passed in SecureRandom and the passed in value
+ for prediction resistance.
+
+ Any SecureRandom created from a builder constructed like this will make use of input passed to SecureRandom.setSeed() if
+ the passed in SecureRandom does for its generateSeed() call.
+
+ @param entropySource
+ @param predictionResistant
+
+
+ Create a builder which makes creates the SecureRandom objects from a specified entropy source provider.
+
+ Note: If this constructor is used any calls to setSeed() in the resulting SecureRandom will be ignored.
+
+ @param entropySourceProvider a provider of EntropySource objects.
+
+
+ Construct a X9.31 secure random generator using the passed in engine and key. If predictionResistant is true the
+ generator will be reseeded on each request.
+
+ @param engine a block cipher to use as the operator.
+ @param key the block cipher key to initialise engine with.
+ @param predictionResistant true if engine to be reseeded on each use, false otherwise.
+ @return a SecureRandom.
+
+
+
+ Uses Microsoft's RNGCryptoServiceProvider
+
+
+
+ Random generation based on the digest with counter. Calling AddSeedMaterial will
+ always increase the entropy of the hash.
+
+ Internal access to the digest is synchronized so a single one of these can be shared.
+
+
+
+ Generic interface for objects generating random bytes.
+
+
+ Add more seed material to the generator.
+ A byte array to be mixed into the generator's state.
+
+
+ Add more seed material to the generator.
+ A long value to be mixed into the generator's state.
+
+
+ Fill byte array with random values.
+ Array to be filled.
+
+
+ Fill byte array with random values.
+ Array to receive bytes.
+ Index to start filling at.
+ Length of segment to fill.
+
+
+
+ Takes bytes generated by an underling RandomGenerator and reverses the order in
+ each small window (of configurable size).
+
+ Access to internals is synchronized so a single one of these can be shared.
+
+
+
+
+ Add more seed material to the generator.
+ A byte array to be mixed into the generator's state.
+
+
+ Add more seed material to the generator.
+ A long value to be mixed into the generator's state.
+
+
+ Fill byte array with random values.
+ Array to be filled.
+
+
+ Fill byte array with random values.
+ Array to receive bytes.
+ Index to start filling at.
+ Length of segment to fill.
+
+
+ A thread based seed generator - one source of randomness.
+
+ Based on an idea from Marcus Lippert.
+
+
+
+ Generate seed bytes. Set fast to false for best quality.
+
+ If fast is set to true, the code should be round about 8 times faster when
+ generating a long sequence of random bytes. 20 bytes of random values using
+ the fast mode take less than half a second on a Nokia e70. If fast is set to false,
+ it takes round about 2500 ms.
+
+ @param numBytes the number of bytes to generate
+ @param fast true if fast mode should be used
+
+
+
+ Permutation generated by code:
+
+ // First 1850 fractional digit of Pi number.
+ byte[] key = new BigInteger("14159265358979323846...5068006422512520511").ToByteArray();
+ s = 0;
+ P = new byte[256];
+ for (int i = 0; i < 256; i++)
+ {
+ P[i] = (byte) i;
+ }
+ for (int m = 0; m < 768; m++)
+ {
+ s = P[(s + P[m & 0xff] + key[m % key.length]) & 0xff];
+ byte temp = P[m & 0xff];
+ P[m & 0xff] = P[s & 0xff];
+ P[s & 0xff] = temp;
+ }
+
+
+
+ Value generated in the same way as P.
+
+
+ a wrapper for block ciphers with a single byte block size, so that they
+ can be treated like stream ciphers.
+
+
+ basic constructor.
+
+ @param cipher the block cipher to be wrapped.
+ @exception ArgumentException if the cipher has a block size other than
+ one.
+
+
+ initialise the underlying cipher.
+
+ @param forEncryption true if we are setting up for encryption, false otherwise.
+ @param param the necessary parameters for the underlying cipher to be initialised.
+
+
+ return the name of the algorithm we are wrapping.
+
+ @return the name of the algorithm we are wrapping.
+
+
+ encrypt/decrypt a single byte returning the result.
+
+ @param in the byte to be processed.
+ @return the result of processing the input byte.
+
+
+ process a block of bytes from in putting the result into out.
+
+ @param in the input byte array.
+ @param inOff the offset into the in array where the data to be processed starts.
+ @param len the number of bytes to be processed.
+ @param out the output buffer the processed bytes go into.
+ @param outOff the offset into the output byte array the processed data stars at.
+ @exception DataLengthException if the output buffer is too small.
+
+
+ reset the underlying cipher. This leaves it in the same state
+ it was at after the last init (if there was one).
+
+
+ a Diffie-Hellman key exchange engine.
+
+ note: This uses MTI/A0 key agreement in order to make the key agreement
+ secure against passive attacks. If you're doing Diffie-Hellman and both
+ parties have long term public keys you should look at using this. For
+ further information have a look at RFC 2631.
+
+ It's possible to extend this to more than two parties as well, for the moment
+ that is left as an exercise for the reader.
+
+
+ calculate our initial message.
+
+
+ given a message from a given party and the corresponding public key
+ calculate the next message in the agreement sequence. In this case
+ this will represent the shared secret.
+
+
+ a Diffie-Hellman key agreement class.
+
+ note: This is only the basic algorithm, it doesn't take advantage of
+ long term public keys if they are available. See the DHAgreement class
+ for a "better" implementation.
+
+
+ given a short term public key from a given party calculate the next
+ message in the agreement sequence.
+
+
+ Standard Diffie-Hellman groups from various IETF specifications.
+
+
+ P1363 7.2.1 ECSVDP-DH
+
+ ECSVDP-DH is Elliptic Curve Secret Value Derivation Primitive,
+ Diffie-Hellman version. It is based on the work of [DH76], [Mil86],
+ and [Kob87]. This primitive derives a shared secret value from one
+ party's private key and another party's public key, where both have
+ the same set of EC domain parameters. If two parties correctly
+ execute this primitive, they will produce the same output. This
+ primitive can be invoked by a scheme to derive a shared secret key;
+ specifically, it may be used with the schemes ECKAS-DH1 and
+ DL/ECKAS-DH2. It assumes that the input keys are valid (see also
+ Section 7.2.2).
+
+
+ P1363 7.2.2 ECSVDP-DHC
+
+ ECSVDP-DHC is Elliptic Curve Secret Value Derivation Primitive,
+ Diffie-Hellman version with cofactor multiplication. It is based on
+ the work of [DH76], [Mil86], [Kob87], [LMQ98] and [Kal98a]. This
+ primitive derives a shared secret value from one party's private key
+ and another party's public key, where both have the same set of EC
+ domain parameters. If two parties correctly execute this primitive,
+ they will produce the same output. This primitive can be invoked by a
+ scheme to derive a shared secret key; specifically, it may be used
+ with the schemes ECKAS-DH1 and DL/ECKAS-DH2. It does not assume the
+ validity of the input public key (see also Section 7.2.1).
+
+ Note: As stated P1363 compatibility mode with ECDH can be preset, and
+ in this case the implementation doesn't have a ECDH compatibility mode
+ (if you want that just use ECDHBasicAgreement and note they both implement
+ BasicAgreement!).
+
+
+
+ A participant in a Password Authenticated Key Exchange by Juggling (J-PAKE) exchange.
+
+ The J-PAKE exchange is defined by Feng Hao and Peter Ryan in the paper
+
+ "Password Authenticated Key Exchange by Juggling, 2008."
+
+ The J-PAKE protocol is symmetric.
+ There is no notion of a client or server, but rather just two participants.
+ An instance of JPakeParticipant represents one participant, and
+ is the primary interface for executing the exchange.
+
+ To execute an exchange, construct a JPakeParticipant on each end,
+ and call the following 7 methods
+ (once and only once, in the given order, for each participant, sending messages between them as described):
+
+ CreateRound1PayloadToSend() - and send the payload to the other participant
+ ValidateRound1PayloadReceived(JPakeRound1Payload) - use the payload received from the other participant
+ CreateRound2PayloadToSend() - and send the payload to the other participant
+ ValidateRound2PayloadReceived(JPakeRound2Payload) - use the payload received from the other participant
+ CalculateKeyingMaterial()
+ CreateRound3PayloadToSend(BigInteger) - and send the payload to the other participant
+ ValidateRound3PayloadReceived(JPakeRound3Payload, BigInteger) - use the payload received from the other participant
+
+ Each side should derive a session key from the keying material returned by CalculateKeyingMaterial().
+ The caller is responsible for deriving the session key using a secure key derivation function (KDF).
+
+ Round 3 is an optional key confirmation process.
+ If you do not execute round 3, then there is no assurance that both participants are using the same key.
+ (i.e. if the participants used different passwords, then their session keys will differ.)
+
+ If the round 3 validation succeeds, then the keys are guaranteed to be the same on both sides.
+
+ The symmetric design can easily support the asymmetric cases when one party initiates the communication.
+ e.g. Sometimes the round1 payload and round2 payload may be sent in one pass.
+ Also, in some cases, the key confirmation payload can be sent together with the round2 payload.
+ These are the trivial techniques to optimize the communication.
+
+ The key confirmation process is implemented as specified in
+ NIST SP 800-56A Revision 1,
+ Section 8.2 Unilateral Key Confirmation for Key Agreement Schemes.
+
+ This class is stateful and NOT threadsafe.
+ Each instance should only be used for ONE complete J-PAKE exchange
+ (i.e. a new JPakeParticipant should be constructed for each new J-PAKE exchange).
+
+
+
+
+ Convenience constructor for a new JPakeParticipant that uses
+ the JPakePrimeOrderGroups#NIST_3072 prime order group,
+ a SHA-256 digest, and a default SecureRandom implementation.
+
+ After construction, the State state will be STATE_INITIALIZED.
+
+ Throws NullReferenceException if any argument is null. Throws
+ ArgumentException if password is empty.
+
+ Unique identifier of this participant.
+ The two participants in the exchange must NOT share the same id.
+ Shared secret.
+ A defensive copy of this array is made (and cleared once CalculateKeyingMaterial() is called).
+ Caller should clear the input password as soon as possible.
+
+
+
+ Convenience constructor for a new JPakeParticipant that uses
+ a SHA-256 digest, and a default SecureRandom implementation.
+
+ After construction, the State state will be STATE_INITIALIZED.
+
+ Throws NullReferenceException if any argument is null. Throws
+ ArgumentException if password is empty.
+
+ Unique identifier of this participant.
+ The two participants in the exchange must NOT share the same id.
+ Shared secret.
+ A defensive copy of this array is made (and cleared once CalculateKeyingMaterial() is called).
+ Caller should clear the input password as soon as possible.
+ Prime order group. See JPakePrimeOrderGroups for standard groups.
+
+
+
+ Constructor for a new JPakeParticipant.
+
+ After construction, the State state will be STATE_INITIALIZED.
+
+ Throws NullReferenceException if any argument is null. Throws
+ ArgumentException if password is empty.
+
+ Unique identifier of this participant.
+ The two participants in the exchange must NOT share the same id.
+ Shared secret.
+ A defensive copy of this array is made (and cleared once CalculateKeyingMaterial() is called).
+ Caller should clear the input password as soon as possible.
+ Prime order group. See JPakePrimeOrderGroups for standard groups.
+ Digest to use during zero knowledge proofs and key confirmation
+ (SHA-256 or stronger preferred).
+ Source of secure random data for x1 and x2, and for the zero knowledge proofs.
+
+
+
+ Gets the current state of this participant.
+ See the STATE_* constants for possible values.
+
+
+
+
+ Creates and returns the payload to send to the other participant during round 1.
+
+ After execution, the State state} will be STATE_ROUND_1_CREATED}.
+
+
+
+
+ Validates the payload received from the other participant during round 1.
+
+ Must be called prior to CreateRound2PayloadToSend().
+
+ After execution, the State state will be STATE_ROUND_1_VALIDATED.
+
+ Throws CryptoException if validation fails. Throws InvalidOperationException
+ if called multiple times.
+
+
+
+
+ Creates and returns the payload to send to the other participant during round 2.
+
+ ValidateRound1PayloadReceived(JPakeRound1Payload) must be called prior to this method.
+
+ After execution, the State state will be STATE_ROUND_2_CREATED.
+
+ Throws InvalidOperationException if called prior to ValidateRound1PayloadReceived(JPakeRound1Payload), or multiple times
+
+
+
+
+ Validates the payload received from the other participant during round 2.
+ Note that this DOES NOT detect a non-common password.
+ The only indication of a non-common password is through derivation
+ of different keys (which can be detected explicitly by executing round 3 and round 4)
+
+ Must be called prior to CalculateKeyingMaterial().
+
+ After execution, the State state will be STATE_ROUND_2_VALIDATED.
+
+ Throws CryptoException if validation fails. Throws
+ InvalidOperationException if called prior to ValidateRound1PayloadReceived(JPakeRound1Payload), or multiple times
+
+
+
+
+ Calculates and returns the key material.
+ A session key must be derived from this key material using a secure key derivation function (KDF).
+ The KDF used to derive the key is handled externally (i.e. not by JPakeParticipant).
+
+ The keying material will be identical for each participant if and only if
+ each participant's password is the same. i.e. If the participants do not
+ share the same password, then each participant will derive a different key.
+ Therefore, if you immediately start using a key derived from
+ the keying material, then you must handle detection of incorrect keys.
+ If you want to handle this detection explicitly, you can optionally perform
+ rounds 3 and 4. See JPakeParticipant for details on how to execute
+ rounds 3 and 4.
+
+ The keying material will be in the range [0, p-1].
+
+ ValidateRound2PayloadReceived(JPakeRound2Payload) must be called prior to this method.
+
+ As a side effect, the internal password array is cleared, since it is no longer needed.
+
+ After execution, the State state will be STATE_KEY_CALCULATED.
+
+ Throws InvalidOperationException if called prior to ValidateRound2PayloadReceived(JPakeRound2Payload),
+ or if called multiple times.
+
+
+
+
+ Creates and returns the payload to send to the other participant during round 3.
+
+ See JPakeParticipant for more details on round 3.
+
+ After execution, the State state} will be STATE_ROUND_3_CREATED.
+ Throws InvalidOperationException if called prior to CalculateKeyingMaterial, or multiple
+ times.
+
+ The keying material as returned from CalculateKeyingMaterial().
+
+
+
+ Validates the payload received from the other participant during round 3.
+
+ See JPakeParticipant for more details on round 3.
+
+ After execution, the State state will be STATE_ROUND_3_VALIDATED.
+
+ Throws CryptoException if validation fails. Throws InvalidOperationException if called prior to
+ CalculateKeyingMaterial or multiple times
+
+ The round 3 payload received from the other participant.
+ The keying material as returned from CalculateKeyingMaterial().
+
+
+
+ A pre-computed prime order group for use during a J-PAKE exchange.
+
+ Typically a Schnorr group is used. In general, J-PAKE can use any prime order group
+ that is suitable for public key cryptography, including elliptic curve cryptography.
+
+ See JPakePrimeOrderGroups for convenient standard groups.
+
+ NIST publishes
+ many groups that can be used for the desired level of security.
+
+
+
+
+ Constructs a new JPakePrimeOrderGroup.
+
+ In general, you should use one of the pre-approved groups from
+ JPakePrimeOrderGroups, rather than manually constructing one.
+
+ The following basic checks are performed:
+
+ p-1 must be evenly divisible by q
+ g must be in [2, p-1]
+ g^q mod p must equal 1
+ p must be prime (within reasonably certainty)
+ q must be prime (within reasonably certainty)
+
+ The prime checks are performed using BigInteger#isProbablePrime(int),
+ and are therefore subject to the same probability guarantees.
+
+ These checks prevent trivial mistakes.
+ However, due to the small uncertainties if p and q are not prime,
+ advanced attacks are not prevented.
+ Use it at your own risk.
+
+ Throws NullReferenceException if any argument is null. Throws
+ InvalidOperationException is any of the above validations fail.
+
+
+
+
+ Constructor used by the pre-approved groups in JPakePrimeOrderGroups.
+ These pre-approved groups can avoid the expensive checks.
+ User-specified groups should not use this constructor.
+
+
+
+
+ Standard pre-computed prime order groups for use by J-PAKE.
+ (J-PAKE can use pre-computed prime order groups, same as DSA and Diffie-Hellman.)
+
+ This class contains some convenient constants for use as input for
+ constructing {@link JPAKEParticipant}s.
+
+ The prime order groups below are taken from Sun's JDK JavaDoc (docs/guide/security/CryptoSpec.html#AppB),
+ and from the prime order groups
+ published by NIST.
+
+
+
+
+ From Sun's JDK JavaDoc (docs/guide/security/CryptoSpec.html#AppB)
+ 1024-bit p, 160-bit q and 1024-bit g for 80-bit security.
+
+
+
+
+ From NIST.
+ 2048-bit p, 224-bit q and 2048-bit g for 112-bit security.
+
+
+
+
+ From NIST.
+ 3072-bit p, 256-bit q and 3072-bit g for 128-bit security.
+
+
+
+
+ The payload sent/received during the first round of a J-PAKE exchange.
+
+ Each JPAKEParticipant creates and sends an instance of this payload to
+ the other. The payload to send should be created via
+ JPAKEParticipant.CreateRound1PayloadToSend().
+
+ Each participant must also validate the payload received from the other.
+ The received payload should be validated via
+ JPAKEParticipant.ValidateRound1PayloadReceived(JPakeRound1Payload).
+
+
+
+
+ The id of the JPAKEParticipant who created/sent this payload.
+
+
+
+
+ The value of g^x1
+
+
+
+
+ The value of g^x2
+
+
+
+
+ The zero knowledge proof for x1.
+
+ This is a two element array, containing {g^v, r} for x1.
+
+
+
+
+ The zero knowledge proof for x2.
+
+ This is a two element array, containing {g^v, r} for x2.
+
+
+
+
+ The payload sent/received during the second round of a J-PAKE exchange.
+
+ Each JPAKEParticipant creates and sends an instance
+ of this payload to the other JPAKEParticipant.
+ The payload to send should be created via
+ JPAKEParticipant#createRound2PayloadToSend()
+
+ Each JPAKEParticipant must also validate the payload
+ received from the other JPAKEParticipant.
+ The received payload should be validated via
+ JPAKEParticipant#validateRound2PayloadReceived(JPakeRound2Payload)
+
+
+
+
+ The id of the JPAKEParticipant who created/sent this payload.
+
+
+
+
+ The value of A, as computed during round 2.
+
+
+
+
+ The zero knowledge proof for x2 * s.
+
+ This is a two element array, containing {g^v, r} for x2 * s.
+
+
+
+
+ The payload sent/received during the optional third round of a J-PAKE exchange,
+ which is for explicit key confirmation.
+
+ Each JPAKEParticipant creates and sends an instance
+ of this payload to the other JPAKEParticipant.
+ The payload to send should be created via
+ JPAKEParticipant#createRound3PayloadToSend(BigInteger)
+
+ Eeach JPAKEParticipant must also validate the payload
+ received from the other JPAKEParticipant.
+ The received payload should be validated via
+ JPAKEParticipant#validateRound3PayloadReceived(JPakeRound3Payload, BigInteger)
+
+
+
+
+ The id of the {@link JPAKEParticipant} who created/sent this payload.
+
+
+
+
+ The value of MacTag, as computed by round 3.
+
+ See JPAKEUtil#calculateMacTag(string, string, BigInteger, BigInteger, BigInteger, BigInteger, BigInteger, org.bouncycastle.crypto.Digest)
+
+
+
+
+ Primitives needed for a J-PAKE exchange.
+
+ The recommended way to perform a J-PAKE exchange is by using
+ two JPAKEParticipants. Internally, those participants
+ call these primitive operations in JPakeUtilities.
+
+ The primitives, however, can be used without a JPAKEParticipant if needed.
+
+
+
+
+ Return a value that can be used as x1 or x3 during round 1.
+ The returned value is a random value in the range [0, q-1].
+
+
+
+
+ Return a value that can be used as x2 or x4 during round 1.
+ The returned value is a random value in the range [1, q-1].
+
+
+
+
+ Converts the given password to a BigInteger
+ for use in arithmetic calculations.
+
+
+
+
+ Calculate g^x mod p as done in round 1.
+
+
+
+
+ Calculate ga as done in round 2.
+
+
+
+
+ Calculate x2 * s as done in round 2.
+
+
+
+
+ Calculate A as done in round 2.
+
+
+
+
+ Calculate a zero knowledge proof of x using Schnorr's signature.
+ The returned array has two elements {g^v, r = v-x*h} for x.
+
+
+
+
+ Validates that g^x4 is not 1.
+ throws CryptoException if g^x4 is 1
+
+
+
+
+ Validates that ga is not 1.
+
+ As described by Feng Hao...
+ Alice could simply check ga != 1 to ensure it is a generator.
+ In fact, as we will explain in Section 3, (x1 + x3 + x4 ) is random over Zq even in the face of active attacks.
+ Hence, the probability for ga = 1 is extremely small - on the order of 2^160 for 160-bit q.
+
+ throws CryptoException if ga is 1
+
+
+
+
+ Validates the zero knowledge proof (generated by
+ calculateZeroKnowledgeProof(BigInteger, BigInteger, BigInteger, BigInteger, BigInteger, string, Digest, SecureRandom)
+ is correct.
+
+ throws CryptoException if the zero knowledge proof is not correct
+
+
+
+
+ Calculates the keying material, which can be done after round 2 has completed.
+ A session key must be derived from this key material using a secure key derivation function (KDF).
+ The KDF used to derive the key is handled externally (i.e. not by JPAKEParticipant).
+
+ KeyingMaterial = (B/g^{x2*x4*s})^x2
+
+
+
+
+ Validates that the given participant ids are not equal.
+ (For the J-PAKE exchange, each participant must use a unique id.)
+
+ Throws CryptoException if the participantId strings are equal.
+
+
+
+
+ Validates that the given participant ids are equal.
+ This is used to ensure that the payloads received from
+ each round all come from the same participant.
+
+
+
+
+ Validates that the given object is not null.
+ throws NullReferenceException if the object is null.
+
+ object in question
+ name of the object (to be used in exception message)
+
+
+
+ Calculates the MacTag (to be used for key confirmation), as defined by
+ NIST SP 800-56A Revision 1,
+ Section 8.2 Unilateral Key Confirmation for Key Agreement Schemes.
+
+ MacTag = HMAC(MacKey, MacLen, MacData)
+ MacKey = H(K || "JPAKE_KC")
+ MacData = "KC_1_U" || participantId || partnerParticipantId || gx1 || gx2 || gx3 || gx4
+
+ Note that both participants use "KC_1_U" because the sender of the round 3 message
+ is always the initiator for key confirmation.
+
+ HMAC = {@link HMac} used with the given {@link Digest}
+ H = The given {@link Digest}
+ MacLen = length of MacTag
+
+
+
+
+ Calculates the MacKey (i.e. the key to use when calculating the MagTag for key confirmation).
+
+ MacKey = H(K || "JPAKE_KC")
+
+
+
+
+ Validates the MacTag received from the partner participant.
+
+ throws CryptoException if the participantId strings are equal.
+
+
+
+ RFC 2631 Diffie-hellman KEK derivation function.
+
+
+ X9.63 based key derivation function for ECDH CMS.
+
+
+ Implements the client side SRP-6a protocol. Note that this class is stateful, and therefore NOT threadsafe.
+ This implementation of SRP is based on the optimized message sequence put forth by Thomas Wu in the paper
+ "SRP-6: Improvements and Refinements to the Secure Remote Password Protocol, 2002"
+
+
+ Initialises the client to begin new authentication attempt
+ @param N The safe prime associated with the client's verifier
+ @param g The group parameter associated with the client's verifier
+ @param digest The digest algorithm associated with the client's verifier
+ @param random For key generation
+
+
+ Generates client's credentials given the client's salt, identity and password
+ @param salt The salt used in the client's verifier.
+ @param identity The user's identity (eg. username)
+ @param password The user's password
+ @return Client's public value to send to server
+
+
+ Generates client's verification message given the server's credentials
+ @param serverB The server's credentials
+ @return Client's verification message for the server
+ @throws CryptoException If server's credentials are invalid
+
+
+ Computes the client evidence message M1 using the previously received values.
+ To be called after calculating the secret S.
+ @return M1: the client side generated evidence message
+ @throws CryptoException
+
+
+ Authenticates the server evidence message M2 received and saves it only if correct.
+ @param M2: the server side generated evidence message
+ @return A boolean indicating if the server message M2 was the expected one.
+ @throws CryptoException
+
+
+ Computes the final session key as a result of the SRP successful mutual authentication
+ To be called after verifying the server evidence message M2.
+ @return Key: the mutually authenticated symmetric session key
+ @throws CryptoException
+
+
+ Implements the server side SRP-6a protocol. Note that this class is stateful, and therefore NOT threadsafe.
+ This implementation of SRP is based on the optimized message sequence put forth by Thomas Wu in the paper
+ "SRP-6: Improvements and Refinements to the Secure Remote Password Protocol, 2002"
+
+
+ Initialises the server to accept a new client authentication attempt
+ @param N The safe prime associated with the client's verifier
+ @param g The group parameter associated with the client's verifier
+ @param v The client's verifier
+ @param digest The digest algorithm associated with the client's verifier
+ @param random For key generation
+
+
+ Generates the server's credentials that are to be sent to the client.
+ @return The server's public value to the client
+
+
+ Processes the client's credentials. If valid the shared secret is generated and returned.
+ @param clientA The client's credentials
+ @return A shared secret BigInteger
+ @throws CryptoException If client's credentials are invalid
+
+
+ Authenticates the received client evidence message M1 and saves it only if correct.
+ To be called after calculating the secret S.
+ @param M1: the client side generated evidence message
+ @return A boolean indicating if the client message M1 was the expected one.
+ @throws CryptoException
+
+
+ Computes the server evidence message M2 using the previously verified values.
+ To be called after successfully verifying the client evidence message M1.
+ @return M2: the server side generated evidence message
+ @throws CryptoException
+
+
+ Computes the final session key as a result of the SRP successful mutual authentication
+ To be called after calculating the server evidence message M2.
+ @return Key: the mutual authenticated symmetric session key
+ @throws CryptoException
+
+
+ Computes the client evidence message (M1) according to the standard routine:
+ M1 = H( A | B | S )
+ @param digest The Digest used as the hashing function H
+ @param N Modulus used to get the pad length
+ @param A The public client value
+ @param B The public server value
+ @param S The secret calculated by both sides
+ @return M1 The calculated client evidence message
+
+
+ Computes the server evidence message (M2) according to the standard routine:
+ M2 = H( A | M1 | S )
+ @param digest The Digest used as the hashing function H
+ @param N Modulus used to get the pad length
+ @param A The public client value
+ @param M1 The client evidence message
+ @param S The secret calculated by both sides
+ @return M2 The calculated server evidence message
+
+
+ Computes the final Key according to the standard routine: Key = H(S)
+ @param digest The Digest used as the hashing function H
+ @param N Modulus used to get the pad length
+ @param S The secret calculated by both sides
+ @return
+
+
+ Generates new SRP verifier for user
+
+
+ Initialises generator to create new verifiers
+ @param N The safe prime to use (see DHParametersGenerator)
+ @param g The group parameter to use (see DHParametersGenerator)
+ @param digest The digest to use. The same digest type will need to be used later for the actual authentication
+ attempt. Also note that the final session key size is dependent on the chosen digest.
+
+
+ Creates a new SRP verifier
+ @param salt The salt to use, generally should be large and random
+ @param identity The user's identifying information (eg. username)
+ @param password The user's password
+ @return A new verifier for use in future SRP authentication
+
+
+ return the X9ECParameters object for the named curve represented by
+ the passed in object identifier. Null if the curve isn't present.
+
+ @param oid an object identifier representing a named curve, if present.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+ ISO 9796-1 padding. Note in the light of recent results you should
+ only use this with RSA (rather than the "simpler" Rabin keys) and you
+ should never use it with anything other than a hash (ie. even if the
+ message is small don't sign the message, sign it's hash) or some "random"
+ value. See your favorite search engine for details.
+
+
+ return the input block size. The largest message we can process
+ is (key_size_in_bits + 3)/16, which in our world comes to
+ key_size_in_bytes / 2.
+
+
+ return the maximum possible size for the output.
+
+
+ set the number of bits in the next message to be treated as
+ pad bits.
+
+
+ retrieve the number of pad bits in the last decoded message.
+
+
+ @exception InvalidCipherTextException if the decrypted block is not a valid ISO 9796 bit string
+
+
+ Optimal Asymmetric Encryption Padding (OAEP) - see PKCS 1 V 2.
+
+
+ @exception InvalidCipherTextException if the decrypted block turns out to
+ be badly formatted.
+
+
+ int to octet string.
+
+
+ mask generator function, as described in PKCS1v2.
+
+
+ this does your basic Pkcs 1 v1.5 padding - whether or not you should be using this
+ depends on your application - see Pkcs1 Version 2 for details.
+
+
+ some providers fail to include the leading zero in PKCS1 encoded blocks. If you need to
+ work with one of these set the system property Org.BouncyCastle.Pkcs1.Strict to false.
+
+
+ The same effect can be achieved by setting the static property directly
+
+ The static property is checked during construction of the encoding object, it is set to
+ true by default.
+
+
+
+ Basic constructor.
+ @param cipher
+
+
+ Constructor for decryption with a fixed plaintext length.
+
+ @param cipher The cipher to use for cryptographic operation.
+ @param pLen Length of the expected plaintext.
+
+
+ Constructor for decryption with a fixed plaintext length and a fallback
+ value that is returned, if the padding is incorrect.
+
+ @param cipher
+ The cipher to use for cryptographic operation.
+ @param fallback
+ The fallback value, we don't to a arraycopy here.
+
+
+ Checks if the argument is a correctly PKCS#1.5 encoded Plaintext
+ for encryption.
+
+ @param encoded The Plaintext.
+ @param pLen Expected length of the plaintext.
+ @return Either 0, if the encoding is correct, or -1, if it is incorrect.
+
+
+ Decode PKCS#1.5 encoding, and return a random value if the padding is not correct.
+
+ @param in The encrypted block.
+ @param inOff Offset in the encrypted block.
+ @param inLen Length of the encrypted block.
+ @param pLen Length of the desired output.
+ @return The plaintext without padding, or a random value if the padding was incorrect.
+
+ @throws InvalidCipherTextException
+
+
+ @exception InvalidCipherTextException if the decrypted block is not in Pkcs1 format.
+
+
+ Basic KDF generator for derived keys and ivs as defined by IEEE P1363a/ISO 18033
+
+ This implementation is based on ISO 18033/P1363a.
+
+
+ Construct a KDF Parameters generator.
+
+ @param counterStart value of counter.
+ @param digest the digest to be used as the source of derived keys.
+
+
+ return the underlying digest.
+
+
+ fill len bytes of the output buffer with bytes generated from
+ the derivation function.
+
+ @throws ArgumentException if the size of the request will cause an overflow.
+ @throws DataLengthException if the out buffer is too small.
+
+
+ a basic Diffie-Hellman key pair generator.
+
+ This generates keys consistent for use with the basic algorithm for
+ Diffie-Hellman.
+
+
+ a Diffie-Hellman key pair generator.
+
+ This generates keys consistent for use in the MTI/A0 key agreement protocol
+ as described in "Handbook of Applied Cryptography", Pages 516-519.
+
+
+ which Generates the p and g values from the given parameters,
+ returning the DHParameters object.
+
+ Note: can take a while...
+
+
+ initialise the key generator - if strength is set to zero
+ the key Generated will be 192 bits in size, otherwise
+ strength can be 128 or 192 (or 112 or 168 if you don't count
+ parity bits), depending on whether you wish to do 2-key or 3-key
+ triple DES.
+
+ @param param the parameters to be used for key generation
+
+
+ initialise the key generator - if strength is set to zero
+ the key generated will be 64 bits in size, otherwise
+ strength can be 64 or 56 bits (if you don't count the parity bits).
+
+ @param param the parameters to be used for key generation
+
+
+ a DSA key pair generator.
+
+ This Generates DSA keys in line with the method described
+ in FIPS 186-3 B.1 FFC Key Pair Generation.
+
+
+ Generate suitable parameters for DSA, in line with FIPS 186-2, or FIPS 186-3.
+
+
+ Initialise the generator
+ This form can only be used for older DSA (pre-DSA2) parameters
+ the size of keys in bits (from 512 up to 1024, and a multiple of 64)
+ measure of robustness of primes (at least 80 for FIPS 186-2 compliance)
+ the source of randomness to use
+
+
+ Initialise the generator for DSA 2
+ You must use this Init method if you need to generate parameters for DSA 2 keys
+ An instance of DsaParameterGenerationParameters used to configure this generator
+
+
+ Generates a set of DsaParameters
+ Can take a while...
+
+
+ generate suitable parameters for DSA, in line with
+ FIPS 186-3 A.1 Generation of the FFC Primes p and q.
+
+
+ Given the domain parameters this routine generates an EC key
+ pair in accordance with X9.62 section 5.2.1 pages 26, 27.
+
+
+ a ElGamal key pair generator.
+
+ This Generates keys consistent for use with ElGamal as described in
+ page 164 of "Handbook of Applied Cryptography".
+
+
+ * which Generates the p and g values from the given parameters,
+ * returning the ElGamalParameters object.
+ *
+ * Note: can take a while...
+ *
+
+
+ a GOST3410 key pair generator.
+ This generates GOST3410 keys in line with the method described
+ in GOST R 34.10-94.
+
+
+ generate suitable parameters for GOST3410.
+
+
+ initialise the key generator.
+
+ @param size size of the key
+ @param typeProcedure type procedure A,B = 1; A',B' - else
+ @param random random byte source.
+
+
+ Procedure C
+ procedure generates the a value from the given p,q,
+ returning the a value.
+
+
+ which generates the p , q and a values from the given parameters,
+ returning the Gost3410Parameters object.
+
+
+ KFD2 generator for derived keys and ivs as defined by IEEE P1363a/ISO 18033
+
+ This implementation is based on IEEE P1363/ISO 18033.
+
+
+ Construct a KDF1 byte generator.
+
+ @param digest the digest to be used as the source of derived keys.
+
+
+ KDF2 generator for derived keys and ivs as defined by IEEE P1363a/ISO 18033
+
+ This implementation is based on IEEE P1363/ISO 18033.
+
+
+ Construct a KDF2 bytes generator. Generates key material
+ according to IEEE P1363 or ISO 18033 depending on the initialisation.
+
+ @param digest the digest to be used as the source of derived keys.
+
+
+ Generator for MGF1 as defined in Pkcs 1v2
+
+
+ @param digest the digest to be used as the source of Generated bytes
+
+
+ return the underlying digest.
+
+
+ int to octet string.
+
+
+ fill len bytes of the output buffer with bytes Generated from
+ the derivation function.
+
+ @throws DataLengthException if the out buffer is too small.
+
+
+ Key generation parameters for NaccacheStern cipher. For details on this cipher, please see
+
+ http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf
+
+
+ Generates a permuted ArrayList from the original one. The original List
+ is not modified
+
+ @param arr
+ the ArrayList to be permuted
+ @param rand
+ the source of Randomness for permutation
+ @return a new IList with the permuted elements.
+
+
+ Finds the first 'count' primes starting with 3
+
+ @param count
+ the number of primes to find
+ @return a vector containing the found primes as Integer
+
+
+ Generator for PBE derived keys and ivs as usd by OpenSSL.
+
+ The scheme is a simple extension of PKCS 5 V2.0 Scheme 1 using MD5 with an
+ iteration count of 1.
+
+
+
+ Construct a OpenSSL Parameters generator.
+
+
+ Initialise - note the iteration count for this algorithm is fixed at 1.
+
+ @param password password to use.
+ @param salt salt to use.
+
+
+ the derived key function, the ith hash of the password and the salt.
+
+
+ Generate a key parameter derived from the password, salt, and iteration
+ count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+ @exception ArgumentException if the key length larger than the base hash size.
+
+
+ Generate a key with initialisation vector parameter derived from
+ the password, salt, and iteration count we are currently initialised
+ with.
+
+ @param keySize the size of the key we want (in bits)
+ @param ivSize the size of the iv we want (in bits)
+ @return a ParametersWithIV object.
+ @exception ArgumentException if keySize + ivSize is larger than the base hash size.
+
+
+ Generate a key parameter for use with a MAC derived from the password,
+ salt, and iteration count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+ @exception ArgumentException if the key length larger than the base hash size.
+
+
+ Generator for Pbe derived keys and ivs as defined by Pkcs 12 V1.0.
+
+ The document this implementation is based on can be found at
+
+ RSA's Pkcs12 Page
+
+
+
+ Construct a Pkcs 12 Parameters generator.
+
+ @param digest the digest to be used as the source of derived keys.
+ @exception ArgumentException if an unknown digest is passed in.
+
+
+ add a + b + 1, returning the result in a. The a value is treated
+ as a BigInteger of length (b.Length * 8) bits. The result is
+ modulo 2^b.Length in case of overflow.
+
+
+ generation of a derived key ala Pkcs12 V1.0.
+
+
+ Generate a key parameter derived from the password, salt, and iteration
+ count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+
+
+ Generate a key with initialisation vector parameter derived from
+ the password, salt, and iteration count we are currently initialised
+ with.
+
+ @param keySize the size of the key we want (in bits)
+ @param ivSize the size of the iv we want (in bits)
+ @return a ParametersWithIV object.
+
+
+ Generate a key parameter for use with a MAC derived from the password,
+ salt, and iteration count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+
+
+ Generator for Pbe derived keys and ivs as defined by Pkcs 5 V2.0 Scheme 1.
+ Note this generator is limited to the size of the hash produced by the
+ digest used to drive it.
+
+ The document this implementation is based on can be found at
+
+ RSA's Pkcs5 Page
+
+
+
+ Construct a Pkcs 5 Scheme 1 Parameters generator.
+
+ @param digest the digest to be used as the source of derived keys.
+
+
+ the derived key function, the ith hash of the mPassword and the mSalt.
+
+
+ Generate a key parameter derived from the mPassword, mSalt, and iteration
+ count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+ @exception ArgumentException if the key length larger than the base hash size.
+
+
+ Generate a key with initialisation vector parameter derived from
+ the mPassword, mSalt, and iteration count we are currently initialised
+ with.
+
+ @param keySize the size of the key we want (in bits)
+ @param ivSize the size of the iv we want (in bits)
+ @return a ParametersWithIV object.
+ @exception ArgumentException if keySize + ivSize is larger than the base hash size.
+
+
+ Generate a key parameter for use with a MAC derived from the mPassword,
+ mSalt, and iteration count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+ @exception ArgumentException if the key length larger than the base hash size.
+
+
+ Generator for Pbe derived keys and ivs as defined by Pkcs 5 V2.0 Scheme 2.
+ This generator uses a SHA-1 HMac as the calculation function.
+
+ The document this implementation is based on can be found at
+
+ RSA's Pkcs5 Page
+
+
+ construct a Pkcs5 Scheme 2 Parameters generator.
+
+
+ Generate a key parameter derived from the password, salt, and iteration
+ count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+
+
+ Generate a key with initialisation vector parameter derived from
+ the password, salt, and iteration count we are currently initialised
+ with.
+
+ @param keySize the size of the key we want (in bits)
+ @param ivSize the size of the iv we want (in bits)
+ @return a ParametersWithIV object.
+
+
+ Generate a key parameter for use with a MAC derived from the password,
+ salt, and iteration count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+
+
+
+ Generates keys for the Poly1305 MAC.
+
+
+ Poly1305 keys are 256 bit keys consisting of a 128 bit secret key used for the underlying block
+ cipher followed by a 128 bit {@code r} value used for the polynomial portion of the Mac.
+ The {@code r} value has a specific format with some bits required to be cleared, resulting in an
+ effective 106 bit key.
+ A separately generated 256 bit key can be modified to fit the Poly1305 key format by using the
+ {@link #clamp(byte[])} method to clear the required bits.
+
+
+
+
+
+ Initialises the key generator.
+
+
+ Poly1305 keys are always 256 bits, so the key length in the provided parameters is ignored.
+
+
+
+
+ Generates a 256 bit key in the format required for Poly1305 - e.g.
+ k[0] ... k[15], r[0] ... r[15]
with the required bits in r
cleared
+ as per .
+
+
+
+
+ Modifies an existing 32 byte key value to comply with the requirements of the Poly1305 key by
+ clearing required bits in the r
(second 16 bytes) portion of the key.
+ Specifically:
+
+ - r[3], r[7], r[11], r[15] have top four bits clear (i.e., are {0, 1, . . . , 15})
+ - r[4], r[8], r[12] have bottom two bits clear (i.e., are in {0, 4, 8, . . . , 252})
+
+
+ a 32 byte key value k[0] ... k[15], r[0] ... r[15]
+
+
+
+ Checks a 32 byte key for compliance with the Poly1305 key requirements, e.g.
+ k[0] ... k[15], r[0] ... r[15]
with the required bits in r
cleared
+ as per .
+
+ Key.
+ if the key is of the wrong length, or has invalid bits set
+ in the r
portion of the key.
+
+
+ Generate a random factor suitable for use with RSA blind signatures
+ as outlined in Chaum's blinding and unblinding as outlined in
+ "Handbook of Applied Cryptography", page 475.
+
+
+ Initialise the factor generator
+
+ @param param the necessary RSA key parameters.
+
+
+ Generate a suitable blind factor for the public key the generator was initialised with.
+
+ @return a random blind factor
+
+
+ an RSA key pair generator.
+
+
+ Choose a random prime value for use with RSA
+ the bit-length of the returned prime
+ the RSA public exponent
+ a prime p, with (p-1) relatively prime to e
+
+
+ CMAC - as specified at www.nuee.nagoya-u.ac.jp/labs/tiwata/omac/omac.html
+
+ CMAC is analogous to OMAC1 - see also en.wikipedia.org/wiki/CMAC
+
+ CMAC is a NIST recomendation - see
+ csrc.nist.gov/CryptoToolkit/modes/800-38_Series_Publications/SP800-38B.pdf
+
+ CMAC/OMAC1 is a blockcipher-based message authentication code designed and
+ analyzed by Tetsu Iwata and Kaoru Kurosawa.
+
+ CMAC/OMAC1 is a simple variant of the CBC MAC (Cipher Block Chaining Message
+ Authentication Code). OMAC stands for One-Key CBC MAC.
+
+ It supports 128- or 64-bits block ciphers, with any key size, and returns
+ a MAC with dimension less or equal to the block size of the underlying
+ cipher.
+
+
+
+ create a standard MAC based on a CBC block cipher (64 or 128 bit block).
+ This will produce an authentication code the length of the block size
+ of the cipher.
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+
+
+ create a standard MAC based on a block cipher with the size of the
+ MAC been given in bits.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8 and @lt;= 128.
+
+
+ Reset the mac generator.
+
+
+ standard CBC Block Cipher MAC - if no padding is specified the default of
+ pad of zeroes is used.
+
+
+ create a standard MAC based on a CBC block cipher. This will produce an
+ authentication code half the length of the block size of the cipher.
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+
+
+ create a standard MAC based on a CBC block cipher. This will produce an
+ authentication code half the length of the block size of the cipher.
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param padding the padding to be used to complete the last block.
+
+
+ create a standard MAC based on a block cipher with the size of the
+ MAC been given in bits. This class uses CBC mode as the basis for the
+ MAC generation.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8.
+
+
+ create a standard MAC based on a block cipher with the size of the
+ MAC been given in bits. This class uses CBC mode as the basis for the
+ MAC generation.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8.
+ @param padding the padding to be used to complete the last block.
+
+
+ Reset the mac generator.
+
+
+ implements a Cipher-FeedBack (CFB) mode on top of a simple cipher.
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used as the basis of the
+ feedback mode.
+ @param blockSize the block size in bits (note: a multiple of 8)
+
+
+ Initialise the cipher and, possibly, the initialisation vector (IV).
+ If an IV isn't passed as part of the parameter, the IV will be all zeros.
+ An IV which is too short is handled in FIPS compliant fashion.
+
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the algorithm name and mode.
+
+ @return the name of the underlying algorithm followed by "/CFB"
+ and the block size in bits.
+
+
+ return the block size we are operating at.
+
+ @return the block size we are operating at (in bytes).
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ reset the chaining vector back to the IV and reset the underlying
+ cipher.
+
+
+ create a standard MAC based on a CFB block cipher. This will produce an
+ authentication code half the length of the block size of the cipher, with
+ the CFB mode set to 8 bits.
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+
+
+ create a standard MAC based on a CFB block cipher. This will produce an
+ authentication code half the length of the block size of the cipher, with
+ the CFB mode set to 8 bits.
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param padding the padding to be used.
+
+
+ create a standard MAC based on a block cipher with the size of the
+ MAC been given in bits. This class uses CFB mode as the basis for the
+ MAC generation.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param cfbBitSize the size of an output block produced by the CFB mode.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8.
+
+
+ create a standard MAC based on a block cipher with the size of the
+ MAC been given in bits. This class uses CFB mode as the basis for the
+ MAC generation.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param cfbBitSize the size of an output block produced by the CFB mode.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8.
+ @param padding a padding to be used.
+
+
+ Reset the mac generator.
+
+
+
+ The GMAC specialisation of Galois/Counter mode (GCM) detailed in NIST Special Publication
+ 800-38D.
+
+
+ GMac is an invocation of the GCM mode where no data is encrypted (i.e. all input data to the Mac
+ is processed as additional authenticated data with the underlying GCM block cipher).
+
+
+
+
+ Creates a GMAC based on the operation of a block cipher in GCM mode.
+
+
+ This will produce an authentication code the length of the block size of the cipher.
+
+ the cipher to be used in GCM mode to generate the MAC.
+
+
+
+ Creates a GMAC based on the operation of a 128 bit block cipher in GCM mode.
+
+
+ This will produce an authentication code the length of the block size of the cipher.
+
+ the cipher to be used in GCM mode to generate the MAC.
+ the mac size to generate, in bits. Must be a multiple of 8, between 32 and 128 (inclusive).
+ Sizes less than 96 are not recommended, but are supported for specialized applications.
+
+
+
+ Initialises the GMAC - requires a
+ providing a and a nonce.
+
+
+
+ implementation of GOST 28147-89 MAC
+
+
+ HMAC implementation based on RFC2104
+
+ H(K XOR opad, H(K XOR ipad, text))
+
+
+ Reset the mac generator.
+
+
+ DES based CBC Block Cipher MAC according to ISO9797, algorithm 3 (ANSI X9.19 Retail MAC)
+
+ This could as well be derived from CBCBlockCipherMac, but then the property mac in the base
+ class must be changed to protected
+
+
+ create a Retail-MAC based on a CBC block cipher. This will produce an
+ authentication code of the length of the block size of the cipher.
+
+ @param cipher the cipher to be used as the basis of the MAC generation. This must
+ be DESEngine.
+
+
+ create a Retail-MAC based on a CBC block cipher. This will produce an
+ authentication code of the length of the block size of the cipher.
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param padding the padding to be used to complete the last block.
+
+
+ create a Retail-MAC based on a block cipher with the size of the
+ MAC been given in bits. This class uses single DES CBC mode as the basis for the
+ MAC generation.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8.
+
+
+ create a standard MAC based on a block cipher with the size of the
+ MAC been given in bits. This class uses single DES CBC mode as the basis for the
+ MAC generation. The final block is decrypted and then encrypted using the
+ middle and right part of the key.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8.
+ @param padding the padding to be used to complete the last block.
+
+
+ Reset the mac generator.
+
+
+
+ Poly1305 message authentication code, designed by D. J. Bernstein.
+
+
+ Poly1305 computes a 128-bit (16 bytes) authenticator, using a 128 bit nonce and a 256 bit key
+ consisting of a 128 bit key applied to an underlying cipher, and a 128 bit key (with 106
+ effective key bits) used in the authenticator.
+
+ The polynomial calculation in this implementation is adapted from the public domain poly1305-donna-unrolled C implementation
+ by Andrew M (@floodyberry).
+
+
+
+
+ Polynomial key
+
+
+ Polynomial key
+
+
+ Polynomial key
+
+
+ Polynomial key
+
+
+ Polynomial key
+
+
+ Precomputed 5 * r[1..4]
+
+
+ Precomputed 5 * r[1..4]
+
+
+ Precomputed 5 * r[1..4]
+
+
+ Precomputed 5 * r[1..4]
+
+
+ Encrypted nonce
+
+
+ Encrypted nonce
+
+
+ Encrypted nonce
+
+
+ Encrypted nonce
+
+
+ Current block of buffered input
+
+
+ Current offset in input buffer
+
+
+ Polynomial accumulator
+
+
+ Polynomial accumulator
+
+
+ Polynomial accumulator
+
+
+ Polynomial accumulator
+
+
+ Polynomial accumulator
+
+
+ Constructs a Poly1305 MAC, where the key passed to init() will be used directly.
+
+
+ Constructs a Poly1305 MAC, using a 128 bit block cipher.
+
+
+
+ Initialises the Poly1305 MAC.
+
+ a {@link ParametersWithIV} containing a 128 bit nonce and a {@link KeyParameter} with
+ a 256 bit key complying to the {@link Poly1305KeyGenerator Poly1305 key format}.
+
+
+
+ Implementation of SipHash as specified in "SipHash: a fast short-input PRF", by Jean-Philippe
+ Aumasson and Daniel J. Bernstein (https://131002.net/siphash/siphash.pdf).
+
+
+ "SipHash is a family of PRFs SipHash-c-d where the integer parameters c and d are the number of
+ compression rounds and the number of finalization rounds. A compression round is identical to a
+ finalization round and this round function is called SipRound. Given a 128-bit key k and a
+ (possibly empty) byte string m, SipHash-c-d returns a 64-bit value..."
+
+
+
+ SipHash-2-4
+
+
+ SipHash-c-d
+ the number of compression rounds
+ the number of finalization rounds
+
+
+
+ Implementation of the Skein parameterised MAC function in 256, 512 and 1024 bit block sizes,
+ based on the Threefish tweakable block cipher.
+
+
+ This is the 1.3 version of Skein defined in the Skein hash function submission to the NIST SHA-3
+ competition in October 2010.
+
+ Skein was designed by Niels Ferguson - Stefan Lucks - Bruce Schneier - Doug Whiting - Mihir
+ Bellare - Tadayoshi Kohno - Jon Callas - Jesse Walker.
+
+
+
+
+
+
+ 256 bit block size - Skein-256
+
+
+
+
+ 512 bit block size - Skein-512
+
+
+
+
+ 1024 bit block size - Skein-1024
+
+
+
+
+ Constructs a Skein MAC with an internal state size and output size.
+
+ the internal state size in bits - one of or
+ .
+ the output/MAC size to produce in bits, which must be an integral number of
+ bytes.
+
+
+
+ Optionally initialises the Skein digest with the provided parameters.
+
+ See for details on the parameterisation of the Skein hash function.
+ the parameters to apply to this engine, or null
to use no parameters.
+
+
+ implements Cipher-Block-Chaining (CBC) mode on top of a simple cipher.
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used as the basis of chaining.
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ Initialise the cipher and, possibly, the initialisation vector (IV).
+ If an IV isn't passed as part of the parameter, the IV will be all zeros.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the algorithm name and mode.
+
+ @return the name of the underlying algorithm followed by "/CBC".
+
+
+ return the block size of the underlying cipher.
+
+ @return the block size of the underlying cipher.
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ reset the chaining vector back to the IV and reset the underlying
+ cipher.
+
+
+ Do the appropriate chaining step for CBC mode encryption.
+
+ @param in the array containing the data to be encrypted.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the encrypted data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ Do the appropriate chaining step for CBC mode decryption.
+
+ @param in the array containing the data to be decrypted.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the decrypted data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ Implements the Counter with Cipher Block Chaining mode (CCM) detailed in
+ NIST Special Publication 800-38C.
+
+ Note: this mode is a packet mode - it needs all the data up front.
+
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used.
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ Returns a byte array containing the mac calculated as part of the
+ last encrypt or decrypt operation.
+
+ @return the last mac calculated.
+
+
+ Process a packet of data for either CCM decryption or encryption.
+
+ @param in data for processing.
+ @param inOff offset at which data starts in the input array.
+ @param inLen length of the data in the input array.
+ @return a byte array containing the processed input..
+ @throws IllegalStateException if the cipher is not appropriately set up.
+ @throws InvalidCipherTextException if the input data is truncated or the mac check fails.
+
+
+ Process a packet of data for either CCM decryption or encryption.
+
+ @param in data for processing.
+ @param inOff offset at which data starts in the input array.
+ @param inLen length of the data in the input array.
+ @param output output array.
+ @param outOff offset into output array to start putting processed bytes.
+ @return the number of bytes added to output.
+ @throws IllegalStateException if the cipher is not appropriately set up.
+ @throws InvalidCipherTextException if the input data is truncated or the mac check fails.
+ @throws DataLengthException if output buffer too short.
+
+
+ implements a Cipher-FeedBack (CFB) mode on top of a simple cipher.
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used as the basis of the
+ feedback mode.
+ @param blockSize the block size in bits (note: a multiple of 8)
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ Initialise the cipher and, possibly, the initialisation vector (IV).
+ If an IV isn't passed as part of the parameter, the IV will be all zeros.
+ An IV which is too short is handled in FIPS compliant fashion.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the algorithm name and mode.
+
+ @return the name of the underlying algorithm followed by "/CFB"
+ and the block size in bits.
+
+
+ return the block size we are operating at.
+
+ @return the block size we are operating at (in bytes).
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ Do the appropriate processing for CFB mode encryption.
+
+ @param in the array containing the data to be encrypted.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the encrypted data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ Do the appropriate processing for CFB mode decryption.
+
+ @param in the array containing the data to be decrypted.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the encrypted data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ reset the chaining vector back to the IV and reset the underlying
+ cipher.
+
+
+ A Cipher Text Stealing (CTS) mode cipher. CTS allows block ciphers to
+ be used to produce cipher text which is the same outLength as the plain text.
+
+
+ Create a buffered block cipher that uses Cipher Text Stealing
+
+ @param cipher the underlying block cipher this buffering object wraps.
+
+
+ return the size of the output buffer required for an update of 'length' bytes.
+
+ @param length the outLength of the input.
+ @return the space required to accommodate a call to update
+ with length bytes of input.
+
+
+ return the size of the output buffer required for an update plus a
+ doFinal with an input of length bytes.
+
+ @param length the outLength of the input.
+ @return the space required to accommodate a call to update and doFinal
+ with length bytes of input.
+
+
+ process a single byte, producing an output block if necessary.
+
+ @param in the input byte.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ process an array of bytes, producing output if necessary.
+
+ @param in the input byte array.
+ @param inOff the offset at which the input data starts.
+ @param length the number of bytes to be copied out of the input array.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ Process the last block in the buffer.
+
+ @param out the array the block currently being held is copied into.
+ @param outOff the offset at which the copying starts.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there is insufficient space in out for
+ the output.
+ @exception InvalidOperationException if the underlying cipher is not
+ initialised.
+ @exception InvalidCipherTextException if cipher text decrypts wrongly (in
+ case the exception will never Get thrown).
+
+
+ A Two-Pass Authenticated-Encryption Scheme Optimized for Simplicity and
+ Efficiency - by M. Bellare, P. Rogaway, D. Wagner.
+
+ http://www.cs.ucdavis.edu/~rogaway/papers/eax.pdf
+
+ EAX is an AEAD scheme based on CTR and OMAC1/CMAC, that uses a single block
+ cipher to encrypt and authenticate data. It's on-line (the length of a
+ message isn't needed to begin processing it), has good performances, it's
+ simple and provably secure (provided the underlying block cipher is secure).
+
+ Of course, this implementations is NOT thread-safe.
+
+
+ Constructor that accepts an instance of a block cipher engine.
+
+ @param cipher the engine to use
+
+
+
+ Implements the Galois/Counter mode (GCM) detailed in
+ NIST Special Publication 800-38D.
+
+
+
+
+ MAC sizes from 32 bits to 128 bits (must be a multiple of 8) are supported. The default is 128 bits.
+ Sizes less than 96 are not recommended, but are supported for specialized applications.
+
+
+
+ implements the GOST 28147 OFB counter mode (GCTR).
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used as the basis of the
+ counter mode (must have a 64 bit block size).
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ Initialise the cipher and, possibly, the initialisation vector (IV).
+ If an IV isn't passed as part of the parameter, the IV will be all zeros.
+ An IV which is too short is handled in FIPS compliant fashion.
+
+ @param encrypting if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param parameters the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is inappropriate.
+
+
+ return the algorithm name and mode.
+
+ @return the name of the underlying algorithm followed by "/GCTR"
+ and the block size in bits
+
+
+ return the block size we are operating at (in bytes).
+
+ @return the block size we are operating at (in bytes).
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ reset the feedback vector back to the IV and reset the underlying
+ cipher.
+
+
+
+ A block cipher mode that includes authenticated encryption with a streaming mode
+ and optional associated data.
+
+
+
+ The name of the algorithm this cipher implements.
+
+
+ The block cipher underlying this algorithm.
+
+
+ Initialise the cipher.
+ Parameter can either be an AeadParameters or a ParametersWithIV object.
+ Initialise for encryption if true, for decryption if false.
+ The key or other data required by the cipher.
+
+
+ The block size for this cipher, in bytes.
+
+
+ Add a single byte to the associated data check.
+ If the implementation supports it, this will be an online operation and will not retain the associated data.
+ The byte to be processed.
+
+
+ Add a sequence of bytes to the associated data check.
+ If the implementation supports it, this will be an online operation and will not retain the associated data.
+ The input byte array.
+ The offset into the input array where the data to be processed starts.
+ The number of bytes to be processed.
+
+
+ Encrypt/decrypt a single byte.
+
+ @param input the byte to be processed.
+ @param outBytes the output buffer the processed byte goes into.
+ @param outOff the offset into the output byte array the processed data starts at.
+ @return the number of bytes written to out.
+ @exception DataLengthException if the output buffer is too small.
+
+
+ Process a block of bytes from in putting the result into out.
+
+ @param inBytes the input byte array.
+ @param inOff the offset into the in array where the data to be processed starts.
+ @param len the number of bytes to be processed.
+ @param outBytes the output buffer the processed bytes go into.
+ @param outOff the offset into the output byte array the processed data starts at.
+ @return the number of bytes written to out.
+ @exception DataLengthException if the output buffer is too small.
+
+
+ Finish the operation either appending or verifying the MAC at the end of the data.
+
+ @param outBytes space for any resulting output data.
+ @param outOff offset into out to start copying the data at.
+ @return number of bytes written into out.
+ @throws InvalidOperationException if the cipher is in an inappropriate state.
+ @throws InvalidCipherTextException if the MAC fails to match.
+
+
+ Return the value of the MAC associated with the last stream processed.
+
+ @return MAC for plaintext data.
+
+
+ Return the size of the output buffer required for a ProcessBytes
+ an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to ProcessBytes
+ with len bytes of input.
+
+
+ Return the size of the output buffer required for a ProcessBytes plus a
+ DoFinal with an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to ProcessBytes and DoFinal
+ with len bytes of input.
+
+
+
+ Reset the cipher to the same state as it was after the last init (if there was one).
+
+
+
+ An implementation of RFC 7253 on The OCB
+ Authenticated-Encryption Algorithm, licensed per:
+
+ License for
+ Open-Source Software Implementations of OCB (Jan 9, 2013) - 'License 1'
+ Under this license, you are authorized to make, use, and distribute open-source software
+ implementations of OCB. This license terminates for you if you sue someone over their open-source
+ software implementation of OCB claiming that you have a patent covering their implementation.
+
+ This is a non-binding summary of a legal document (the link above). The parameters of the license
+ are specified in the license document and that document is controlling.
+
+
+ implements a Output-FeedBack (OFB) mode on top of a simple cipher.
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used as the basis of the
+ feedback mode.
+ @param blockSize the block size in bits (note: a multiple of 8)
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ Initialise the cipher and, possibly, the initialisation vector (IV).
+ If an IV isn't passed as part of the parameter, the IV will be all zeros.
+ An IV which is too short is handled in FIPS compliant fashion.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the algorithm name and mode.
+
+ @return the name of the underlying algorithm followed by "/OFB"
+ and the block size in bits
+
+
+ return the block size we are operating at (in bytes).
+
+ @return the block size we are operating at (in bytes).
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ reset the feedback vector back to the IV and reset the underlying
+ cipher.
+
+
+ * Implements OpenPGP's rather strange version of Cipher-FeedBack (CFB) mode
+ * on top of a simple cipher. This class assumes the IV has been prepended
+ * to the data stream already, and just accomodates the reset after
+ * (blockSize + 2) bytes have been read.
+ *
+ * For further info see RFC 2440.
+ *
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used as the basis of the
+ feedback mode.
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ return the algorithm name and mode.
+
+ @return the name of the underlying algorithm followed by "/PGPCFB"
+ and the block size in bits.
+
+
+ return the block size we are operating at.
+
+ @return the block size we are operating at (in bytes).
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ reset the chaining vector back to the IV and reset the underlying
+ cipher.
+
+
+ Initialise the cipher and, possibly, the initialisation vector (IV).
+ If an IV isn't passed as part of the parameter, the IV will be all zeros.
+ An IV which is too short is handled in FIPS compliant fashion.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param parameters the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Encrypt one byte of data according to CFB mode.
+ @param data the byte to encrypt
+ @param blockOff offset in the current block
+ @returns the encrypted byte
+
+
+ Do the appropriate processing for CFB IV mode encryption.
+
+ @param in the array containing the data to be encrypted.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the encrypted data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ Do the appropriate processing for CFB IV mode decryption.
+
+ @param in the array containing the data to be decrypted.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the encrypted data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ Implements the Segmented Integer Counter (SIC) mode on top of a simple
+ block cipher.
+
+
+ Basic constructor.
+
+ @param c the block cipher to be used.
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ Return the digest algorithm using one of the standard JCA string
+ representations rather than the algorithm identifier (if possible).
+
+
+
+ Calculator factory class for signature generation in ASN.1 based profiles that use an AlgorithmIdentifier to preserve
+ signature algorithm details.
+
+
+
+
+ Base constructor.
+
+ The name of the signature algorithm to use.
+ The private key to be used in the signing operation.
+
+
+
+ Constructor which also specifies a source of randomness to be used if one is required.
+
+ The name of the signature algorithm to use.
+ The private key to be used in the signing operation.
+ The source of randomness to be used in signature calculation.
+
+
+
+ Allows enumeration of the signature names supported by the verifier provider.
+
+
+
+
+ Verifier class for signature verification in ASN.1 based profiles that use an AlgorithmIdentifier to preserve
+ signature algorithm details.
+
+
+
+
+ Base constructor.
+
+ The name of the signature algorithm to use.
+ The public key to be used in the verification operation.
+
+
+
+ Provider class which supports dynamic creation of signature verifiers.
+
+
+
+
+ Base constructor - specify the public key to be used in verification.
+
+ The public key to be used in creating verifiers provided by this object.
+
+
+
+ Allows enumeration of the signature names supported by the verifier provider.
+
+
+
+ Block cipher padders are expected to conform to this interface
+
+
+ Initialise the padder.
+
+ @param param parameters, if any required.
+
+
+ Return the name of the algorithm the cipher implements.
+
+ @return the name of the algorithm the cipher implements.
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+
+ return the number of pad bytes present in the block.
+ @exception InvalidCipherTextException if the padding is badly formed
+ or invalid.
+
+
+ A padder that adds ISO10126-2 padding to a block.
+
+
+ Initialise the padder.
+
+ @param random a SecureRandom if available.
+
+
+ Return the name of the algorithm the cipher implements.
+
+ @return the name of the algorithm the cipher implements.
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+
+ return the number of pad bytes present in the block.
+
+
+ A padder that adds the padding according to the scheme referenced in
+ ISO 7814-4 - scheme 2 from ISO 9797-1. The first byte is 0x80, rest is 0x00
+
+
+ Initialise the padder.
+
+ @param random - a SecureRandom if available.
+
+
+ Return the name of the algorithm the padder implements.
+
+ @return the name of the algorithm the padder implements.
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+
+ return the number of pad bytes present in the block.
+
+
+ A wrapper class that allows block ciphers to be used to process data in
+ a piecemeal fashion with padding. The PaddedBufferedBlockCipher
+ outputs a block only when the buffer is full and more data is being added,
+ or on a doFinal (unless the current block in the buffer is a pad block).
+ The default padding mechanism used is the one outlined in Pkcs5/Pkcs7.
+
+
+ Create a buffered block cipher with the desired padding.
+
+ @param cipher the underlying block cipher this buffering object wraps.
+ @param padding the padding type.
+
+
+ Create a buffered block cipher Pkcs7 padding
+
+ @param cipher the underlying block cipher this buffering object wraps.
+
+
+ initialise the cipher.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the minimum size of the output buffer required for an update
+ plus a doFinal with an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to update and doFinal
+ with len bytes of input.
+
+
+ return the size of the output buffer required for an update
+ an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to update
+ with len bytes of input.
+
+
+ process a single byte, producing an output block if necessary.
+
+ @param in the input byte.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ process an array of bytes, producing output if necessary.
+
+ @param in the input byte array.
+ @param inOff the offset at which the input data starts.
+ @param len the number of bytes to be copied out of the input array.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ Process the last block in the buffer. If the buffer is currently
+ full and padding needs to be added a call to doFinal will produce
+ 2 * GetBlockSize() bytes.
+
+ @param out the array the block currently being held is copied into.
+ @param outOff the offset at which the copying starts.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there is insufficient space in out for
+ the output or we are decrypting and the input is not block size aligned.
+ @exception InvalidOperationException if the underlying cipher is not
+ initialised.
+ @exception InvalidCipherTextException if padding is expected and not found.
+
+
+ A padder that adds Pkcs7/Pkcs5 padding to a block.
+
+
+ Initialise the padder.
+
+ @param random - a SecureRandom if available.
+
+
+ Return the name of the algorithm the cipher implements.
+
+ @return the name of the algorithm the cipher implements.
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+
+ return the number of pad bytes present in the block.
+
+
+ A padder that adds Trailing-Bit-Compliment padding to a block.
+
+ This padding pads the block out compliment of the last bit
+ of the plain text.
+
+
+
+
+ Return the name of the algorithm the cipher implements.
+ the name of the algorithm the cipher implements.
+
+
+
+ Initialise the padder.
+ - a SecureRandom if available.
+
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+ Note: this assumes that the last block of plain text is always
+ passed to it inside in. i.e. if inOff is zero, indicating the
+ entire block is to be overwritten with padding the value of in
+ should be the same as the last block of plain text.
+
+
+
+
+ return the number of pad bytes present in the block.
+
+
+ A padder that adds X9.23 padding to a block - if a SecureRandom is
+ passed in random padding is assumed, otherwise padding with zeros is used.
+
+
+ Initialise the padder.
+
+ @param random a SecureRandom if one is available.
+
+
+ Return the name of the algorithm the cipher implements.
+
+ @return the name of the algorithm the cipher implements.
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+
+ return the number of pad bytes present in the block.
+
+
+ A padder that adds Null byte padding to a block.
+
+
+ Return the name of the algorithm the cipher implements.
+
+
+ the name of the algorithm the cipher implements.
+
+
+
+ Initialise the padder.
+
+
+ - a SecureRandom if available.
+
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+
+
+ return the number of pad bytes present in the block.
+
+
+ Base constructor.
+
+ @param key key to be used by underlying cipher
+ @param macSize macSize in bits
+ @param nonce nonce to be used
+
+
+ Base constructor.
+
+ @param key key to be used by underlying cipher
+ @param macSize macSize in bits
+ @param nonce nonce to be used
+ @param associatedText associated text, if any
+
+
+ Base constructor.
+
+ @param key key to be used by underlying cipher
+ @param macSize macSize in bits
+ @param nonce nonce to be used
+ @param associatedText associated text, if any
+
+
+ The minimum bitlength of the private value.
+
+
+ The bitlength of the private value.
+
+
+ Construct without a usage index, this will do a random construction of G.
+
+ @param L desired length of prime P in bits (the effective key size).
+ @param N desired length of prime Q in bits.
+ @param certainty certainty level for prime number generation.
+ @param random the source of randomness to use.
+
+
+ Construct for a specific usage index - this has the effect of using verifiable canonical generation of G.
+
+ @param L desired length of prime P in bits (the effective key size).
+ @param N desired length of prime Q in bits.
+ @param certainty certainty level for prime number generation.
+ @param random the source of randomness to use.
+ @param usageIndex a valid usage index.
+
+
+ return true if the passed in key is a DES-EDE weak key.
+
+ @param key bytes making up the key
+ @param offset offset into the byte array the key starts at
+ @param length number of bytes making up the key
+
+
+ return true if the passed in key is a DES-EDE weak key.
+
+ @param key bytes making up the key
+ @param offset offset into the byte array the key starts at
+
+
+ return true if the passed in key is a real 2/3 part DES-EDE key.
+
+ @param key bytes making up the key
+ @param offset offset into the byte array the key starts at
+
+
+ return true if the passed in key is a real 2 part DES-EDE key.
+
+ @param key bytes making up the key
+ @param offset offset into the byte array the key starts at
+
+
+ return true if the passed in key is a real 3 part DES-EDE key.
+
+ @param key bytes making up the key
+ @param offset offset into the byte array the key starts at
+
+
+ DES has 16 weak keys. This method will check
+ if the given DES key material is weak or semi-weak.
+ Key material that is too short is regarded as weak.
+
+ See "Applied
+ Cryptography" by Bruce Schneier for more information.
+
+ @return true if the given DES key material is weak or semi-weak,
+ false otherwise.
+
+
+ DES Keys use the LSB as the odd parity bit. This can
+ be used to check for corrupt keys.
+
+ @param bytes the byte array to set the parity on.
+
+
+ return the generator - g
+
+
+ return private value limit - l
+
+
+ parameters for Key derivation functions for ISO-18033
+
+
+ parameters for using an integrated cipher in stream mode.
+
+
+ @param derivation the derivation parameter for the KDF function.
+ @param encoding the encoding parameter for the KDF function.
+ @param macKeySize the size of the MAC key (in bits).
+
+
+ @param derivation the derivation parameter for the KDF function.
+ @param encoding the encoding parameter for the KDF function.
+ @param macKeySize the size of the MAC key (in bits).
+ @param cipherKeySize the size of the associated Cipher key (in bits).
+
+
+ parameters for Key derivation functions for IEEE P1363a
+
+
+ Parameters for mask derivation functions.
+
+
+ Parameters for NaccacheStern public private key generation. For details on
+ this cipher, please see
+
+ http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf
+
+
+ Parameters for generating a NaccacheStern KeyPair.
+
+ @param random
+ The source of randomness
+ @param strength
+ The desired strength of the Key in Bits
+ @param certainty
+ the probability that the generated primes are not really prime
+ as integer: 2^(-certainty) is then the probability
+ @param countSmallPrimes
+ How many small key factors are desired
+
+
+ * Parameters for a NaccacheStern KeyPair.
+ *
+ * @param random
+ * The source of randomness
+ * @param strength
+ * The desired strength of the Key in Bits
+ * @param certainty
+ * the probability that the generated primes are not really prime
+ * as integer: 2^(-certainty) is then the probability
+ * @param cntSmallPrimes
+ * How many small key factors are desired
+ * @param debug
+ * Ignored
+
+
+ @return Returns the certainty.
+
+
+ @return Returns the countSmallPrimes.
+
+
+ Public key parameters for NaccacheStern cipher. For details on this cipher,
+ please see
+
+ http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf
+
+
+ @param privateKey
+
+
+ @return Returns the g.
+
+
+ @return Returns the lowerSigmaBound.
+
+
+ @return Returns the n.
+
+
+ Private key parameters for NaccacheStern cipher. For details on this cipher,
+ please see
+
+ http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf
+
+
+ Constructs a NaccacheSternPrivateKey
+
+ @param g
+ the public enryption parameter g
+ @param n
+ the public modulus n = p*q
+ @param lowerSigmaBound
+ the public lower sigma bound up to which data can be encrypted
+ @param smallPrimes
+ the small primes, of which sigma is constructed in the right
+ order
+ @param phi_n
+ the private modulus phi(n) = (p-1)(q-1)
+
+
+ Cipher parameters with a fixed salt value associated with them.
+
+
+
+ Parameters for the Skein hash function - a series of byte[] strings identified by integer tags.
+
+
+ Parameterised Skein can be used for:
+
+ - MAC generation, by providing a key.
+ - Randomised hashing, by providing a nonce.
+ - A hash function for digital signatures, associating a
+ public key with the message digest.
+ - A key derivation function, by providing a
+ key identifier.
+ - Personalised hashing, by providing a
+ recommended format or
+ arbitrary personalisation string.
+
+
+
+
+
+
+
+
+ The parameter type for a secret key, supporting MAC or KDF functions: 0
+
+
+
+
+ The parameter type for the Skein configuration block: 4
+
+
+
+
+ The parameter type for a personalisation string: 8
+
+
+
+
+ The parameter type for a public key: 12
+
+
+
+
+ The parameter type for a key identifier string: 16
+
+
+
+
+ The parameter type for a nonce: 20
+
+
+
+
+ The parameter type for the message: 48
+
+
+
+
+ The parameter type for the output transformation: 63
+
+
+
+
+ Obtains a map of type (int) to value (byte[]) for the parameters tracked in this object.
+
+
+
+
+ Obtains the value of the key parameter, or null
if not
+ set.
+
+ The key.
+
+
+
+ Obtains the value of the personalisation parameter, or
+ null
if not set.
+
+
+
+
+ Obtains the value of the public key parameter, or
+ null
if not set.
+
+
+
+
+ Obtains the value of the key identifier parameter, or
+ null
if not set.
+
+
+
+
+ Obtains the value of the nonce parameter, or null
if
+ not set.
+
+
+
+
+ A builder for .
+
+
+
+
+ Sets a parameters to apply to the Skein hash function.
+
+
+ Parameter types must be in the range 0,5..62, and cannot use the value 48
+ (reserved for message body).
+
+ Parameters with type < 48 are processed before
+ the message content, parameters with type > 48
+ are processed after the message and prior to output.
+
+ the type of the parameter, in the range 5..62.
+ the byte sequence of the parameter.
+
+
+
+ Sets the parameter.
+
+
+
+
+ Sets the parameter.
+
+
+
+
+ Implements the recommended personalisation format for Skein defined in Section 4.11 of
+ the Skein 1.3 specification.
+
+
+ The format is YYYYMMDD email@address distinguisher
, encoded to a byte
+ sequence using UTF-8 encoding.
+
+ the date the personalised application of the Skein was defined.
+ the email address of the creation of the personalised application.
+ an arbitrary personalisation string distinguishing the application.
+
+
+
+ Sets the parameter.
+
+
+
+
+ Sets the parameter.
+
+
+
+
+ Sets the parameter.
+
+
+
+
+ Constructs a new instance with the parameters provided to this
+ builder.
+
+
+
+
+ Parameters for tweakable block ciphers.
+
+
+
+
+ Gets the key.
+
+ the key to use, or null
to use the current key.
+
+
+
+ Gets the tweak value.
+
+ The tweak to use, or null
to use the current tweak.
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ Generate a signature for the message we've been loaded with using
+ the key we were initialised with.
+
+
+ true if the internal state represents the signature described in the passed in array.
+
+
+ Reset the internal state
+
+
+ The Digital Signature Algorithm - as described in "Handbook of Applied
+ Cryptography", pages 452 - 453.
+
+
+ Default configuration, random K values.
+
+
+ Configuration with an alternate, possibly deterministic calculator of K.
+
+ @param kCalculator a K value calculator.
+
+
+ Generate a signature for the given message using the key we were
+ initialised with. For conventional DSA the message should be a SHA-1
+ hash of the message of interest.
+
+ @param message the message that will be verified later.
+
+
+ return true if the value r and s represent a DSA signature for
+ the passed in message for standard DSA the message should be a
+ SHA-1 hash of the real message to be verified.
+
+
+ EC-DSA as described in X9.62
+
+
+ Default configuration, random K values.
+
+
+ Configuration with an alternate, possibly deterministic calculator of K.
+
+ @param kCalculator a K value calculator.
+
+
+ Generate a signature for the given message using the key we were
+ initialised with. For conventional DSA the message should be a SHA-1
+ hash of the message of interest.
+
+ @param message the message that will be verified later.
+
+
+ return true if the value r and s represent a DSA signature for
+ the passed in message (for standard DSA the message should be
+ a SHA-1 hash of the real message to be verified).
+
+
+ GOST R 34.10-2001 Signature Algorithm
+
+
+ generate a signature for the given message using the key we were
+ initialised with. For conventional GOST3410 the message should be a GOST3411
+ hash of the message of interest.
+
+ @param message the message that will be verified later.
+
+
+ return true if the value r and s represent a GOST3410 signature for
+ the passed in message (for standard GOST3410 the message should be
+ a GOST3411 hash of the real message to be verified).
+
+
+ EC-NR as described in IEEE 1363-2000
+
+
+ generate a signature for the given message using the key we were
+ initialised with. Generally, the order of the curve should be at
+ least as long as the hash of the message of interest, and with
+ ECNR it *must* be at least as long.
+
+ @param digest the digest to be signed.
+ @exception DataLengthException if the digest is longer than the key allows
+
+
+ return true if the value r and s represent a signature for the
+ message passed in. Generally, the order of the curve should be at
+ least as long as the hash of the message of interest, and with
+ ECNR, it *must* be at least as long. But just in case the signer
+ applied mod(n) to the longer digest, this implementation will
+ apply mod(n) during verification.
+
+ @param digest the digest to be verified.
+ @param r the r value of the signature.
+ @param s the s value of the signature.
+ @exception DataLengthException if the digest is longer than the key allows
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ Generate a signature for the message we've been loaded with using
+ the key we were initialised with.
+
+
+ true if the internal state represents the signature described in the passed in array.
+
+
+ Reset the internal state
+
+
+ Gost R 34.10-94 Signature Algorithm
+
+
+ generate a signature for the given message using the key we were
+ initialised with. For conventional Gost3410 the message should be a Gost3411
+ hash of the message of interest.
+
+ @param message the message that will be verified later.
+
+
+ return true if the value r and s represent a Gost3410 signature for
+ the passed in message for standard Gost3410 the message should be a
+ Gost3411 hash of the real message to be verified.
+
+
+ initialise the signer for signing or verification.
+
+ @param forSigning
+ true if for signing, false otherwise
+ @param parameters
+ necessary parameters.
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ Generate a signature for the message we've been loaded with using the key
+ we were initialised with.
+
+
+ return true if the internal state represents the signature described in
+ the passed in array.
+
+
+ A deterministic K calculator based on the algorithm in section 3.2 of RFC 6979.
+
+
+ Base constructor.
+
+ @param digest digest to build the HMAC on.
+
+
+ Interface define calculators of K values for DSA/ECDSA.
+
+
+ Return true if this calculator is deterministic, false otherwise.
+
+ @return true if deterministic, otherwise false.
+
+
+ Non-deterministic initialiser.
+
+ @param n the order of the DSA group.
+ @param random a source of randomness.
+
+
+ Deterministic initialiser.
+
+ @param n the order of the DSA group.
+ @param d the DSA private value.
+ @param message the message being signed.
+
+
+ Return the next valid value of K.
+
+ @return a K value.
+
+
+ ISO9796-2 - mechanism using a hash function with recovery (scheme 2 and 3).
+
+ Note: the usual length for the salt is the length of the hash
+ function used in bytes.
+
+
+
+
+ Return a reference to the recoveredMessage message.
+
+ The full/partial recoveredMessage message.
+
+
+
+
+ Generate a signer with either implicit or explicit trailers for ISO9796-2, scheme 2 or 3.
+
+ base cipher to use for signature creation/verification
+ digest to use.
+ length of salt in bytes.
+ whether or not the trailer is implicit or gives the hash.
+
+
+ Constructor for a signer with an explicit digest trailer.
+
+
+ cipher to use.
+
+ digest to sign with.
+
+ length of salt in bytes.
+
+
+
+ Initialise the signer.
+ true if for signing, false if for verification.
+ parameters for signature generation/verification. If the
+ parameters are for generation they should be a ParametersWithRandom,
+ a ParametersWithSalt, or just an RsaKeyParameters object. If RsaKeyParameters
+ are passed in a SecureRandom will be created.
+
+ if wrong parameter type or a fixed
+ salt is passed in which is the wrong length.
+
+
+
+ compare two byte arrays - constant time.
+
+
+ clear possible sensitive data
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ reset the internal state
+
+
+ Generate a signature for the loaded message using the key we were
+ initialised with.
+
+
+
+ return true if the signature represents a ISO9796-2 signature
+ for the passed in message.
+
+
+
+
+ Return true if the full message was recoveredMessage.
+
+ true on full message recovery, false otherwise, or if not sure.
+
+
+
+ int to octet string.
+ int to octet string.
+
+
+ long to octet string.
+
+
+ mask generator function, as described in Pkcs1v2.
+
+
+ ISO9796-2 - mechanism using a hash function with recovery (scheme 1)
+
+
+
+ Return a reference to the recoveredMessage message.
+
+ The full/partial recoveredMessage message.
+
+
+
+
+ Generate a signer with either implicit or explicit trailers for ISO9796-2.
+
+ base cipher to use for signature creation/verification
+ digest to use.
+ whether or not the trailer is implicit or gives the hash.
+
+
+ Constructor for a signer with an explicit digest trailer.
+
+
+ cipher to use.
+
+ digest to sign with.
+
+
+
+ compare two byte arrays - constant time.
+
+
+ clear possible sensitive data
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ reset the internal state
+
+
+ Generate a signature for the loaded message using the key we were
+ initialised with.
+
+
+
+ return true if the signature represents a ISO9796-2 signature
+ for the passed in message.
+
+
+
+
+ Return true if the full message was recoveredMessage.
+
+ true on full message recovery, false otherwise.
+
+
+
+ RSA-PSS as described in Pkcs# 1 v 2.1.
+
+ Note: the usual value for the salt length is the number of
+ bytes in the hash function.
+
+
+
+ Basic constructor
+ the asymmetric cipher to use.
+ the digest to use.
+ the length of the salt to use (in bytes).
+
+
+ Basic constructor
+ the asymmetric cipher to use.
+ the digest to use.
+ the fixed salt to be used.
+
+
+ clear possible sensitive data
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ reset the internal state
+
+
+ Generate a signature for the message we've been loaded with using
+ the key we were initialised with.
+
+
+
+ return true if the internal state represents the signature described
+ in the passed in array.
+
+
+
+ int to octet string.
+
+
+ mask generator function, as described in Pkcs1v2.
+
+
+
+ Load oid table.
+
+
+
+ Initialise the signer for signing or verification.
+
+ @param forSigning true if for signing, false otherwise
+ @param param necessary parameters.
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ Generate a signature for the message we've been loaded with using
+ the key we were initialised with.
+
+
+ return true if the internal state represents the signature described
+ in the passed in array.
+
+
+ X9.31-1998 - signing using a hash.
+
+ The message digest hash, H, is encapsulated to form a byte string as follows
+
+
+ EB = 06 || PS || 0xBA || H || TRAILER
+
+ where PS is a string of bytes all of value 0xBB of length such that |EB|=|n|, and TRAILER is the ISO/IEC 10118 part number†for the digest. The byte string, EB, is converted to an integer value, the message representative, f.
+
+
+ Generate a signer with either implicit or explicit trailers for X9.31.
+
+ @param cipher base cipher to use for signature creation/verification
+ @param digest digest to use.
+ @param implicit whether or not the trailer is implicit or gives the hash.
+
+
+ Constructor for a signer with an explicit digest trailer.
+
+ @param cipher cipher to use.
+ @param digest digest to sign with.
+
+
+ clear possible sensitive data
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ reset the internal state
+
+
+ generate a signature for the loaded message using the key we were
+ initialised with.
+
+
+ return true if the signature represents a ISO9796-2 signature
+ for the passed in message.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ RFC 5246 7.2
+
+
+
+ This message notifies the recipient that the sender will not send any more messages on this
+ connection. Note that as of TLS 1.1, failure to properly close a connection no longer
+ requires that a session not be resumed. This is a change from TLS 1.0 ("The session becomes
+ unresumable if any connection is terminated without proper close_notify messages with level
+ equal to warning.") to conform with widespread implementation practice.
+
+
+ An inappropriate message was received. This alert is always fatal and should never be
+ observed in communication between proper implementations.
+
+
+ This alert is returned if a record is received with an incorrect MAC. This alert also MUST be
+ returned if an alert is sent because a TLSCiphertext decrypted in an invalid way: either it
+ wasn't an even multiple of the block length, or its padding values, when checked, weren't
+ correct. This message is always fatal and should never be observed in communication between
+ proper implementations (except when messages were corrupted in the network).
+
+
+ This alert was used in some earlier versions of TLS, and may have permitted certain attacks
+ against the CBC mode [CBCATT]. It MUST NOT be sent by compliant implementations.
+
+
+ A TLSCiphertext record was received that had a length more than 2^14+2048 bytes, or a record
+ decrypted to a TLSCompressed record with more than 2^14+1024 bytes. This message is always
+ fatal and should never be observed in communication between proper implementations (except
+ when messages were corrupted in the network).
+
+
+ The decompression function received improper input (e.g., data that would expand to excessive
+ length). This message is always fatal and should never be observed in communication between
+ proper implementations.
+
+
+ Reception of a handshake_failure alert message indicates that the sender was unable to
+ negotiate an acceptable set of security parameters given the options available. This is a
+ fatal error.
+
+
+ This alert was used in SSLv3 but not any version of TLS. It MUST NOT be sent by compliant
+ implementations.
+
+
+ A certificate was corrupt, contained signatures that did not verify correctly, etc.
+
+
+ A certificate was of an unsupported type.
+
+
+ A certificate was revoked by its signer.
+
+
+ A certificate has expired or is not currently valid.
+
+
+ Some other (unspecified) issue arose in processing the certificate, rendering it
+ unacceptable.
+
+
+ A field in the handshake was out of range or inconsistent with other fields. This message is
+ always fatal.
+
+
+ A valid certificate chain or partial chain was received, but the certificate was not accepted
+ because the CA certificate could not be located or couldn't be matched with a known, trusted
+ CA. This message is always fatal.
+
+
+ A valid certificate was received, but when access control was applied, the sender decided not
+ to proceed with negotiation. This message is always fatal.
+
+
+ A message could not be decoded because some field was out of the specified range or the
+ length of the message was incorrect. This message is always fatal and should never be
+ observed in communication between proper implementations (except when messages were corrupted
+ in the network).
+
+
+ A handshake cryptographic operation failed, including being unable to correctly verify a
+ signature or validate a Finished message. This message is always fatal.
+
+
+ This alert was used in some earlier versions of TLS. It MUST NOT be sent by compliant
+ implementations.
+
+
+ The protocol version the client has attempted to negotiate is recognized but not supported.
+ (For example, old protocol versions might be avoided for security reasons.) This message is
+ always fatal.
+
+
+ Returned instead of handshake_failure when a negotiation has failed specifically because the
+ server requires ciphers more secure than those supported by the client. This message is
+ always fatal.
+
+
+ An internal error unrelated to the peer or the correctness of the protocol (such as a memory
+ allocation failure) makes it impossible to continue. This message is always fatal.
+
+
+ This handshake is being canceled for some reason unrelated to a protocol failure. If the user
+ cancels an operation after the handshake is complete, just closing the connection by sending
+ a close_notify is more appropriate. This alert should be followed by a close_notify. This
+ message is generally a warning.
+
+
+ Sent by the client in response to a hello request or by the server in response to a client
+ hello after initial handshaking. Either of these would normally lead to renegotiation; when
+ that is not appropriate, the recipient should respond with this alert. At that point, the
+ original requester can decide whether to proceed with the connection. One case where this
+ would be appropriate is where a server has spawned a process to satisfy a request; the
+ process might receive security parameters (key length, authentication, etc.) at startup, and
+ it might be difficult to communicate changes to these parameters after that point. This
+ message is always a warning.
+
+
+ Sent by clients that receive an extended server hello containing an extension that they did
+ not put in the corresponding client hello. This message is always fatal.
+
+
+ This alert is sent by servers who are unable to retrieve a certificate chain from the URL
+ supplied by the client (see Section 3.3). This message MAY be fatal - for example if client
+ authentication is required by the server for the handshake to continue and the server is
+ unable to retrieve the certificate chain, it may send a fatal alert.
+
+
+ This alert is sent by servers that receive a server_name extension request, but do not
+ recognize the server name. This message MAY be fatal.
+
+
+ This alert is sent by clients that receive an invalid certificate status response (see
+ Section 3.6). This message is always fatal.
+
+
+ This alert is sent by servers when a certificate hash does not match a client provided
+ certificate_hash. This message is always fatal.
+
+
+ If the server does not recognize the PSK identity, it MAY respond with an
+ "unknown_psk_identity" alert message.
+
+
+ If TLS_FALLBACK_SCSV appears in ClientHello.cipher_suites and the highest protocol version
+ supported by the server is higher than the version indicated in ClientHello.client_version,
+ the server MUST respond with an inappropriate_fallback alert.
+
+
+
+ RFC 5246 7.2
+
+
+
+ RFC 2246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+
+ A queue for bytes.
+
+ This file could be more optimized.
+
+
+
+
+ The smallest number which can be written as 2^x which is bigger than i.
+
+
+ The initial size for our buffer.
+
+
+ The buffer where we store our data.
+
+
+ How many bytes at the beginning of the buffer are skipped.
+
+
+ How many bytes in the buffer are valid data.
+
+
+ Read data from the buffer.
+ The buffer where the read data will be copied to.
+ How many bytes to skip at the beginning of buf.
+ How many bytes to read at all.
+ How many bytes from our data to skip.
+
+
+ Add some data to our buffer.
+ A byte-array to read data from.
+ How many bytes to skip at the beginning of the array.
+ How many bytes to read from the array.
+
+
+ Remove some bytes from our data from the beginning.
+ How many bytes to remove.
+
+
+ The number of bytes which are available in this buffer.
+
+
+ Parsing and encoding of a Certificate struct from RFC 4346.
+
+
+ opaque ASN.1Cert<2^24-1>;
+
+ struct {
+ ASN.1Cert certificate_list<0..2^24-1>;
+ } Certificate;
+
+
+ @see Org.BouncyCastle.Asn1.X509.X509CertificateStructure
+
+
+ The certificates.
+
+
+ @return an array of {@link org.bouncycastle.asn1.x509.Certificate} representing a certificate
+ chain.
+
+
+ @return true
if this certificate chain contains no certificates, or
+ false
otherwise.
+
+
+ Encode this {@link Certificate} to a {@link Stream}.
+
+ @param output the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link Certificate} from a {@link Stream}.
+
+ @param input the {@link Stream} to parse from.
+ @return a {@link Certificate} object.
+ @throws IOException
+
+
+ Parsing and encoding of a CertificateRequest struct from RFC 4346.
+
+
+ struct {
+ ClientCertificateType certificate_types<1..2^8-1>;
+ DistinguishedName certificate_authorities<3..2^16-1>
+ } CertificateRequest;
+
+
+ @see ClientCertificateType
+ @see X509Name
+
+
+ @param certificateTypes see {@link ClientCertificateType} for valid constants.
+ @param certificateAuthorities an {@link IList} of {@link X509Name}.
+
+
+ @return an array of certificate types
+ @see {@link ClientCertificateType}
+
+
+ @return an {@link IList} of {@link SignatureAndHashAlgorithm} (or null before TLS 1.2).
+
+
+ @return an {@link IList} of {@link X509Name}
+
+
+ Encode this {@link CertificateRequest} to a {@link Stream}.
+
+ @param output the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link CertificateRequest} from a {@link Stream}.
+
+ @param context
+ the {@link TlsContext} of the current connection.
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link CertificateRequest} object.
+ @throws IOException
+
+
+ Encode this {@link CertificateStatus} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link CertificateStatus} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link CertificateStatus} object.
+ @throws IOException
+
+
+ Encode this {@link CertificateStatusRequest} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link CertificateStatusRequest} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link CertificateStatusRequest} object.
+ @throws IOException
+
+
+ @param type
+ see {@link CertChainType} for valid constants.
+ @param urlAndHashList
+ a {@link IList} of {@link UrlAndHash}.
+
+
+ @return {@link CertChainType}
+
+
+ @return an {@link IList} of {@link UrlAndHash}
+
+
+ Encode this {@link CertificateUrl} to a {@link Stream}.
+
+ @param output the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link CertificateUrl} from a {@link Stream}.
+
+ @param context
+ the {@link TlsContext} of the current connection.
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link CertificateUrl} object.
+ @throws IOException
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ RFC 2246 A.5
+
+
+
+ RFC 2246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+ A combined hash, which implements md5(m) || sha1(m).
+
+
+ @see org.bouncycastle.crypto.Digest#update(byte[], int, int)
+
+
+ @see org.bouncycastle.crypto.Digest#doFinal(byte[], int)
+
+
+ @see org.bouncycastle.crypto.Digest#reset()
+
+
+
+ RFC 2246 6.1
+
+
+
+ RFC 2246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+ RFC 2246 6.2.1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Accept only the group parameters specified in RFC 5054 Appendix A.
+
+
+ Specify a custom set of acceptable group parameters.
+
+ @param groups a {@link Vector} of acceptable {@link SRP6GroupParameters}
+
+
+ Buffers input until the hash algorithm is determined.
+
+
+ @return a {@link SignatureAndHashAlgorithm} (or null before TLS 1.2).
+
+
+ Encode this {@link DigitallySigned} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link DigitallySigned} from a {@link Stream}.
+
+ @param context
+ the {@link TlsContext} of the current connection.
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link DigitallySigned} object.
+ @throws IOException
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Check that there are no "extra" messages left in the current inbound flight
+
+
+ RFC 4347 4.1.2.5 Anti-replay
+
+ Support fast rejection of duplicate records by maintaining a sliding receive window
+
+
+ Check whether a received record with the given sequence number should be rejected as a duplicate.
+
+ @param seq the 48-bit DTLSPlainText.sequence_number field of a received record.
+ @return true if the record should be discarded without further processing.
+
+
+ Report that a received record with the given sequence number passed authentication checks.
+
+ @param seq the 48-bit DTLSPlainText.sequence_number field of an authenticated record.
+
+
+ When a new epoch begins, sequence numbers begin again at 0
+
+
+ RFC 4492 5.4. (Errata ID: 2389)
+
+
+
+ RFC 4492 5.4
+
+
+
+ Indicates the elliptic curve domain parameters are conveyed verbosely, and the
+ underlying finite field is a prime field.
+
+
+ Indicates the elliptic curve domain parameters are conveyed verbosely, and the
+ underlying finite field is a characteristic-2 field.
+
+
+ Indicates that a named curve is used. This option SHOULD be used when applicable.
+
+
+
+ RFC 4492 5.1.2
+
+
+
+ RFC 2246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+ RFC 5705
+
+
+ RFC 5246 7.4.1.4.1
+
+
+ Encode this {@link HeartbeatExtension} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link HeartbeatExtension} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link HeartbeatExtension} object.
+ @throws IOException
+
+
+ Encode this {@link HeartbeatMessage} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link HeartbeatMessage} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link HeartbeatMessage} object.
+ @throws IOException
+
+
+ RFC 2246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+ RFC 2246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+
+ RFC 4492 5.1.1
+ The named curves defined here are those specified in SEC 2 [13]. Note that many of
+ these curves are also recommended in ANSI X9.62 [7] and FIPS 186-2 [11]. Values 0xFE00
+ through 0xFEFF are reserved for private use. Values 0xFF01 and 0xFF02 indicate that the
+ client supports arbitrary prime and characteristic-2 curves, respectively (the curve
+ parameters must be encoded explicitly in ECParameters).
+
+
+
+ Encode this {@link NewSessionTicket} to a {@link Stream}.
+
+ @param output the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link NewSessionTicket} from a {@link Stream}.
+
+ @param input the {@link Stream} to parse from.
+ @return a {@link NewSessionTicket} object.
+ @throws IOException
+
+
+ RFC 3546 3.6
+
+
+ @param responderIDList
+ an {@link IList} of {@link ResponderID}, specifying the list of trusted OCSP
+ responders. An empty list has the special meaning that the responders are
+ implicitly known to the server - e.g., by prior arrangement.
+ @param requestExtensions
+ OCSP request extensions. A null value means that there are no extensions.
+
+
+ @return an {@link IList} of {@link ResponderID}
+
+
+ @return OCSP request extensions
+
+
+ Encode this {@link OcspStatusRequest} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link OcspStatusRequest} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return an {@link OcspStatusRequest} object.
+ @throws IOException
+
+
+ RFC 5246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+
+
+
+ An implementation of the TLS 1.0/1.1/1.2 record layer, allowing downgrade to SSLv3.
+
+
+ RFC 5246 E.1. "Earlier versions of the TLS specification were not fully clear on what the
+ record layer version number (TLSPlaintext.version) should contain when sending ClientHello
+ (i.e., before it is known which version of the protocol will be employed). Thus, TLS servers
+ compliant with this specification MUST accept any value {03,XX} as the record layer version
+ number for ClientHello."
+
+
+ @return {@link ConnectionEnd}
+
+
+ @return {@link CipherSuite}
+
+
+ @return {@link CompressionMethod}
+
+
+ @return {@link PRFAlgorithm}
+
+
+ Encode this {@link ServerDHParams} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link ServerDHParams} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link ServerDHParams} object.
+ @throws IOException
+
+
+ Encode this {@link ServerName} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link ServerName} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link ServerName} object.
+ @throws IOException
+
+
+ @param serverNameList an {@link IList} of {@link ServerName}.
+
+
+ @return an {@link IList} of {@link ServerName}.
+
+
+ Encode this {@link ServerNameList} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link ServerNameList} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link ServerNameList} object.
+ @throws IOException
+
+
+ Encode this {@link ServerSRPParams} to an {@link OutputStream}.
+
+ @param output
+ the {@link OutputStream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link ServerSRPParams} from an {@link InputStream}.
+
+ @param input
+ the {@link InputStream} to parse from.
+ @return a {@link ServerSRPParams} object.
+ @throws IOException
+
+
+ RFC 5246 7.4.1.4.1 (in RFC 2246, there were no specific values assigned)
+
+
+ RFC 5246 7.4.1.4.1
+
+
+ @param hash {@link HashAlgorithm}
+ @param signature {@link SignatureAlgorithm}
+
+
+ @return {@link HashAlgorithm}
+
+
+ @return {@link SignatureAlgorithm}
+
+
+ Encode this {@link SignatureAndHashAlgorithm} to a {@link Stream}.
+
+ @param output the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link SignatureAndHashAlgorithm} from a {@link Stream}.
+
+ @param input the {@link Stream} to parse from.
+ @return a {@link SignatureAndHashAlgorithm} object.
+ @throws IOException
+
+
+ An implementation of {@link TlsSRPIdentityManager} that simulates the existence of "unknown" identities
+ to obscure the fact that there is no verifier for them.
+
+
+ Create a {@link SimulatedTlsSRPIdentityManager} that implements the algorithm from RFC 5054 2.5.1.3
+
+ @param group the {@link SRP6GroupParameters} defining the group that SRP is operating in
+ @param seedKey the secret "seed key" referred to in RFC 5054 2.5.1.3
+ @return an instance of {@link SimulatedTlsSRPIdentityManager}
+
+
+ HMAC implementation based on original internet draft for HMAC (RFC 2104)
+
+ The difference is that padding is concatentated versus XORed with the key
+
+ H(K + opad, H(K + ipad, text))
+
+
+ Base constructor for one of the standard digest algorithms that the byteLength of
+ the algorithm is know for. Behaviour is undefined for digests other than MD5 or SHA1.
+
+ @param digest the digest.
+
+
+ Reset the mac generator.
+
+
+ RFC 4680
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Called by the protocol handler to report the server certificate.
+
+
+ This method is responsible for certificate verification and validation
+
+ The server received
+
+
+
+
+ Return client credentials in response to server's certificate request
+
+
+ A containing server certificate request details
+
+
+ A to be used for client authentication
+ (or null for no client authentication)
+
+
+
+
+
+ A generic TLS 1.0-1.2 / SSLv3 block cipher. This can be used for AES or 3DES for example.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Called at the start of a new TLS session, before any other methods.
+
+
+ A
+
+
+
+ Return the session this client wants to resume, if any.
+ Note that the peer's certificate chain for the session (if any) may need to be periodically revalidated.
+
+ A representing the resumable session to be used for this connection,
+ or null to use a new session.
+
+
+
+
+ Return the to use for the TLSPlaintext.version field prior to
+ receiving the server version. NOTE: This method is not called for DTLS.
+
+
+ See RFC 5246 E.1.: "TLS clients that wish to negotiate with older servers MAY send any value
+ {03,XX} as the record layer version number. Typical values would be {03,00}, the lowest
+ version number supported by the client, and the value of ClientHello.client_version. No
+ single value will guarantee interoperability with all old servers, but this is a complex
+ topic beyond the scope of this document."
+
+ The to use.
+
+
+
+ Get the list of cipher suites that this client supports.
+
+
+ An array of values, each specifying a supported cipher suite.
+
+
+
+
+ Get the list of compression methods that this client supports.
+
+
+ An array of values, each specifying a supported compression method.
+
+
+
+
+ Get the (optional) table of client extensions to be included in (extended) client hello.
+
+
+ A (Int32 -> byte[]). May be null.
+
+
+
+
+
+
+
+
+ Notifies the client of the session_id sent in the ServerHello.
+
+ An array of
+
+
+
+ Report the cipher suite that was selected by the server.
+
+
+ The protocol handler validates this value against the offered cipher suites
+
+
+
+ A
+
+
+
+
+ Report the compression method that was selected by the server.
+
+
+ The protocol handler validates this value against the offered compression methods
+
+
+
+ A
+
+
+
+
+ Report the extensions from an extended server hello.
+
+
+ Will only be called if we returned a non-null result from .
+
+
+ A (Int32 -> byte[])
+
+
+
+ A list of
+
+
+
+
+ Return an implementation of to negotiate the key exchange
+ part of the protocol.
+
+
+ A
+
+
+
+
+
+ Return an implementation of to handle authentication
+ part of the protocol.
+
+
+
+
+ A list of
+
+
+
+ RFC 5077 3.3. NewSessionTicket Handshake Message
+
+ This method will be called (only) when a NewSessionTicket handshake message is received. The
+ ticket is opaque to the client and clients MUST NOT examine the ticket under the assumption
+ that it complies with e.g. RFC 5077 4. Recommended Ticket Construction.
+
+ The ticket
+
+
+
+ Constructor for blocking mode.
+ @param stream The bi-directional stream of data to/from the server
+ @param secureRandom Random number generator for various cryptographic functions
+
+
+ Constructor for blocking mode.
+ @param input The stream of data from the server
+ @param output The stream of data to the server
+ @param secureRandom Random number generator for various cryptographic functions
+
+
+ Constructor for non-blocking mode.
+
+ When data is received, use {@link #offerInput(java.nio.ByteBuffer)} to
+ provide the received ciphertext, then use
+ {@link #readInput(byte[], int, int)} to read the corresponding cleartext.
+
+ Similarly, when data needs to be sent, use
+ {@link #offerOutput(byte[], int, int)} to provide the cleartext, then use
+ {@link #readOutput(byte[], int, int)} to get the corresponding
+ ciphertext.
+
+ @param secureRandom
+ Random number generator for various cryptographic functions
+
+
+ Initiates a TLS handshake in the role of client.
+
+ In blocking mode, this will not return until the handshake is complete.
+ In non-blocking mode, use {@link TlsPeer#NotifyHandshakeComplete()} to
+ receive a callback when the handshake is complete.
+
+ @param tlsClient The {@link TlsClient} to use for the handshake.
+ @throws IOException If in blocking mode and handshake was not successful.
+
+
+ Used to get the resumable session, if any, used by this connection. Only available after the
+ handshake has successfully completed.
+
+ @return A {@link TlsSession} representing the resumable session used by this connection, or
+ null if no resumable session available.
+ @see TlsPeer#NotifyHandshakeComplete()
+
+
+ Export keying material according to RFC 5705: "Keying Material Exporters for TLS".
+
+ @param asciiLabel indicates which application will use the exported keys.
+ @param context_value allows the application using the exporter to mix its own data with the TLS PRF for
+ the exporter output.
+ @param length the number of bytes to generate
+ @return a pseudorandom bit string of 'length' bytes generated from the master_secret.
+
+
+ (D)TLS DH key exchange.
+
+
+ (D)TLS ECDH key exchange (see RFC 4492).
+
+
+ (D)TLS ECDHE key exchange (see RFC 4492).
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ A generic interface for key exchange implementations in (D)TLS.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ A generic TLS MAC implementation, acting as an HMAC based on some underlying Digest.
+
+
+
+ Generate a new instance of an TlsMac.
+
+ @param context the TLS client context
+ @param digest The digest to use.
+ @param key A byte-array where the key for this MAC is located.
+ @param keyOff The number of bytes to skip, before the key starts in the buffer.
+ @param keyLen The length of the key.
+
+
+ @return the MAC write secret
+
+
+ @return The output length of this MAC.
+
+
+ Calculate the MAC for some given data.
+
+ @param type The message type of the message.
+ @param message A byte-buffer containing the message.
+ @param offset The number of bytes to skip, before the message starts.
+ @param length The length of the message.
+ @return A new byte-buffer containing the MAC value.
+
+
+
+ A NULL CipherSuite, with optional MAC.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ draft-mathewson-no-gmtunixtime-00 2. "If existing users of a TLS implementation may rely on
+ gmt_unix_time containing the current time, we recommend that implementors MAY provide the
+ ability to set gmt_unix_time as an option only, off by default."
+
+
+ true
if the current time should be used in the gmt_unix_time field of
+ Random, or false
if gmt_unix_time should contain a cryptographically
+ random value.
+
+
+
+
+ Report whether the server supports secure renegotiation
+
+
+ The protocol handler automatically processes the relevant extensions
+
+
+ A , true if the server supports secure renegotiation
+
+
+
+
+
+ Return an implementation of to handle record compression.
+
+ A
+
+
+
+
+ Return an implementation of to use for encryption/decryption.
+
+ A
+
+
+
+ This method will be called when an alert is raised by the protocol.
+
+
+ A human-readable message explaining what caused this alert. May be null.
+ The Exception that caused this alert to be raised. May be null.
+
+
+ This method will be called when an alert is received from the remote peer.
+
+
+
+
+ Notifies the peer that the handshake has been successfully completed.
+
+
+
+ This method is called, when a change cipher spec message is received.
+
+ @throws IOException If the message has an invalid content or the handshake is not in the correct
+ state.
+
+
+ Read data from the network. The method will return immediately, if there is still some data
+ left in the buffer, or block until some application data has been read from the network.
+
+ @param buf The buffer where the data will be copied to.
+ @param offset The position where the data will be placed in the buffer.
+ @param len The maximum number of bytes to read.
+ @return The number of bytes read.
+ @throws IOException If something goes wrong during reading data.
+
+
+ Send some application data to the remote system.
+
+ The method will handle fragmentation internally.
+
+ @param buf The buffer with the data.
+ @param offset The position in the buffer where the data is placed.
+ @param len The length of the data.
+ @throws IOException If something goes wrong during sending.
+
+
+ The secure bidirectional stream for this connection
+ Only allowed in blocking mode.
+
+
+ Offer input from an arbitrary source. Only allowed in non-blocking mode.
+
+ After this method returns, the input buffer is "owned" by this object. Other code
+ must not attempt to do anything with it.
+
+ This method will decrypt and process all records that are fully available.
+ If only part of a record is available, the buffer will be retained until the
+ remainder of the record is offered.
+
+ If any records containing application data were processed, the decrypted data
+ can be obtained using {@link #readInput(byte[], int, int)}. If any records
+ containing protocol data were processed, a response may have been generated.
+ You should always check to see if there is any available output after calling
+ this method by calling {@link #getAvailableOutputBytes()}.
+ @param input The input buffer to offer
+ @throws IOException If an error occurs while decrypting or processing a record
+
+
+ Gets the amount of received application data. A call to {@link #readInput(byte[], int, int)}
+ is guaranteed to be able to return at least this much data.
+
+ Only allowed in non-blocking mode.
+ @return The number of bytes of available application data
+
+
+ Retrieves received application data. Use {@link #getAvailableInputBytes()} to check
+ how much application data is currently available. This method functions similarly to
+ {@link InputStream#read(byte[], int, int)}, except that it never blocks. If no data
+ is available, nothing will be copied and zero will be returned.
+
+ Only allowed in non-blocking mode.
+ @param buffer The buffer to hold the application data
+ @param offset The start offset in the buffer at which the data is written
+ @param length The maximum number of bytes to read
+ @return The total number of bytes copied to the buffer. May be less than the
+ length specified if the length was greater than the amount of available data.
+
+
+ Offer output from an arbitrary source. Only allowed in non-blocking mode.
+
+ After this method returns, the specified section of the buffer will have been
+ processed. Use {@link #readOutput(byte[], int, int)} to get the bytes to
+ transmit to the other peer.
+
+ This method must not be called until after the handshake is complete! Attempting
+ to call it before the handshake is complete will result in an exception.
+ @param buffer The buffer containing application data to encrypt
+ @param offset The offset at which to begin reading data
+ @param length The number of bytes of data to read
+ @throws IOException If an error occurs encrypting the data, or the handshake is not complete
+
+
+ Gets the amount of encrypted data available to be sent. A call to
+ {@link #readOutput(byte[], int, int)} is guaranteed to be able to return at
+ least this much data.
+
+ Only allowed in non-blocking mode.
+ @return The number of bytes of available encrypted data
+
+
+ Retrieves encrypted data to be sent. Use {@link #getAvailableOutputBytes()} to check
+ how much encrypted data is currently available. This method functions similarly to
+ {@link InputStream#read(byte[], int, int)}, except that it never blocks. If no data
+ is available, nothing will be copied and zero will be returned.
+
+ Only allowed in non-blocking mode.
+ @param buffer The buffer to hold the encrypted data
+ @param offset The start offset in the buffer at which the data is written
+ @param length The maximum number of bytes to read
+ @return The total number of bytes copied to the buffer. May be less than the
+ length specified if the length was greater than the amount of available data.
+
+
+ Terminate this connection with an alert. Can be used for normal closure too.
+
+ @param alertLevel
+ See {@link AlertLevel} for values.
+ @param alertDescription
+ See {@link AlertDescription} for values.
+ @throws IOException
+ If alert was fatal.
+
+
+ Closes this connection.
+
+ @throws IOException If something goes wrong during closing.
+
+
+ Make sure the InputStream 'buf' now empty. Fail otherwise.
+
+ @param buf The InputStream to check.
+ @throws IOException If 'buf' is not empty.
+
+
+ 'sender' only relevant to SSLv3
+
+
+ Both streams can be the same object
+
+
+ (D)TLS PSK key exchange (RFC 4279).
+
+
+ (D)TLS and SSLv3 RSA key exchange.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ A (Int32 -> byte[]). Will never be null.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Get the (optional) table of server extensions to be included in (extended) server hello.
+
+
+ A (Int32 -> byte[]). May be null.
+
+
+
+
+
+ A (). May be null.
+
+
+
+
+
+
+
+
+ This method will be called (only) if the server included an extension of type
+ "status_request" with empty "extension_data" in the extended server hello. See RFC 3546
+ 3.6. Certificate Status Request. If a non-null is returned, it
+ is sent to the client as a handshake message of type "certificate_status".
+
+ A to be sent to the client (or null for none).
+
+
+
+
+
+
+
+
+
+ ()
+
+
+
+
+ Called by the protocol handler to report the client certificate, only if GetCertificateRequest
+ returned non-null.
+
+ Note: this method is responsible for certificate verification and validation.
+ the effective client certificate (may be an empty chain).
+
+
+
+ RFC 5077 3.3. NewSessionTicket Handshake Message.
+
+ This method will be called (only) if a NewSessionTicket extension was sent by the server. See
+ RFC 5077 4. Recommended Ticket Construction for recommended format and protection.
+
+ The ticket)
+
+
+
+ Constructor for blocking mode.
+ @param stream The bi-directional stream of data to/from the client
+ @param output The stream of data to the client
+ @param secureRandom Random number generator for various cryptographic functions
+
+
+ Constructor for blocking mode.
+ @param input The stream of data from the client
+ @param output The stream of data to the client
+ @param secureRandom Random number generator for various cryptographic functions
+
+
+ Constructor for non-blocking mode.
+
+ When data is received, use {@link #offerInput(java.nio.ByteBuffer)} to
+ provide the received ciphertext, then use
+ {@link #readInput(byte[], int, int)} to read the corresponding cleartext.
+
+ Similarly, when data needs to be sent, use
+ {@link #offerOutput(byte[], int, int)} to provide the cleartext, then use
+ {@link #readOutput(byte[], int, int)} to get the corresponding
+ ciphertext.
+
+ @param secureRandom
+ Random number generator for various cryptographic functions
+
+
+ Receives a TLS handshake in the role of server.
+
+ In blocking mode, this will not return until the handshake is complete.
+ In non-blocking mode, use {@link TlsPeer#notifyHandshakeComplete()} to
+ receive a callback when the handshake is complete.
+
+ @param tlsServer
+ @throws IOException If in blocking mode and handshake was not successful.
+
+
+
+
+
+ Check whether the given SRP group parameters are acceptable for use.
+
+ @param group the {@link SRP6GroupParameters} to check
+ @return true if (and only if) the specified group parameters are acceptable
+
+
+ Lookup the {@link TlsSRPLoginParameters} corresponding to the specified identity.
+
+ NOTE: To avoid "identity probing", unknown identities SHOULD be handled as recommended in RFC
+ 5054 2.5.1.3. {@link SimulatedTlsSRPIdentityManager} is provided for this purpose.
+
+ @param identity
+ the SRP identity sent by the connecting client
+ @return the {@link TlsSRPLoginParameters} for the specified identity, or else 'simulated'
+ parameters if the identity is not recognized. A null value is also allowed, but not
+ recommended.
+
+
+ (D)TLS SRP key exchange (RFC 5054).
+
+
+ RFC 5764 DTLS Extension to Establish Keys for SRTP.
+
+
+
+
+
+
+
+
+
+
+
+ Some helper functions for MicroTLS.
+
+
+ Add a 'signature_algorithms' extension to existing extensions.
+
+ @param extensions A {@link Hashtable} to add the extension to.
+ @param supportedSignatureAlgorithms {@link Vector} containing at least 1 {@link SignatureAndHashAlgorithm}.
+ @throws IOException
+
+
+ Get a 'signature_algorithms' extension from extensions.
+
+ @param extensions A {@link Hashtable} to get the extension from, if it is present.
+ @return A {@link Vector} containing at least 1 {@link SignatureAndHashAlgorithm}, or null.
+ @throws IOException
+
+
+ Create a 'signature_algorithms' extension value.
+
+ @param supportedSignatureAlgorithms A {@link Vector} containing at least 1 {@link SignatureAndHashAlgorithm}.
+ @return A byte array suitable for use as an extension value.
+ @throws IOException
+
+
+ Read 'signature_algorithms' extension data.
+
+ @param extensionData The extension data.
+ @return A {@link Vector} containing at least 1 {@link SignatureAndHashAlgorithm}.
+ @throws IOException
+
+
+ RFC 6066 5.
+
+
+ Encode this {@link UrlAndHash} to a {@link Stream}.
+
+ @param output the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link UrlAndHash} from a {@link Stream}.
+
+ @param context
+ the {@link TlsContext} of the current connection.
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link UrlAndHash} object.
+ @throws IOException
+
+
+ RFC 5764 4.1.1
+
+
+ @param protectionProfiles see {@link SrtpProtectionProfile} for valid constants.
+ @param mki valid lengths from 0 to 255.
+
+
+ @return see {@link SrtpProtectionProfile} for valid constants.
+
+
+ @return valid lengths from 0 to 255.
+
+
+ RFC 4681
+
+
+ return a = a + b - b preserved.
+
+
+ unsigned comparison on two arrays - note the arrays may
+ start with leading zeros.
+
+
+ return z = x / y - done in place (z value preserved, x contains the
+ remainder)
+
+
+ return whether or not a BigInteger is probably prime with a
+ probability of 1 - (1/2)**certainty.
+ From Knuth Vol 2, pg 395.
+
+
+ Calculate the numbers u1, u2, and u3 such that:
+
+ u1 * a + u2 * b = u3
+
+ where u3 is the greatest common divider of a and b.
+ a and b using the extended Euclid algorithm (refer p. 323
+ of The Art of Computer Programming vol 2, 2nd ed).
+ This also seems to have the side effect of calculating
+ some form of multiplicative inverse.
+
+ @param a First number to calculate gcd for
+ @param b Second number to calculate gcd for
+ @param u1Out the return object for the u1 value
+ @return The greatest common divisor of a and b
+
+
+ return w with w = x * x - w is assumed to have enough space.
+
+
+ return x with x = y * z - x is assumed to have enough space.
+
+
+ Calculate mQuote = -m^(-1) mod b with b = 2^32 (32 = word size)
+
+
+ Montgomery multiplication: a = x * y * R^(-1) mod m
+
+ Based algorithm 14.36 of Handbook of Applied Cryptography.
+
+ m, x, y should have length n
+ a should have length (n + 1)
+ b = 2^32, R = b^n
+
+ The result is put in x
+
+ NOTE: the indices of x, y, m, a different in HAC and in Java
+
+
+ return x = x % y - done in place (y value preserved)
+
+
+ do a left shift - this returns a new array.
+
+
+ do a right shift - this does it in place.
+
+
+ do a right shift by one - this does it in place.
+
+
+ returns x = x - y - we assume x is >= y
+
+
+ Utility methods for generating primes and testing for primality.
+
+
+ Used to return the output from the
+ {@linkplain Primes#enhancedMRProbablePrimeTest(BigInteger, SecureRandom, int) Enhanced
+ Miller-Rabin Probabilistic Primality Test}
+
+
+ Used to return the output from the {@linkplain Primes#generateSTRandomPrime(Digest, int, byte[]) Shawe-Taylor Random_Prime Routine}
+
+
+ FIPS 186-4 C.6 Shawe-Taylor Random_Prime Routine
+
+ Construct a provable prime number using a hash function.
+
+ @param hash
+ the {@link Digest} instance to use (as "Hash()"). Cannot be null.
+ @param length
+ the length (in bits) of the prime to be generated. Must be at least 2.
+ @param inputSeed
+ the seed to be used for the generation of the requested prime. Cannot be null or
+ empty.
+ @return an {@link STOutput} instance containing the requested prime.
+
+
+ FIPS 186-4 C.3.2 Enhanced Miller-Rabin Probabilistic Primality Test
+
+ Run several iterations of the Miller-Rabin algorithm with randomly-chosen bases. This is an
+ alternative to {@link #isMRProbablePrime(BigInteger, SecureRandom, int)} that provides more
+ information about a composite candidate, which may be useful when generating or validating
+ RSA moduli.
+
+ @param candidate
+ the {@link BigInteger} instance to test for primality.
+ @param random
+ the source of randomness to use to choose bases.
+ @param iterations
+ the number of randomly-chosen bases to perform the test for.
+ @return an {@link MROutput} instance that can be further queried for details.
+
+
+ A fast check for small divisors, up to some implementation-specific limit.
+
+ @param candidate
+ the {@link BigInteger} instance to test for division by small factors.
+
+ @return true
if the candidate is found to have any small factors,
+ false
otherwise.
+
+
+ FIPS 186-4 C.3.1 Miller-Rabin Probabilistic Primality Test
+
+ Run several iterations of the Miller-Rabin algorithm with randomly-chosen bases.
+
+ @param candidate
+ the {@link BigInteger} instance to test for primality.
+ @param random
+ the source of randomness to use to choose bases.
+ @param iterations
+ the number of randomly-chosen bases to perform the test for.
+ @return false
if any witness to compositeness is found amongst the chosen bases
+ (so candidate
is definitely NOT prime), or else true
+ (indicating primality with some probability dependent on the number of iterations
+ that were performed).
+
+
+ FIPS 186-4 C.3.1 Miller-Rabin Probabilistic Primality Test (to a fixed base).
+
+ Run a single iteration of the Miller-Rabin algorithm against the specified base.
+
+ @param candidate
+ the {@link BigInteger} instance to test for primality.
+ @param baseValue
+ the base value to use for this iteration.
+ @return false
if the specified base is a witness to compositeness (so
+ candidate
is definitely NOT prime), or else true
.
+
+
+ Simple shift-and-add multiplication. Serves as reference implementation
+ to verify (possibly faster) implementations, and for very small scalars.
+
+ @param p
+ The point to multiply.
+ @param k
+ The multiplier.
+ @return The result of the point multiplication kP
.
+
+
+ Base class for an elliptic curve.
+
+
+ Adds PreCompInfo
for a point on this curve, under a given name. Used by
+ ECMultiplier
s to save the precomputation for this ECPoint
for use
+ by subsequent multiplication.
+
+ @param point
+ The ECPoint
to store precomputations for.
+ @param name
+ A String
used to index precomputations of different types.
+ @param preCompInfo
+ The values precomputed by the ECMultiplier
.
+
+
+ Normalization ensures that any projective coordinate is 1, and therefore that the x, y
+ coordinates reflect those of the equivalent point in an affine coordinate system. Where more
+ than one point is to be normalized, this method will generally be more efficient than
+ normalizing each point separately.
+
+ @param points
+ An array of points that will be updated in place with their normalized versions,
+ where necessary
+
+
+ Normalization ensures that any projective coordinate is 1, and therefore that the x, y
+ coordinates reflect those of the equivalent point in an affine coordinate system. Where more
+ than one point is to be normalized, this method will generally be more efficient than
+ normalizing each point separately. An (optional) z-scaling factor can be applied; effectively
+ each z coordinate is scaled by this value prior to normalization (but only one
+ actual multiplication is needed).
+
+ @param points
+ An array of points that will be updated in place with their normalized versions,
+ where necessary
+ @param off
+ The start of the range of points to normalize
+ @param len
+ The length of the range of points to normalize
+ @param iso
+ The (optional) z-scaling factor - can be null
+
+
+ Sets the default ECMultiplier
, unless already set.
+
+
+ Decode a point on this curve from its ASN.1 encoding. The different
+ encodings are taken account of, including point compression for
+ Fp
(X9.62 s 4.2.1 pg 17).
+ @return The decoded point.
+
+
+ Elliptic curve over Fp
+
+
+ The auxiliary values s0
and
+ s1
used for partial modular reduction for
+ Koblitz curves.
+
+
+ Solves a quadratic equation z2 + z = beta
(X9.62
+ D.1.6) The other solution is z + 1
.
+
+ @param beta
+ The value to solve the qradratic equation for.
+ @return the solution for z2 + z = beta
or
+ null
if no solution exists.
+
+
+ @return the auxiliary values s0
and
+ s1
used for partial modular reduction for
+ Koblitz curves.
+
+
+ Returns true if this is a Koblitz curve (ABC curve).
+ @return true if this is a Koblitz curve (ABC curve), false otherwise
+
+
+ Elliptic curves over F2m. The Weierstrass equation is given by
+ y2 + xy = x3 + ax2 + b
.
+
+
+ The exponent m
of F2m
.
+
+
+ TPB: The integer k
where xm +
+ xk + 1
represents the reduction polynomial
+ f(z)
.
+ PPB: The integer k1
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ TPB: Always set to 0
+ PPB: The integer k2
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ TPB: Always set to 0
+ PPB: The integer k3
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ The point at infinity on this curve.
+
+
+ Constructor for Trinomial Polynomial Basis (TPB).
+ @param m The exponent m
of
+ F2m
.
+ @param k The integer k
where xm +
+ xk + 1
represents the reduction
+ polynomial f(z)
.
+ @param a The coefficient a
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+ @param b The coefficient b
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+
+
+ Constructor for Trinomial Polynomial Basis (TPB).
+ @param m The exponent m
of
+ F2m
.
+ @param k The integer k
where xm +
+ xk + 1
represents the reduction
+ polynomial f(z)
.
+ @param a The coefficient a
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+ @param b The coefficient b
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+ @param order The order of the main subgroup of the elliptic curve.
+ @param cofactor The cofactor of the elliptic curve, i.e.
+ #Ea(F2m) = h * n
.
+
+
+ Constructor for Pentanomial Polynomial Basis (PPB).
+ @param m The exponent m
of
+ F2m
.
+ @param k1 The integer k1
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k2 The integer k2
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k3 The integer k3
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param a The coefficient a
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+ @param b The coefficient b
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+
+
+ Constructor for Pentanomial Polynomial Basis (PPB).
+ @param m The exponent m
of
+ F2m
.
+ @param k1 The integer k1
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k2 The integer k2
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k3 The integer k3
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param a The coefficient a
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+ @param b The coefficient b
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+ @param order The order of the main subgroup of the elliptic curve.
+ @param cofactor The cofactor of the elliptic curve, i.e.
+ #Ea(F2m) = h * n
.
+
+
+ Return true if curve uses a Trinomial basis.
+
+ @return true if curve Trinomial, false otherwise.
+
+
+ return the field name for this field.
+
+ @return the string "Fp".
+
+
+ return a sqrt root - the routine verifies that the calculation
+ returns the right value - if none exists it returns null.
+
+
+ Class representing the Elements of the finite field
+ F2m
in polynomial basis (PB)
+ representation. Both trinomial (Tpb) and pentanomial (Ppb) polynomial
+ basis representations are supported. Gaussian normal basis (GNB)
+ representation is not supported.
+
+
+ Indicates gaussian normal basis representation (GNB). Number chosen
+ according to X9.62. GNB is not implemented at present.
+
+
+ Indicates trinomial basis representation (Tpb). Number chosen
+ according to X9.62.
+
+
+ Indicates pentanomial basis representation (Ppb). Number chosen
+ according to X9.62.
+
+
+ Tpb or Ppb.
+
+
+ The exponent m
of F2m
.
+
+
+ The LongArray
holding the bits.
+
+
+ Constructor for Ppb.
+ @param m The exponent m
of
+ F2m
.
+ @param k1 The integer k1
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k2 The integer k2
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k3 The integer k3
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param x The BigInteger representing the value of the field element.
+
+
+ Constructor for Tpb.
+ @param m The exponent m
of
+ F2m
.
+ @param k The integer k
where xm +
+ xk + 1
represents the reduction
+ polynomial f(z)
.
+ @param x The BigInteger representing the value of the field element.
+
+
+ Checks, if the ECFieldElements a
and b
+ are elements of the same field F2m
+ (having the same representation).
+ @param a field element.
+ @param b field element to be compared.
+ @throws ArgumentException if a
and b
+ are not elements of the same field
+ F2m
(having the same
+ representation).
+
+
+ @return the representation of the field
+ F2m
, either of
+ {@link F2mFieldElement.Tpb} (trinomial
+ basis representation) or
+ {@link F2mFieldElement.Ppb} (pentanomial
+ basis representation).
+
+
+ @return the degree m
of the reduction polynomial
+ f(z)
.
+
+
+ @return Tpb: The integer k
where xm +
+ xk + 1
represents the reduction polynomial
+ f(z)
.
+ Ppb: The integer k1
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ @return Tpb: Always returns 0
+ Ppb: The integer k2
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ @return Tpb: Always set to 0
+ Ppb: The integer k3
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ base class for points on elliptic curves.
+
+
+ Normalizes this point, and then returns the affine x-coordinate.
+
+ Note: normalization can be expensive, this method is deprecated in favour
+ of caller-controlled normalization.
+
+
+ Normalizes this point, and then returns the affine y-coordinate.
+
+ Note: normalization can be expensive, this method is deprecated in favour
+ of caller-controlled normalization.
+
+
+ Returns the affine x-coordinate after checking that this point is normalized.
+
+ @return The affine x-coordinate of this point
+ @throws IllegalStateException if the point is not normalized
+
+
+ Returns the affine y-coordinate after checking that this point is normalized
+
+ @return The affine y-coordinate of this point
+ @throws IllegalStateException if the point is not normalized
+
+
+ Returns the x-coordinate.
+
+ Caution: depending on the curve's coordinate system, this may not be the same value as in an
+ affine coordinate system; use Normalize() to get a point where the coordinates have their
+ affine values, or use AffineXCoord if you expect the point to already have been normalized.
+
+ @return the x-coordinate of this point
+
+
+ Returns the y-coordinate.
+
+ Caution: depending on the curve's coordinate system, this may not be the same value as in an
+ affine coordinate system; use Normalize() to get a point where the coordinates have their
+ affine values, or use AffineYCoord if you expect the point to already have been normalized.
+
+ @return the y-coordinate of this point
+
+
+ Normalization ensures that any projective coordinate is 1, and therefore that the x, y
+ coordinates reflect those of the equivalent point in an affine coordinate system.
+
+ @return a new ECPoint instance representing the same point, but with normalized coordinates
+
+
+ return the field element encoded with point compression. (S 4.3.6)
+
+
+ Multiplies this ECPoint
by the given number.
+ @param k The multiplicator.
+ @return k * this
.
+
+
+ Elliptic curve points over Fp
+
+
+ Create a point which encodes without point compression.
+
+ @param curve the curve to use
+ @param x affine x co-ordinate
+ @param y affine y co-ordinate
+
+
+ Create a point that encodes with or without point compression.
+
+ @param curve the curve to use
+ @param x affine x co-ordinate
+ @param y affine y co-ordinate
+ @param withCompression if true encode with point compression
+
+
+ Elliptic curve points over F2m
+
+
+ @param curve base curve
+ @param x x point
+ @param y y point
+
+
+ @param curve base curve
+ @param x x point
+ @param y y point
+ @param withCompression true if encode with point compression.
+
+
+ Constructor for point at infinity
+
+
+ Class representing a simple version of a big decimal. A
+ SimpleBigDecimal
is basically a
+ {@link java.math.BigInteger BigInteger} with a few digits on the right of
+ the decimal point. The number of (binary) digits on the right of the decimal
+ point is called the scale
of the SimpleBigDecimal
.
+ Unlike in {@link java.math.BigDecimal BigDecimal}, the scale is not adjusted
+ automatically, but must be set manually. All SimpleBigDecimal
s
+ taking part in the same arithmetic operation must have equal scale. The
+ result of a multiplication of two SimpleBigDecimal
s returns a
+ SimpleBigDecimal
with double scale.
+
+
+ Returns a SimpleBigDecimal
representing the same numerical
+ value as value
.
+ @param value The value of the SimpleBigDecimal
to be
+ created.
+ @param scale The scale of the SimpleBigDecimal
to be
+ created.
+ @return The such created SimpleBigDecimal
.
+
+
+ Constructor for SimpleBigDecimal
. The value of the
+ constructed SimpleBigDecimal
Equals bigInt /
+ 2scale
.
+ @param bigInt The bigInt
value parameter.
+ @param scale The scale of the constructed SimpleBigDecimal
.
+
+
+ Class holding methods for point multiplication based on the window
+ τ-adic nonadjacent form (WTNAF). The algorithms are based on the
+ paper "Improved Algorithms for Arithmetic on Anomalous Binary Curves"
+ by Jerome A. Solinas. The paper first appeared in the Proceedings of
+ Crypto 1997.
+
+
+ The window width of WTNAF. The standard value of 4 is slightly less
+ than optimal for running time, but keeps space requirements for
+ precomputation low. For typical curves, a value of 5 or 6 results in
+ a better running time. When changing this value, the
+ αu
's must be computed differently, see
+ e.g. "Guide to Elliptic Curve Cryptography", Darrel Hankerson,
+ Alfred Menezes, Scott Vanstone, Springer-Verlag New York Inc., 2004,
+ p. 121-122
+
+
+ 24
+
+
+ The αu
's for a=0
as an array
+ of ZTauElement
s.
+
+
+ The αu
's for a=0
as an array
+ of TNAFs.
+
+
+ The αu
's for a=1
as an array
+ of ZTauElement
s.
+
+
+ The αu
's for a=1
as an array
+ of TNAFs.
+
+
+ Computes the norm of an element λ
of
+ Z[τ]
.
+ @param mu The parameter μ
of the elliptic curve.
+ @param lambda The element λ
of
+ Z[τ]
.
+ @return The norm of λ
.
+
+
+ Computes the norm of an element λ
of
+ R[τ]
, where λ = u + vτ
+ and u
and u
are real numbers (elements of
+ R
).
+ @param mu The parameter μ
of the elliptic curve.
+ @param u The real part of the element λ
of
+ R[τ]
.
+ @param v The τ
-adic part of the element
+ λ
of R[τ]
.
+ @return The norm of λ
.
+
+
+ Rounds an element λ
of R[τ]
+ to an element of Z[τ]
, such that their difference
+ has minimal norm. λ
is given as
+ λ = λ0 + λ1τ
.
+ @param lambda0 The component λ0
.
+ @param lambda1 The component λ1
.
+ @param mu The parameter μ
of the elliptic curve. Must
+ equal 1 or -1.
+ @return The rounded element of Z[τ]
.
+ @throws ArgumentException if lambda0
and
+ lambda1
do not have same scale.
+
+
+ Approximate division by n
. For an integer
+ k
, the value λ = s k / n
is
+ computed to c
bits of accuracy.
+ @param k The parameter k
.
+ @param s The curve parameter s0
or
+ s1
.
+ @param vm The Lucas Sequence element Vm
.
+ @param a The parameter a
of the elliptic curve.
+ @param m The bit length of the finite field
+ Fm
.
+ @param c The number of bits of accuracy, i.e. the scale of the returned
+ SimpleBigDecimal
.
+ @return The value λ = s k / n
computed to
+ c
bits of accuracy.
+
+
+ Computes the τ
-adic NAF (non-adjacent form) of an
+ element λ
of Z[τ]
.
+ @param mu The parameter μ
of the elliptic curve.
+ @param lambda The element λ
of
+ Z[τ]
.
+ @return The τ
-adic NAF of λ
.
+
+
+ Applies the operation τ()
to an
+ AbstractF2mPoint
.
+ @param p The AbstractF2mPoint to which τ()
is applied.
+ @return τ(p)
+
+
+ Returns the parameter μ
of the elliptic curve.
+ @param curve The elliptic curve from which to obtain μ
.
+ The curve must be a Koblitz curve, i.e. a
Equals
+ 0
or 1
and b
Equals
+ 1
.
+ @return μ
of the elliptic curve.
+ @throws ArgumentException if the given ECCurve is not a Koblitz
+ curve.
+
+
+ Calculates the Lucas Sequence elements Uk-1
and
+ Uk
or Vk-1
and
+ Vk
.
+ @param mu The parameter μ
of the elliptic curve.
+ @param k The index of the second element of the Lucas Sequence to be
+ returned.
+ @param doV If set to true, computes Vk-1
and
+ Vk
, otherwise Uk-1
and
+ Uk
.
+ @return An array with 2 elements, containing Uk-1
+ and Uk
or Vk-1
+ and Vk
.
+
+
+ Computes the auxiliary value tw
. If the width is
+ 4, then for mu = 1
, tw = 6
and for
+ mu = -1
, tw = 10
+ @param mu The parameter μ
of the elliptic curve.
+ @param w The window width of the WTNAF.
+ @return the auxiliary value tw
+
+
+ Computes the auxiliary values s0
and
+ s1
used for partial modular reduction.
+ @param curve The elliptic curve for which to compute
+ s0
and s1
.
+ @throws ArgumentException if curve
is not a
+ Koblitz curve (Anomalous Binary Curve, ABC).
+
+
+ Partial modular reduction modulo
+ (τm - 1)/(τ - 1)
.
+ @param k The integer to be reduced.
+ @param m The bitlength of the underlying finite field.
+ @param a The parameter a
of the elliptic curve.
+ @param s The auxiliary values s0
and
+ s1
.
+ @param mu The parameter μ of the elliptic curve.
+ @param c The precision (number of bits of accuracy) of the partial
+ modular reduction.
+ @return ρ := k partmod (τm - 1)/(τ - 1)
+
+
+ Multiplies a {@link org.bouncycastle.math.ec.AbstractF2mPoint AbstractF2mPoint}
+ by a BigInteger
using the reduced τ
-adic
+ NAF (RTNAF) method.
+ @param p The AbstractF2mPoint to Multiply.
+ @param k The BigInteger
by which to Multiply p
.
+ @return k * p
+
+
+ Multiplies a {@link org.bouncycastle.math.ec.AbstractF2mPoint AbstractF2mPoint}
+ by an element λ
of Z[τ]
+ using the τ
-adic NAF (TNAF) method.
+ @param p The AbstractF2mPoint to Multiply.
+ @param lambda The element λ
of
+ Z[τ]
.
+ @return λ * p
+
+
+ Multiplies a {@link org.bouncycastle.math.ec.AbstractF2mPoint AbstractF2mPoint}
+ by an element λ
of Z[τ]
+ using the τ
-adic NAF (TNAF) method, given the TNAF
+ of λ
.
+ @param p The AbstractF2mPoint to Multiply.
+ @param u The the TNAF of λ
..
+ @return λ * p
+
+
+ Computes the [τ]
-adic window NAF of an element
+ λ
of Z[τ]
.
+ @param mu The parameter μ of the elliptic curve.
+ @param lambda The element λ
of
+ Z[τ]
of which to compute the
+ [τ]
-adic NAF.
+ @param width The window width of the resulting WNAF.
+ @param pow2w 2width.
+ @param tw The auxiliary value tw
.
+ @param alpha The αu
's for the window width.
+ @return The [τ]
-adic window NAF of
+ λ
.
+
+
+ Does the precomputation for WTNAF multiplication.
+ @param p The ECPoint
for which to do the precomputation.
+ @param a The parameter a
of the elliptic curve.
+ @return The precomputation array for p
.
+
+
+ Class representing an element of Z[τ]
. Let
+ λ
be an element of Z[τ]
. Then
+ λ
is given as λ = u + vτ
. The
+ components u
and v
may be used directly, there
+ are no accessor methods.
+ Immutable class.
+
+
+ The "real" part of λ
.
+
+
+ The "τ
-adic" part of λ
.
+
+
+ Constructor for an element λ
of
+ Z[τ]
.
+ @param u The "real" part of λ
.
+ @param v The "τ
-adic" part of
+ λ
.
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve the curve to use
+ @param x affine x co-ordinate
+ @param y affine y co-ordinate
+
+ @deprecated Use ECCurve.CreatePoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve the curve to use
+ @param x affine x co-ordinate
+ @param y affine y co-ordinate
+ @param withCompression if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(boolean)}
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.CreatePoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.CreatePoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.CreatePoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ Joye's double-add algorithm.
+
+
+ Interface for classes encapsulating a point multiplication algorithm
+ for ECPoint
s.
+
+
+ Multiplies the ECPoint p
by k
, i.e.
+ p
is added k
times to itself.
+ @param p The ECPoint
to be multiplied.
+ @param k The factor by which p
is multiplied.
+ @return p
multiplied by k
.
+
+
+ Class holding precomputation data for fixed-point multiplications.
+
+
+ Array holding the precomputed ECPoint
s used for a fixed
+ point multiplication.
+
+
+ The width used for the precomputation. If a larger width precomputation
+ is already available this may be larger than was requested, so calling
+ code should refer to the actual width.
+
+
+ Class implementing the NAF (Non-Adjacent Form) multiplication algorithm (right-to-left) using
+ mixed coordinates.
+
+
+ By default, addition will be done in Jacobian coordinates, and doubling will be done in
+ Modified Jacobian coordinates (independent of the original coordinate system of each point).
+
+
+ Montgomery ladder.
+
+
+ Class implementing the NAF (Non-Adjacent Form) multiplication algorithm (left-to-right).
+
+
+ Class implementing the NAF (Non-Adjacent Form) multiplication algorithm (right-to-left).
+
+
+ Interface for classes storing precomputation data for multiplication
+ algorithms. Used as a Memento (see GOF patterns) for
+ WNafMultiplier
.
+
+
+ Class implementing the WNAF (Window Non-Adjacent Form) multiplication
+ algorithm.
+
+
+ Multiplies this
by an integer k
using the
+ Window NAF method.
+ @param k The integer by which this
is multiplied.
+ @return A new ECPoint
which equals this
+ multiplied by k
.
+
+
+ Determine window width to use for a scalar multiplication of the given size.
+
+ @param bits the bit-length of the scalar to multiply by
+ @return the window size to use
+
+
+ Class holding precomputation data for the WNAF (Window Non-Adjacent Form)
+ algorithm.
+
+
+ Array holding the precomputed ECPoint
s used for a Window
+ NAF multiplication.
+
+
+ Array holding the negations of the precomputed ECPoint
s used
+ for a Window NAF multiplication.
+
+
+ Holds an ECPoint
representing Twice(this). Used for the
+ Window NAF multiplication to create or extend the precomputed values.
+
+
+ Computes the Window NAF (non-adjacent Form) of an integer.
+ @param width The width w
of the Window NAF. The width is
+ defined as the minimal number w
, such that for any
+ w
consecutive digits in the resulting representation, at
+ most one is non-zero.
+ @param k The integer of which the Window NAF is computed.
+ @return The Window NAF of the given width, such that the following holds:
+ k = ∑i=0l-1 ki2i
+
, where the ki
denote the elements of the
+ returned byte[]
.
+
+
+ Determine window width to use for a scalar multiplication of the given size.
+
+ @param bits the bit-length of the scalar to multiply by
+ @return the window size to use
+
+
+ Determine window width to use for a scalar multiplication of the given size.
+
+ @param bits the bit-length of the scalar to multiply by
+ @param windowSizeCutoffs a monotonically increasing list of bit sizes at which to increment the window width
+ @return the window size to use
+
+
+ Class implementing the WTNAF (Window
+ τ
-adic Non-Adjacent Form) algorithm.
+
+
+ Multiplies a {@link org.bouncycastle.math.ec.AbstractF2mPoint AbstractF2mPoint}
+ by k
using the reduced τ
-adic NAF (RTNAF)
+ method.
+ @param p The AbstractF2mPoint to multiply.
+ @param k The integer by which to multiply k
.
+ @return p
multiplied by k
.
+
+
+ Multiplies a {@link org.bouncycastle.math.ec.AbstractF2mPoint AbstractF2mPoint}
+ by an element λ
of Z[τ]
using
+ the τ
-adic NAF (TNAF) method.
+ @param p The AbstractF2mPoint to multiply.
+ @param lambda The element λ
of
+ Z[τ]
of which to compute the
+ [τ]
-adic NAF.
+ @return p
multiplied by λ
.
+
+
+ Multiplies a {@link org.bouncycastle.math.ec.AbstractF2mPoint AbstractF2mPoint}
+ by an element λ
of Z[τ]
+ using the window τ
-adic NAF (TNAF) method, given the
+ WTNAF of λ
.
+ @param p The AbstractF2mPoint to multiply.
+ @param u The the WTNAF of λ
..
+ @return λ * p
+
+
+ Class holding precomputation data for the WTNAF (Window
+ τ
-adic Non-Adjacent Form) algorithm.
+
+
+ Array holding the precomputed AbstractF2mPoint
s used for the
+ WTNAF multiplication in
+ {@link org.bouncycastle.math.ec.multiplier.WTauNafMultiplier.multiply()
+ WTauNafMultiplier.multiply()}
.
+
+
+ 'Zeroless' Signed Digit Left-to-Right.
+
+
+ 'Zeroless' Signed Digit Right-to-Left.
+
+
+
+
+ BasicOcspResponse ::= SEQUENCE {
+ tbsResponseData ResponseData,
+ signatureAlgorithm AlgorithmIdentifier,
+ signature BIT STRING,
+ certs [0] EXPLICIT SEQUENCE OF Certificate OPTIONAL
+ }
+
+
+
+
+ The DER encoding of the tbsResponseData field.
+ In the event of an encoding error.
+
+
+ The certificates, if any, associated with the response.
+ In the event of an encoding error.
+
+
+
+ Verify the signature against the tbsResponseData object we contain.
+
+
+
+ The ASN.1 encoded representation of this object.
+
+
+ Generator for basic OCSP response objects.
+
+
+ basic constructor
+
+
+ construct with the responderID to be the SHA-1 keyHash of the passed in public key.
+
+
+ Add a response for a particular Certificate ID.
+
+ @param certID certificate ID details
+ @param certStatus status of the certificate - null if okay
+
+
+ Add a response for a particular Certificate ID.
+
+ @param certID certificate ID details
+ @param certStatus status of the certificate - null if okay
+ @param singleExtensions optional extensions
+
+
+ Add a response for a particular Certificate ID.
+
+ @param certID certificate ID details
+ @param nextUpdate date when next update should be requested
+ @param certStatus status of the certificate - null if okay
+ @param singleExtensions optional extensions
+
+
+ Add a response for a particular Certificate ID.
+
+ @param certID certificate ID details
+ @param thisUpdate date this response was valid on
+ @param nextUpdate date when next update should be requested
+ @param certStatus status of the certificate - null if okay
+ @param singleExtensions optional extensions
+
+
+ Set the extensions for the response.
+
+ @param responseExtensions the extension object to carry.
+
+
+
+ Generate the signed response using the passed in signature calculator.
+
+ Implementation of signing calculator factory.
+ The certificate chain associated with the response signer.
+ "produced at" date.
+
+
+
+ Return an IEnumerable of the signature names supported by the generator.
+
+ @return an IEnumerable containing recognised names.
+
+
+ create from an issuer certificate and the serial number of the
+ certificate it signed.
+ @exception OcspException if any problems occur creating the id fields.
+
+
+ return the serial number for the certificate associated
+ with this request.
+
+
+ Create a new CertificateID for a new serial number derived from a previous one
+ calculated for the same CA certificate.
+
+ @param original the previously calculated CertificateID for the CA.
+ @param newSerialNumber the serial number for the new certificate of interest.
+
+ @return a new CertificateID for newSerialNumber
+
+
+
+ OcspRequest ::= SEQUENCE {
+ tbsRequest TBSRequest,
+ optionalSignature [0] EXPLICIT Signature OPTIONAL }
+
+ TBSRequest ::= SEQUENCE {
+ version [0] EXPLICIT Version DEFAULT v1,
+ requestorName [1] EXPLICIT GeneralName OPTIONAL,
+ requestList SEQUENCE OF Request,
+ requestExtensions [2] EXPLICIT Extensions OPTIONAL }
+
+ Signature ::= SEQUENCE {
+ signatureAlgorithm AlgorithmIdentifier,
+ signature BIT STRING,
+ certs [0] EXPLICIT SEQUENCE OF Certificate OPTIONAL}
+
+ Version ::= INTEGER { v1(0) }
+
+ Request ::= SEQUENCE {
+ reqCert CertID,
+ singleRequestExtensions [0] EXPLICIT Extensions OPTIONAL }
+
+ CertID ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ issuerNameHash OCTET STRING, -- Hash of Issuer's DN
+ issuerKeyHash OCTET STRING, -- Hash of Issuers public key
+ serialNumber CertificateSerialNumber }
+
+
+
+ Return the DER encoding of the tbsRequest field.
+ @return DER encoding of tbsRequest
+ @throws OcspException in the event of an encoding error.
+
+
+ return the object identifier representing the signature algorithm
+
+
+ If the request is signed return a possibly empty CertStore containing the certificates in the
+ request. If the request is not signed the method returns null.
+
+ @return null if not signed, a CertStore otherwise
+ @throws OcspException
+
+
+ Return whether or not this request is signed.
+
+ @return true if signed false otherwise.
+
+
+ Verify the signature against the TBSRequest object we contain.
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ Add a request for the given CertificateID.
+
+ @param certId certificate ID of interest
+
+
+ Add a request with extensions
+
+ @param certId certificate ID of interest
+ @param singleRequestExtensions the extensions to attach to the request
+
+
+ Set the requestor name to the passed in X509Principal
+
+ @param requestorName a X509Principal representing the requestor name.
+
+
+ Generate an unsigned request
+
+ @return the OcspReq
+ @throws OcspException
+
+
+ Return an IEnumerable of the signature names supported by the generator.
+
+ @return an IEnumerable containing recognised names.
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ base generator for an OCSP response - at the moment this only supports the
+ generation of responses containing BasicOCSP responses.
+
+
+ note 4 is not used.
+
+
+ Carrier for a ResponderID.
+
+
+ wrapper for the RevokedInfo object
+
+
+ return the revocation reason. Note: this field is optional, test for it
+ with hasRevocationReason() first.
+ @exception InvalidOperationException if a reason is asked for and none is avaliable
+
+
+ Return the status object for the response - null indicates good.
+
+ @return the status object for the response, null if it is good.
+
+
+ return the NextUpdate value - note: this is an optional field so may
+ be returned as null.
+
+ @return nextUpdate, or null if not present.
+
+
+ wrapper for the UnknownInfo object
+
+
+
+ Utility class for creating IBasicAgreement objects from their names/Oids
+
+
+
+
+ Cipher Utility class contains methods that can not be specifically grouped into other classes.
+
+
+
+
+ Returns a ObjectIdentifier for a give encoding.
+
+ A string representation of the encoding.
+ A DerObjectIdentifier, null if the Oid is not available.
+
+
+
+ Utility class for creating IDigest objects from their names/Oids
+
+
+
+
+ Returns a ObjectIdentifier for a given digest mechanism.
+
+ A string representation of the digest meanism.
+ A DerObjectIdentifier, null if the Oid is not available.
+
+
+
+ A class containing methods to interface the BouncyCastle world to the .NET Crypto world.
+
+
+
+
+ Create an System.Security.Cryptography.X509Certificate from an X509Certificate Structure.
+
+
+ A System.Security.Cryptography.X509Certificate.
+
+
+
+ Utility class for creating HMac object from their names/Oids
+
+
+
+
+
+
+
+
+
+ Returns a ObjectIdentifier for a give encoding.
+
+ A string representation of the encoding.
+ A DerObjectIdentifier, null if the Oid is not available.
+
+
+
+ Create and auto-seed an instance based on the given algorithm.
+
+ Equivalent to GetInstance(algorithm, true)
+ e.g. "SHA256PRNG"
+
+
+
+ Create an instance based on the given algorithm, with optional auto-seeding
+
+ e.g. "SHA256PRNG"
+ If true, the instance will be auto-seeded.
+
+
+
+ To replicate existing predictable output, replace with GetInstance("SHA1PRNG", false), followed by SetSeed(seed)
+
+
+
+ Use the specified instance of IRandomGenerator as random source.
+
+ This constructor performs no seeding of either the IRandomGenerator or the
+ constructed SecureRandom. It is the responsibility of the client to provide
+ proper seed material as necessary/appropriate for the given IRandomGenerator
+ implementation.
+
+ The source to generate all random bytes from.
+
+
+ base constructor.
+
+
+ create a SecurityUtilityException with the given message.
+
+ @param message the message to be carried with the exception.
+
+
+
+ Signer Utility class contains methods that can not be specifically grouped into other classes.
+
+
+
+
+ Returns an ObjectIdentifier for a given encoding.
+
+ A string representation of the encoding.
+ A DerObjectIdentifier, null if the OID is not available.
+
+
+
+ Utility class for creating IWrapper objects from their names/Oids
+
+
+
+ PEM generator for the original set of PEM objects used in Open SSL.
+
+
+ Class for reading OpenSSL PEM encoded streams containing
+ X509 certificates, PKCS8 encoded keys and PKCS7 objects.
+
+ In the case of PKCS7 objects the reader will return a CMS ContentInfo object. Keys and
+ Certificates will be returned using the appropriate java.security type.
+
+
+ Create a new PemReader
+
+ @param reader the Reader
+
+
+ Create a new PemReader with a password finder
+
+ @param reader the Reader
+ @param pFinder the password finder
+
+
+ Reads in a X509Certificate.
+
+ @return the X509Certificate
+ @throws IOException if an I/O error occured
+
+
+ Reads in a X509CRL.
+
+ @return the X509Certificate
+ @throws IOException if an I/O error occured
+
+
+ Reads in a PKCS10 certification request.
+
+ @return the certificate request.
+ @throws IOException if an I/O error occured
+
+
+ Reads in a X509 Attribute Certificate.
+
+ @return the X509 Attribute Certificate
+ @throws IOException if an I/O error occured
+
+
+ Reads in a PKCS7 object. This returns a ContentInfo object suitable for use with the CMS
+ API.
+
+ @return the X509Certificate
+ @throws IOException if an I/O error occured
+
+
+ Read a Key Pair
+
+
+ General purpose writer for OpenSSL PEM objects.
+
+
+ The TextWriter object to write the output to.
+
+
+ Constructor for an unencrypted private key PEM object.
+
+ @param key private key to be encoded.
+
+
+ Constructor for an encrypted private key PEM object.
+
+ @param key private key to be encoded
+ @param algorithm encryption algorithm to use
+ @param provider provider to use
+ @throws NoSuchAlgorithmException if algorithm/mode cannot be found
+
+
+
+ A class for verifying and creating Pkcs10 Certification requests.
+
+
+ CertificationRequest ::= Sequence {
+ certificationRequestInfo CertificationRequestInfo,
+ signatureAlgorithm AlgorithmIdentifier{{ SignatureAlgorithms }},
+ signature BIT STRING
+ }
+
+ CertificationRequestInfo ::= Sequence {
+ version Integer { v1(0) } (v1,...),
+ subject Name,
+ subjectPKInfo SubjectPublicKeyInfo{{ PKInfoAlgorithms }},
+ attributes [0] Attributes{{ CRIAttributes }}
+ }
+
+ Attributes { ATTRIBUTE:IOSet } ::= Set OF Attr{{ IOSet }}
+
+ Attr { ATTRIBUTE:IOSet } ::= Sequence {
+ type ATTRIBUTE.&id({IOSet}),
+ values Set SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{\@type})
+ }
+
+ see
+
+
+
+ Instantiate a Pkcs10CertificationRequest object with the necessary credentials.
+
+ Name of Sig Alg.
+ X509Name of subject eg OU="My unit." O="My Organisatioin" C="au"
+ Public Key to be included in cert reqest.
+ ASN1Set of Attributes.
+ Matching Private key for nominated (above) public key to be used to sign the request.
+
+
+
+ Instantiate a Pkcs10CertificationRequest object with the necessary credentials.
+
+ The factory for signature calculators to sign the PKCS#10 request with.
+ X509Name of subject eg OU="My unit." O="My Organisatioin" C="au"
+ Public Key to be included in cert reqest.
+ ASN1Set of Attributes.
+ Matching Private key for nominated (above) public key to be used to sign the request.
+
+
+
+ Get the public key.
+
+ The public key.
+
+
+
+ Verify Pkcs10 Cert Request is valid.
+
+ true = valid.
+
+
+
+ A class for creating and verifying Pkcs10 Certification requests (this is an extension on ).
+ The requests are made using delay signing. This is useful for situations where
+ the private key is in another environment and not directly accessible (e.g. HSM)
+ So the first step creates the request, then the signing is done outside this
+ object and the signature is then used to complete the request.
+
+
+ CertificationRequest ::= Sequence {
+ certificationRequestInfo CertificationRequestInfo,
+ signatureAlgorithm AlgorithmIdentifier{{ SignatureAlgorithms }},
+ signature BIT STRING
+ }
+
+ CertificationRequestInfo ::= Sequence {
+ version Integer { v1(0) } (v1,...),
+ subject Name,
+ subjectPKInfo SubjectPublicKeyInfo{{ PKInfoAlgorithms }},
+ attributes [0] Attributes{{ CRIAttributes }}
+ }
+
+ Attributes { ATTRIBUTE:IOSet } ::= Set OF Attr{{ IOSet }}
+
+ Attr { ATTRIBUTE:IOSet } ::= Sequence {
+ type ATTRIBUTE.&id({IOSet}),
+ values Set SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{\@type})
+ }
+
+ see
+
+
+
+ Instantiate a Pkcs10CertificationRequest object with the necessary credentials.
+
+ Name of Sig Alg.
+ X509Name of subject eg OU="My unit." O="My Organisatioin" C="au"
+ Public Key to be included in cert reqest.
+ ASN1Set of Attributes.
+
+ After the object is constructed use the and finally the
+ SignRequest methods to finalize the request.
+
+
+
+ simply return the cert entry for the private key
+
+
+ Utility class for reencoding PKCS#12 files to definite length.
+
+
+ Just re-encode the outer layer of the PKCS#12 file to definite length encoding.
+
+ @param berPKCS12File - original PKCS#12 file
+ @return a byte array representing the DER encoding of the PFX structure
+ @throws IOException
+
+
+ Re-encode the PKCS#12 structure to definite length encoding at the inner layer
+ as well, recomputing the MAC accordingly.
+
+ @param berPKCS12File - original PKCS12 file.
+ @param provider - provider to use for MAC calculation.
+ @return a byte array representing the DER encoding of the PFX structure.
+ @throws IOException on parsing, encoding errors.
+
+
+
+ Returns the revocationDate.
+
+
+
+
+ Returns the certStatus.
+
+
+
+ Returns an immutable Set
of X.509 attribute certificate
+ extensions that this PkixAttrCertChecker
supports or
+ null
if no extensions are supported.
+
+ Each element of the set is a String
representing the
+ Object Identifier (OID) of the X.509 extension that is supported.
+
+
+ All X.509 attribute certificate extensions that a
+ PkixAttrCertChecker
might possibly be able to process
+ should be included in the set.
+
+
+ @return an immutable Set
of X.509 extension OIDs (in
+ String
format) supported by this
+ PkixAttrCertChecker
, or null
if no
+ extensions are supported
+
+
+ Performs checks on the specified attribute certificate. Every handled
+ extension is rmeoved from the unresolvedCritExts
+ collection.
+
+ @param attrCert The attribute certificate to be checked.
+ @param certPath The certificate path which belongs to the attribute
+ certificate issuer public key certificate.
+ @param holderCertPath The certificate path which belongs to the holder
+ certificate.
+ @param unresolvedCritExts a Collection
of OID strings
+ representing the current set of unresolved critical extensions
+ @throws CertPathValidatorException if the specified attribute certificate
+ does not pass the check.
+
+
+ Returns a clone of this object.
+
+ @return a copy of this PkixAttrCertChecker
+
+
+ Build and validate a CertPath using the given parameter.
+
+ @param params PKIXBuilderParameters object containing all information to
+ build the CertPath
+
+
+ CertPathValidatorSpi implementation for X.509 Attribute Certificates la RFC 3281.
+
+ @see org.bouncycastle.x509.ExtendedPkixParameters
+
+
+ Validates an attribute certificate with the given certificate path.
+
+
+ params
must be an instance of
+ ExtendedPkixParameters
.
+
+ The target constraints in the params
must be an
+ X509AttrCertStoreSelector
with at least the attribute
+ certificate criterion set. Obey that also target informations may be
+ necessary to correctly validate this attribute certificate.
+
+ The attribute certificate issuer must be added to the trusted attribute
+ issuers with {@link ExtendedPkixParameters#setTrustedACIssuers(Set)}.
+
+ @param certPath The certificate path which belongs to the attribute
+ certificate issuer public key certificate.
+ @param params The PKIX parameters.
+ @return A PKIXCertPathValidatorResult
of the result of
+ validating the certPath
.
+ @throws InvalidAlgorithmParameterException if params
is
+ inappropriate for this validator.
+ @throws CertPathValidatorException if the verification fails.
+
+
+
+ Summary description for PkixBuilderParameters.
+
+
+
+ Returns an instance of PkixBuilderParameters
.
+
+ This method can be used to get a copy from other
+ PKIXBuilderParameters
, PKIXParameters
,
+ and ExtendedPKIXParameters
instances.
+
+
+ @param pkixParams The PKIX parameters to create a copy of.
+ @return An PkixBuilderParameters
instance.
+
+
+
+ Excluded certificates are not used for building a certification path.
+
+ the excluded certificates.
+
+
+
+ Sets the excluded certificates which are not used for building a
+ certification path. If the ISet
is null
an
+ empty set is assumed.
+
+
+ The given set is cloned to protect it against subsequent modifications.
+
+ The excluded certificates to set.
+
+
+ Can alse handle ExtendedPKIXBuilderParameters
and
+ PKIXBuilderParameters
.
+
+ @param params Parameters to set.
+ @see org.bouncycastle.x509.ExtendedPKIXParameters#setParams(java.security.cert.PKIXParameters)
+
+
+ Makes a copy of this PKIXParameters
object. Changes to the
+ copy will not affect the original and vice versa.
+
+ @return a copy of this PKIXParameters
object
+
+
+ An immutable sequence of certificates (a certification path).
+
+ This is an abstract class that defines the methods common to all CertPaths.
+ Subclasses can handle different kinds of certificates (X.509, PGP, etc.).
+
+ All CertPath objects have a type, a list of Certificates, and one or more
+ supported encodings. Because the CertPath class is immutable, a CertPath
+ cannot change in any externally visible way after being constructed. This
+ stipulation applies to all public fields and methods of this class and any
+ added or overridden by subclasses.
+
+ The type is a string that identifies the type of Certificates in the
+ certification path. For each certificate cert in a certification path
+ certPath, cert.getType().equals(certPath.getType()) must be true.
+
+ The list of Certificates is an ordered List of zero or more Certificates.
+ This List and all of the Certificates contained in it must be immutable.
+
+ Each CertPath object must support one or more encodings so that the object
+ can be translated into a byte array for storage or transmission to other
+ parties. Preferably, these encodings should be well-documented standards
+ (such as PKCS#7). One of the encodings supported by a CertPath is considered
+ the default encoding. This encoding is used if no encoding is explicitly
+ requested (for the {@link #getEncoded()} method, for instance).
+
+ All CertPath objects are also Serializable. CertPath objects are resolved
+ into an alternate {@link CertPathRep} object during serialization. This
+ allows a CertPath object to be serialized into an equivalent representation
+ regardless of its underlying implementation.
+
+ CertPath objects can be created with a CertificateFactory or they can be
+ returned by other classes, such as a CertPathBuilder.
+
+ By convention, X.509 CertPaths (consisting of X509Certificates), are ordered
+ starting with the target certificate and ending with a certificate issued by
+ the trust anchor. That is, the issuer of one certificate is the subject of
+ the following one. The certificate representing the
+ {@link TrustAnchor TrustAnchor} should not be included in the certification
+ path. Unvalidated X.509 CertPaths may not follow these conventions. PKIX
+ CertPathValidators will detect any departure from these conventions that
+ cause the certification path to be invalid and throw a
+ CertPathValidatorException.
+
+ Concurrent Access
+
+ All CertPath objects must be thread-safe. That is, multiple threads may
+ concurrently invoke the methods defined in this class on a single CertPath
+ object (or more than one) with no ill effects. This is also true for the List
+ returned by CertPath.getCertificates.
+
+ Requiring CertPath objects to be immutable and thread-safe allows them to be
+ passed around to various pieces of code without worrying about coordinating
+ access. Providing this thread-safety is generally not difficult, since the
+ CertPath and List objects in question are immutable.
+
+ @see CertificateFactory
+ @see CertPathBuilder
+
+ CertPath implementation for X.509 certificates.
+
+
+
+ @param certs
+
+
+ Creates a CertPath of the specified type.
+ This constructor is protected because most users should use
+ a CertificateFactory to create CertPaths.
+ @param type the standard name of the type of Certificatesin this path
+
+
+
+ Creates a CertPath of the specified type.
+ This constructor is protected because most users should use
+ a CertificateFactory to create CertPaths.
+
+ @param type the standard name of the type of Certificatesin this path
+
+
+
+ Returns an iteration of the encodings supported by this
+ certification path, with the default encoding
+ first. Attempts to modify the returned Iterator via its
+ remove method result in an UnsupportedOperationException.
+
+ @return an Iterator over the names of the supported encodings (as Strings)
+
+
+
+ Compares this certification path for equality with the specified object.
+ Two CertPaths are equal if and only if their types are equal and their
+ certificate Lists (and by implication the Certificates in those Lists)
+ are equal. A CertPath is never equal to an object that is not a CertPath.
+
+ This algorithm is implemented by this method. If it is overridden, the
+ behavior specified here must be maintained.
+
+ @param other
+ the object to test for equality with this certification path
+
+ @return true if the specified object is equal to this certification path,
+ false otherwise
+
+ @see Object#hashCode() Object.hashCode()
+
+
+ Returns the encoded form of this certification path, using
+ the default encoding.
+
+ @return the encoded bytes
+ @exception CertificateEncodingException if an encoding error occurs
+
+
+
+ Returns the encoded form of this certification path, using
+ the specified encoding.
+
+ @param encoding the name of the encoding to use
+ @return the encoded bytes
+ @exception CertificateEncodingException if an encoding error
+ occurs or the encoding requested is not supported
+
+
+
+
+ Returns the list of certificates in this certification
+ path.
+
+
+
+ Return a DERObject containing the encoded certificate.
+
+ @param cert the X509Certificate object to be encoded
+
+ @return the DERObject
+
+
+
+ Implements the PKIX CertPathBuilding algorithm for BouncyCastle.
+
+ @see CertPathBuilderSpi
+
+
+ Build and validate a CertPath using the given parameter.
+
+ @param params PKIXBuilderParameters object containing all information to
+ build the CertPath
+
+
+
+ Summary description for PkixCertPathBuilderException.
+
+
+
+
+ Summary description for PkixCertPathBuilderResult.
+
+
+
+ * Initializes the internal state of this PKIXCertPathChecker
.
+ *
+ * The forward
flag specifies the order that certificates
+ * will be passed to the {@link #check check} method (forward or reverse). A
+ * PKIXCertPathChecker
must support reverse checking
+ * and may support forward checking.
+ *
+ *
+ * @param forward
+ * the order that certificates are presented to the
+ * check
method. If true
,
+ * certificates are presented from target to most-trusted CA
+ * (forward); if false
, from most-trusted CA to
+ * target (reverse).
+ * @exception CertPathValidatorException
+ * if this PKIXCertPathChecker
is unable to
+ * check certificates in the specified order; it should never
+ * be thrown if the forward flag is false since reverse
+ * checking must be supported
+
+
+ Indicates if forward checking is supported. Forward checking refers to
+ the ability of the PKIXCertPathChecker
to perform its
+ checks when certificates are presented to the check
method
+ in the forward direction (from target to most-trusted CA).
+
+ @return true
if forward checking is supported,
+ false
otherwise
+
+
+ * Returns an immutable Set
of X.509 certificate extensions
+ * that this PKIXCertPathChecker
supports (i.e. recognizes,
+ * is able to process), or null
if no extensions are
+ * supported.
+ *
+ * Each element of the set is a String
representing the
+ * Object Identifier (OID) of the X.509 extension that is supported. The OID
+ * is represented by a set of nonnegative integers separated by periods.
+ *
+ * All X.509 certificate extensions that a PKIXCertPathChecker
+ * might possibly be able to process should be included in the set.
+ *
+ *
+ * @return an immutable Set
of X.509 extension OIDs (in
+ * String
format) supported by this
+ * PKIXCertPathChecker
, or null
if no
+ * extensions are supported
+
+
+ Performs the check(s) on the specified certificate using its internal
+ state and removes any critical extensions that it processes from the
+ specified collection of OID strings that represent the unresolved
+ critical extensions. The certificates are presented in the order
+ specified by the init
method.
+
+ @param cert
+ the Certificate
to be checked
+ @param unresolvedCritExts
+ a Collection
of OID strings representing the
+ current set of unresolved critical extensions
+ @exception CertPathValidatorException
+ if the specified certificate does not pass the check
+
+
+ Returns a clone of this object. Calls the Object.clone()
+ method. All subclasses which maintain state must support and override
+ this method, if necessary.
+
+ @return a copy of this PKIXCertPathChecker
+
+
+ The Service Provider Interface (SPI)
+ for the {@link CertPathValidator CertPathValidator} class. All
+ CertPathValidator
implementations must include a class (the
+ SPI class) that extends this class (CertPathValidatorSpi
)
+ and implements all of its methods. In general, instances of this class
+ should only be accessed through the CertPathValidator
class.
+ For details, see the Java Cryptography Architecture.
+
+ Concurrent Access
+
+ Instances of this class need not be protected against concurrent
+ access from multiple threads. Threads that need to access a single
+ CertPathValidatorSpi
instance concurrently should synchronize
+ amongst themselves and provide the necessary locking before calling the
+ wrapping CertPathValidator
object.
+
+ However, implementations of CertPathValidatorSpi
may still
+ encounter concurrency issues, since multiple threads each
+ manipulating a different CertPathValidatorSpi
instance need not
+ synchronize.
+
+ CertPathValidatorSpi implementation for X.509 Certificate validation a la RFC
+ 3280.
+
+
+
+ An exception indicating one of a variety of problems encountered when
+ validating a certification path.
+
+ A CertPathValidatorException
provides support for wrapping
+ exceptions. The {@link #getCause getCause} method returns the throwable,
+ if any, that caused this exception to be thrown.
+
+ A CertPathValidatorException
may also include the
+ certification path that was being validated when the exception was thrown
+ and the index of the certificate in the certification path that caused the
+ exception to be thrown. Use the {@link #getCertPath getCertPath} and
+ {@link #getIndex getIndex} methods to retrieve this information.
+
+ Concurrent Access
+
+ Unless otherwise specified, the methods defined in this class are not
+ thread-safe. Multiple threads that need to access a single
+ object concurrently should synchronize amongst themselves and
+ provide the necessary locking. Multiple threads each manipulating
+ separate objects need not synchronize.
+
+ @see CertPathValidator
+
+
+
+
+ Creates a PkixCertPathValidatorException
with the given detail
+ message. A detail message is a String
that describes this
+ particular exception.
+
+ the detail message
+
+
+
+ Creates a PkixCertPathValidatorException
with the specified
+ detail message and cause.
+
+ the detail message
+ the cause (which is saved for later retrieval by the
+ {@link #getCause getCause()} method). (A null
+ value is permitted, and indicates that the cause is
+ nonexistent or unknown.)
+
+
+
+ Creates a PkixCertPathValidatorException
with the specified
+ detail message, cause, certification path, and index.
+
+ the detail message (or null
if none)
+ the cause (or null
if none)
+ the certification path that was in the process of being
+ validated when the error was encountered
+ the index of the certificate in the certification path that *
+
+
+
+ Returns the detail message for this CertPathValidatorException
.
+
+ the detail message, or null
if neither the message nor cause were specified
+
+
+ Returns the certification path that was being validated when the
+ exception was thrown.
+
+ @return the CertPath
that was being validated when the
+ exception was thrown (or null
if not specified)
+
+
+ Returns the index of the certificate in the certification path that
+ caused the exception to be thrown. Note that the list of certificates in
+ a CertPath
is zero based. If no index has been set, -1 is
+ returned.
+
+ @return the index that has been set, or -1 if none has been set
+
+
+
+ Summary description for PkixCertPathValidatorResult.
+
+
+
+
+ Summary description for PkixCertPathValidatorUtilities.
+
+
+
+
+ key usage bits
+
+
+
+
+ Search the given Set of TrustAnchor's for one that is the
+ issuer of the given X509 certificate.
+
+ the X509 certificate
+ a Set of TrustAnchor's
+ the TrustAnchor
object if found or
+ null
if not.
+
+ @exception
+
+
+
+ Returns the issuer of an attribute certificate or certificate.
+
+ The attribute certificate or certificate.
+ The issuer as X500Principal
.
+
+
+ Return the next working key inheriting DSA parameters if necessary.
+
+ This methods inherits DSA parameters from the indexed certificate or
+ previous certificates in the certificate chain to the returned
+ PublicKey
. The list is searched upwards, meaning the end
+ certificate is at position 0 and previous certificates are following.
+
+
+ If the indexed certificate does not contain a DSA key this method simply
+ returns the public key. If the DSA key already contains DSA parameters
+ the key is also only returned.
+
+
+ @param certs The certification path.
+ @param index The index of the certificate which contains the public key
+ which should be extended with DSA parameters.
+ @return The public key of the certificate in list position
+ index
extended with DSA parameters if applicable.
+ @throws Exception if DSA parameters cannot be inherited.
+
+
+
+ Return a Collection of all certificates or attribute certificates found
+ in the X509Store's that are matching the certSelect criteriums.
+
+ a {@link Selector} object that will be used to select
+ the certificates
+ a List containing only X509Store objects. These
+ are used to search for certificates.
+ a Collection of all found or
+ objects.
+ May be empty but never null
.
+
+
+
+ Add the CRL issuers from the cRLIssuer field of the distribution point or
+ from the certificate if not given to the issuer criterion of the
+ selector
.
+
+ The issuerPrincipals
are a collection with a single
+ X500Principal
for X509Certificate
s. For
+ {@link X509AttributeCertificate}s the issuer may contain more than one
+ X500Principal
.
+
+
+ @param dp The distribution point.
+ @param issuerPrincipals The issuers of the certificate or attribute
+ certificate which contains the distribution point.
+ @param selector The CRL selector.
+ @param pkixParams The PKIX parameters containing the cert stores.
+ @throws Exception if an exception occurs while processing.
+ @throws ClassCastException if issuerPrincipals
does not
+ contain only X500Principal
s.
+
+
+ Fetches complete CRLs according to RFC 3280.
+
+ @param dp The distribution point for which the complete CRL
+ @param cert The X509Certificate
or
+ {@link org.bouncycastle.x509.X509AttributeCertificate} for
+ which the CRL should be searched.
+ @param currentDate The date for which the delta CRLs must be valid.
+ @param paramsPKIX The extended PKIX parameters.
+ @return A Set
of X509CRL
s with complete
+ CRLs.
+ @throws Exception if an exception occurs while picking the CRLs
+ or no CRLs are found.
+
+
+ Fetches delta CRLs according to RFC 3280 section 5.2.4.
+
+ @param currentDate The date for which the delta CRLs must be valid.
+ @param paramsPKIX The extended PKIX parameters.
+ @param completeCRL The complete CRL the delta CRL is for.
+ @return A Set
of X509CRL
s with delta CRLs.
+ @throws Exception if an exception occurs while picking the delta
+ CRLs.
+
+
+ Find the issuer certificates of a given certificate.
+
+ @param cert
+ The certificate for which an issuer should be found.
+ @param pkixParams
+ @return A Collection
object containing the issuer
+ X509Certificate
s. Never null
.
+
+ @exception Exception
+ if an error occurs.
+
+
+
+ Extract the value of the given extension, if it exists.
+
+ The extension object.
+ The object identifier to obtain.
+ Asn1Object
+ if the extension cannot be read.
+
+
+
+ crl checking
+ Return a Collection of all CRLs found in the X509Store's that are
+ matching the crlSelect criteriums.
+
+ a {@link X509CRLStoreSelector} object that will be used
+ to select the CRLs
+ a List containing only {@link org.bouncycastle.x509.X509Store
+ X509Store} objects. These are used to search for CRLs
+ a Collection of all found {@link X509CRL X509CRL} objects. May be
+ empty but never null
.
+
+
+
+ Returns the intersection of the permitted IP ranges in
+ permitted
with ip
.
+
+ @param permitted A Set
of permitted IP addresses with
+ their subnet mask as byte arrays.
+ @param ips The IP address with its subnet mask.
+ @return The Set
of permitted IP ranges intersected with
+ ip
.
+
+
+ Returns the union of the excluded IP ranges in excluded
+ with ip
.
+
+ @param excluded A Set
of excluded IP addresses with their
+ subnet mask as byte arrays.
+ @param ip The IP address with its subnet mask.
+ @return The Set
of excluded IP ranges unified with
+ ip
as byte arrays.
+
+
+ Calculates the union if two IP ranges.
+
+ @param ipWithSubmask1 The first IP address with its subnet mask.
+ @param ipWithSubmask2 The second IP address with its subnet mask.
+ @return A Set
with the union of both addresses.
+
+
+ Calculates the interesction if two IP ranges.
+
+ @param ipWithSubmask1 The first IP address with its subnet mask.
+ @param ipWithSubmask2 The second IP address with its subnet mask.
+ @return A Set
with the single IP address with its subnet
+ mask as a byte array or an empty Set
.
+
+
+ Concatenates the IP address with its subnet mask.
+
+ @param ip The IP address.
+ @param subnetMask Its subnet mask.
+ @return The concatenated IP address with its subnet mask.
+
+
+ Splits the IP addresses and their subnet mask.
+
+ @param ipWithSubmask1 The first IP address with the subnet mask.
+ @param ipWithSubmask2 The second IP address with the subnet mask.
+ @return An array with two elements. Each element contains the IP address
+ and the subnet mask in this order.
+
+
+ Based on the two IP addresses and their subnet masks the IP range is
+ computed for each IP address - subnet mask pair and returned as the
+ minimum IP address and the maximum address of the range.
+
+ @param ip1 The first IP address.
+ @param subnetmask1 The subnet mask of the first IP address.
+ @param ip2 The second IP address.
+ @param subnetmask2 The subnet mask of the second IP address.
+ @return A array with two elements. The first/second element contains the
+ min and max IP address of the first/second IP address and its
+ subnet mask.
+
+
+ Checks if the IP ip
is included in the permitted ISet
+ permitted
.
+
+ @param permitted A Set
of permitted IP addresses with
+ their subnet mask as byte arrays.
+ @param ip The IP address.
+ @throws PkixNameConstraintValidatorException
+ if the IP is not permitted.
+
+
+ Checks if the IP ip
is included in the excluded ISet
+ excluded
.
+
+ @param excluded A Set
of excluded IP addresses with their
+ subnet mask as byte arrays.
+ @param ip The IP address.
+ @throws PkixNameConstraintValidatorException
+ if the IP is excluded.
+
+
+ Checks if the IP address ip
is constrained by
+ constraint
.
+
+ @param ip The IP address.
+ @param constraint The constraint. This is an IP address concatenated with
+ its subnetmask.
+ @return true
if constrained, false
+ otherwise.
+
+
+ The common part of email1
and email2
is
+ added to the union union
. If email1
and
+ email2
have nothing in common they are added both.
+
+ @param email1 Email address constraint 1.
+ @param email2 Email address constraint 2.
+ @param union The union.
+
+
+ The most restricting part from email1
and
+ email2
is added to the intersection intersect
.
+
+ @param email1 Email address constraint 1.
+ @param email2 Email address constraint 2.
+ @param intersect The intersection.
+
+
+ Checks if the given GeneralName is in the permitted ISet.
+
+ @param name The GeneralName
+ @throws PkixNameConstraintValidatorException
+ If the name
+
+
+ Check if the given GeneralName is contained in the excluded ISet.
+
+ @param name The GeneralName.
+ @throws PkixNameConstraintValidatorException
+ If the name
is
+ excluded.
+
+
+ Updates the permitted ISet of these name constraints with the intersection
+ with the given subtree.
+
+ @param permitted The permitted subtrees
+
+
+ Adds a subtree to the excluded ISet of these name constraints.
+
+ @param subtree A subtree with an excluded GeneralName.
+
+
+ Returns the maximum IP address.
+
+ @param ip1 The first IP address.
+ @param ip2 The second IP address.
+ @return The maximum IP address.
+
+
+ Returns the minimum IP address.
+
+ @param ip1 The first IP address.
+ @param ip2 The second IP address.
+ @return The minimum IP address.
+
+
+ Compares IP address ip1
with ip2
. If ip1
+ is equal to ip2 0 is returned. If ip1 is bigger 1 is returned, -1
+ otherwise.
+
+ @param ip1 The first IP address.
+ @param ip2 The second IP address.
+ @return 0 if ip1 is equal to ip2, 1 if ip1 is bigger, -1 otherwise.
+
+
+ Returns the logical OR of the IP addresses ip1
and
+ ip2
.
+
+ @param ip1 The first IP address.
+ @param ip2 The second IP address.
+ @return The OR of ip1
and ip2
.
+
+
+ Stringifies an IPv4 or v6 address with subnet mask.
+
+ @param ip The IP with subnet mask.
+ @return The stringified IP address.
+
+
+
+ Summary description for PkixParameters.
+
+
+
+ This is the default PKIX validity model. Actually there are two variants
+ of this: The PKIX model and the modified PKIX model. The PKIX model
+ verifies that all involved certificates must have been valid at the
+ current time. The modified PKIX model verifies that all involved
+ certificates were valid at the signing time. Both are indirectly choosen
+ with the {@link PKIXParameters#setDate(java.util.Date)} method, so this
+ methods sets the Date when all certificates must have been
+ valid.
+
+
+ This model uses the following validity model. Each certificate must have
+ been valid at the moment where is was used. That means the end
+ certificate must have been valid at the time the signature was done. The
+ CA certificate which signed the end certificate must have been valid,
+ when the end certificate was signed. The CA (or Root CA) certificate must
+ have been valid, when the CA certificate was signed and so on. So the
+ {@link PKIXParameters#setDate(java.util.Date)} method sets the time, when
+ the end certificate must have been valid. It is used e.g.
+ in the German signature law.
+
+
+ Creates an instance of PKIXParameters with the specified Set of
+ most-trusted CAs. Each element of the set is a TrustAnchor.
+
+ Note that the Set is copied to protect against subsequent modifications.
+
+ @param trustAnchors
+ a Set of TrustAnchors
+
+ @exception InvalidAlgorithmParameterException
+ if the specified Set is empty
+ (trustAnchors.isEmpty() == true)
+ @exception NullPointerException
+ if the specified Set is null
+ @exception ClassCastException
+ if any of the elements in the Set are not of type
+ java.security.cert.TrustAnchor
+
+
+ Returns the required constraints on the target certificate. The
+ constraints are returned as an instance of CertSelector. If
+ null
, no constraints are defined.
+
+ Note that the CertSelector returned is cloned to protect against
+ subsequent modifications.
+
+ @return a CertSelector specifying the constraints on the target
+ certificate (or null
)
+
+ @see #setTargetCertConstraints(CertSelector)
+
+
+ Sets the required constraints on the target certificate. The constraints
+ are specified as an instance of CertSelector. If null, no constraints are
+ defined.
+
+ Note that the CertSelector specified is cloned to protect against
+ subsequent modifications.
+
+ @param selector
+ a CertSelector specifying the constraints on the target
+ certificate (or null
)
+
+ @see #getTargetCertConstraints()
+
+
+ Returns an immutable Set of initial policy identifiers (OID strings),
+ indicating that any one of these policies would be acceptable to the
+ certificate user for the purposes of certification path processing. The
+ default return value is an empty Set
, which is
+ interpreted as meaning that any policy would be acceptable.
+
+ @return an immutable Set
of initial policy OIDs in String
+ format, or an empty Set
(implying any policy is
+ acceptable). Never returns null
.
+
+ @see #setInitialPolicies(java.util.Set)
+
+
+ Sets the Set
of initial policy identifiers (OID strings),
+ indicating that any one of these policies would be acceptable to the
+ certificate user for the purposes of certification path processing. By
+ default, any policy is acceptable (i.e. all policies), so a user that
+ wants to allow any policy as acceptable does not need to call this
+ method, or can call it with an empty Set
(or
+ null
).
+
+ Note that the Set is copied to protect against subsequent modifications.
+
+
+ @param initialPolicies
+ a Set of initial policy OIDs in String format (or
+ null
)
+
+ @exception ClassCastException
+ if any of the elements in the set are not of type String
+
+ @see #getInitialPolicies()
+
+
+ Sets a List
of additional certification path checkers. If
+ the specified List contains an object that is not a PKIXCertPathChecker,
+ it is ignored.
+
+ Each PKIXCertPathChecker
specified implements additional
+ checks on a certificate. Typically, these are checks to process and
+ verify private extensions contained in certificates. Each
+ PKIXCertPathChecker
should be instantiated with any
+ initialization parameters needed to execute the check.
+
+ This method allows sophisticated applications to extend a PKIX
+ CertPathValidator
or CertPathBuilder
. Each
+ of the specified PKIXCertPathCheckers will be called, in turn, by a PKIX
+ CertPathValidator
or CertPathBuilder
for
+ each certificate processed or validated.
+
+ Regardless of whether these additional PKIXCertPathCheckers are set, a
+ PKIX CertPathValidator
or CertPathBuilder
+ must perform all of the required PKIX checks on each certificate. The one
+ exception to this rule is if the RevocationEnabled flag is set to false
+ (see the {@link #setRevocationEnabled(boolean) setRevocationEnabled}
+ method).
+
+ Note that the List supplied here is copied and each PKIXCertPathChecker
+ in the list is cloned to protect against subsequent modifications.
+
+ @param checkers
+ a List of PKIXCertPathCheckers. May be null, in which case no
+ additional checkers will be used.
+ @exception ClassCastException
+ if any of the elements in the list are not of type
+ java.security.cert.PKIXCertPathChecker
+ @see #getCertPathCheckers()
+
+
+ Returns the List of certification path checkers. Each PKIXCertPathChecker
+ in the returned IList is cloned to protect against subsequent modifications.
+
+ @return an immutable List of PKIXCertPathCheckers (may be empty, but not
+ null
)
+
+ @see #setCertPathCheckers(java.util.List)
+
+
+ Adds a PKIXCertPathChecker
to the list of certification
+ path checkers. See the {@link #setCertPathCheckers setCertPathCheckers}
+ method for more details.
+
+ Note that the PKIXCertPathChecker
is cloned to protect
+ against subsequent modifications.
+
+ @param checker a PKIXCertPathChecker
to add to the list of
+ checks. If null
, the checker is ignored (not added to list).
+
+
+ Method to support Clone()
under J2ME.
+ super.Clone()
does not exist and fields are not copied.
+
+ @param params Parameters to set. If this are
+ ExtendedPkixParameters
they are copied to.
+
+
+ Whether delta CRLs should be used for checking the revocation status.
+ Defaults to false
.
+
+
+ The validity model.
+ @see #CHAIN_VALIDITY_MODEL
+ @see #PKIX_VALIDITY_MODEL
+
+
+ Sets the Bouncy Castle Stores for finding CRLs, certificates, attribute
+ certificates or cross certificates.
+
+ The IList
is cloned.
+
+
+ @param stores A list of stores to use.
+ @see #getStores
+ @throws ClassCastException if an element of stores
is not
+ a {@link Store}.
+
+
+ Adds a Bouncy Castle {@link Store} to find CRLs, certificates, attribute
+ certificates or cross certificates.
+
+ This method should be used to add local stores, like collection based
+ X.509 stores, if available. Local stores should be considered first,
+ before trying to use additional (remote) locations, because they do not
+ need possible additional network traffic.
+
+ If store
is null
it is ignored.
+
+
+ @param store The store to add.
+ @see #getStores
+
+
+ Adds an additional Bouncy Castle {@link Store} to find CRLs, certificates,
+ attribute certificates or cross certificates.
+
+ You should not use this method. This method is used for adding additional
+ X.509 stores, which are used to add (remote) locations, e.g. LDAP, found
+ during X.509 object processing, e.g. in certificates or CRLs. This method
+ is used in PKIX certification path processing.
+
+ If store
is null
it is ignored.
+
+
+ @param store The store to add.
+ @see #getStores()
+
+
+ Returns an IList
of additional Bouncy Castle
+ Store
s used for finding CRLs, certificates, attribute
+ certificates or cross certificates.
+
+ @return an immutable IList
of additional Bouncy Castle
+ Store
s. Never null
.
+
+ @see #addAddionalStore(Store)
+
+
+ Returns an IList
of Bouncy Castle
+ Store
s used for finding CRLs, certificates, attribute
+ certificates or cross certificates.
+
+ @return an immutable IList
of Bouncy Castle
+ Store
s. Never null
.
+
+ @see #setStores(IList)
+
+
+ Returns if additional {@link X509Store}s for locations like LDAP found
+ in certificates or CRLs should be used.
+
+ @return Returns true
if additional stores are used.
+
+
+ Sets if additional {@link X509Store}s for locations like LDAP found in
+ certificates or CRLs should be used.
+
+ @param enabled true
if additional stores are used.
+
+
+ Returns the required constraints on the target certificate or attribute
+ certificate. The constraints are returned as an instance of
+ IX509Selector
. If null
, no constraints are
+ defined.
+
+
+ The target certificate in a PKIX path may be a certificate or an
+ attribute certificate.
+
+ Note that the IX509Selector
returned is cloned to protect
+ against subsequent modifications.
+
+ @return a IX509Selector
specifying the constraints on the
+ target certificate or attribute certificate (or null
)
+ @see #setTargetConstraints
+ @see X509CertStoreSelector
+ @see X509AttributeCertStoreSelector
+
+
+ Sets the required constraints on the target certificate or attribute
+ certificate. The constraints are specified as an instance of
+ IX509Selector
. If null
, no constraints are
+ defined.
+
+ The target certificate in a PKIX path may be a certificate or an
+ attribute certificate.
+
+ Note that the IX509Selector
specified is cloned to protect
+ against subsequent modifications.
+
+
+ @param selector a IX509Selector
specifying the constraints on
+ the target certificate or attribute certificate (or
+ null
)
+ @see #getTargetConstraints
+ @see X509CertStoreSelector
+ @see X509AttributeCertStoreSelector
+
+
+ Returns the trusted attribute certificate issuers. If attribute
+ certificates is verified the trusted AC issuers must be set.
+
+ The returned ISet
consists of TrustAnchor
s.
+
+ The returned ISet
is immutable. Never null
+
+
+ @return Returns an immutable set of the trusted AC issuers.
+
+
+ Sets the trusted attribute certificate issuers. If attribute certificates
+ is verified the trusted AC issuers must be set.
+
+ The trustedACIssuers
must be a ISet
of
+ TrustAnchor
+
+ The given set is cloned.
+
+
+ @param trustedACIssuers The trusted AC issuers to set. Is never
+ null
.
+ @throws ClassCastException if an element of stores
is not
+ a TrustAnchor
.
+
+
+ Returns the necessary attributes which must be contained in an attribute
+ certificate.
+
+ The returned ISet
is immutable and contains
+ String
s with the OIDs.
+
+
+ @return Returns the necessary AC attributes.
+
+
+ Sets the necessary which must be contained in an attribute certificate.
+
+ The ISet
must contain String
s with the
+ OIDs.
+
+ The set is cloned.
+
+
+ @param necessaryACAttributes The necessary AC attributes to set.
+ @throws ClassCastException if an element of
+ necessaryACAttributes
is not a
+ String
.
+
+
+ Returns the attribute certificates which are not allowed.
+
+ The returned ISet
is immutable and contains
+ String
s with the OIDs.
+
+
+ @return Returns the prohibited AC attributes. Is never null
.
+
+
+ Sets the attribute certificates which are not allowed.
+
+ The ISet
must contain String
s with the
+ OIDs.
+
+ The set is cloned.
+
+
+ @param prohibitedACAttributes The prohibited AC attributes to set.
+ @throws ClassCastException if an element of
+ prohibitedACAttributes
is not a
+ String
.
+
+
+ Returns the attribute certificate checker. The returned set contains
+ {@link PKIXAttrCertChecker}s and is immutable.
+
+ @return Returns the attribute certificate checker. Is never
+ null
.
+
+
+ Sets the attribute certificate checkers.
+
+ All elements in the ISet
must a {@link PKIXAttrCertChecker}.
+
+
+ The given set is cloned.
+
+
+ @param attrCertCheckers The attribute certificate checkers to set. Is
+ never null
.
+ @throws ClassCastException if an element of attrCertCheckers
+ is not a PKIXAttrCertChecker
.
+
+
+
+ Summary description for PkixPolicyNode.
+
+
+
+ Constructors
+
+
+
+ This class helps to handle CRL revocation reasons mask. Each CRL handles a
+ certain set of revocation reasons.
+
+
+
+
+ Constructs are reason mask with the reasons.
+
+ The reasons.
+
+
+
+ A reason mask with no reason.
+
+
+
+
+ A mask with all revocation reasons.
+
+
+
+ Adds all reasons from the reasons mask to this mask.
+
+ @param mask The reasons mask to add.
+
+
+
+ Returns true
if this reasons mask contains all possible
+ reasons.
+
+ true if this reasons mask contains all possible reasons.
+
+
+
+
+ Intersects this mask with the given reasons mask.
+
+ mask The mask to intersect with.
+ The intersection of this and teh given mask.
+
+
+
+ Returns true if the passed reasons mask has new reasons.
+
+ The reasons mask which should be tested for new reasons.
+ true if the passed reasons mask has new reasons.
+
+
+
+ Returns the reasons in this mask.
+
+
+
+ If the complete CRL includes an issuing distribution point (IDP) CRL
+ extension check the following:
+
+ (i) If the distribution point name is present in the IDP CRL extension
+ and the distribution field is present in the DP, then verify that one of
+ the names in the IDP matches one of the names in the DP. If the
+ distribution point name is present in the IDP CRL extension and the
+ distribution field is omitted from the DP, then verify that one of the
+ names in the IDP matches one of the names in the cRLIssuer field of the
+ DP.
+
+
+ (ii) If the onlyContainsUserCerts boolean is asserted in the IDP CRL
+ extension, verify that the certificate does not include the basic
+ constraints extension with the cA boolean asserted.
+
+
+ (iii) If the onlyContainsCACerts boolean is asserted in the IDP CRL
+ extension, verify that the certificate includes the basic constraints
+ extension with the cA boolean asserted.
+
+
+ (iv) Verify that the onlyContainsAttributeCerts boolean is not asserted.
+
+
+ @param dp The distribution point.
+ @param cert The certificate.
+ @param crl The CRL.
+ @throws AnnotatedException if one of the conditions is not met or an error occurs.
+
+
+ If the DP includes cRLIssuer, then verify that the issuer field in the
+ complete CRL matches cRLIssuer in the DP and that the complete CRL
+ contains an
+ g distribution point extension with the indirectCRL
+ boolean asserted. Otherwise, verify that the CRL issuer matches the
+ certificate issuer.
+
+ @param dp The distribution point.
+ @param cert The certificate ot attribute certificate.
+ @param crl The CRL for cert
.
+ @throws AnnotatedException if one of the above conditions does not apply or an error
+ occurs.
+
+
+ Obtain and validate the certification path for the complete CRL issuer.
+ If a key usage extension is present in the CRL issuer's certificate,
+ verify that the cRLSign bit is set.
+
+ @param crl CRL which contains revocation information for the certificate
+ cert
.
+ @param cert The attribute certificate or certificate to check if it is
+ revoked.
+ @param defaultCRLSignCert The issuer certificate of the certificate cert
.
+ @param defaultCRLSignKey The public key of the issuer certificate
+ defaultCRLSignCert
.
+ @param paramsPKIX paramsPKIX PKIX parameters.
+ @param certPathCerts The certificates on the certification path.
+ @return A Set
with all keys of possible CRL issuer
+ certificates.
+ @throws AnnotatedException if the CRL is not valid or the status cannot be checked or
+ some error occurs.
+
+
+ Checks a distribution point for revocation information for the
+ certificate cert
.
+
+ @param dp The distribution point to consider.
+ @param paramsPKIX PKIX parameters.
+ @param cert Certificate to check if it is revoked.
+ @param validDate The date when the certificate revocation status should be
+ checked.
+ @param defaultCRLSignCert The issuer certificate of the certificate cert
.
+ @param defaultCRLSignKey The public key of the issuer certificate
+ defaultCRLSignCert
.
+ @param certStatus The current certificate revocation status.
+ @param reasonMask The reasons mask which is already checked.
+ @param certPathCerts The certificates of the certification path.
+ @throws AnnotatedException if the certificate is revoked or the status cannot be checked
+ or some error occurs.
+
+
+ Checks a certificate if it is revoked.
+
+ @param paramsPKIX PKIX parameters.
+ @param cert Certificate to check if it is revoked.
+ @param validDate The date when the certificate revocation status should be
+ checked.
+ @param sign The issuer certificate of the certificate cert
.
+ @param workingPublicKey The public key of the issuer certificate sign
.
+ @param certPathCerts The certificates of the certification path.
+ @throws AnnotatedException if the certificate is revoked or the status cannot be checked
+ or some error occurs.
+
+
+ If use-deltas is set, verify the issuer and scope of the delta CRL.
+
+ @param deltaCRL The delta CRL.
+ @param completeCRL The complete CRL.
+ @param pkixParams The PKIX paramaters.
+ @throws AnnotatedException if an exception occurs.
+
+
+ Checks if an attribute certificate is revoked.
+
+ @param attrCert Attribute certificate to check if it is revoked.
+ @param paramsPKIX PKIX parameters.
+ @param issuerCert The issuer certificate of the attribute certificate
+ attrCert
.
+ @param validDate The date when the certificate revocation status should
+ be checked.
+ @param certPathCerts The certificates of the certification path to be
+ checked.
+
+ @throws CertPathValidatorException if the certificate is revoked or the
+ status cannot be checked or some error occurs.
+
+
+ Searches for a holder public key certificate and verifies its
+ certification path.
+
+ @param attrCert the attribute certificate.
+ @param pkixParams The PKIX parameters.
+ @return The certificate path of the holder certificate.
+ @throws Exception if
+
+ - no public key certificate can be found although holder
+ information is given by an entity name or a base certificate
+ ID
+ - support classes cannot be created
+ - no certification path for the public key certificate can
+ be built
+
+
+
+
+ Checks a distribution point for revocation information for the
+ certificate attrCert
.
+
+ @param dp The distribution point to consider.
+ @param attrCert The attribute certificate which should be checked.
+ @param paramsPKIX PKIX parameters.
+ @param validDate The date when the certificate revocation status should
+ be checked.
+ @param issuerCert Certificate to check if it is revoked.
+ @param reasonMask The reasons mask which is already checked.
+ @param certPathCerts The certificates of the certification path to be
+ checked.
+ @throws Exception if the certificate is revoked or the status
+ cannot be checked or some error occurs.
+
+
+
+ A trust anchor or most-trusted Certification Authority (CA).
+
+ This class represents a "most-trusted CA", which is used as a trust anchor
+ for validating X.509 certification paths. A most-trusted CA includes the
+ public key of the CA, the CA's name, and any constraints upon the set of
+ paths which may be validated using this key. These parameters can be
+ specified in the form of a trusted X509Certificate or as individual
+ parameters.
+
+
+
+
+ Creates an instance of TrustAnchor with the specified X509Certificate and
+ optional name constraints, which are intended to be used as additional
+ constraints when validating an X.509 certification path.
+ The name constraints are specified as a byte array. This byte array
+ should contain the DER encoded form of the name constraints, as they
+ would appear in the NameConstraints structure defined in RFC 2459 and
+ X.509. The ASN.1 definition of this structure appears below.
+
+
+ NameConstraints ::= SEQUENCE {
+ permittedSubtrees [0] GeneralSubtrees OPTIONAL,
+ excludedSubtrees [1] GeneralSubtrees OPTIONAL }
+
+ GeneralSubtrees ::= SEQUENCE SIZE (1..MAX) OF GeneralSubtree
+
+ GeneralSubtree ::= SEQUENCE {
+ base GeneralName,
+ minimum [0] BaseDistance DEFAULT 0,
+ maximum [1] BaseDistance OPTIONAL }
+
+ BaseDistance ::= INTEGER (0..MAX)
+
+ GeneralName ::= CHOICE {
+ otherName [0] OtherName,
+ rfc822Name [1] IA5String,
+ dNSName [2] IA5String,
+ x400Address [3] ORAddress,
+ directoryName [4] Name,
+ ediPartyName [5] EDIPartyName,
+ uniformResourceIdentifier [6] IA5String,
+ iPAddress [7] OCTET STRING,
+ registeredID [8] OBJECT IDENTIFIER}
+
+
+ Note that the name constraints byte array supplied is cloned to protect
+ against subsequent modifications.
+
+ a trusted X509Certificate
+ a byte array containing the ASN.1 DER encoding of a
+ NameConstraints extension to be used for checking name
+ constraints. Only the value of the extension is included, not
+ the OID or criticality flag. Specify null to omit the
+ parameter.
+ if the specified X509Certificate is null
+
+
+
+ Creates an instance of TrustAnchor where the
+ most-trusted CA is specified as an X500Principal and public key.
+
+
+
+ Name constraints are an optional parameter, and are intended to be used
+ as additional constraints when validating an X.509 certification path.
+
+ The name constraints are specified as a byte array. This byte array
+ contains the DER encoded form of the name constraints, as they
+ would appear in the NameConstraints structure defined in RFC 2459
+ and X.509. The ASN.1 notation for this structure is supplied in the
+ documentation for the other constructors.
+
+ Note that the name constraints byte array supplied here is cloned to
+ protect against subsequent modifications.
+
+
+ the name of the most-trusted CA as X509Name
+ the public key of the most-trusted CA
+
+ a byte array containing the ASN.1 DER encoding of a NameConstraints extension to
+ be used for checking name constraints. Only the value of the extension is included,
+ not the OID or criticality flag. Specify null to omit the parameter.
+
+
+ if caPrincipal or pubKey is null
+
+
+
+
+ Creates an instance of TrustAnchor
where the most-trusted
+ CA is specified as a distinguished name and public key. Name constraints
+ are an optional parameter, and are intended to be used as additional
+ constraints when validating an X.509 certification path.
+
+ The name constraints are specified as a byte array. This byte array
+ contains the DER encoded form of the name constraints, as they would
+ appear in the NameConstraints structure defined in RFC 2459 and X.509.
+
+ the X.500 distinguished name of the most-trusted CA in RFC
+ 2253 string format
+ the public key of the most-trusted CA
+ a byte array containing the ASN.1 DER encoding of a
+ NameConstraints extension to be used for checking name
+ constraints. Only the value of the extension is included, not
+ the OID or criticality flag. Specify null to omit the
+ parameter.
+ throws NullPointerException, IllegalArgumentException
+
+
+
+ Returns the most-trusted CA certificate.
+
+
+
+
+ Returns the name of the most-trusted CA as an X509Name.
+
+
+
+
+ Returns the name of the most-trusted CA in RFC 2253 string format.
+
+
+
+
+ Returns the public key of the most-trusted CA.
+
+
+
+
+ Decode the name constraints and clone them if not null.
+
+
+
+
+ Returns a formatted string describing the TrustAnchor
.
+
+ a formatted string describing the TrustAnchor
+
+
+ Recognised hash algorithms for the time stamp protocol.
+
+
+ Fetches the signature time-stamp attributes from a SignerInformation object.
+ Checks that the MessageImprint for each time-stamp matches the signature field.
+ (see RFC 3161 Appendix A).
+
+ @param signerInfo a SignerInformation to search for time-stamps
+ @return a collection of TimeStampToken objects
+ @throws TSPValidationException
+
+
+ Validate the passed in certificate as being of the correct type to be used
+ for time stamping. To be valid it must have an ExtendedKeyUsage extension
+ which has a key purpose identifier of id-kp-timeStamping.
+
+ @param cert the certificate of interest.
+ @throws TspValidationException if the certicate fails on one of the check points.
+
+
+
+ Return the digest algorithm using one of the standard JCA string
+ representations rather than the algorithm identifier (if possible).
+
+
+
+ Exception thrown if a TSP request or response fails to validate.
+
+ If a failure code is associated with the exception it can be retrieved using
+ the getFailureCode() method.
+
+
+ Return the failure code associated with this exception - if one is set.
+
+ @return the failure code if set, -1 otherwise.
+
+
+ Base class for an RFC 3161 Time Stamp Request.
+
+
+ Create a TimeStampRequest from the past in byte array.
+
+ @param req byte array containing the request.
+ @throws IOException if the request is malformed.
+
+
+ Create a TimeStampRequest from the past in input stream.
+
+ @param in input stream containing the request.
+ @throws IOException if the request is malformed.
+
+
+ Validate the timestamp request, checking the digest to see if it is of an
+ accepted type and whether it is of the correct length for the algorithm specified.
+
+ @param algorithms a set of string OIDS giving accepted algorithms.
+ @param policies if non-null a set of policies we are willing to sign under.
+ @param extensions if non-null a set of extensions we are willing to accept.
+ @throws TspException if the request is invalid, or processing fails.
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ Generator for RFC 3161 Time Stamp Request objects.
+
+
+ add a given extension field for the standard extensions tag (tag 3)
+ @throws IOException
+
+
+ add a given extension field for the standard extensions tag
+ The value parameter becomes the contents of the octet string associated
+ with the extension.
+
+
+ add a given extension field for the standard extensions tag (tag 3)
+ @throws IOException
+
+
+ add a given extension field for the standard extensions tag
+ The value parameter becomes the contents of the octet string associated
+ with the extension.
+
+
+ Base class for an RFC 3161 Time Stamp Response object.
+
+
+ Create a TimeStampResponse from a byte array containing an ASN.1 encoding.
+
+ @param resp the byte array containing the encoded response.
+ @throws TspException if the response is malformed.
+ @throws IOException if the byte array doesn't represent an ASN.1 encoding.
+
+
+ Create a TimeStampResponse from an input stream containing an ASN.1 encoding.
+
+ @param input the input stream containing the encoded response.
+ @throws TspException if the response is malformed.
+ @throws IOException if the stream doesn't represent an ASN.1 encoding.
+
+
+ Check this response against to see if it a well formed response for
+ the passed in request. Validation will include checking the time stamp
+ token if the response status is GRANTED or GRANTED_WITH_MODS.
+
+ @param request the request to be checked against
+ @throws TspException if the request can not match this response.
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ Generator for RFC 3161 Time Stamp Responses.
+
+
+ Return an appropriate TimeStampResponse.
+
+ If genTime is null a timeNotAvailable error response will be returned.
+
+ @param request the request this response is for.
+ @param serialNumber serial number for the response token.
+ @param genTime generation time for the response token.
+ @param provider provider to use for signature calculation.
+ @return
+ @throws NoSuchAlgorithmException
+ @throws NoSuchProviderException
+ @throws TSPException
+
+
+
+ Generate a TimeStampResponse with chosen status and FailInfoField.
+
+ @param status the PKIStatus to set.
+ @param failInfoField the FailInfoField to set.
+ @param statusString an optional string describing the failure.
+ @return a TimeStampResponse with a failInfoField and optional statusString
+ @throws TSPException in case the response could not be created
+
+
+ Validate the time stamp token.
+
+ To be valid the token must be signed by the passed in certificate and
+ the certificate must be the one referred to by the SigningCertificate
+ attribute included in the hashed attributes of the token. The
+ certificate must also have the ExtendedKeyUsageExtension with only
+ KeyPurposeID.IdKPTimeStamping and have been valid at the time the
+ timestamp was created.
+
+
+ A successful call to validate means all the above are true.
+
+
+
+ Return the underlying CmsSignedData object.
+
+ @return the underlying CMS structure.
+
+
+ Return a ASN.1 encoded byte stream representing the encoded object.
+
+ @throws IOException if encoding fails.
+
+
+ basic creation - only the default attributes will be included here.
+
+
+ create with a signer with extra signed/unsigned attributes.
+
+
+ @return the nonce value, null if there isn't one.
+
+
+ General array utilities.
+
+
+
+ Are two arrays equal.
+
+ Left side.
+ Right side.
+ True if equal.
+
+
+
+ A constant time equals comparison - does not terminate early if
+ test will fail.
+
+ first array
+ second array
+ true if arrays equal, false otherwise.
+
+
+ Make a copy of a range of bytes from the passed in data array. The range can
+ extend beyond the end of the input array, in which case the return array will
+ be padded with zeroes.
+
+ @param data the array from which the data is to be copied.
+ @param from the start index at which the copying should take place.
+ @param to the final index of the range (exclusive).
+
+ @return a new byte array containing the range given.
+
+
+ BigInteger utilities.
+
+
+ Return the passed in value as an unsigned byte array.
+
+ @param value value to be converted.
+ @return a byte array without a leading zero byte if present in the signed encoding.
+
+
+ Return the passed in value as an unsigned byte array of specified length, zero-extended as necessary.
+
+ @param length desired length of result array.
+ @param n value to be converted.
+ @return a byte array of specified length, with leading zeroes as necessary given the size of n.
+
+
+ Return a random BigInteger not less than 'min' and not greater than 'max'
+
+ @param min the least value that may be generated
+ @param max the greatest value that may be generated
+ @param random the source of randomness
+ @return a random BigInteger value in the range [min,max]
+
+
+
+ Produce a copy of this object with its configuration and in its current state.
+
+
+ The returned object may be used simply to store the state, or may be used as a similar object
+ starting from the copied state.
+
+
+
+
+ Restore a copied object state into this object.
+
+
+ Implementations of this method should try to avoid or minimise memory allocation to perform the reset.
+
+ an object originally {@link #copy() copied} from an object of the same type as this instance.
+ if the provided object is not of the correct type.
+ if the other parameter is in some other way invalid.
+
+
+ Exception to be thrown on a failure to reset an object implementing Memoable.
+
+ The exception extends InvalidCastException to enable users to have a single handling case,
+ only introducing specific handling of this one if required.
+
+
+
+ Basic Constructor.
+
+ @param msg message to be associated with this exception.
+
+
+ General string utilities.
+
+
+
+ Return the number of milliseconds since the Unix epoch (1 Jan., 1970 UTC) for a given DateTime value.
+
+ A UTC DateTime value not before epoch.
+ Number of whole milliseconds after epoch.
+ 'dateTime' is before epoch.
+
+
+
+ Create a DateTime value from the number of milliseconds since the Unix epoch (1 Jan., 1970 UTC).
+
+ Number of milliseconds since the epoch.
+ A UTC DateTime value
+
+
+
+ Return the current number of milliseconds since the Unix epoch (1 Jan., 1970 UTC).
+
+
+
+ encode the input data producing a base 64 encoded byte array.
+
+ @return a byte array containing the base 64 encoded data.
+
+
+ encode the input data producing a base 64 encoded byte array.
+
+ @return a byte array containing the base 64 encoded data.
+
+
+ Encode the byte data to base 64 writing it to the given output stream.
+
+ @return the number of bytes produced.
+
+
+ Encode the byte data to base 64 writing it to the given output stream.
+
+ @return the number of bytes produced.
+
+
+ decode the base 64 encoded input data. It is assumed the input data is valid.
+
+ @return a byte array representing the decoded data.
+
+
+ decode the base 64 encoded string data - whitespace will be ignored.
+
+ @return a byte array representing the decoded data.
+
+
+ decode the base 64 encoded string data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+ encode the input data producing a base 64 output stream.
+
+ @return the number of bytes produced.
+
+
+ decode the base 64 encoded byte data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+ decode the base 64 encoded string data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+
+ A buffering class to allow translation from one format to another to
+ be done in discrete chunks.
+
+
+
+
+ Create a buffered Decoder.
+
+ The translater to use.
+ The size of the buffer.
+
+
+
+ Process one byte of data.
+
+ Data in.
+ Byte array for the output.
+ The offset in the output byte array to start writing from.
+ The amount of output bytes.
+
+
+
+ Process data from a byte array.
+
+ The input data.
+ Start position within input data array.
+ Amount of data to process from input data array.
+ Array to store output.
+ Position in output array to start writing from.
+ The amount of output bytes.
+
+
+
+ A class that allows encoding of data using a specific encoder to be processed in chunks.
+
+
+
+
+ Create.
+
+ The translator to use.
+ Size of the chunks.
+
+
+
+ Process one byte of data.
+
+ The byte.
+ An array to store output in.
+ Offset within output array to start writing from.
+
+
+
+
+ Process data from a byte array.
+
+ Input data Byte array containing data to be processed.
+ Start position within input data array.
+ Amount of input data to be processed.
+ Output data array.
+ Offset within output data array to start writing to.
+ The amount of data written.
+
+
+
+ Class to decode and encode Hex.
+
+
+
+ encode the input data producing a Hex encoded byte array.
+
+ @return a byte array containing the Hex encoded data.
+
+
+ encode the input data producing a Hex encoded byte array.
+
+ @return a byte array containing the Hex encoded data.
+
+
+ Hex encode the byte data writing it to the given output stream.
+
+ @return the number of bytes produced.
+
+
+ Hex encode the byte data writing it to the given output stream.
+
+ @return the number of bytes produced.
+
+
+ decode the Hex encoded input data. It is assumed the input data is valid.
+
+ @return a byte array representing the decoded data.
+
+
+ decode the Hex encoded string data - whitespace will be ignored.
+
+ @return a byte array representing the decoded data.
+
+
+ decode the Hex encoded string data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+ encode the input data producing a Hex output stream.
+
+ @return the number of bytes produced.
+
+
+ decode the Hex encoded byte data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+ decode the Hex encoded string data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+
+ A hex translator.
+
+
+
+
+ Return encoded block size.
+
+ 2
+
+
+
+ Encode some data.
+
+ Input data array.
+ Start position within input data array.
+ The amount of data to process.
+ The output data array.
+ The offset within the output data array to start writing from.
+ Amount of data encoded.
+
+
+
+ Returns the decoded block size.
+
+ 1
+
+
+
+ Decode data from a byte array.
+
+ The input data array.
+ Start position within input data array.
+ The amounty of data to process.
+ The output data array.
+ The position within the output data array to start writing from.
+ The amount of data written.
+
+
+ Encode and decode byte arrays (typically from binary to 7-bit ASCII
+ encodings).
+
+
+
+ Translator interface.
+
+
+
+ Convert binary data to and from UrlBase64 encoding. This is identical to
+ Base64 encoding, except that the padding character is "." and the other
+ non-alphanumeric characters are "-" and "_" instead of "+" and "/".
+
+ The purpose of UrlBase64 encoding is to provide a compact encoding of binary
+ data that is safe for use as an URL parameter. Base64 encoding does not
+ produce encoded values that are safe for use in URLs, since "/" can be
+ interpreted as a path delimiter; "+" is the encoded form of a space; and
+ "=" is used to separate a name from the corresponding value in an URL
+ parameter.
+
+
+
+ Encode the input data producing a URL safe base 64 encoded byte array.
+
+ @return a byte array containing the URL safe base 64 encoded data.
+
+
+ Encode the byte data writing it to the given output stream.
+
+ @return the number of bytes produced.
+
+
+ Decode the URL safe base 64 encoded input data - white space will be ignored.
+
+ @return a byte array representing the decoded data.
+
+
+ decode the URL safe base 64 encoded byte data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+ decode the URL safe base 64 encoded string data - whitespace will be ignored.
+
+ @return a byte array representing the decoded data.
+
+
+ Decode the URL safe base 64 encoded string data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+ Convert binary data to and from UrlBase64 encoding. This is identical to
+ Base64 encoding, except that the padding character is "." and the other
+ non-alphanumeric characters are "-" and "_" instead of "+" and "/".
+
+ The purpose of UrlBase64 encoding is to provide a compact encoding of binary
+ data that is safe for use as an URL parameter. Base64 encoding does not
+ produce encoded values that are safe for use in URLs, since "/" can be
+ interpreted as a path delimiter; "+" is the encoded form of a space; and
+ "=" is used to separate a name from the corresponding value in an URL
+ parameter.
+
+
+
+
+ Pipe all bytes from inStr to outStr, throwing StreamFlowException if greater
+ than limit bytes in inStr.
+
+
+ A
+
+
+ A
+
+
+ A
+
+ The number of bytes actually transferred, if not greater than limit
+
+
+
+
+ A
+
+
+
+
+
+ A
+
+
+ A
+
+
+
+
+
+ A
+
+
+
+
+ A generic PEM writer, based on RFC 1421
+
+
+ Base constructor.
+
+ @param out output stream to use.
+
+
+ Return the number of bytes or characters required to contain the
+ passed in object if it is PEM encoded.
+
+ @param obj pem object to be output
+ @return an estimate of the number of bytes
+
+
+ Validate the given IPv4 or IPv6 address.
+
+ @param address the IP address as a string.
+
+ @return true if a valid address, false otherwise
+
+
+ Validate the given IPv4 or IPv6 address and netmask.
+
+ @param address the IP address as a string.
+
+ @return true if a valid address with netmask, false otherwise
+
+
+ Validate the given IPv4 address.
+
+ @param address the IP address as a string.
+
+ @return true if a valid IPv4 address, false otherwise
+
+
+ Validate the given IPv6 address.
+
+ @param address the IP address as a string.
+
+ @return true if a valid IPv4 address, false otherwise
+
+
+
+ Summary description for DeflaterOutputStream.
+
+
+
+
+ Summary description for DeflaterOutputStream.
+
+
+
+
+ The Holder object.
+
+ Holder ::= SEQUENCE {
+ baseCertificateID [0] IssuerSerial OPTIONAL,
+ -- the issuer and serial number of
+ -- the holder's Public Key Certificate
+ entityName [1] GeneralNames OPTIONAL,
+ -- the name of the claimant or role
+ objectDigestInfo [2] ObjectDigestInfo OPTIONAL
+ -- used to directly authenticate the holder,
+ -- for example, an executable
+ }
+
+
+
+
+ Constructs a holder for v2 attribute certificates with a hash value for
+ some type of object.
+
+ digestedObjectType
can be one of the following:
+
+ - 0 - publicKey - A hash of the public key of the holder must be
+ passed.
+ - 1 - publicKeyCert - A hash of the public key certificate of the
+ holder must be passed.
+ - 2 - otherObjectDigest - A hash of some other object type must be
+ passed.
otherObjectTypeID
must not be empty.
+
+
+ This cannot be used if a v1 attribute certificate is used.
+
+ @param digestedObjectType The digest object type.
+ @param digestAlgorithm The algorithm identifier for the hash.
+ @param otherObjectTypeID The object type ID if
+ digestedObjectType
is
+ otherObjectDigest
.
+ @param objectDigest The hash value.
+
+
+ Returns the digest object type if an object digest info is used.
+
+
+ - 0 - publicKey - A hash of the public key of the holder must be
+ passed.
+ - 1 - publicKeyCert - A hash of the public key certificate of the
+ holder must be passed.
+ - 2 - otherObjectDigest - A hash of some other object type must be
+ passed.
otherObjectTypeID
must not be empty.
+
+
+
+ @return The digest object type or -1 if no object digest info is set.
+
+
+ Returns the other object type ID if an object digest info is used.
+
+ @return The other object type ID or null
if no object
+ digest info is set.
+
+
+ Returns the hash if an object digest info is used.
+
+ @return The hash or null
if no object digest info is set.
+
+
+ Returns the digest algorithm ID if an object digest info is used.
+
+ @return The digest algorithm ID or null
if no object
+ digest info is set.
+
+
+ Return any principal objects inside the attribute certificate holder entity names field.
+
+ @return an array of IPrincipal objects (usually X509Name), null if no entity names field is set.
+
+
+ Return the principals associated with the issuer attached to this holder
+
+ @return an array of principals, null if no BaseCertificateID is set.
+
+
+ Return the serial number associated with the issuer attached to this holder.
+
+ @return the certificate serial number, null if no BaseCertificateID is set.
+
+
+ Carrying class for an attribute certificate issuer.
+
+
+ Set the issuer directly with the ASN.1 structure.
+
+ @param issuer The issuer
+
+
+ Return any principal objects inside the attribute certificate issuer object.
+ An array of IPrincipal objects (usually X509Principal).
+
+
+ Interface for an X.509 Attribute Certificate.
+
+
+ The version number for the certificate.
+
+
+ The serial number for the certificate.
+
+
+ The UTC DateTime before which the certificate is not valid.
+
+
+ The UTC DateTime after which the certificate is not valid.
+
+
+ The holder of the certificate.
+
+
+ The issuer details for the certificate.
+
+
+ Return the attributes contained in the attribute block in the certificate.
+ An array of attributes.
+
+
+ Return the attributes with the same type as the passed in oid.
+ The object identifier we wish to match.
+ An array of matched attributes, null if there is no match.
+
+
+ Return an ASN.1 encoded byte array representing the attribute certificate.
+ An ASN.1 encoded byte array.
+ If the certificate cannot be encoded.
+
+
+
+ Get all critical extension values, by oid
+
+ IDictionary with string (OID) keys and Asn1OctetString values
+
+
+
+ Get all non-critical extension values, by oid
+
+ IDictionary with string (OID) keys and Asn1OctetString values
+
+
+
+ A utility class that will extract X509Principal objects from X.509 certificates.
+
+ Use this in preference to trying to recreate a principal from a string, not all
+ DNs are what they should be, so it's best to leave them encoded where they
+ can be.
+
+
+
+ Return the issuer of the given cert as an X509Principal.
+
+
+ Return the subject of the given cert as an X509Principal.
+
+
+ Return the issuer of the given CRL as an X509Principal.
+
+
+
+ A factory to produce Public Key Info Objects.
+
+
+
+
+ Create a Subject Public Key Info object for a given public key.
+
+ One of ElGammalPublicKeyParameters, DSAPublicKeyParameter, DHPublicKeyParameters, RsaKeyParameters or ECPublicKeyParameters
+ A subject public key info object.
+ Throw exception if object provided is not one of the above.
+
+
+
+ Create loading data from byte array.
+
+
+
+
+
+ Create loading data from byte array.
+
+
+
+
+ Generates a certificate object and initializes it with the data
+ read from the input stream inStream.
+
+
+ Returns a (possibly empty) collection view of the certificates
+ read from the given input stream inStream.
+
+
+ Class for carrying the values in an X.509 Attribute.
+
+
+ @param at an object representing an attribute.
+
+
+ Create an X.509 Attribute with the type given by the passed in oid and
+ the value represented by an ASN.1 Set containing value.
+
+ @param oid type of the attribute
+ @param value value object to go into the atribute's value set.
+
+
+ Create an X.59 Attribute with the type given by the passed in oid and the
+ value represented by an ASN.1 Set containing the objects in value.
+
+ @param oid type of the attribute
+ @param value vector of values to go in the attribute's value set.
+
+
+
+ Create loading data from byte array.
+
+
+
+
+
+ Create loading data from byte array.
+
+
+
+
+
+ An Object representing an X509 Certificate.
+ Has static methods for loading Certificates encoded in many forms that return X509Certificate Objects.
+
+
+
+
+ Return true if the current time is within the start and end times nominated on the certificate.
+
+ true id certificate is valid for the current time.
+
+
+
+ Return true if the nominated time is within the start and end times nominated on the certificate.
+
+ The time to test validity against.
+ True if certificate is valid for nominated time.
+
+
+
+ Checks if the current date is within certificate's validity period.
+
+
+
+
+ Checks if the given date is within certificate's validity period.
+
+ if the certificate is expired by given date
+ if the certificate is not yet valid on given date
+
+
+
+ Return the certificate's version.
+
+ An integer whose value Equals the version of the cerficate.
+
+
+
+ Return a BigInteger containing the serial number.
+
+ The Serial number.
+
+
+
+ Get the Issuer Distinguished Name. (Who signed the certificate.)
+
+ And X509Object containing name and value pairs.
+
+
+
+ Get the subject of this certificate.
+
+ An X509Name object containing name and value pairs.
+
+
+
+ The time that this certificate is valid from.
+
+ A DateTime object representing that time in the local time zone.
+
+
+
+ The time that this certificate is valid up to.
+
+ A DateTime object representing that time in the local time zone.
+
+
+
+ Return the Der encoded TbsCertificate data.
+ This is the certificate component less the signature.
+ To Get the whole certificate call the GetEncoded() member.
+
+ A byte array containing the Der encoded Certificate component.
+
+
+
+ The signature.
+
+ A byte array containg the signature of the certificate.
+
+
+
+ A meaningful version of the Signature Algorithm. (EG SHA1WITHRSA)
+
+ A sting representing the signature algorithm.
+
+
+
+ Get the Signature Algorithms Object ID.
+
+ A string containg a '.' separated object id.
+
+
+
+ Get the signature algorithms parameters. (EG DSA Parameters)
+
+ A byte array containing the Der encoded version of the parameters or null if there are none.
+
+
+
+ Get the issuers UID.
+
+ A DerBitString.
+
+
+
+ Get the subjects UID.
+
+ A DerBitString.
+
+
+
+ Get a key usage guidlines.
+
+
+
+
+ Get the public key of the subject of the certificate.
+
+ The public key parameters.
+
+
+
+ Return a Der encoded version of this certificate.
+
+ A byte array.
+
+
+
+ Verify the certificate's signature using the nominated public key.
+
+ An appropriate public key parameter object, RsaPublicKeyParameters, DsaPublicKeyParameters or ECDsaPublicKeyParameters
+ True if the signature is valid.
+ If key submitted is not of the above nominated types.
+
+
+
+ Verify the certificate's signature using a verifier created using the passed in verifier provider.
+
+ An appropriate provider for verifying the certificate's signature.
+ True if the signature is valid.
+ If verifier provider is not appropriate or the certificate algorithm is invalid.
+
+
+
+ This class contains a cross certificate pair. Cross certificates pairs may
+ contain two cross signed certificates from two CAs. A certificate from the
+ other CA to this CA is contained in the forward certificate, the certificate
+ from this CA to the other CA is contained in the reverse certificate.
+
+
+
+ Constructor
+ Certificate from the other CA to this CA.
+ Certificate from this CA to the other CA.
+
+
+ Constructor from a ASN.1 CertificatePair structure.
+ The CertificatePair ASN.1 object.
+
+
+ Returns the certificate from the other CA to this CA.
+
+
+ Returns the certificate from this CA to the other CA.
+
+
+ class for dealing with X509 certificates.
+
+ At the moment this will deal with "-----BEGIN CERTIFICATE-----" to "-----END CERTIFICATE-----"
+ base 64 encoded certs, as well as the BER binaries of certificates and some classes of PKCS#7
+ objects.
+
+
+
+ Create loading data from byte array.
+
+
+
+
+
+ Create loading data from byte array.
+
+
+
+
+ Generates a certificate object and initializes it with the data
+ read from the input stream inStream.
+
+
+ Returns a (possibly empty) collection view of the certificates
+ read from the given input stream inStream.
+
+
+ The following extensions are listed in RFC 2459 as relevant to CRLs
+
+ Authority Key Identifier
+ Issuer Alternative Name
+ CRL Number
+ Delta CRL Indicator (critical)
+ Issuing Distribution Point (critical)
+
+
+
+ Verify the CRL's signature using a verifier created using the passed in verifier provider.
+
+ An appropriate provider for verifying the CRL's signature.
+ True if the signature is valid.
+ If verifier provider is not appropriate or the CRL algorithm is invalid.
+
+
+ Returns a string representation of this CRL.
+
+ @return a string representation of this CRL.
+
+
+ Checks whether the given certificate is on this CRL.
+
+ @param cert the certificate to check for.
+ @return true if the given certificate is on this CRL,
+ false otherwise.
+
+
+ The following extensions are listed in RFC 2459 as relevant to CRL Entries
+
+ ReasonCode Hode Instruction Code Invalidity Date Certificate Issuer
+ (critical)
+
+
+ Constructor for CRLEntries of indirect CRLs. If isIndirect
+ is false
{@link #getCertificateIssuer()} will always
+ return null
, previousCertificateIssuer
is
+ ignored. If this isIndirect
is specified and this CrlEntry
+ has no certificate issuer CRL entry extension
+ previousCertificateIssuer
is returned by
+ {@link #getCertificateIssuer()}.
+
+ @param c
+ TbsCertificateList.CrlEntry object.
+ @param isIndirect
+ true
if the corresponding CRL is a indirect
+ CRL.
+ @param previousCertificateIssuer
+ Certificate issuer of the previous CrlEntry.
+
+
+
+ Create loading data from byte array.
+
+
+
+
+
+ Create loading data from byte array.
+
+
+
+
+ Generates a certificate revocation list (CRL) object and initializes
+ it with the data read from the input stream inStream.
+
+
+ Returns a (possibly empty) collection view of the CRLs read from
+ the given input stream inStream.
+
+ The inStream may contain a sequence of DER-encoded CRLs, or
+ a PKCS#7 CRL set. This is a PKCS#7 SignedData object, with the
+ only significant field being crls. In particular the signature
+ and the contents are ignored.
+
+
+
+ Get non critical extensions.
+
+ A set of non critical extension oids.
+
+
+
+ Get any critical extensions.
+
+ A sorted list of critical entension.
+
+
+
+ Get the value of a given extension.
+
+ The object ID of the extension.
+ An Asn1OctetString object if that extension is found or null if not.
+
+
+ A holding class for constructing an X509 Key Usage extension.
+
+
+ id-ce-keyUsage OBJECT IDENTIFIER ::= { id-ce 15 }
+
+ KeyUsage ::= BIT STRING {
+ digitalSignature (0),
+ nonRepudiation (1),
+ keyEncipherment (2),
+ dataEncipherment (3),
+ keyAgreement (4),
+ keyCertSign (5),
+ cRLSign (6),
+ encipherOnly (7),
+ decipherOnly (8) }
+
+
+
+ Basic constructor.
+
+ @param usage - the bitwise OR of the Key Usage flags giving the
+ allowed uses for the key.
+ e.g. (X509KeyUsage.keyEncipherment | X509KeyUsage.dataEncipherment)
+
+
+ Return the digest algorithm using one of the standard JCA string
+ representations rather than the algorithm identifier (if possible).
+
+
+
+ Class to Generate X509V1 Certificates.
+
+
+
+
+ Default Constructor.
+
+
+
+
+ Reset the generator.
+
+
+
+
+ Set the certificate's serial number.
+
+ Make serial numbers long, if you have no serial number policy make sure the number is at least 16 bytes of secure random data.
+ You will be surprised how ugly a serial number collision can get.
+ The serial number.
+
+
+
+ Set the issuer distinguished name.
+ The issuer is the entity whose private key is used to sign the certificate.
+
+ The issuers DN.
+
+
+
+ Set the date that this certificate is to be valid from.
+
+
+
+
+
+ Set the date after which this certificate will no longer be valid.
+
+
+
+
+
+ Set the subject distinguished name.
+ The subject describes the entity associated with the public key.
+
+
+
+
+
+ Set the public key that this certificate identifies.
+
+
+
+
+
+ Set the signature algorithm that will be used to sign this certificate.
+ This can be either a name or an OID, names are treated as case insensitive.
+
+ string representation of the algorithm name
+
+
+
+ Generate a new X509Certificate.
+
+ The private key of the issuer used to sign this certificate.
+ An X509Certificate.
+
+
+
+ Generate a new X509Certificate specifying a SecureRandom instance that you would like to use.
+
+ The private key of the issuer used to sign this certificate.
+ The Secure Random you want to use.
+ An X509Certificate.
+
+
+
+ Generate a new X509Certificate using the passed in SignatureCalculator.
+
+ A signature calculator factory with the necessary algorithm details.
+ An X509Certificate.
+
+
+
+ Allows enumeration of the signature names supported by the generator.
+
+
+
+ An implementation of a version 2 X.509 Attribute Certificate.
+
+
+
+ Verify the certificate's signature using a verifier created using the passed in verifier provider.
+
+ An appropriate provider for verifying the certificate's signature.
+ True if the signature is valid.
+ If verifier provider is not appropriate or the certificate algorithm is invalid.
+
+
+ Class to produce an X.509 Version 2 AttributeCertificate.
+
+
+ Reset the generator
+
+
+ Set the Holder of this Attribute Certificate.
+
+
+ Set the issuer.
+
+
+ Set the serial number for the certificate.
+
+
+
+ Set the signature algorithm. This can be either a name or an OID, names
+ are treated as case insensitive.
+
+ The algorithm name.
+
+
+ Add an attribute.
+
+
+ Add a given extension field for the standard extensions tag.
+
+
+
+ Add a given extension field for the standard extensions tag.
+ The value parameter becomes the contents of the octet string associated
+ with the extension.
+
+
+
+
+ Generate an X509 certificate, based on the current issuer and subject.
+
+
+
+
+ Generate an X509 certificate, based on the current issuer and subject,
+ using the supplied source of randomness, if required.
+
+
+
+
+ Generate a new X.509 Attribute Certificate using the passed in SignatureCalculator.
+
+ A signature calculator factory with the necessary algorithm details.
+ An IX509AttributeCertificate.
+
+
+
+ Allows enumeration of the signature names supported by the generator.
+
+
+
+ class to produce an X.509 Version 2 CRL.
+
+
+ reset the generator
+
+
+ Set the issuer distinguished name - the issuer is the entity whose private key is used to sign the
+ certificate.
+
+
+ Reason being as indicated by CrlReason, i.e. CrlReason.KeyCompromise
+ or 0 if CrlReason is not to be used
+
+
+
+ Add a CRL entry with an Invalidity Date extension as well as a CrlReason extension.
+ Reason being as indicated by CrlReason, i.e. CrlReason.KeyCompromise
+ or 0 if CrlReason is not to be used
+
+
+
+ Add a CRL entry with extensions.
+
+
+
+ Add the CRLEntry objects contained in a previous CRL.
+
+ @param other the X509Crl to source the other entries from.
+
+
+
+ Set the signature algorithm that will be used to sign this CRL.
+
+
+
+
+ add a given extension field for the standard extensions tag (tag 0)
+
+
+ add a given extension field for the standard extensions tag (tag 0)
+
+
+ add a given extension field for the standard extensions tag (tag 0)
+
+
+ add a given extension field for the standard extensions tag (tag 0)
+
+
+
+ Generate an X.509 CRL, based on the current issuer and subject.
+
+ The private key of the issuer that is signing this certificate.
+ An X509Crl.
+
+
+
+ Generate an X.509 CRL, based on the current issuer and subject using the specified secure random.
+
+ The private key of the issuer that is signing this certificate.
+ Your Secure Random instance.
+ An X509Crl.
+
+
+
+ Generate a new X509Crl using the passed in SignatureCalculator.
+
+ A signature calculator factory with the necessary algorithm details.
+ An X509Crl.
+
+
+
+ Allows enumeration of the signature names supported by the generator.
+
+
+
+
+ A class to Generate Version 3 X509Certificates.
+
+
+
+
+ Reset the Generator.
+
+
+
+
+ Set the certificate's serial number.
+
+ Make serial numbers long, if you have no serial number policy make sure the number is at least 16 bytes of secure random data.
+ You will be surprised how ugly a serial number collision can Get.
+ The serial number.
+
+
+
+ Set the distinguished name of the issuer.
+ The issuer is the entity which is signing the certificate.
+
+ The issuer's DN.
+
+
+
+ Set the date that this certificate is to be valid from.
+
+
+
+
+
+ Set the date after which this certificate will no longer be valid.
+
+
+
+
+
+ Set the DN of the entity that this certificate is about.
+
+
+
+
+
+ Set the public key that this certificate identifies.
+
+
+
+
+
+ Set the signature algorithm that will be used to sign this certificate.
+
+
+
+
+
+ Set the subject unique ID - note: it is very rare that it is correct to do this.
+
+
+
+
+
+ Set the issuer unique ID - note: it is very rare that it is correct to do this.
+
+
+
+
+
+ Add a given extension field for the standard extensions tag (tag 3).
+
+ string containing a dotted decimal Object Identifier.
+ Is it critical.
+ The value.
+
+
+
+ Add an extension to this certificate.
+
+ Its Object Identifier.
+ Is it critical.
+ The value.
+
+
+
+ Add an extension using a string with a dotted decimal OID.
+
+ string containing a dotted decimal Object Identifier.
+ Is it critical.
+ byte[] containing the value of this extension.
+
+
+
+ Add an extension to this certificate.
+
+ Its Object Identifier.
+ Is it critical.
+ byte[] containing the value of this extension.
+
+
+
+ Add a given extension field for the standard extensions tag (tag 3),
+ copying the extension value from another certificate.
+
+
+
+ add a given extension field for the standard extensions tag (tag 3)
+ copying the extension value from another certificate.
+ @throws CertificateParsingException if the extension cannot be extracted.
+
+
+
+ Generate an X509Certificate.
+
+ The private key of the issuer that is signing this certificate.
+ An X509Certificate.
+
+
+
+ Generate an X509Certificate using your own SecureRandom.
+
+ The private key of the issuer that is signing this certificate.
+ You Secure Random instance.
+ An X509Certificate.
+
+
+
+ Generate a new X509Certificate using the passed in SignatureCalculator.
+
+ A signature calculator factory with the necessary algorithm details.
+ An X509Certificate.
+
+
+
+ Allows enumeration of the signature names supported by the generator.
+
+
+
+ A high level authority key identifier.
+
+
+ Constructor which will take the byte[] returned from getExtensionValue()
+
+ @param encodedValue a DER octet encoded string with the extension structure in it.
+ @throws IOException on parsing errors.
+
+
+ Create an AuthorityKeyIdentifier using the passed in certificate's public
+ key, issuer and serial number.
+
+ @param certificate the certificate providing the information.
+ @throws CertificateParsingException if there is a problem processing the certificate
+
+
+ Create an AuthorityKeyIdentifier using just the hash of the
+ public key.
+
+ @param pubKey the key to generate the hash from.
+ @throws InvalidKeyException if there is a problem using the key.
+
+
+ A high level subject key identifier.
+
+
+ Constructor which will take the byte[] returned from getExtensionValue()
+
+ @param encodedValue a DER octet encoded string with the extension structure in it.
+ @throws IOException on parsing errors.
+
+
+ This class is an Selector
like implementation to select
+ attribute certificates from a given set of criteria.
+
+ @see org.bouncycastle.x509.X509AttributeCertificate
+ @see org.bouncycastle.x509.X509Store
+
+
+
+ Decides if the given attribute certificate should be selected.
+
+ The attribute certificate to be checked.
+ true
if the object matches this selector.
+
+
+ The attribute certificate which must be matched.
+ If null is given, any will do.
+
+
+ The criteria for validity
+ If null is given any will do.
+
+
+ The holder.
+ If null is given any will do.
+
+
+ The issuer.
+ If null is given any will do.
+
+
+ The serial number.
+ If null is given any will do.
+
+
+ Adds a target name criterion for the attribute certificate to the target
+ information extension criteria. The X509AttributeCertificate
+ must contain at least one of the specified target names.
+
+ Each attribute certificate may contain a target information extension
+ limiting the servers where this attribute certificate can be used. If
+ this extension is not present, the attribute certificate is not targeted
+ and may be accepted by any server.
+
+
+ @param name The name as a GeneralName (not null
)
+
+
+ Adds a target name criterion for the attribute certificate to the target
+ information extension criteria. The X509AttributeCertificate
+ must contain at least one of the specified target names.
+
+ Each attribute certificate may contain a target information extension
+ limiting the servers where this attribute certificate can be used. If
+ this extension is not present, the attribute certificate is not targeted
+ and may be accepted by any server.
+
+
+ @param name a byte array containing the name in ASN.1 DER encoded form of a GeneralName
+ @throws IOException if a parsing error occurs.
+
+
+ Adds a collection with target names criteria. If null
is
+ given any will do.
+
+ The collection consists of either GeneralName objects or byte[] arrays representing
+ DER encoded GeneralName structures.
+
+
+ @param names A collection of target names.
+ @throws IOException if a parsing error occurs.
+ @see #AddTargetName(byte[])
+ @see #AddTargetName(GeneralName)
+
+
+ Gets the target names. The collection consists of List
s
+ made up of an Integer
in the first entry and a DER encoded
+ byte array or a String
in the second entry.
+ The returned collection is immutable.
+
+ @return The collection of target names
+ @see #setTargetNames(Collection)
+
+
+ Adds a target group criterion for the attribute certificate to the target
+ information extension criteria. The X509AttributeCertificate
+ must contain at least one of the specified target groups.
+
+ Each attribute certificate may contain a target information extension
+ limiting the servers where this attribute certificate can be used. If
+ this extension is not present, the attribute certificate is not targeted
+ and may be accepted by any server.
+
+
+ @param group The group as GeneralName form (not null
)
+
+
+ Adds a target group criterion for the attribute certificate to the target
+ information extension criteria. The X509AttributeCertificate
+ must contain at least one of the specified target groups.
+
+ Each attribute certificate may contain a target information extension
+ limiting the servers where this attribute certificate can be used. If
+ this extension is not present, the attribute certificate is not targeted
+ and may be accepted by any server.
+
+
+ @param name a byte array containing the group in ASN.1 DER encoded form of a GeneralName
+ @throws IOException if a parsing error occurs.
+
+
+ Adds a collection with target groups criteria. If null
is
+ given any will do.
+
+ The collection consists of GeneralName
objects or byte[]
+ representing DER encoded GeneralNames.
+
+
+ @param names A collection of target groups.
+ @throws IOException if a parsing error occurs.
+ @see #AddTargetGroup(byte[])
+ @see #AddTargetGroup(GeneralName)
+
+
+ Gets the target groups. The collection consists of List
s
+ made up of an Integer
in the first entry and a DER encoded
+ byte array or a String
in the second entry.
+ The returned collection is immutable.
+
+ @return The collection of target groups.
+ @see #setTargetGroups(Collection)
+
+
+
+ This class is an IX509Selector
implementation to select
+ certificate pairs, which are e.g. used for cross certificates. The set of
+ criteria is given from two X509CertStoreSelector
objects,
+ each of which, if present, must match the respective component of a pair.
+
+
+
+ The certificate pair which is used for testing on equality.
+
+
+ The certificate selector for the forward part.
+
+
+ The certificate selector for the reverse part.
+
+
+
+ Decides if the given certificate pair should be selected. If
+ obj is not a X509CertificatePair
, this method
+ returns false
.
+
+ The X509CertificatePair
to be tested.
+ true
if the object matches this selector.
+
+
+
+ An ISet
of DerObjectIdentifier
objects.
+
+
+
+ A simple collection backed store.
+
+
+ Basic constructor.
+
+ @param collection - initial contents for the store, this is copied.
+
+
+ Return the matches in the collection for the passed in selector.
+
+ @param selector the selector to match against.
+ @return a possibly empty collection of matching objects.
+
+
+ This class contains a collection for collection based X509Store
s.
+
+
+
+ Constructor.
+
+ The collection is copied.
+
+
+ The collection containing X.509 object types.
+ If collection is null.
+
+
+ Returns a copy of the ICollection
.
+
+
+ Returns a formatted string describing the parameters.
+
+
+
+ An ICollection
of X509Name
objects
+
+
+
+ The attribute certificate being checked. This is not a criterion.
+ Rather, it is optional information that may help a {@link X509Store} find
+ CRLs that would be relevant when checking revocation for the specified
+ attribute certificate. If null
is specified, then no such
+ optional information is provided.
+
+ @param attrCert the IX509AttributeCertificate
being checked (or
+ null
)
+ @see #getAttrCertificateChecking()
+
+
+ If true
only complete CRLs are returned. Defaults to
+ false
.
+
+ @return true
if only complete CRLs are returned.
+
+
+ Returns if this selector must match CRLs with the delta CRL indicator
+ extension set. Defaults to false
.
+
+ @return Returns true
if only CRLs with the delta CRL
+ indicator extension are selected.
+
+
+ The issuing distribution point.
+
+ The issuing distribution point extension is a CRL extension which
+ identifies the scope and the distribution point of a CRL. The scope
+ contains among others information about revocation reasons contained in
+ the CRL. Delta CRLs and complete CRLs must have matching issuing
+ distribution points.
+
+ The byte array is cloned to protect against subsequent modifications.
+
+ You must also enable or disable this criteria with
+ {@link #setIssuingDistributionPointEnabled(bool)}.
+
+ @param issuingDistributionPoint The issuing distribution point to set.
+ This is the DER encoded OCTET STRING extension value.
+ @see #getIssuingDistributionPoint()
+
+
+ Whether the issuing distribution point criteria should be applied.
+ Defaults to false
.
+
+ You may also set the issuing distribution point criteria if not a missing
+ issuing distribution point should be assumed.
+
+ @return Returns if the issuing distribution point check is enabled.
+
+
+ The maximum base CRL number. Defaults to null
.
+
+ @return Returns the maximum base CRL number.
+ @see #setMaxBaseCRLNumber(BigInteger)
+
+
+
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/ExchangeDkimSigner.dll
new file mode 100644
index 00000000..d0dd86d7
Binary files /dev/null and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/ExchangeDkimSigner.dll.config b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/ExchangeDkimSigner.dll.config
new file mode 100644
index 00000000..87478233
--- /dev/null
+++ b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/ExchangeDkimSigner.dll.config
@@ -0,0 +1,6 @@
+
+
+
+
+
+
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/ExchangeDkimSigner.pdb
new file mode 100644
index 00000000..f70e8b29
Binary files /dev/null and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/MimeKit.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/MimeKit.dll
new file mode 100644
index 00000000..8a58db8f
Binary files /dev/null and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/MimeKit.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/MimeKit.xml b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/MimeKit.xml
new file mode 100644
index 00000000..8fc68d18
--- /dev/null
+++ b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU20/MimeKit.xml
@@ -0,0 +1,38398 @@
+
+
+
+ MimeKit
+
+
+
+
+ A MIME part with a Content-Type of application/pgp-encrypted.
+
+
+ An application/pgp-encrypted part will typically be the first child of
+ a part and contains only a Version
+ header.
+
+
+
+
+ Initializes a new instance of the
+ class based on the .
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new MIME part with a Content-Type of application/pgp-encrypted
+ and content matching "Version: 1\n".
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ A MIME part with a Content-Type of application/pgp-signature.
+
+
+ An application/pgp-signature part contains detatched pgp signature data
+ and is typically contained within a part.
+ To verify the signature, use the
+ method on the parent multipart/signed part.
+
+
+
+
+ Initializes a new instance of the
+ class based on the .
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the
+ class with a Content-Type of application/pgp-signature.
+
+
+ Creates a new MIME part with a Content-Type of application/pgp-signature
+ and the as its content.
+
+ The content stream.
+
+ is null.
+
+
+ does not support reading.
+ -or-
+ does not support seeking.
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ An S/MIME part with a Content-Type of application/pkcs7-mime.
+
+
+ An application/pkcs7-mime is an S/MIME part and may contain encrypted,
+ signed or compressed data (or any combination of the above).
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new MIME part with a Content-Type of application/pkcs7-mime
+ and the as its content.
+ Unless you are writing your own pkcs7 implementation, you'll probably
+ want to use the ,
+ , and/or
+ method to create new instances
+ of this class.
+
+ The S/MIME type.
+ The content stream.
+
+ is null.
+
+
+ is not a valid value.
+
+
+ does not support reading.
+ -or-
+ does not support seeking.
+
+
+
+
+ Gets the value of the "smime-type" parameter.
+
+
+ Gets the value of the "smime-type" parameter.
+
+ The value of the "smime-type" parameter.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Decompresses the content.
+
+
+ Decompresses the content using the specified .
+
+ The decompressed .
+ The S/MIME context to use for decompressing.
+
+ is null.
+
+
+ The "smime-type" parameter on the Content-Type header is not "compressed-data".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Decompresses the content.
+
+
+ Decompresses the content using the default .
+
+ The decompressed .
+
+ The "smime-type" parameter on the Content-Type header is not "compressed-data".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Decrypts the content.
+
+
+ Decrypts the content using the specified .
+
+ The decrypted .
+ The S/MIME context to use for decrypting.
+
+ is null.
+
+
+ The "smime-type" parameter on the Content-Type header is not "enveloped-data".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Decrypts the content.
+
+
+ Decrypts the content using the default .
+
+ The decrypted .
+
+ The "smime-type" parameter on the Content-Type header is not "certs-only".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Imports the certificates contained in the content.
+
+
+ Imports the certificates contained in the content.
+
+ The S/MIME context to import certificates into.
+
+ is null.
+
+
+ The "smime-type" parameter on the Content-Type header is not "certs-only".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Verifies the signed-data and returns the unencapsulated .
+
+
+ Verifies the signed-data and returns the unencapsulated .
+
+ The list of digital signatures.
+ The S/MIME context to use for verifying the signature.
+ The unencapsulated entity.
+
+ is null.
+
+
+ The "smime-type" parameter on the Content-Type header is not "signed-data".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Verifies the signed-data and returns the unencapsulated .
+
+
+ Verifies the signed-data and returns the unencapsulated .
+
+ The list of digital signatures.
+ The unencapsulated entity.
+
+ The "smime-type" parameter on the Content-Type header is not "signed-data".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Compresses the specified entity.
+
+
+ Compresses the specified entity using the specified .
+ Most mail clients, even among those that support S/MIME,
+ do not support compression.
+
+ The compressed entity.
+ The S/MIME context to use for compressing.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Compresses the specified entity.
+
+
+ Compresses the specified entity using the default .
+ Most mail clients, even among those that support S/MIME,
+ do not support compression.
+
+ The compressed entity.
+ The entity.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Encrypts the specified entity.
+
+
+ Encrypts the entity to the specified recipients using the supplied .
+
+ The encrypted entity.
+ The S/MIME context to use for encrypting.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Encrypts the specified entity.
+
+
+ Encrypts the entity to the specified recipients using the default .
+
+ The encrypted entity.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Encrypts the specified entity.
+
+
+ Encrypts the entity to the specified recipients using the supplied .
+
+ The encrypted entity.
+ The S/MIME context to use for encrypting.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ Valid certificates could not be found for one or more of the .
+
+
+ A certificate could not be found for one or more of the .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Encrypts the specified entity.
+
+
+ Encrypts the entity to the specified recipients using the default .
+
+ The encrypted entity.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+
+
+ Valid certificates could not be found for one or more of the .
+
+
+ A certificate could not be found for one or more of the .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs the specified entity.
+
+
+ Signs the entity using the supplied signer and .
+ For better interoperability with other mail clients, you should use
+
+ instead as the multipart/signed format is supported among a much larger
+ subset of mail client software.
+
+ The signed entity.
+ The S/MIME context to use for signing.
+ The signer.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs the specified entity.
+
+
+ Signs the entity using the supplied signer.
+ For better interoperability with other mail clients, you should use
+
+ instead as the multipart/signed format is supported among a much larger
+ subset of mail client software.
+
+ The signed entity.
+ The signer.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs the specified entity.
+
+
+ Signs the entity using the supplied signer, digest algorithm and .
+ For better interoperability with other mail clients, you should use
+
+ instead as the multipart/signed format is supported among a much larger
+ subset of mail client software.
+
+ The signed entity.
+ The S/MIME context to use for signing.
+ The signer.
+ The digest algorithm to use for signing.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A signing certificate could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm.
+ For better interoperability with other mail clients, you should use
+
+ instead as the multipart/signed format is supported among a much larger
+ subset of mail client software.
+
+ The signed entity.
+ The signer.
+ The digest algorithm to use for signing.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+
+
+ A signing certificate could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs and encrypts the specified entity.
+
+
+ Cryptographically signs entity using the supplied signer and then
+ encrypts the result to the specified recipients.
+
+ The signed and encrypted entity.
+ The S/MIME context to use for signing and encrypting.
+ The signer.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs and encrypts the specified entity.
+
+
+ Cryptographically signs entity using the supplied signer and then
+ encrypts the result to the specified recipients.
+
+ The signed and encrypted entity.
+ The signer.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs and encrypts the specified entity.
+
+
+ Cryptographically signs entity using the supplied signer and then
+ encrypts the result to the specified recipients.
+
+ The signed and encrypted entity.
+ The S/MIME context to use for signing and encrypting.
+ The signer.
+ The digest algorithm to use for signing.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A signing certificate could not be found for .
+ -or-
+ A certificate could not be found for one or more of the .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs and encrypts the specified entity.
+
+
+ Cryptographically signs entity using the supplied signer and then
+ encrypts the result to the specified recipients.
+
+ The signed and encrypted entity.
+ The signer.
+ The digest algorithm to use for signing.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A signing certificate could not be found for .
+ -or-
+ A certificate could not be found for one or more of the .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ An S/MIME part with a Content-Type of application/pkcs7-signature.
+
+
+ An application/pkcs7-signature part contains detatched pkcs7 signature data
+ and is typically contained within a part.
+ To verify the signature, use the
+ method on the parent multipart/signed part.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the
+ class with a Content-Type of application/pkcs7-signature.
+
+
+ Creates a new MIME part with a Content-Type of application/pkcs7-signature
+ and the as its content.
+
+ The content stream.
+
+ is null.
+
+
+ does not support reading.
+ -or-
+ does not support seeking.
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ An exception that is thrown when a certificate could not be found for a specified mailbox.
+
+
+ An exception that is thrown when a certificate could not be found for a specified mailbox.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The serialization info.
+ The stream context.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The mailbox that could not be resolved to a valid certificate.
+ A message explaining the error.
+
+
+
+ When overridden in a derived class, sets the
+ with information about the exception.
+
+
+ Sets the
+ with information about the exception.
+
+ The serialization info.
+ The streaming context.
+
+ is null.
+
+
+
+
+ Gets the mailbox address that could not be resolved to a certificate.
+
+
+ Gets the mailbox address that could not be resolved to a certificate.
+
+ The mailbox address.
+
+
+
+ An S/MIME recipient.
+
+
+ If the X.509 certificates are known for each of the recipients, you
+ may wish to use a as opposed to having
+ the do its own certificate
+ lookups for each .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the property will be set to
+ the Triple-DES encryption algorithm, which should be safe to assume for all modern
+ S/MIME v3.x client implementations.
+
+ The recipient's certificate.
+ The recipient identifier type.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the property will be set to
+ the Triple-DES encryption algorithm, which should be safe to assume for all modern
+ S/MIME v3.x client implementations.
+ The will be initialized to
+ .
+
+ The recipient's certificate.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the property will be set to
+ the Triple-DES encryption algorithm, which should be safe to assume for all modern
+ S/MIME v3.x client implementations.
+
+ The recipient's certificate.
+ The recipient identifier type.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the property will be set to
+ the Triple-DES encryption algorithm, which should be safe to assume for all modern
+ S/MIME v3.x client implementations.
+ The will be initialized to
+ .
+
+ The recipient's certificate.
+
+ is null.
+
+
+
+
+ Gets the recipient's certificate.
+
+
+ The certificate is used for the purpose of encrypting data.
+
+ The certificate.
+
+
+
+ Gets the recipient identifier type.
+
+
+ Specifies how the certificate should be looked up on the recipient's end.
+
+ The recipient identifier type.
+
+
+
+ Gets or sets the known S/MIME encryption capabilities of the
+ recipient's mail client, in their preferred order.
+
+
+ Provides the with an array of
+ encryption algorithms that are known to be supported by the
+ recpipient's client software and should be in the recipient's
+ order of preference.
+
+ The encryption algorithms.
+
+
+
+ A collection of objects.
+
+
+ If the X.509 certificates are known for each of the recipients, you
+ may wish to use a as opposed to
+ using the methods that take a list of
+ objects.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the number of recipients in the collection.
+
+
+ Indicates the number of recipients in the collection.
+
+ The number of recipients in the collection.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Adds the specified recipient.
+
+
+ Adds the specified recipient.
+
+ The recipient.
+
+ is null.
+
+
+
+
+ Clears the recipient collection.
+
+
+ Removes all of the recipients from the collection.
+
+
+
+
+ Checks if the collection contains the specified recipient.
+
+
+ Determines whether or not the collection contains the specified recipient.
+
+ true if the specified recipient exists;
+ otherwise false.
+ The recipient.
+
+ is null.
+
+
+
+
+ Copies all of the recipients in the to the specified array.
+
+
+ Copies all of the recipients within the into the array,
+ starting at the specified array index.
+
+ The array.
+ The array index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified recipient.
+
+
+ Removes the specified recipient.
+
+ true if the recipient was removed; otherwise false.
+ The recipient.
+
+ is null.
+
+
+
+
+ Gets an enumerator for the collection of recipients.
+
+
+ Gets an enumerator for the collection of recipients.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the collection of recipients.
+
+
+ Gets an enumerator for the collection of recipients.
+
+ The enumerator.
+
+
+
+ An S/MIME signer.
+
+
+ If the X.509 certificate is known for the signer, you may wish to use a
+ as opposed to having the
+ do its own certificate lookup for the signer's .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the will be set to
+ and both the
+ and properties
+ will be initialized to empty tables.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the will be set to
+ and both the
+ and properties
+ will be initialized to empty tables.
+
+ The chain of certificates starting with the signer's certificate back to the root.
+ The signer's private key.
+
+ is null.
+ -or-
+ is null.
+
+
+ did not contain any certificates.
+ -or-
+ The certificate cannot be used for signing.
+ -or-
+ is not a private key.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the will
+ be set to and both the
+ and properties will be
+ initialized to empty tables.
+
+ The signer's certificate.
+ The signer's private key.
+
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ is not a private key.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the will
+ be set to and both the
+ and properties will be
+ initialized to empty tables.
+
+ The signer's certificate.
+
+ is null.
+
+
+ cannot be used for signing.
+
+
+
+
+ Gets the signer's certificate.
+
+
+ The signer's certificate that contains a public key that can be used for
+ verifying the digital signature.
+
+ The signer's certificate.
+
+
+
+ Gets the certificate chain.
+
+
+ Gets the certificate chain.
+
+ The certificate chain.
+
+
+
+ Gets or sets the digest algorithm.
+
+
+ Specifies which digest algorithm to use to generate the
+ cryptographic hash of the content being signed.
+
+ The digest algorithm.
+
+
+
+ Gets the private key.
+
+
+ The private key used for signing.
+
+ The private key.
+
+
+
+ Gets or sets the signed attributes.
+
+
+ A table of attributes that should be included in the signature.
+
+ The signed attributes.
+
+
+
+ Gets or sets the unsigned attributes.
+
+
+ A table of attributes that should not be signed in the signature,
+ but still included in transport.
+
+ The unsigned attributes.
+
+
+
+ An abstract cryptography context.
+
+
+ Generally speaking, applications should not use a
+ directly, but rather via higher level APIs such as ,
+ and .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the signature protocol.
+
+
+ The signature protocol is used by
+ in order to determine what the protocol parameter of the Content-Type
+ header should be.
+
+ The signature protocol.
+
+
+
+ Gets the encryption protocol.
+
+
+ The encryption protocol is used by
+ in order to determine what the protocol parameter of the Content-Type
+ header should be.
+
+ The encryption protocol.
+
+
+
+ Gets the key exchange protocol.
+
+
+ The key exchange protocol is really only used for PGP.
+
+ The key exchange protocol.
+
+
+
+ Checks whether or not the specified protocol is supported by the .
+
+
+ Used in order to make sure that the protocol parameter value specified in either a multipart/signed
+ or multipart/encrypted part is supported by the supplied cryptography context.
+
+ true if the protocol is supported; otherwise false
+ The protocol.
+
+ is null.
+
+
+
+
+ Gets the string name of the digest algorithm for use with the micalg parameter of a multipart/signed part.
+
+
+ Maps the to the appropriate string identifier
+ as used by the micalg parameter value of a multipart/signed Content-Type
+ header.
+
+ The micalg value.
+ The digest algorithm.
+
+ is out of range.
+
+
+
+
+ Gets the digest algorithm from the micalg parameter value in a multipart/signed part.
+
+
+ Maps the micalg parameter value string back to the appropriate .
+
+ The digest algorithm.
+ The micalg parameter value.
+
+ is null.
+
+
+
+
+ Cryptographically signs the content.
+
+
+ Cryptographically signs the content using the specified signer and digest algorithm.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+ A signing certificate could not be found for .
+
+
+
+
+ Verifies the specified content using the detached signatureData.
+
+
+ Verifies the specified content using the detached signatureData.
+
+ A list of digital signatures.
+ The content.
+ The signature data.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ A certificate could not be found for one or more of the .
+
+
+
+
+ Decrypts the specified encryptedData.
+
+
+ Decrypts the specified encryptedData.
+
+ The decrypted .
+ The encrypted data.
+
+ is null.
+
+
+
+
+ Imports the public certificates or keys from the specified stream.
+
+
+ Imports the public certificates or keys from the specified stream.
+
+ The raw certificate or key data.
+
+ is null.
+
+
+ Importing keys is not supported by this cryptography context.
+
+
+
+
+ Exports the keys for the specified mailboxes.
+
+
+ Exports the keys for the specified mailboxes.
+
+ A new instance containing the exported keys.
+ The mailboxes.
+
+ is null.
+
+
+ was empty.
+
+
+ Exporting keys is not supported by this cryptography context.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ Releases all resources used by the object.
+
+ Call when you are finished using the . The
+ method leaves the in an unusable state. After
+ calling , you must release all references to the so
+ the garbage collector can reclaim the memory that the was occupying.
+
+
+
+ Creates a new for the specified protocol.
+
+
+ Creates a new for the specified protocol.
+ The default types can over overridden by calling
+ the method with the preferred type.
+
+ The for the protocol.
+ The protocol.
+
+ is null.
+
+
+ There are no supported s that support
+ the specified .
+
+
+
+
+ Registers a default or .
+
+
+ Registers the specified type as the default or
+ .
+
+ A custom subclass of or
+ .
+
+ is null.
+
+
+ is not a subclass of
+ or .
+ -or-
+ does not have a parameterless constructor.
+
+
+
+
+ Useful extensions for working with System.Data types.
+
+
+
+
+ Creates a with the specified name and value and then adds it to the command's parameters.
+
+ The database command.
+ The parameter name.
+ The parameter value.
+
+
+
+ A default implementation that uses
+ an SQLite database as a certificate and private key store.
+
+
+ The default S/MIME context is designed to be usable on any platform
+ where there exists a .NET runtime by storing certificates, CRLs, and
+ (encrypted) private keys in a SQLite database.
+
+
+
+
+ The default database path for certificates, private keys and CRLs.
+
+
+ On Microsoft Windows-based systems, this path will be something like C:\Users\UserName\AppData\Roaming\mimekit\smime.db.
+ On Unix systems such as Linux and Mac OS X, this path will be ~/.mimekit/smime.db.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Allows the program to specify its own location for the SQLite database. If the file does not exist,
+ it will be created and the necessary tables and indexes will be constructed.
+ Requires linking with Mono.Data.Sqlite.
+
+ The path to the SQLite database.
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+ Mono.Data.Sqlite is not available.
+
+
+ The user does not have access to read the specified file.
+
+
+ An error occurred reading the file.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Allows the program to specify its own password for the default database.
+ Requires linking with Mono.Data.Sqlite.
+
+ The password used for encrypting and decrypting the private keys.
+
+ Mono.Data.Sqlite is not available.
+
+
+ The user does not have access to read the database at the default location.
+
+
+ An error occurred reading the database at the default location.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Not recommended for production use as the password to unlock the private keys is hard-coded.
+ Requires linking with Mono.Data.Sqlite.
+
+
+ Mono.Data.Sqlite is not available.
+
+
+ The user does not have access to read the database at the default location.
+
+
+ An error occurred reading the database at the default location.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is useful for supplying a custom .
+
+ The certificate database.
+
+ is null.
+
+
+
+
+ Gets the X.509 certificate matching the specified selector.
+
+
+ Gets the first certificate that matches the specified selector.
+
+ The certificate on success; otherwise null.
+ The search criteria for the certificate.
+
+
+
+ Gets the private key for the certificate matching the specified selector.
+
+
+ Gets the private key for the first certificate that matches the specified selector.
+
+ The private key on success; otherwise null.
+ The search criteria for the private key.
+
+
+
+ Gets the trusted anchors.
+
+
+ A trusted anchor is a trusted root-level X.509 certificate,
+ generally issued by a Certificate Authority (CA).
+
+ The trusted anchors.
+
+
+
+ Gets the intermediate certificates.
+
+
+ An intermediate certificate is any certificate that exists between the root
+ certificate issued by a Certificate Authority (CA) and the certificate at
+ the end of the chain.
+
+ The intermediate certificates.
+
+
+
+ Gets the certificate revocation lists.
+
+
+ A Certificate Revocation List (CRL) is a list of certificate serial numbers issued
+ by a particular Certificate Authority (CA) that have been revoked, either by the CA
+ itself or by the owner of the revoked certificate.
+
+ The certificate revocation lists.
+
+
+
+ Gets the for the specified mailbox.
+
+
+ Constructs a with the appropriate certificate and
+ for the specified mailbox.
+ If the mailbox is a , the
+ property will be used instead of
+ the mailbox address for database lookups.
+
+ A .
+ The mailbox.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Gets the for the specified mailbox.
+
+
+ Constructs a with the appropriate signing certificate
+ for the specified mailbox.
+ If the mailbox is a , the
+ property will be used instead of
+ the mailbox address for database lookups.
+
+ A .
+ The mailbox.
+ The preferred digest algorithm.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+ The certificate.
+ The encryption algorithm capabilities of the client (in preferred order).
+ The timestamp.
+
+
+
+ Imports a certificate.
+
+
+ Imports the specified certificate into the database.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Imports a certificate revocation list.
+
+
+ Imports the specified certificate revocation list.
+
+ The certificate revocation list.
+
+ is null.
+
+
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+
+ Imports all of the certificates and keys from the pkcs12-encoded stream.
+
+ The raw certificate and key data.
+ The password to unlock the data.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Imports a DER-encoded certificate stream.
+
+
+ Imports all of the certificates in the DER-encoded stream.
+
+ The raw certificate(s).
+ true if the certificates are trusted.
+
+ is null.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ A digest algorithm.
+
+
+ Digest algorithms are secure hashing algorithms that are used
+ to generate unique fixed-length signatures for arbitrary data.
+ The most commonly used digest algorithms are currently MD5
+ and SHA-1, however, MD5 was successfully broken in 2008 and should
+ be avoided. In late 2013, Microsoft announced that they would be
+ retiring their use of SHA-1 in their products by 2016 with the
+ assumption that its days as an unbroken digest algorithm were
+ numbered. It is speculated that the SHA-1 digest algorithm will
+ be vulnerable to collisions, and thus no longer considered secure,
+ by 2018.
+ Microsoft and other vendors plan to move to the SHA-2 suite of
+ digest algorithms which includes the following 4 variants: SHA-224,
+ SHA-256, SHA-384, and SHA-512.
+
+
+
+
+ No digest algorithm specified.
+
+
+
+
+ The MD5 digest algorithm.
+
+
+
+
+ The SHA-1 digest algorithm.
+
+
+
+
+ The Ripe-MD/160 digest algorithm.
+
+
+
+
+ The double-SHA digest algorithm.
+
+
+
+
+ The MD2 digest algorithm.
+
+
+
+
+ The TIGER/192 digest algorithm.
+
+
+
+
+ The HAVAL 5-pass 160-bit digest algorithm.
+
+
+
+
+ The SHA-256 digest algorithm.
+
+
+
+
+ The SHA-384 digest algorithm.
+
+
+
+
+ The SHA-512 digest algorithm.
+
+
+
+
+ The SHA-224 digest algorithm.
+
+
+
+
+ The MD4 digest algorithm.
+
+
+
+
+ A collection of digital signatures.
+
+
+ When verifying a digitally signed MIME part such as a
+ or a , you will get back a collection of
+ digital signatures. Typically, a signed message will only have a single signature
+ (created by the sender of the message), but it is possible for there to be
+ multiple signatures.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The signatures.
+
+
+
+ An exception that is thrown when an error occurrs in .
+
+
+ For more information about the error condition, check the property.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The serialization info.
+ The stream context.
+
+ is null.
+
+
+
+
+ A base implementation for DKIM body filters.
+
+
+ A base implementation for DKIM body filters.
+
+
+
+
+ Get or set whether the last filtered character was a newline.
+
+
+ Gets or sets whether the last filtered character was a newline.
+
+
+
+
+ Get or set whether the current line is empty.
+
+
+ Gets or sets whether the current line is empty.
+
+
+
+
+ Get or set the number of consecutive empty lines encountered.
+
+
+ Gets or sets the number of consecutive empty lines encountered.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ A DKIM canonicalization algorithm.
+
+
+ Empirical evidence demonstrates that some mail servers and relay systems
+ modify email in transit, potentially invalidating a signature. There are two
+ competing perspectives on such modifications. For most signers, mild modification
+ of email is immaterial to the authentication status of the email. For such signers,
+ a canonicalization algorithm that survives modest in-transit modification is
+ preferred.
+ Other signers demand that any modification of the email, however minor,
+ result in a signature verification failure. These signers prefer a canonicalization
+ algorithm that does not tolerate in-transit modification of the signed email.
+
+
+
+
+ The simple canonicalization algorithm tolerates almost no modification
+ by mail servers while the message is in-transit.
+
+
+
+
+ The relaxed canonicalization algorithm tolerates common modifications
+ by mail servers while the message is in-transit such as whitespace
+ replacement and header field line rewrapping.
+
+
+
+
+ A DKIM hash stream.
+
+
+ A DKIM hash stream.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The signature algorithm.
+ The max length of data to hash.
+
+
+
+ Generate the hash.
+
+
+ Generates the hash.
+
+ The hash.
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ A is not readable.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ A is always writable.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ A is not seekable.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not reading and writing to the stream can timeout.
+
+
+ Writing to a cannot timeout.
+
+ true if reading and writing to the stream can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ The length of a indicates the
+ number of bytes that have been written to it.
+
+ The length of the stream in bytes.
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ Since it is possible to seek within a ,
+ it is possible that the position will not always be identical to the
+ length of the stream, but typically it will be.
+
+ The position of the stream.
+
+ An I/O error occurred.
+
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reading from a is not supported.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Increments the property by the number of bytes written.
+ If the updated position is greater than the current length of the stream, then
+ the property will be updated to be identical to the
+ position.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Updates the within the stream.
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ is not a valid .
+
+
+ The stream has been disposed.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Since a does not actually do anything other than
+ count bytes, this method is a no-op.
+
+
+ The stream has been disposed.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Sets the to the specified value and updates
+ to the specified value if (and only if)
+ the current position is greater than the new length value.
+
+ The desired length of the stream in bytes.
+
+ is out of range.
+
+
+ The stream has been disposed.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ A filter for the DKIM relaxed body canonicalization.
+
+
+ A filter for the DKIM relaxed body canonicalization.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A DKIM signature algorithm.
+
+
+ A DKIM signature algorithm.
+
+
+
+
+ The RSA-SHA1 signature algorithm.
+
+
+
+
+ The RSA-SHA256 signature algorithm.
+
+
+
+
+ A DKIM signature stream.
+
+
+ A DKIM signature stream.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The digest signer.
+
+ is null.
+
+
+
+
+ Get the digest signer.
+
+
+ Gets the digest signer.
+
+ The signer.
+
+
+
+ Generate the signature.
+
+
+ Generates the signature.
+
+ The signature.
+
+
+
+ Verify the DKIM signature.
+
+
+ Verifies the DKIM signature.
+
+ true if signature is valid; otherwise, false.
+ The base64 encoded DKIM signature from the b= parameter.
+
+ is null.
+
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ A is not readable.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ A is always writable.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ A is not seekable.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not reading and writing to the stream can timeout.
+
+
+ Writing to a cannot timeout.
+
+ true if reading and writing to the stream can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ The length of a indicates the
+ number of bytes that have been written to it.
+
+ The length of the stream in bytes.
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ Since it is possible to seek within a ,
+ it is possible that the position will not always be identical to the
+ length of the stream, but typically it will be.
+
+ The position of the stream.
+
+ An I/O error occurred.
+
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reading from a is not supported.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Increments the property by the number of bytes written.
+ If the updated position is greater than the current length of the stream, then
+ the property will be updated to be identical to the
+ position.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Updates the within the stream.
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ is not a valid .
+
+
+ The stream has been disposed.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Since a does not actually do anything other than
+ count bytes, this method is a no-op.
+
+
+ The stream has been disposed.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Sets the to the specified value and updates
+ to the specified value if (and only if)
+ the current position is greater than the new length value.
+
+ The desired length of the stream in bytes.
+
+ is out of range.
+
+
+ The stream has been disposed.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ A DKIM signer.
+
+
+ A DKIM signer.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The signer's private key.
+ The domain that the signer represents.
+ The selector subdividing the domain.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ is not a private key.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The file containing the private key.
+ The domain that the signer represents.
+ The selector subdividing the domain.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The file did not contain a private key.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Gets the private key.
+
+
+ The private key used for signing.
+
+ The private key.
+
+
+
+ Get the domain that the signer represents.
+
+
+ Gets the domain that the signer represents.
+
+ The domain.
+
+
+
+ Get the selector subdividing the domain.
+
+
+ Gets the selector subdividing the domain.
+
+ The selector.
+
+
+
+ Get or set the agent or user identifier.
+
+
+ Gets or sets the agent or user identifier.
+
+ The agent or user identifier.
+
+
+
+ Get or set the algorithm to use for signing.
+
+
+ Gets or sets the algorithm to use for signing.
+
+ The signature algorithm.
+
+
+
+ Get or set the public key query method.
+
+
+ Gets or sets the public key query method.
+ The value should be a colon-separated list of query methods used to
+ retrieve the public key (plain-text; OPTIONAL, default is "dns/txt"). Each
+ query method is of the form "type[/options]", where the syntax and
+ semantics of the options depend on the type and specified options.
+
+ The public key query method.
+
+
+
+ A filter for the DKIM simple body canonicalization.
+
+
+ A filter for the DKIM simple body canonicalization.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ Encryption algorithms supported by S/MIME and OpenPGP.
+
+
+ Represents the available encryption algorithms for use with S/MIME and OpenPGP.
+ RC-2/40 was required by all S/MIME v2 implementations. However, since the
+ mid-to-late 1990's, RC-2/40 has been considered to be extremely weak and starting with
+ S/MIME v3.0 (published in 1999), all S/MIME implementations are required to implement
+ support for Triple-DES (aka 3DES) and should no longer encrypt using RC-2/40 unless
+ explicitly requested to do so by the user.
+ These days, most S/MIME implementations support the AES-128 and AES-256
+ algorithms which are the recommended algorithms specified in S/MIME v3.2 and
+ should be preferred over the use of Triple-DES unless the client capabilities
+ of one or more of the recipients is unknown (or only supports Triple-DES).
+
+
+
+
+ The AES 128-bit encryption algorithm.
+
+
+
+
+ The AES 192-bit encryption algorithm.
+
+
+
+
+ The AES 256-bit encryption algorithm.
+
+
+
+
+ The Camellia 128-bit encryption algorithm.
+
+
+
+
+ The Camellia 192-bit encryption algorithm.
+
+
+
+
+ The Camellia 256-bit encryption algorithm.
+
+
+
+
+ The Cast-5 128-bit encryption algorithm.
+
+
+
+
+ The DES 56-bit encryption algorithm.
+
+
+ This is extremely weak encryption and should not be used
+ without consent from the user.
+
+
+
+
+ The Triple-DES encryption algorithm.
+
+
+ This is the weakest recommended encryption algorithm for use
+ starting with S/MIME v3 and should only be used as a fallback
+ if it is unknown what encryption algorithms are supported by
+ the recipient's mail client.
+
+
+
+
+ The IDEA 128-bit encryption algorithm.
+
+
+
+
+ The blowfish encryption algorithm (OpenPGP only).
+
+
+
+
+ The twofish encryption algorithm (OpenPGP only).
+
+
+
+
+ The RC2 40-bit encryption algorithm (S/MIME only).
+
+
+ This is extremely weak encryption and should not be used
+ without consent from the user.
+
+
+
+
+ The RC2 64-bit encryption algorithm (S/MIME only).
+
+
+ This is very weak encryption and should not be used
+ without consent from the user.
+
+
+
+
+ The RC2 128-bit encryption algorithm (S/MIME only).
+
+
+
+
+ A that uses the GnuPG keyrings.
+
+
+ A that uses the GnuPG keyrings.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ An interface for a digital certificate.
+
+
+ An interface for a digital certificate.
+
+
+
+
+ Gets the public key algorithm supported by the certificate.
+
+
+ Gets the public key algorithm supported by the certificate.
+
+ The public key algorithm.
+
+
+
+ Gets the date that the certificate was created.
+
+
+ Gets the date that the certificate was created.
+
+ The creation date.
+
+
+
+ Gets the expiration date of the certificate.
+
+
+ Gets the expiration date of the certificate.
+
+ The expiration date.
+
+
+
+ Gets the fingerprint of the certificate.
+
+
+ Gets the fingerprint of the certificate.
+
+ The fingerprint.
+
+
+
+ Gets the email address of the owner of the certificate.
+
+
+ Gets the email address of the owner of the certificate.
+
+ The email address.
+
+
+
+ Gets the name of the owner of the certificate.
+
+
+ Gets the name of the owner of the certificate.
+
+ The name of the owner.
+
+
+
+ An interface for a digital signature.
+
+
+ An interface for a digital signature.
+
+
+
+
+ Gets certificate used by the signer.
+
+
+ Gets certificate used by the signer.
+
+ The signer's certificate.
+
+
+
+ Gets the public key algorithm used for the signature.
+
+
+ Gets the public key algorithm used for the signature.
+
+ The public key algorithm.
+
+
+
+ Gets the digest algorithm used for the signature.
+
+
+ Gets the digest algorithm used for the signature.
+
+ The digest algorithm.
+
+
+
+ Gets the creation date of the digital signature.
+
+
+ Gets the creation date of the digital signature.
+
+ The creation date.
+
+
+
+ Verifies the digital signature.
+
+
+ Verifies the digital signature.
+
+ true if the signature is valid; otherwise false.
+
+ An error verifying the signature has occurred.
+
+
+
+
+ An interface for a service which locates and retrieves DKIM public keys (probably via DNS).
+
+
+ An interface for a service which locates and retrieves DKIM public keys (probably via DNS).
+ Since MimeKit itself does not implement DNS, it is up to the client to implement public key lookups
+ via DNS.
+
+
+
+
+
+ Locate and retrieves the public key for the given domain and selector.
+
+
+ Locates and retrieves the public key for the given domain and selector.
+
+ The public key.
+ A colon-separated list of query methods used to retrieve the public key. The default is "dns/txt".
+ The domain.
+ The selector.
+ The cancellation token.
+
+
+
+ An interface for an X.509 Certificate database.
+
+
+ An X.509 certificate database is used for storing certificates, metdata related to the certificates
+ (such as encryption algorithms supported by the associated client), certificate revocation lists (CRLs),
+ and private keys.
+
+
+
+
+ Find the specified certificate.
+
+
+ Searches the database for the specified certificate, returning the matching
+ record with the desired fields populated.
+
+ The matching record if found; otherwise null.
+ The certificate.
+ The desired fields.
+
+
+
+ Finds the certificates matching the specified selector.
+
+
+ Searches the database for certificates matching the selector, returning all
+ matching certificates.
+
+ The matching certificates.
+ The match selector or null to return all certificates.
+
+
+
+ Finds the private keys matching the specified selector.
+
+
+ Searches the database for certificate records matching the selector, returning the
+ private keys for each matching record.
+
+ The matching certificates.
+ The match selector or null to return all private keys.
+
+
+
+ Finds the certificate records for the specified mailbox.
+
+
+ Searches the database for certificates matching the specified mailbox that are valid
+ for the date and time specified, returning all matching records populated with the
+ desired fields.
+
+ The matching certificate records populated with the desired fields.
+ The mailbox.
+ The date and time.
+ true if a private key is required.
+ The desired fields.
+
+
+
+ Finds the certificate records matching the specified selector.
+
+
+ Searches the database for certificate records matching the selector, returning all
+ of the matching records populated with the desired fields.
+
+ The matching certificate records populated with the desired fields.
+ The match selector or null to match all certificates.
+ true if only trusted certificates should be returned.
+ The desired fields.
+
+
+
+ Add the specified certificate record.
+
+
+ Adds the specified certificate record to the database.
+
+ The certificate record.
+
+
+
+ Remove the specified certificate record.
+
+
+ Removes the specified certificate record from the database.
+
+ The certificate record.
+
+
+
+ Update the specified certificate record.
+
+
+ Updates the specified fields of the record in the database.
+
+ The certificate record.
+ The fields to update.
+
+
+
+ Finds the CRL records for the specified issuer.
+
+
+ Searches the database for CRL records matching the specified issuer, returning
+ all matching records populated with the desired fields.
+
+ The matching CRL records populated with the desired fields.
+ The issuer.
+ The desired fields.
+
+
+
+ Finds the specified certificate revocation list.
+
+
+ Searches the database for the specified CRL, returning the matching record with
+ the desired fields populated.
+
+ The matching record if found; otherwise null.
+ The certificate revocation list.
+ The desired fields.
+
+
+
+ Add the specified CRL record.
+
+
+ Adds the specified CRL record to the database.
+
+ The CRL record.
+
+
+
+ Remove the specified CRL record.
+
+
+ Removes the specified CRL record from the database.
+
+ The CRL record.
+
+
+
+ Update the specified CRL record.
+
+
+ Updates the specified fields of the record in the database.
+
+ The CRL record.
+
+
+
+ Gets a certificate revocation list store.
+
+
+ Gets a certificate revocation list store.
+
+ A certificate recovation list store.
+
+
+
+ A multipart MIME part with a ContentType of multipart/encrypted containing an encrypted MIME part.
+
+
+ This mime-type is common when dealing with PGP/MIME but is not used for S/MIME.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for signing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The private key for could not be found.
+
+
+ A public key for one or more of the could not be found.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A default has not been registered.
+
+
+ The private key for could not be found.
+
+
+ A public key for one or more of the could not be found.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for singing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ The is not supported.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for singing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ A default has not been registered.
+ -or-
+ The is not supported.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ A default has not been registered.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A public key for one or more of the could not be found.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ A default has not been registered.
+
+
+ A public key for one or more of the could not be found.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ THe specified encryption algorithm is not supported.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ A default has not been registered.
+ -or-
+ The specified encryption algorithm is not supported.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ A default has not been registered.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for singing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ The is not supported.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for signing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The private key for could not be found.
+
+
+ A public key for one or more of the could not be found.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ A default has not been registered.
+ -or-
+ The is not supported.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A default has not been registered.
+
+
+ The private key for could not be found.
+
+
+ A public key for one or more of the could not be found.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for singing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ The is not supported.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for singing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ A default has not been registered.
+ -or-
+ The is not supported.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ A default has not been registered.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ THe specified encryption algorithm is not supported.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A public key for one or more of the could not be found.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ A default has not been registered.
+ -or-
+ The specified encryption algorithm is not supported.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ A default has not been registered.
+
+
+ A public key for one or more of the could not be found.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ THe specified encryption algorithm is not supported.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ A default has not been registered.
+ -or-
+ The specified encryption algorithm is not supported.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ A default has not been registered.
+
+
+
+
+ Decrypts the part.
+
+
+ Decrypts the and extracts any digital signatures in cases
+ where the content was also signed.
+
+ The decrypted entity.
+ The OpenPGP cryptography context to use for decrypting.
+ A list of digital signatures if the data was both signed and encrypted.
+
+ is null.
+
+
+ The protocol parameter was not specified.
+ -or-
+ The multipart is malformed in some way.
+
+
+ The provided does not support the protocol parameter.
+
+
+ The private key could not be found to decrypt the encrypted data.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Decrypts the part.
+
+
+ Decrypts the part.
+
+ The decrypted entity.
+ The OpenPGP cryptography context to use for decrypting.
+
+ is null.
+
+
+ The protocol parameter was not specified.
+ -or-
+ The multipart is malformed in some way.
+
+
+ The provided does not support the protocol parameter.
+
+
+ The private key could not be found to decrypt the encrypted data.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Decrypts the part.
+
+
+ Decrypts the and extracts any digital signatures in cases
+ where the content was also signed.
+
+ The decrypted entity.
+ A list of digital signatures if the data was both signed and encrypted.
+
+ The protocol parameter was not specified.
+ -or-
+ The multipart is malformed in some way.
+
+
+ A suitable for
+ decrypting could not be found.
+
+
+ The private key could not be found to decrypt the encrypted data.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Decrypts the part.
+
+
+ Decrypts the part.
+
+ The decrypted entity.
+
+ The protocol parameter was not specified.
+ -or-
+ The multipart is malformed in some way.
+
+
+ A suitable for
+ decrypting could not be found.
+
+
+ The private key could not be found to decrypt the encrypted data.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ A signed multipart, as used by both S/MIME and PGP/MIME protocols.
+
+
+ The first child of a multipart/signed is the content while the second child
+ is the detached signature data. Any other children are not defined and could
+ be anything.
+
+
+
+
+ Initializes a new instance of the class.
+
+ This constructor is used by .
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Creates a new .
+
+
+ Cryptographically signs the entity using the supplied signer and digest algorithm in
+ order to generate a detached signature and then adds the entity along with the
+ detached signature data to a new multipart/signed part.
+
+ A new instance.
+ The cryptography context to use for signing.
+ The signer.
+ The digest algorithm to use for signing.
+ The entity to sign.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The was out of range.
+
+
+ The is not supported.
+
+
+ A signing certificate could not be found for .
+
+
+ The private key could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Creates a new .
+
+
+ Cryptographically signs the entity using the supplied signer and digest algorithm in
+ order to generate a detached signature and then adds the entity along with the
+ detached signature data to a new multipart/signed part.
+
+ A new instance.
+ The OpenPGP context to use for signing.
+ The signer.
+ The digest algorithm to use for signing.
+ The entity to sign.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+
+
+ The was out of range.
+
+
+ The is not supported.
+
+
+ An error occurred in the OpenPGP subsystem.
+
+
+
+
+ Creates a new .
+
+
+ Cryptographically signs the entity using the supplied signer and digest algorithm in
+ order to generate a detached signature and then adds the entity along with the
+ detached signature data to a new multipart/signed part.
+
+ A new instance.
+ The signer.
+ The digest algorithm to use for signing.
+ The entity to sign.
+
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+
+
+ The was out of range.
+
+
+ A cryptography context suitable for signing could not be found.
+ -or-
+ The is not supported.
+
+
+ An error occurred in the OpenPGP subsystem.
+
+
+
+
+ Creates a new .
+
+
+ Cryptographically signs the entity using the supplied signer in order
+ to generate a detached signature and then adds the entity along with
+ the detached signature data to a new multipart/signed part.
+
+ A new instance.
+ The S/MIME context to use for signing.
+ The signer.
+ The entity to sign.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Creates a new .
+
+
+ Cryptographically signs the entity using the supplied signer in order
+ to generate a detached signature and then adds the entity along with
+ the detached signature data to a new multipart/signed part.
+
+ A new instance.
+ The signer.
+ The entity to sign.
+
+ is null.
+ -or-
+ is null.
+
+
+ A cryptography context suitable for signing could not be found.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Prepare the MIME entity for transport using the specified encoding constraints.
+
+
+ Prepares the MIME entity for transport using the specified encoding constraints.
+
+ The encoding constraint.
+ The maximum number of octets allowed per line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Verifies the multipart/signed part.
+
+
+ Verifies the multipart/signed part using the supplied cryptography context.
+
+ A signer info collection.
+ The cryptography context to use for verifying the signature.
+
+ is null.
+
+
+ The multipart is malformed in some way.
+
+
+ does not support verifying the signature part.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Verifies the multipart/signed part.
+
+
+ Verifies the multipart/signed part using the default cryptography context.
+
+ A signer info collection.
+
+ The protocol parameter was not specified.
+ -or-
+ The multipart is malformed in some way.
+
+
+ A cryptography context suitable for verifying the signature could not be found.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ An X.509 certificate database built on PostgreSQL.
+
+
+ An X.509 certificate database is used for storing certificates, metdata related to the certificates
+ (such as encryption algorithms supported by the associated client), certificate revocation lists (CRLs),
+ and private keys.
+ This particular database uses PostgreSQL to store the data.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new and opens a connection to the
+ PostgreSQL database using the specified connection string.
+
+ The connection string.
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+ is empty.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new using the provided Npgsql database connection.
+
+ The Npgsql connection.
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets the command to create the certificates table.
+
+
+ Constructs the command to create a certificates table suitable for storing
+ objects.
+
+ The .
+ The .
+
+
+
+ Gets the command to create the CRLs table.
+
+
+ Constructs the command to create a CRLs table suitable for storing
+ objects.
+
+ The .
+ The .
+
+
+
+ An abstract OpenPGP cryptography context which can be used for PGP/MIME.
+
+
+ Generally speaking, applications should not use a
+ directly, but rather via higher level APIs such as
+ and .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Subclasses choosing to use this constructor MUST set the ,
+ , , and the
+ properties themselves.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new using the specified public and private keyring paths.
+
+ The public keyring file path.
+ The secret keyring file path.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred while reading one of the keyring files.
+
+
+ An error occurred while parsing one of the keyring files.
+
+
+
+
+ Gets or sets the default encryption algorithm.
+
+
+ Gets or sets the default encryption algorithm.
+
+ The encryption algorithm.
+
+ The specified encryption algorithm is not supported.
+
+
+
+
+ Gets the public keyring path.
+
+
+ Gets the public keyring path.
+
+ The public key ring path.
+
+
+
+ Gets the secret keyring path.
+
+
+ Gets the secret keyring path.
+
+ The secret key ring path.
+
+
+
+ Gets the public keyring bundle.
+
+
+ Gets the public keyring bundle.
+
+ The public keyring bundle.
+
+
+
+ Gets the secret keyring bundle.
+
+
+ Gets the secret keyring bundle.
+
+ The secret keyring bundle.
+
+
+
+ Gets the signature protocol.
+
+
+ The signature protocol is used by
+ in order to determine what the protocol parameter of the Content-Type
+ header should be.
+
+ The signature protocol.
+
+
+
+ Gets the encryption protocol.
+
+
+ The encryption protocol is used by
+ in order to determine what the protocol parameter of the Content-Type
+ header should be.
+
+ The encryption protocol.
+
+
+
+ Gets the key exchange protocol.
+
+
+ Gets the key exchange protocol.
+
+ The key exchange protocol.
+
+
+
+ Checks whether or not the specified protocol is supported.
+
+
+ Used in order to make sure that the protocol parameter value specified in either a multipart/signed
+ or multipart/encrypted part is supported by the supplied cryptography context.
+
+ true if the protocol is supported; otherwise false
+ The protocol.
+
+ is null.
+
+
+
+
+ Gets the string name of the digest algorithm for use with the micalg parameter of a multipart/signed part.
+
+
+ Maps the to the appropriate string identifier
+ as used by the micalg parameter value of a multipart/signed Content-Type
+ header. For example:
+
+ AlgorithmName
+ - pgp-md5
+ - pgp-sha1
+ - pgp-ripemd160
+ - pgp-md2
+ - pgp-tiger192
+ - pgp-haval-5-160
+ - pgp-sha256
+ - pgp-sha384
+ - pgp-sha512
+ - pgp-sha224
+
+
+ The micalg value.
+ The digest algorithm.
+
+ is out of range.
+
+
+
+
+ Gets the digest algorithm from the micalg parameter value in a multipart/signed part.
+
+
+ Maps the micalg parameter value string back to the appropriate .
+
+ The digest algorithm.
+ The micalg parameter value.
+
+ is null.
+
+
+
+
+ Gets the public key associated with the mailbox address.
+
+
+ Gets the public key associated with the mailbox address.
+
+ The encryption key.
+ The mailbox.
+
+ is null.
+
+
+ The public key for the specified could not be found.
+
+
+
+
+ Gets the public keys for the specified mailbox addresses.
+
+
+ Gets the public keys for the specified mailbox addresses.
+
+ The encryption keys.
+ The mailboxes.
+
+ is null.
+
+
+ A public key for one or more of the could not be found.
+
+
+
+
+ Gets the signing key associated with the mailbox address.
+
+
+ Gets the signing key associated with the mailbox address.
+
+ The signing key.
+ The mailbox.
+
+ is null.
+
+
+ A private key for the specified could not be found.
+
+
+
+
+ Gets the password for key.
+
+
+ Gets the password for key.
+
+ The password for key.
+ The key.
+
+ The user chose to cancel the password request.
+
+
+
+
+ Gets the private key from the specified secret key.
+
+
+ Gets the private key from the specified secret key.
+
+ The private key.
+ The secret key.
+
+ is null.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Gets the private key.
+
+
+ Gets the private key.
+
+ The private key.
+ The key identifier.
+
+ The specified secret key could not be found.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Gets the equivalent for the
+ specified .
+
+
+ Maps a to the equivalent .
+
+ The hash algorithm.
+ The digest algorithm.
+
+ is out of range.
+
+
+ is not a supported digest algorithm.
+
+
+
+
+ Cryptographically signs the content.
+
+
+ Cryptographically signs the content using the specified signer and digest algorithm.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+ A signing key could not be found for .
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Cryptographically signs the content.
+
+
+ Cryptographically signs the content using the specified signer and digest algorithm.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+
+
+ The was out of range.
+
+
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Gets the equivalent for the specified
+ .
+
+
+ Gets the equivalent for the specified
+ .
+
+ The digest algorithm.
+ The hash algorithm.
+
+ is out of range.
+
+
+ does not have an equivalent value.
+
+
+
+
+ Gets the equivalent for the specified
+ .
+
+
+ Gets the equivalent for the specified
+ .
+
+ The public-key algorithm.
+ The public-key algorithm.
+
+ is out of range.
+
+
+ does not have an equivalent value.
+
+
+
+
+ Verifies the specified content using the detached signatureData.
+
+
+ Verifies the specified content using the detached signatureData.
+
+ A list of digital signatures.
+ The content.
+ The signature data.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ A public key could not be found for one or more of the .
+
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The encryption algorithm.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ A public key could not be found for one or more of the .
+
+
+ The specified encryption algorithm is not supported.
+
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The encryption algorithm.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The specified encryption algorithm is not supported.
+
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The signer.
+ The digest algorithm to use for signing.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The specified is not supported by this context.
+
+
+ The private key could not be found for .
+
+
+ A public key could not be found for one or more of the .
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The signer.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The specified encryption algorithm is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The signer.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The specified encryption algorithm is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The signer.
+ The digest algorithm to use for signing.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Decrypts the specified encryptedData and extracts the digital signers if the content was also signed.
+
+
+ Decrypts the specified encryptedData and extracts the digital signers if the content was also signed.
+
+ The decrypted stream.
+ The encrypted data.
+ A list of digital signatures if the data was both signed and encrypted.
+
+ is null.
+
+
+ The private key could not be found to decrypt the stream.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+ An OpenPGP error occurred.
+
+
+
+
+ Decrypts the specified encryptedData.
+
+
+ Decrypts the specified encryptedData.
+
+ The decrypted stream.
+ The encrypted data.
+
+ is null.
+
+
+ The private key could not be found to decrypt the stream.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+ An OpenPGP error occurred.
+
+
+
+
+ Decrypts the specified encryptedData and extracts the digital signers if the content was also signed.
+
+
+ Decrypts the specified encryptedData and extracts the digital signers if the content was also signed.
+
+ The decrypted .
+ The encrypted data.
+ A list of digital signatures if the data was both signed and encrypted.
+
+ is null.
+
+
+ The private key could not be found to decrypt the stream.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+ An OpenPGP error occurred.
+
+
+
+
+ Decrypts the specified encryptedData.
+
+
+ Decrypts the specified encryptedData.
+
+ The decrypted .
+ The encrypted data.
+
+ is null.
+
+
+ The private key could not be found to decrypt the stream.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+ An OpenPGP error occurred.
+
+
+
+
+ Saves the public key-ring bundle.
+
+
+ Atomically saves the public key-ring bundle to the path specified by .
+ Called by if any public keys were successfully imported.
+
+
+ An error occured while saving the public key-ring bundle.
+
+
+
+
+ Saves the secret key-ring bundle.
+
+
+ Atomically saves the secret key-ring bundle to the path specified by .
+ Called by if any secret keys were successfully imported.
+
+
+ An error occured while saving the secret key-ring bundle.
+
+
+
+
+ Imports a public pgp keyring.
+
+
+ Imports a public pgp keyring.
+
+ The pgp keyring.
+
+ is null.
+
+
+
+
+ Imports a public pgp keyring bundle.
+
+
+ Imports a public pgp keyring bundle.
+
+ The pgp keyring bundle.
+
+ is null.
+
+
+
+
+ Imports public pgp keys from the specified stream.
+
+
+ Imports public pgp keys from the specified stream.
+
+ The raw key data.
+
+ is null.
+
+
+ An error occurred while parsing the raw key-ring data
+ -or-
+ An error occured while saving the public key-ring bundle.
+
+
+
+
+ Imports a secret pgp keyring.
+
+
+ Imports a secret pgp keyring.
+
+ The pgp keyring.
+
+ is null.
+
+
+
+
+ Imports a secret pgp keyring bundle.
+
+
+ Imports a secret pgp keyring bundle.
+
+ The pgp keyring bundle.
+
+ is null.
+
+
+
+
+ Imports secret pgp keys from the specified stream.
+
+
+ Imports secret pgp keys from the specified stream.
+ The stream should consist of an armored secret keyring bundle
+ containing 1 or more secret keyrings.
+
+ The raw key data.
+
+ is null.
+
+
+ An error occurred while parsing the raw key-ring data
+ -or-
+ An error occured while saving the public key-ring bundle.
+
+
+
+
+ Exports the public keys for the specified mailboxes.
+
+
+ Exports the public keys for the specified mailboxes.
+
+ A new instance containing the exported public keys.
+ The mailboxes.
+
+ is null.
+
+
+ was empty.
+
+
+
+
+ Exports the specified public keys.
+
+
+ Exports the specified public keys.
+
+ A new instance containing the exported public keys.
+ The keys.
+
+ is null.
+
+
+
+
+ Exports the specified public keys.
+
+
+ Exports the specified public keys.
+
+ A new instance containing the exported public keys.
+ The keys.
+
+ is null.
+
+
+
+
+ An OpenPGP digital certificate.
+
+
+ An OpenPGP digital certificate.
+
+
+
+
+ Gets the public key.
+
+
+ Gets the public key.
+
+ The public key.
+
+
+
+ Gets the public key algorithm supported by the certificate.
+
+
+ Gets the public key algorithm supported by the certificate.
+
+ The public key algorithm.
+
+
+
+ Gets the date that the certificate was created.
+
+
+ Gets the date that the certificate was created.
+
+ The creation date.
+
+
+
+ Gets the expiration date of the certificate.
+
+
+ Gets the expiration date of the certificate.
+
+ The expiration date.
+
+
+
+ Gets the fingerprint of the certificate.
+
+
+ Gets the fingerprint of the certificate.
+
+ The fingerprint.
+
+
+
+ Gets the email address of the owner of the certificate.
+
+
+ Gets the email address of the owner of the certificate.
+
+ The email address.
+
+
+
+ Gets the name of the owner of the certificate.
+
+
+ Gets the name of the owner of the certificate.
+
+ The name of the owner.
+
+
+
+ An OpenPGP digital signature.
+
+
+ An OpenPGP digital signature.
+
+
+
+
+ Gets certificate used by the signer.
+
+
+ Gets certificate used by the signer.
+
+ The signer's certificate.
+
+
+
+ Gets the public key algorithm used for the signature.
+
+
+ Gets the public key algorithm used for the signature.
+
+ The public key algorithm.
+
+
+
+ Gets the digest algorithm used for the signature.
+
+
+ Gets the digest algorithm used for the signature.
+
+ The digest algorithm.
+
+
+
+ Gets the creation date of the digital signature.
+
+
+ Gets the creation date of the digital signature.
+
+ The creation date.
+
+
+
+ Verifies the digital signature.
+
+
+ Verifies the digital signature.
+
+ true if the signature is valid; otherwise false.
+
+ An error verifying the signature has occurred.
+
+
+
+
+ An exception that is thrown when a private key could not be found for a specified mailbox or key id.
+
+
+ An exception that is thrown when a private key could not be found for a specified mailbox or key id.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The serialization info.
+ The stream context.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The mailbox that could not be resolved to a valid private key.
+ A message explaining the error.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The key id that could not be resolved to a valid certificate.
+ A message explaining the error.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The key id that could not be resolved to a valid certificate.
+ A message explaining the error.
+
+ is null.
+
+
+
+
+ When overridden in a derived class, sets the
+ with information about the exception.
+
+
+ Sets the
+ with information about the exception.
+
+ The serialization info.
+ The streaming context.
+
+ is null.
+
+
+
+
+ Gets the key id that could not be found.
+
+
+ Gets the key id that could not be found.
+
+ The key id.
+
+
+
+ An enumeration of public key algorithms.
+
+
+ An enumeration of public key algorithms.
+
+
+
+
+ No public key algorithm specified.
+
+
+
+
+ The RSA algorithm.
+
+
+
+
+ The RSA encryption-only algorithm.
+
+
+
+
+ The RSA sign-only algorithm.
+
+
+
+
+ The El-Gamal encryption-only algorithm.
+
+
+
+
+ The DSA algorithm.
+
+
+
+
+ The elliptic curve algorithm.
+
+
+
+
+ The elliptic curve DSA algorithm.
+
+
+
+
+ The El-Gamal algorithm.
+
+
+
+
+ The Diffie-Hellman algorithm.
+
+
+
+
+ An exception that is thrown when a public key could not be found for a specified mailbox.
+
+
+ An exception that is thrown when a public key could not be found for a specified mailbox.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The serialization info.
+ The stream context.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The mailbox that could not be resolved to a valid private key.
+ A message explaining the error.
+
+
+
+ When overridden in a derived class, sets the
+ with information about the exception.
+
+
+ Sets the
+ with information about the exception.
+
+ The serialization info.
+ The streaming context.
+
+ is null.
+
+
+
+
+ Gets the key id that could not be found.
+
+
+ Gets the key id that could not be found.
+
+ The key id.
+
+
+
+ A secure mailbox address which includes a fingerprint for a certificate.
+
+
+ When signing or encrypting a message, it is necessary to look up the
+ X.509 certificate in order to do the actual sign or encrypt operation. One
+ way of accomplishing this is to use the email address of sender or recipient
+ as a unique identifier. However, a better approach is to use the fingerprint
+ (or 'thumbprint' in Microsoft parlance) of the user's certificate.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified fingerprint.
+
+ The character encoding to be used for encoding the name.
+ The name of the mailbox.
+ The route of the mailbox.
+ The address of the mailbox.
+ The fingerprint of the certificate belonging to the owner of the mailbox.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified fingerprint.
+
+ The name of the mailbox.
+ The route of the mailbox.
+ The address of the mailbox.
+ The fingerprint of the certificate belonging to the owner of the mailbox.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified fingerprint.
+
+ The character encoding to be used for encoding the name.
+ The name of the mailbox.
+ The address of the mailbox.
+ The fingerprint of the certificate belonging to the owner of the mailbox.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified fingerprint.
+
+ The name of the mailbox.
+ The address of the mailbox.
+ The fingerprint of the certificate belonging to the owner of the mailbox.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets the fingerprint of the certificate and/or key to use for signing or encrypting.
+
+
+
+
+ A fingerprint is a SHA-1 hash of the raw certificate data and is often used
+ as a unique identifier for a particular certificate in a certificate store.
+
+ The fingerprint of the certificate.
+
+
+
+ A Secure MIME (S/MIME) cryptography context.
+
+
+ Generally speaking, applications should not use a
+ directly, but rather via higher level APIs such as
+ and .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Enables the following encryption algorithms by default:
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the signature protocol.
+
+
+ The signature protocol is used by
+ in order to determine what the protocol parameter of the Content-Type
+ header should be.
+
+ The signature protocol.
+
+
+
+ Gets the encryption protocol.
+
+
+ The encryption protocol is used by
+ in order to determine what the protocol parameter of the Content-Type
+ header should be.
+
+ The encryption protocol.
+
+
+
+ Gets the key exchange protocol.
+
+
+ Gets the key exchange protocol.
+
+ The key exchange protocol.
+
+
+
+ Checks whether or not the specified protocol is supported by the .
+
+
+ Used in order to make sure that the protocol parameter value specified in either a multipart/signed
+ or multipart/encrypted part is supported by the supplied cryptography context.
+
+ true if the protocol is supported; otherwise false
+ The protocol.
+
+ is null.
+
+
+
+
+ Gets the string name of the digest algorithm for use with the micalg parameter of a multipart/signed part.
+
+
+ Maps the to the appropriate string identifier
+ as used by the micalg parameter value of a multipart/signed Content-Type
+ header. For example:
+
+ AlgorithmName
+ - md5
+ - sha-1
+ - sha-224
+ - sha-256
+ - sha-384
+ - sha-512
+
+
+ The micalg value.
+ The digest algorithm.
+
+ is out of range.
+
+
+
+
+ Gets the digest algorithm from the micalg parameter value in a multipart/signed part.
+
+
+ Maps the micalg parameter value string back to the appropriate .
+
+ The digest algorithm.
+ The micalg parameter value.
+
+ is null.
+
+
+
+
+ Gets the preferred rank order for the encryption algorithms; from the strongest to the weakest.
+
+
+ Gets the preferred rank order for the encryption algorithms; from the strongest to the weakest.
+
+ The preferred encryption algorithm ranking.
+
+
+
+ Gets the enabled encryption algorithms in ranked order.
+
+
+ Gets the enabled encryption algorithms in ranked order.
+
+ The enabled encryption algorithms.
+
+
+
+ Enables the encryption algorithm.
+
+
+ Enables the encryption algorithm.
+
+ The encryption algorithm.
+
+
+
+ Disables the encryption algorithm.
+
+
+ Disables the encryption algorithm.
+
+ The encryption algorithm.
+
+
+
+ Checks whether the specified encryption algorithm is enabled.
+
+
+ Determines whether the specified encryption algorithm is enabled.
+
+ true if the specified encryption algorithm is enabled; otherwise, false.
+ Algorithm.
+
+
+
+ Gets the X.509 certificate matching the specified selector.
+
+
+ Gets the first certificate that matches the specified selector.
+
+ The certificate on success; otherwise null.
+ The search criteria for the certificate.
+
+
+
+ Gets the private key for the certificate matching the specified selector.
+
+
+ Gets the private key for the first certificate that matches the specified selector.
+
+ The private key on success; otherwise null.
+ The search criteria for the private key.
+
+
+
+ Gets the trusted anchors.
+
+
+ A trusted anchor is a trusted root-level X.509 certificate,
+ generally issued by a certificate authority (CA).
+
+ The trusted anchors.
+
+
+
+ Gets the intermediate certificates.
+
+
+ An intermediate certificate is any certificate that exists between the root
+ certificate issued by a Certificate Authority (CA) and the certificate at
+ the end of the chain.
+
+ The intermediate certificates.
+
+
+
+ Gets the certificate revocation lists.
+
+
+ A Certificate Revocation List (CRL) is a list of certificate serial numbers issued
+ by a particular Certificate Authority (CA) that have been revoked, either by the CA
+ itself or by the owner of the revoked certificate.
+
+ The certificate revocation lists.
+
+
+
+ Gets the for the specified mailbox.
+
+
+ Constructs a with the appropriate certificate and
+ for the specified mailbox.
+ If the mailbox is a , the
+ property will be used instead of
+ the mailbox address.
+
+ A .
+ The mailbox.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Gets a collection of CmsRecipients for the specified mailboxes.
+
+
+ Gets a collection of CmsRecipients for the specified mailboxes.
+
+ A .
+ The mailboxes.
+
+ is null.
+
+
+ A certificate for one or more of the specified could not be found.
+
+
+
+
+ Gets the for the specified mailbox.
+
+
+ Constructs a with the appropriate signing certificate
+ for the specified mailbox.
+ If the mailbox is a , the
+ property will be used instead of
+ the mailbox address for database lookups.
+
+ A .
+ The mailbox.
+ The preferred digest algorithm.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+ The certificate.
+ The encryption algorithm capabilities of the client (in preferred order).
+ The timestamp.
+
+
+
+ Gets the OID for the digest algorithm.
+
+
+ Gets the OID for the digest algorithm.
+
+ The digest oid.
+ The digest algorithm.
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+
+
+ Compresses the specified stream.
+
+
+ Compresses the specified stream.
+
+ A new instance
+ containing the compressed content.
+ The stream to compress.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Decompress the specified stream.
+
+
+ Decompress the specified stream.
+
+ The decompressed mime part.
+ The stream to decompress.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs and encapsulates the content using the specified signer.
+
+
+ Cryptographically signs and encapsulates the content using the specified signer.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs and encapsulates the content using the specified signer and digest algorithm.
+
+
+ Cryptographically signs and encapsulates the content using the specified signer and digest algorithm.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+ A signing certificate could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs the content using the specified signer.
+
+
+ Cryptographically signs the content using the specified signer.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs the content using the specified signer and digest algorithm.
+
+
+ Cryptographically signs the content using the specified signer and digest algorithm.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+ A signing certificate could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Attempts to map a
+ to a .
+
+
+ Attempts to map a
+ to a .
+
+ true if the algorithm identifier was successfully mapped; false otherwise.
+ The algorithm identifier.
+ The encryption algorithm.
+
+ is null.
+
+
+
+
+ Verifies the specified content using the detached signatureData.
+
+
+ Verifies the specified content using the detached signatureData.
+
+ A list of the digital signatures.
+ The content.
+ The detached signature data.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Verifies the digital signatures of the specified signedData and extract the original content.
+
+
+ Verifies the digital signatures of the specified signedData and extract the original content.
+
+ The list of digital signatures.
+ The signed data.
+ The unencapsulated entity.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Gets the preferred encryption algorithm to use for encrypting to the specified recipients.
+
+
+ Gets the preferred encryption algorithm to use for encrypting to the specified recipients
+ based on the encryption algorithms supported by each of the recipients, the
+ , and the .
+ If the supported encryption algorithms are unknown for any recipient, it is assumed that
+ the recipient supports at least the Triple-DES encryption algorithm.
+
+ The preferred encryption algorithm.
+ The recipients.
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted content.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ A certificate for one or more of the could not be found.
+
+
+ A certificate could not be found for one or more of the .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Decrypts the specified encryptedData.
+
+
+ Decrypts the specified encryptedData.
+
+ The decrypted .
+ The encrypted data.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+ The raw certificate and key data.
+ The password to unlock the stream.
+
+ is null.
+ -or-
+ is null.
+
+
+ Importing keys is not supported by this cryptography context.
+
+
+
+
+ Exports the certificates for the specified mailboxes.
+
+
+ Exports the certificates for the specified mailboxes.
+
+ A new instance containing
+ the exported keys.
+ The mailboxes.
+
+ is null.
+
+
+ No mailboxes were specified.
+
+
+ A certificate for one or more of the could not be found.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Imports the specified certificate.
+
+
+ Imports the specified certificate.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Imports the specified certificate revocation list.
+
+
+ Imports the specified certificate revocation list.
+
+ The certificate revocation list.
+
+ is null.
+
+
+
+
+ Imports certificates (as from a certs-only application/pkcs-mime part)
+ from the specified stream.
+
+
+ Imports certificates (as from a certs-only application/pkcs-mime part)
+ from the specified stream.
+
+ The raw key data.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ An S/MIME digital certificate.
+
+
+ An S/MIME digital certificate.
+
+
+
+
+ Gets the .
+
+
+ Gets the .
+
+ The certificate.
+
+
+
+ Gets the public key algorithm supported by the certificate.
+
+
+ Gets the public key algorithm supported by the certificate.
+
+ The public key algorithm.
+
+
+
+ Gets the date that the certificate was created.
+
+
+ Gets the date that the certificate was created.
+
+ The creation date.
+
+
+
+ Gets the expiration date of the certificate.
+
+
+ Gets the expiration date of the certificate.
+
+ The expiration date.
+
+
+
+ Gets the fingerprint of the certificate.
+
+
+ Gets the fingerprint of the certificate.
+
+ The fingerprint.
+
+
+
+ Gets the email address of the owner of the certificate.
+
+
+ Gets the email address of the owner of the certificate.
+
+ The email address.
+
+
+
+ Gets the name of the owner of the certificate.
+
+
+ Gets the name of the owner of the certificate.
+
+ The name of the owner.
+
+
+
+ An S/MIME digital signature.
+
+
+ An S/MIME digital signature.
+
+
+
+
+ Gets the signer info.
+
+
+ Gets the signer info.
+
+ The signer info.
+
+
+
+ Gets the list of encryption algorithms, in preferential order,
+ that the signer's client supports.
+
+
+ Gets the list of encryption algorithms, in preferential order,
+ that the signer's client supports.
+
+ The S/MIME encryption algorithms.
+
+
+
+ Gets the certificate chain.
+
+
+ If building the certificate chain failed, this value will be null and
+ will be set.
+
+ The certificate chain.
+
+
+
+ The exception that occurred, if any, while building the certificate chain.
+
+
+ This will only be set if building the certificate chain failed.
+
+ The exception.
+
+
+
+ Gets certificate used by the signer.
+
+
+ Gets certificate used by the signer.
+
+ The signer's certificate.
+
+
+
+ Gets the public key algorithm used for the signature.
+
+
+ Gets the public key algorithm used for the signature.
+
+ The public key algorithm.
+
+
+
+ Gets the digest algorithm used for the signature.
+
+
+ Gets the digest algorithm used for the signature.
+
+ The digest algorithm.
+
+
+
+ Gets the creation date of the digital signature.
+
+
+ Gets the creation date of the digital signature.
+
+ The creation date.
+
+
+
+ Verifies the digital signature.
+
+
+ Verifies the digital signature.
+
+ true if the signature is valid; otherwise false.
+
+ An error verifying the signature has occurred.
+
+
+
+
+ The type of S/MIME data that an application/pkcs7-mime part contains.
+
+
+ The type of S/MIME data that an application/pkcs7-mime part contains.
+
+
+
+
+ S/MIME compressed data.
+
+
+
+
+ S/MIME enveloped data.
+
+
+
+
+ S/MIME signed data.
+
+
+
+
+ S/MIME certificate data.
+
+
+
+
+ The S/MIME data type is unknown.
+
+
+
+
+ An abstract X.509 certificate database built on generic SQL storage.
+
+
+ An X.509 certificate database is used for storing certificates, metdata related to the certificates
+ (such as encryption algorithms supported by the associated client), certificate revocation lists (CRLs),
+ and private keys.
+ This particular database uses SQLite to store the data.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new using the provided database connection.
+
+ The database .
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets the command to create the certificates table.
+
+
+ Constructs the command to create a certificates table suitable for storing
+ objects.
+
+ The .
+ The .
+
+
+
+ Gets the command to create the CRLs table.
+
+
+ Constructs the command to create a CRLs table suitable for storing
+ objects.
+
+ The .
+ The .
+
+
+
+ Gets the database command to select the record matching the specified certificate.
+
+
+ Gets the database command to select the record matching the specified certificate.
+
+ The database command.
+ The certificate.
+ The fields to return.
+
+
+
+ Gets the database command to select the certificate records for the specified mailbox.
+
+
+ Gets the database command to select the certificate records for the specified mailbox.
+
+ The database command.
+ The mailbox.
+ The date and time for which the certificate should be valid.
+ true
+ The fields to return.
+
+
+
+ Gets the database command to select the certificate records for the specified mailbox.
+
+
+ Gets the database command to select the certificate records for the specified mailbox.
+
+ The database command.
+ Selector.
+ If set to true trusted only.
+ true
+ The fields to return.
+
+
+
+ Gets the database command to select the CRL records matching the specified issuer.
+
+
+ Gets the database command to select the CRL records matching the specified issuer.
+
+ The database command.
+ The issuer.
+ The fields to return.
+
+
+
+ Gets the database command to select the record for the specified CRL.
+
+
+ Gets the database command to select the record for the specified CRL.
+
+ The database command.
+ The X.509 CRL.
+ The fields to return.
+
+
+
+ Gets the database command to select all CRLs in the table.
+
+
+ Gets the database command to select all CRLs in the table.
+
+ The database command.
+
+
+
+ Gets the database command to delete the specified certificate record.
+
+
+ Gets the database command to delete the specified certificate record.
+
+ The database command.
+ The certificate record.
+
+
+
+ Gets the database command to delete the specified CRL record.
+
+
+ Gets the database command to delete the specified CRL record.
+
+ The database command.
+ The record.
+
+
+
+ Gets the database command to insert the specified certificate record.
+
+
+ Gets the database command to insert the specified certificate record.
+
+ The database command.
+ The certificate record.
+
+
+
+ Gets the database command to insert the specified CRL record.
+
+
+ Gets the database command to insert the specified CRL record.
+
+ The database command.
+ The CRL record.
+
+
+
+ Gets the database command to update the specified record.
+
+
+ Gets the database command to update the specified record.
+
+ The database command.
+ The certificate record.
+ The fields to update.
+
+
+
+ Gets the database command to update the specified CRL record.
+
+
+ Gets the database command to update the specified CRL record.
+
+ The database command.
+ The CRL record.
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ An X.509 certificate database built on SQLite.
+
+
+ An X.509 certificate database is used for storing certificates, metdata related to the certificates
+ (such as encryption algorithms supported by the associated client), certificate revocation lists (CRLs),
+ and private keys.
+ This particular database uses SQLite to store the data.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new and opens a connection to the
+ SQLite database at the specified path using the Mono.Data.Sqlite binding to the native
+ SQLite library.
+ If Mono.Data.Sqlite is not available or if an alternative binding to the native
+ SQLite library is preferred, then consider using
+ instead.
+
+ The file name.
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+ The user does not have access to read the specified file.
+
+
+ An error occurred reading the file.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new using the provided SQLite database connection.
+
+ The SQLite connection.
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets the command to create the certificates table.
+
+
+ Constructs the command to create a certificates table suitable for storing
+ objects.
+
+ The .
+ The .
+
+
+
+ Gets the command to create the CRLs table.
+
+
+ Constructs the command to create a CRLs table suitable for storing
+ objects.
+
+ The .
+ The .
+
+
+
+ The method to use for identifying a certificate.
+
+
+ The method to use for identifying a certificate.
+
+
+
+
+ The identifier type is unknown.
+
+
+
+
+ Identify the certificate by its Issuer and Serial Number properties.
+
+
+
+
+ Identify the certificate by the sha1 hash of its public key.
+
+
+
+
+ An S/MIME context that does not persist certificates, private keys or CRLs.
+
+
+ A is a special S/MIME context that
+ does not use a persistent store for certificates, private keys, or CRLs.
+ Instead, certificates, private keys, and CRLs are maintained in memory only.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the X.509 certificate matching the specified selector.
+
+
+ Gets the first certificate that matches the specified selector.
+
+ The certificate on success; otherwise null.
+ The search criteria for the certificate.
+
+
+
+ Gets the private key for the certificate matching the specified selector.
+
+
+ Gets the private key for the first certificate that matches the specified selector.
+
+ The private key on success; otherwise null.
+ The search criteria for the private key.
+
+
+
+ Gets the trusted anchors.
+
+
+ A trusted anchor is a trusted root-level X.509 certificate,
+ generally issued by a certificate authority (CA).
+
+ The trusted anchors.
+
+
+
+ Gets the intermediate certificates.
+
+
+ An intermediate certificate is any certificate that exists between the root
+ certificate issued by a Certificate Authority (CA) and the certificate at
+ the end of the chain.
+
+ The intermediate certificates.
+
+
+
+ Gets the certificate revocation lists.
+
+
+ A Certificate Revocation List (CRL) is a list of certificate serial numbers issued
+ by a particular Certificate Authority (CA) that have been revoked, either by the CA
+ itself or by the owner of the revoked certificate.
+
+ The certificate revocation lists.
+
+
+
+ Gets the for the specified mailbox.
+
+
+ Constructs a with the appropriate certificate and
+ for the specified mailbox.
+ If the mailbox is a , the
+ property will be used instead of
+ the mailbox address.
+
+ A .
+ The mailbox.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Gets the for the specified mailbox.
+
+
+ Constructs a with the appropriate signing certificate
+ for the specified mailbox.
+ If the mailbox is a , the
+ property will be used instead of
+ the mailbox address for database lookups.
+
+ A .
+ The mailbox.
+ The preferred digest algorithm.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+ The certificate.
+ The encryption algorithm capabilities of the client (in preferred order).
+ The timestamp.
+
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+ The raw certificate and key data.
+ The password to unlock the stream.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Imports the specified certificate.
+
+
+ Imports the specified certificate.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Imports the specified certificate revocation list.
+
+
+ Imports the specified certificate revocation list.
+
+ The certificate revocation list.
+
+ is null.
+
+
+
+
+ An S/MIME cryptography context that uses Windows' .
+
+
+ An S/MIME cryptography context that uses Windows' .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The X.509 store location.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Constructs an S/MIME context using the current user's X.509 store location.
+
+
+
+
+ Gets the X.509 store location.
+
+
+ Gets the X.509 store location.
+
+ The store location.
+
+
+
+ Gets the X.509 certificate based on the selector.
+
+
+ Gets the X.509 certificate based on the selector.
+
+ The certificate on success; otherwise null.
+ The search criteria for the certificate.
+
+
+
+ Gets the private key based on the provided selector.
+
+
+ Gets the private key based on the provided selector.
+
+ The private key on success; otherwise null.
+ The search criteria for the private key.
+
+
+
+ Gets the trusted anchors.
+
+
+ Gets the trusted anchors.
+
+ The trusted anchors.
+
+
+
+ Gets the intermediate certificates.
+
+
+ Gets the intermediate certificates.
+
+ The intermediate certificates.
+
+
+
+ Gets the certificate revocation lists.
+
+
+ Gets the certificate revocation lists.
+
+ The certificate revocation lists.
+
+
+
+ Gets the X.509 certificate associated with the .
+
+
+ Gets the X.509 certificate associated with the .
+
+ The certificate.
+ The mailbox.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Gets the cms signer for the specified .
+
+
+ Gets the cms signer for the specified .
+
+ The cms signer.
+ The mailbox.
+ The preferred digest algorithm.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+ The certificate.
+ The encryption algorithm capabilities of the client (in preferred order).
+ The timestamp.
+
+
+
+ Sign and encapsulate the content using the specified signer.
+
+
+ Sign and encapsulate the content using the specified signer.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+ A signing certificate could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Sign the content using the specified signer.
+
+
+ Sign the content using the specified signer.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+ A signing certificate could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Decrypt the encrypted data.
+
+
+ Decrypt the encrypted data.
+
+ The decrypted .
+ The encrypted data.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Import the specified certificate.
+
+
+ Import the specified certificate.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Import the specified certificate revocation list.
+
+
+ Import the specified certificate revocation list.
+
+ The certificate revocation list.
+
+ is null.
+
+
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+ The raw certificate and key data.
+ The password to unlock the stream.
+
+ is null.
+ -or-
+ is null.
+
+
+ Importing keys is not supported by this cryptography context.
+
+
+
+
+ An X.509 certificate chain.
+
+
+ An X.509 certificate chain.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new X.509 certificate chain.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new X.509 certificate chain based on the specified collection of certificates.
+
+ A collection of certificates.
+
+
+
+ Gets the index of the specified certificate within the chain.
+
+
+ Finds the index of the specified certificate, if it exists.
+
+ The index of the specified certificate if found; otherwise -1.
+ The certificate to get the index of.
+
+ is null.
+
+
+
+
+ Inserts the certificate at the specified index.
+
+
+ Inserts the certificate at the specified index in the certificates.
+
+ The index to insert the certificate.
+ The certificate.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the certificate at the specified index.
+
+
+ Removes the certificate at the specified index.
+
+ The index of the certificate to remove.
+
+ is out of range.
+
+
+
+
+ Gets or sets the certificate at the specified index.
+
+
+ Gets or sets the certificate at the specified index.
+
+ The internet certificate at the specified index.
+ The index of the certificate to get or set.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Gets the number of certificates in the chain.
+
+
+ Indicates the number of certificates in the chain.
+
+ The number of certificates.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Adds the specified certificate to the chain.
+
+
+ Adds the specified certificate to the chain.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Adds the specified range of certificates to the chain.
+
+
+ Adds the specified range of certificates to the chain.
+
+ The certificates.
+
+ is null.
+
+
+
+
+ Clears the certificate chain.
+
+
+ Removes all of the certificates from the chain.
+
+
+
+
+ Checks if the chain contains the specified certificate.
+
+
+ Determines whether or not the certificate chain contains the specified certificate.
+
+ true if the specified certificate exists;
+ otherwise false.
+ The certificate.
+
+ is null.
+
+
+
+
+ Copies all of the certificates in the chain to the specified array.
+
+
+ Copies all of the certificates within the chain into the array,
+ starting at the specified array index.
+
+ The array to copy the certificates to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified certificate from the chain.
+
+
+ Removes the specified certificate from the chain.
+
+ true if the certificate was removed; otherwise false.
+ The certificate.
+
+ is null.
+
+
+
+
+ Removes the specified range of certificates from the chain.
+
+
+ Removes the specified range of certificates from the chain.
+
+ The certificates.
+
+ is null.
+
+
+
+
+ Gets an enumerator for the list of certificates.
+
+
+ Gets an enumerator for the list of certificates.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of certificates.
+
+
+ Gets an enumerator for the list of certificates.
+
+ The enumerator.
+
+
+
+ Gets an enumerator of matching X.509 certificates based on the specified selector.
+
+
+ Gets an enumerator of matching X.509 certificates based on the specified selector.
+
+ The matching certificates.
+ The match criteria.
+
+
+
+ Gets a collection of matching X.509 certificates based on the specified selector.
+
+
+ Gets a collection of matching X.509 certificates based on the specified selector.
+
+ The matching certificates.
+ The match criteria.
+
+
+
+ An X.509 certificate database.
+
+
+ An X.509 certificate database is used for storing certificates, metadata related to the certificates
+ (such as encryption algorithms supported by the associated client), certificate revocation lists (CRLs),
+ and private keys.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The password is used to encrypt and decrypt private keys in the database and cannot be null.
+
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+
+
+
+
+ Releases unmanaged resources and performs other cleanup operations before the
+ is reclaimed by garbage collection.
+
+
+ Releases unmanaged resources and performs other cleanup operations before the
+ is reclaimed by garbage collection.
+
+
+
+
+ Gets or sets the algorithm used for encrypting the private keys.
+
+
+ The encryption algorithm should be one of the PBE (password-based encryption) algorithms
+ supported by Bouncy Castle.
+ The default algorithm is SHA-256 + AES256.
+
+ The encryption algorithm.
+
+
+
+ Gets or sets the minimum iterations.
+
+
+ The default minimum number of iterations is 1024.
+
+ The minimum iterations.
+
+
+
+ Gets or sets the size of the salt.
+
+
+ The default salt size is 20.
+
+ The size of the salt.
+
+
+
+ Gets the column names for the specified fields.
+
+
+ Gets the column names for the specified fields.
+
+ The column names.
+ The fields.
+
+
+
+ Gets the database command to select the record matching the specified certificate.
+
+
+ Gets the database command to select the record matching the specified certificate.
+
+ The database command.
+ The certificate.
+ The fields to return.
+
+
+
+ Gets the database command to select the certificate records for the specified mailbox.
+
+
+ Gets the database command to select the certificate records for the specified mailbox.
+
+ The database command.
+ The mailbox.
+ The date and time for which the certificate should be valid.
+ true if the certificate must have a private key.
+ The fields to return.
+
+
+
+ Gets the database command to select certificate records matching the specified selector.
+
+
+ Gets the database command to select certificate records matching the specified selector.
+
+ The database command.
+ Selector.
+ true if only trusted certificates should be matched.
+ true if the certificate must have a private key.
+ The fields to return.
+
+
+
+ Gets the column names for the specified fields.
+
+
+ Gets the column names for the specified fields.
+
+ The column names.
+ The fields.
+
+
+
+ Gets the database command to select the CRL records matching the specified issuer.
+
+
+ Gets the database command to select the CRL records matching the specified issuer.
+
+ The database command.
+ The issuer.
+ The fields to return.
+
+
+
+ Gets the database command to select the record for the specified CRL.
+
+
+ Gets the database command to select the record for the specified CRL.
+
+ The database command.
+ The X.509 CRL.
+ The fields to return.
+
+
+
+ Gets the database command to select all CRLs in the table.
+
+
+ Gets the database command to select all CRLs in the table.
+
+ The database command.
+
+
+
+ Gets the database command to delete the specified certificate record.
+
+
+ Gets the database command to delete the specified certificate record.
+
+ The database command.
+ The certificate record.
+
+
+
+ Gets the database command to delete the specified CRL record.
+
+
+ Gets the database command to delete the specified CRL record.
+
+ The database command.
+ The record.
+
+
+
+ Gets the value for the specified column.
+
+
+ Gets the value for the specified column.
+
+ The value.
+ The certificate record.
+ The column name.
+
+ is not a known column name.
+
+
+
+
+ Gets the value for the specified column.
+
+
+ Gets the value for the specified column.
+
+ The value.
+ The CRL record.
+ The column name.
+
+ is not a known column name.
+
+
+
+
+ Gets the database command to insert the specified certificate record.
+
+
+ Gets the database command to insert the specified certificate record.
+
+ The database command.
+ The certificate record.
+
+
+
+ Gets the database command to insert the specified CRL record.
+
+
+ Gets the database command to insert the specified CRL record.
+
+ The database command.
+ The CRL record.
+
+
+
+ Gets the database command to update the specified record.
+
+
+ Gets the database command to update the specified record.
+
+ The database command.
+ The certificate record.
+ The fields to update.
+
+
+
+ Gets the database command to update the specified CRL record.
+
+
+ Gets the database command to update the specified CRL record.
+
+ The database command.
+ The CRL record.
+
+
+
+ Find the specified certificate.
+
+
+ Searches the database for the specified certificate, returning the matching
+ record with the desired fields populated.
+
+ The matching record if found; otherwise null.
+ The certificate.
+ The desired fields.
+
+ is null.
+
+
+
+
+ Finds the certificates matching the specified selector.
+
+
+ Searches the database for certificates matching the selector, returning all
+ matching certificates.
+
+ The matching certificates.
+ The match selector or null to return all certificates.
+
+
+
+ Finds the private keys matching the specified selector.
+
+
+ Searches the database for certificate records matching the selector, returning the
+ private keys for each matching record.
+
+ The matching certificates.
+ The match selector or null to return all private keys.
+
+
+
+ Finds the certificate records for the specified mailbox.
+
+
+ Searches the database for certificates matching the specified mailbox that are valid
+ for the date and time specified, returning all matching records populated with the
+ desired fields.
+
+ The matching certificate records populated with the desired fields.
+ The mailbox.
+ The date and time.
+ true if a private key is required.
+ The desired fields.
+
+ is null.
+
+
+
+
+ Finds the certificate records matching the specified selector.
+
+
+ Searches the database for certificate records matching the selector, returning all
+ of the matching records populated with the desired fields.
+
+ The matching certificate records populated with the desired fields.
+ The match selector or null to match all certificates.
+ true if only trusted certificates should be returned.
+ The desired fields.
+
+
+
+ Add the specified certificate record.
+
+
+ Adds the specified certificate record to the database.
+
+ The certificate record.
+
+ is null.
+
+
+
+
+ Remove the specified certificate record.
+
+
+ Removes the specified certificate record from the database.
+
+ The certificate record.
+
+ is null.
+
+
+
+
+ Update the specified certificate record.
+
+
+ Updates the specified fields of the record in the database.
+
+ The certificate record.
+ The fields to update.
+
+ is null.
+
+
+
+
+ Finds the CRL records for the specified issuer.
+
+
+ Searches the database for CRL records matching the specified issuer, returning
+ all matching records populated with the desired fields.
+
+ The matching CRL records populated with the desired fields.
+ The issuer.
+ The desired fields.
+
+ is null.
+
+
+
+
+ Finds the specified certificate revocation list.
+
+
+ Searches the database for the specified CRL, returning the matching record with
+ the desired fields populated.
+
+ The matching record if found; otherwise null.
+ The certificate revocation list.
+ The desired fields.
+
+ is null.
+
+
+
+
+ Add the specified CRL record.
+
+
+ Adds the specified CRL record to the database.
+
+ The CRL record.
+
+ is null.
+
+
+
+
+ Remove the specified CRL record.
+
+
+ Removes the specified CRL record from the database.
+
+ The CRL record.
+
+ is null.
+
+
+
+
+ Update the specified CRL record.
+
+
+ Updates the specified fields of the record in the database.
+
+ The CRL record.
+
+ is null.
+
+
+
+
+ Gets a certificate revocation list store.
+
+
+ Gets a certificate revocation list store.
+
+ A certificate recovation list store.
+
+
+
+ Gets a collection of matching certificates matching the specified selector.
+
+
+ Gets a collection of matching certificates matching the specified selector.
+
+ The matching certificates.
+ The match criteria.
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ Releases all resource used by the object.
+
+ Call when you are finished using the
+ . The method leaves the
+ in an unusable state. After calling
+ , you must release all references to the
+ so the garbage collector can reclaim the memory that
+ the was occupying.
+
+
+
+ X509Certificate extension methods.
+
+
+ A collection of useful extension methods for an .
+
+
+
+
+ Gets the issuer name info.
+
+
+ For a list of available identifiers, see .
+
+ The issuer name info.
+ The certificate.
+ The name identifier.
+
+ is null.
+
+
+
+
+ Gets the issuer name info.
+
+
+ For a list of available identifiers, see .
+
+ The issuer name info.
+ The certificate.
+ The name identifier.
+
+ is null.
+
+
+
+
+ Gets the common name of the certificate.
+
+
+ Gets the common name of the certificate.
+
+ The common name.
+ The certificate.
+
+ is null.
+
+
+
+
+ Gets the subject name of the certificate.
+
+
+ Gets the subject name of the certificate.
+
+ The subject name.
+ The certificate.
+
+ is null.
+
+
+
+
+ Gets the subject email address of the certificate.
+
+
+ The email address component of the certificate's Subject identifier is
+ sometimes used as a way of looking up certificates for a particular
+ user if a fingerprint is not available.
+
+ The subject email address.
+ The certificate.
+
+ is null.
+
+
+
+
+ Gets the fingerprint of the certificate.
+
+
+ A fingerprint is a SHA-1 hash of the raw certificate data and is often used
+ as a unique identifier for a particular certificate in a certificate store.
+
+ The fingerprint.
+ The certificate.
+
+ is null.
+
+
+
+
+ Gets the key usage flags.
+
+
+ The X.509 Key Usage Flags are used to determine which operations a certificate
+ may be used for.
+
+ The key usage flags.
+ The certificate.
+
+ is null.
+
+
+
+
+ X.509 certificate record fields.
+
+
+ The record fields are used when querying the
+ for certificates.
+
+
+
+
+ The "id" field is typically just the ROWID in the database.
+
+
+
+
+ The "trusted" field is a boolean value indicating whether the certificate
+ is trusted.
+
+
+
+
+ The "algorithms" field is used for storing the last known list of
+ values that are supported by the
+ client associated with the certificate.
+
+
+
+
+ The "algorithms updated" field is used to store the timestamp of the
+ most recent update to the Algorithms field.
+
+
+
+
+ The "certificate" field is sued for storing the binary data of the actual
+ certificate.
+
+
+
+
+ The "private key" field is used to store the encrypted binary data of the
+ private key associated with the certificate, if available.
+
+
+
+
+ An X.509 certificate record.
+
+
+ Represents an X.509 certificate record loaded from a database.
+
+
+
+
+ Gets the identifier.
+
+
+ The id is typically the ROWID of the certificate in the database and is not
+ generally useful outside of the internals of the database implementation.
+
+ The identifier.
+
+
+
+ Gets the basic constraints of the certificate.
+
+
+ Gets the basic constraints of the certificate.
+
+ The basic constraints of the certificate.
+
+
+
+ Gets or sets a value indicating whether the certificate is trusted.
+
+
+ Indiciates whether or not the certificate is trusted.
+
+ true if the certificate is trusted; otherwise, false.
+
+
+
+ Gets the key usage flags for the certificate.
+
+
+ Gets the key usage flags for the certificate.
+
+ The X.509 key usage.
+
+
+
+ Gets the starting date and time where the certificate is valid.
+
+
+ Gets the starting date and time where the certificate is valid.
+
+ The date and time.
+
+
+
+ Gets the end date and time where the certificate is valid.
+
+
+ Gets the end date and time where the certificate is valid.
+
+ The date and time.
+
+
+
+ Gets the certificate issuer's name.
+
+
+ Gets the certificate issuer's name.
+
+ The issuer's name.
+
+
+
+ Gets the serial number of the certificate.
+
+
+ Gets the serial number of the certificate.
+
+ The serial number.
+
+
+
+ Gets the subject email address.
+
+
+ Gets the subject email address.
+
+ The subject email address.
+
+
+
+ Gets the fingerprint of the certificate.
+
+
+ Gets the fingerprint of the certificate.
+
+ The fingerprint.
+
+
+
+ Gets or sets the encryption algorithm capabilities.
+
+
+ Gets or sets the encryption algorithm capabilities.
+
+ The encryption algorithms.
+
+
+
+ Gets or sets the date when the algorithms were last updated.
+
+
+ Gets or sets the date when the algorithms were last updated.
+
+ The date the algorithms were updated.
+
+
+
+ Gets the certificate.
+
+
+ Gets the certificate.
+
+ The certificate.
+
+
+
+ Gets the private key.
+
+
+ Gets the private key.
+
+ The private key.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new certificate record with a private key for storing in a
+ .
+
+ The certificate.
+ The private key.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a private key.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new certificate record for storing in a .
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is only meant to be used by implementors of
+ when loading records from the database.
+
+
+
+
+ A store for X.509 certificates and keys.
+
+
+ A store for X.509 certificates and keys.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Enumerates the certificates currently in the store.
+
+
+ Enumerates the certificates currently in the store.
+
+ The certificates.
+
+
+
+ Gets the private key for the specified certificate.
+
+
+ Gets the private key for the specified certificate, if it exists.
+
+ The private key on success; otherwise null.
+ The certificate.
+
+
+
+ Adds the specified certificate to the store.
+
+
+ Adds the specified certificate to the store.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Adds the specified range of certificates to the store.
+
+
+ Adds the specified range of certificates to the store.
+
+ The certificates.
+
+ is null.
+
+
+
+
+ Removes the specified certificate from the store.
+
+
+ Removes the specified certificate from the store.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Removes the specified range of certificates from the store.
+
+
+ Removes the specified range of certificates from the store.
+
+ The certificates.
+
+ is null.
+
+
+
+
+ Imports the certificate(s) from the specified stream.
+
+
+ Imports the certificate(s) from the specified stream.
+
+ The stream to import.
+
+ is null.
+
+
+ An error occurred reading the stream.
+
+
+
+
+ Imports the certificate(s) from the specified file.
+
+
+ Imports the certificate(s) from the specified file.
+
+ The name of the file to import.
+
+ is null.
+
+
+ The specified file could not be found.
+
+
+ An error occurred reading the file.
+
+
+
+
+ Imports the certificate(s) from the specified byte array.
+
+
+ Imports the certificate(s) from the specified byte array.
+
+ The raw certificate data.
+
+ is null.
+
+
+
+
+ Imports certificates and private keys from the specified stream.
+
+
+ Imports certificates and private keys from the specified pkcs12 stream.
+
+ The stream to import.
+ The password to unlock the stream.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred reading the stream.
+
+
+
+
+ Imports certificates and private keys from the specified file.
+
+
+ Imports certificates and private keys from the specified pkcs12 stream.
+
+ The name of the file to import.
+ The password to unlock the file.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+ The specified file could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ An error occurred reading the file.
+
+
+
+
+ Imports certificates and private keys from the specified byte array.
+
+
+ Imports certificates and private keys from the specified pkcs12 stream.
+
+ The raw certificate data.
+ The password to unlock the raw data.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Exports the certificates to an unencrypted stream.
+
+
+ Exports the certificates to an unencrypted stream.
+
+ The output stream.
+
+ is null.
+
+
+ An error occurred while writing to the stream.
+
+
+
+
+ Exports the certificates to an unencrypted file.
+
+
+ Exports the certificates to an unencrypted file.
+
+ The file path to write to.
+
+ is null.
+
+
+ The specified file path is empty.
+
+
+ The specified path exceeds the maximum allowed path length of the system.
+
+
+ A directory in the specified path does not exist.
+
+
+ The user does not have access to create the specified file.
+
+
+ An error occurred while writing to the stream.
+
+
+
+
+ Exports the specified stream and password to a pkcs12 encrypted file.
+
+
+ Exports the specified stream and password to a pkcs12 encrypted file.
+
+ The output stream.
+ The password to use to lock the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred while writing to the stream.
+
+
+
+
+ Exports the specified stream and password to a pkcs12 encrypted file.
+
+
+ Exports the specified stream and password to a pkcs12 encrypted file.
+
+ The file path to write to.
+ The password to use to lock the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+ The specified path exceeds the maximum allowed path length of the system.
+
+
+ A directory in the specified path does not exist.
+
+
+ The user does not have access to create the specified file.
+
+
+ An error occurred while writing to the stream.
+
+
+
+
+ Gets an enumerator of matching X.509 certificates based on the specified selector.
+
+
+ Gets an enumerator of matching X.509 certificates based on the specified selector.
+
+ The matching certificates.
+ The match criteria.
+
+
+
+ Gets a collection of matching X.509 certificates based on the specified selector.
+
+
+ Gets a collection of matching X.509 certificates based on the specified selector.
+
+ The matching certificates.
+ The match criteria.
+
+
+
+ X.509 certificate revocation list record fields.
+
+
+ The record fields are used when querying the
+ for certificate revocation lists.
+
+
+
+
+ The "id" field is typically just the ROWID in the database.
+
+
+
+
+ The "delta" field is a boolean value indicating whether the certificate
+ revocation list is a delta.
+
+
+
+
+ The "issuer name" field stores the issuer name of the certificate revocation list.
+
+
+
+
+ The "this update" field stores the date and time of the most recent update.
+
+
+
+
+ The "next update" field stores the date and time of the next scheduled update.
+
+
+
+
+ The "crl" field stores the raw binary data of the certificate revocation list.
+
+
+
+
+ An X.509 certificate revocation list (CRL) record.
+
+
+ Represents an X.509 certificate revocation list record loaded from a database.
+
+
+
+
+ Gets the identifier.
+
+
+ The id is typically the ROWID of the certificate revocation list in the
+ database and is not generally useful outside of the internals of the
+ database implementation.
+
+ The identifier.
+
+
+
+ Gets whether or not this certificate revocation list is a delta.
+
+
+ Indicates whether or not this certificate revocation list is a delta.
+
+ true if th crl is delta; otherwise, false.
+
+
+
+ Gets the issuer name of the certificate revocation list.
+
+
+ Gets the issuer name of the certificate revocation list.
+
+ The issuer's name.
+
+
+
+ Gets the date and time of the most recent update.
+
+
+ Gets the date and time of the most recent update.
+
+ The date and time.
+
+
+
+ Gets the end date and time where the certificate is valid.
+
+
+ Gets the end date and time where the certificate is valid.
+
+ The date and time.
+
+
+
+ Gets the certificate revocation list.
+
+
+ Gets the certificate revocation list.
+
+ The certificate revocation list.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new CRL record for storing in a .
+
+ The certificate revocation list.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is only meant to be used by implementors of
+ when loading records from the database.
+
+
+
+
+ X.509 key usage flags.
+
+
+ The X.509 Key Usage Flags can be used to determine what operations
+ a certificate can be used for.
+ A value of indicates that
+ there are no restrictions on the use of the
+ .
+
+
+
+
+ No limitations for the key usage are set.
+
+
+ The key may be used for anything.
+
+
+
+
+ The key may only be used for enciphering data during key agreement.
+
+
+ When both the bit and the
+ bit are both set, the key
+ may be used only for enciphering data while
+ performing key agreement.
+
+
+
+
+ The key may be used for verifying signatures on
+ certificate revocation lists (CRLs).
+
+
+
+
+ The key may be used for verifying signatures on certificates.
+
+
+
+
+ The key is meant to be used for key agreement.
+
+
+
+
+ The key may be used for data encipherment.
+
+
+
+
+ The key is meant to be used for key encipherment.
+
+
+
+
+ The key may be used to verify digital signatures used to
+ provide a non-repudiation service.
+
+
+
+
+ The key may be used for digitally signing data.
+
+
+
+
+ The key may only be used for deciphering data during key agreement.
+
+
+ When both the bit and the
+ bit are both set, the key
+ may be used only for deciphering data while
+ performing key agreement.
+
+
+
+
+ Incrementally decodes content encoded with the base64 encoding.
+
+
+ Base64 is an encoding often used in MIME to encode binary content such
+ as images and other types of multi-media to ensure that the data remains
+ intact when sent via 7bit transports such as SMTP.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new base64 decoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ Incrementally encodes content using the base64 encoding.
+
+
+ Base64 is an encoding often used in MIME to encode binary content such
+ as images and other types of multi-media to ensure that the data remains
+ intact when sent via 7bit transports such as SMTP.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new base64 encoder.
+
+ true if this encoder will be used to encode rfc2047 encoded-word payloads; false otherwise.
+ The maximum number of octets allowed per line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new base64 encoder.
+
+ The maximum number of octets allowed per line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ Incrementally decodes content encoded with a Uri hex encoding.
+
+
+ This is mostly meant for decoding parameter values encoded using
+ the rules specified by rfc2184 and rfc2231.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new hex decoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ Incrementally encodes content using a Uri hex encoding.
+
+
+ This is mostly meant for decoding parameter values encoded using
+ the rules specified by rfc2184 and rfc2231.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new hex encoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ An interface for incrementally decoding content.
+
+
+ An interface for incrementally decoding content.
+
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ An interface for incrementally encoding content.
+
+
+ An interface for incrementally encoding content.
+
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ A pass-through decoder implementing the interface.
+
+
+ Simply copies data as-is from the input buffer into the output buffer.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The encoding to return in the property.
+
+ Creates a new pass-through decoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Copies the input buffer into the output buffer, verbatim.
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Copies the input buffer into the output buffer, verbatim.
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ A pass-through encoder implementing the interface.
+
+
+ Simply copies data as-is from the input buffer into the output buffer.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The encoding to return in the property.
+
+ Creates a new pass-through encoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Copies the input buffer into the output buffer, verbatim.
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Copies the input buffer into the output buffer, verbatim.
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ Q-Encoding mode.
+
+
+ The encoding mode for the 'Q' encoding used in rfc2047.
+
+
+
+
+ A mode for encoding phrases, as defined by rfc822.
+
+
+
+
+ A mode for encoding text.
+
+
+
+
+ Incrementally encodes content using a variation of the quoted-printable encoding
+ that is specifically meant to be used for rfc2047 encoded-word tokens.
+
+
+ The Q-Encoding is an encoding often used in MIME to encode textual content outside
+ of the ASCII range within an rfc2047 encoded-word token in order to ensure that
+ the text remains intact when sent via 7bit transports such as SMTP.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new rfc2047 quoted-printable encoder.
+
+ The rfc2047 encoding mode.
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ Incrementally decodes content encoded with the quoted-printable encoding.
+
+
+ Quoted-Printable is an encoding often used in MIME to textual content outside
+ of the ASCII range in order to ensure that the text remains intact when sent
+ via 7bit transports such as SMTP.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new quoted-printable decoder.
+
+
+ true if this decoder will be used to decode rfc2047 encoded-word payloads; false otherwise.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new quoted-printable decoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ Incrementally encodes content using the quoted-printable encoding.
+
+
+ Quoted-Printable is an encoding often used in MIME to encode textual content
+ outside of the ASCII range in order to ensure that the text remains intact
+ when sent via 7bit transports such as SMTP.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new quoted-printable encoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ Incrementally decodes content encoded with the Unix-to-Unix encoding.
+
+
+ The UUEncoding is an encoding that predates MIME and was used to encode
+ binary content such as images and other types of multi-media to ensure
+ that the data remained intact when sent via 7bit transports such as SMTP.
+ These days, the UUEncoding has largely been deprecated in favour of
+ the base64 encoding, however, some older mail clients still use it.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new Unix-to-Unix decoder.
+
+
+ If true, decoding begins immediately rather than after finding a begin-line.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new Unix-to-Unix decoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ Incrementally encodes content using the Unix-to-Unix encoding.
+
+
+ The UUEncoding is an encoding that predates MIME and was used to encode
+ binary content such as images and other types of multi-media to ensure
+ that the data remained intact when sent via 7bit transports such as SMTP.
+ These days, the UUEncoding has largely been deprecated in favour of
+ the base64 encoding, however, some older mail clients still use it.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new Unix-to-Unix encoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ Incrementally decodes content encoded with the yEnc encoding.
+
+
+ The yEncoding is an encoding that is most commonly used with Usenet and
+ is a binary encoding that includes a 32-bit cyclic redundancy check.
+ For more information, see www.yenc.org.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new yEnc decoder.
+
+
+ If true, decoding begins immediately rather than after finding an =ybegin line.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new yEnc decoder.
+
+
+
+
+ Gets the checksum.
+
+
+ Gets the checksum.
+
+ The checksum.
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ Incrementally encodes content using the yEnc encoding.
+
+
+ The yEncoding is an encoding that is most commonly used with Usenet and
+ is a binary encoding that includes a 32-bit cyclic redundancy check.
+ For more information, see www.yenc.org.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new yEnc encoder.
+
+ The line length to use.
+
+
+
+ Gets the checksum.
+
+
+ Gets the checksum.
+
+ The checksum.
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ A bounded stream, confined to reading and writing data to a limited subset of the overall source stream.
+
+
+ Wraps an arbitrary stream, limiting I/O operations to a subset of the source stream.
+ If the is -1, then the end of the stream is unbound.
+ When a is set to parse a persistent stream, it will construct
+ s using bounded streams instead of loading the content into memory.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ If the is less than 0, then the end of the stream
+ is unbounded.
+
+ The underlying stream.
+ The offset in the base stream that will mark the start of this substream.
+ The offset in the base stream that will mark the end of this substream.
+ true to leave the baseStream open after the
+ is disposed; otherwise, false.
+
+ is null.
+
+
+ is less than zero.
+ -or-
+ is greater than or equal to zero
+ -and- is less than .
+
+
+
+
+ Gets the underlying stream.
+
+
+ All I/O is performed on the base stream.
+
+ The underlying stream.
+
+
+
+ Gets the start boundary offset of the underlying stream.
+
+
+ The start boundary is the byte offset into the
+ that marks the beginning of the substream.
+
+ The start boundary offset of the underlying stream.
+
+
+
+ Gets the end boundary offset of the underlying stream.
+
+
+ The end boundary is the byte offset into the
+ that marks the end of the substream. If the value is less than 0,
+ then the end of the stream is treated as unbound.
+
+ The end boundary offset of the underlying stream.
+
+
+
+ Checks whether or not the underlying stream will remain open after
+ the is disposed.
+
+
+ Checks whether or not the underlying stream will remain open after
+ the is disposed.
+
+ true if the underlying stream should remain open after the
+ is disposed; otherwise, false.
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ The will only support reading if the
+ supports it.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ The will only support writing if the
+ supports it.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ The will only support seeking if the
+ supports it.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not I/O operations can timeout.
+
+
+ The will only support timing out if the
+ supports it.
+
+ true if I/O operations can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ If the property is greater than or equal to 0,
+ then the length will be calculated by subtracting the
+ from the . If the end of the stream is unbound, then the
+ will be subtracted from the length of the
+ .
+
+ The length of the stream in bytes.
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ The is relative to the .
+
+ The position of the stream.
+
+ An I/O error occurred.
+
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets a value, in miliseconds, that determines how long the stream will attempt to read before timing out.
+
+
+ Gets or sets the 's read timeout.
+
+ A value, in miliseconds, that determines how long the stream will attempt to read before timing out.
+
+
+
+ Gets or sets a value, in miliseconds, that determines how long the stream will attempt to write before timing out.
+
+
+ Gets or sets the 's write timeout.
+
+ A value, in miliseconds, that determines how long the stream will attempt to write before timing out.
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reads data from the , not allowing it to
+ read beyond the .
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Writes data to the , not allowing it to
+ write beyond the .
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Seeks within the confines of the and the .
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ is not a valid .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support seeking.
+
+
+ An I/O error occurred.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Flushes the .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Updates the to be plus
+ the specified new length. If the needs to be grown
+ to allow this, then the length of the will also be
+ updated.
+
+ The desired length of the stream in bytes.
+
+ The stream has been disposed.
+
+
+ The stream does not support setting the length.
+
+
+ An I/O error occurred.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ If the property is false, then
+ the is also disposed.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ A chained stream.
+
+
+ Chains multiple streams together such that reading or writing beyond the end
+ of one stream spills over into the next stream in the chain. The idea is to
+ make it appear is if the chain of streams is all one continuous stream.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Add the specified stream to the chained stream.
+
+
+ Adds the stream to the end of the chain.
+
+ The stream.
+ true if the
+ should remain open after the is disposed;
+ otherwise, false.
+
+ is null.
+
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ The only supports reading if all of its
+ streams support it.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ The only supports writing if all of its
+ streams support it.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ The only supports seeking if all of its
+ streams support it.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not I/O operations can timeout.
+
+
+ The only supports timeouts if all of its
+ streams support them.
+
+ true if I/O operations can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ The length of a is the combined lenths of all
+ of its chained streams.
+
+ The length of the stream in bytes.
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ It is always possible to get the position of a ,
+ but setting the position is only possible if all of its streams are seekable.
+
+ The position of the stream.
+
+ An I/O error occurred.
+
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reads up to the requested number of bytes if reading is supported. If the
+ current child stream does not have enough remaining data to complete the
+ read, the read will progress into the next stream in the chain in order
+ to complete the read.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Writes the requested number of bytes if writing is supported. If the
+ current child stream does not have enough remaining space to fit the
+ complete buffer, the data will spill over into the next stream in the
+ chain in order to complete the write.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Seeks to the specified position within the stream if all child streams
+ support seeking.
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ is not a valid .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support seeking.
+
+
+ An I/O error occurred.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ If all of the child streams support writing, then the current child stream
+ will be flushed.
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Setting the length of a is not supported.
+
+ The desired length of the stream in bytes.
+
+ The stream has been disposed.
+
+
+ The stream does not support setting the length.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ A stream which filters data as it is read or written.
+
+
+ Passes data through each as the data is read or written.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a filtered stream using the specified source stream.
+
+ The underlying stream to filter.
+
+ is null.
+
+
+
+
+ Gets the underlying source stream.
+
+
+ In general, it is not a good idea to manipulate the underlying
+ source stream because most s store
+ important state about previous bytes read from or written to
+ the source stream.
+
+ The underlying source stream.
+
+
+
+ Adds the specified filter.
+
+
+ Adds the to the end of the list of filters
+ that data will pass through as data is read from or written to the
+ underlying source stream.
+
+ The filter.
+
+ is null.
+
+
+
+
+ Checks if the filtered stream contains the specified filter.
+
+
+ Determines whether or not the filtered stream contains the specified filter.
+
+ true if the specified filter exists;
+ otherwise false.
+ The filter.
+
+ is null.
+
+
+
+
+ Remove the specified filter.
+
+
+ Removes the specified filter from the list if it exists.
+
+ true if the filter was removed; otherwise false.
+ The filter.
+
+ is null.
+
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ The will only support reading if the
+ supports it.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ The will only support writing if the
+ supports it.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ Seeking is not supported by the .
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not I/O operations can timeout.
+
+
+ The will only support timing out if the
+ supports it.
+
+ true if I/O operations can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ Getting the length of a is not supported.
+
+ The length of the stream in bytes.
+
+ The stream does not support seeking.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ Getting and setting the position of a is not supported.
+
+ The position of the stream.
+
+ The stream does not support seeking.
+
+
+
+
+ Gets or sets a value, in miliseconds, that determines how long the stream will attempt to read before timing out.
+
+
+ Gets or sets the read timeout on the stream.
+
+ A value, in miliseconds, that determines how long the stream will attempt to read before timing out.
+
+
+
+ Gets or sets a value, in miliseconds, that determines how long the stream will attempt to write before timing out.
+
+
+ Gets or sets the write timeout on the stream.
+
+ A value, in miliseconds, that determines how long the stream will attempt to write before timing out.
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reads up to the requested number of bytes, passing the data read from the stream
+ through each of the filters before finally copying the result into the provided buffer.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+ The cancellation token.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reads up to the requested number of bytes, passing the data read from the stream
+ through each of the filters before finally copying the result into the provided buffer.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Filters the provided buffer through each of the filters before finally writing
+ the result to the underlying stream.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+ The cancellation token.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Filters the provided buffer through each of the filters before finally writing
+ the result to the underlying stream.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Seeking is not supported by the .
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ The stream does not support seeking.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Flushes the state of all filters, writing any output to the underlying
+ stream and then calling on the .
+
+ The cancellation token.
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Flushes the state of all filters, writing any output to the underlying
+ stream and then calling on the .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Setting the length of a is not supported.
+
+ The desired length of the stream in bytes.
+
+ The stream has been disposed.
+
+
+ The stream does not support setting the length.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ An interface allowing for a cancellable stream reading operation.
+
+
+ This interface is meant to extend the functionality of a ,
+ allowing the to have much finer-grained canellability.
+ When a custom stream implementation also implements this interface,
+ the will opt to use this interface
+ instead of the normal
+ API to read data from the stream.
+ This is really useful when parsing a message or other MIME entity
+ directly from a network-based stream.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ When a custom stream implementation also implements this interface,
+ the will opt to use this interface
+ instead of the normal
+ API to read data from the stream.
+ This is really useful when parsing a message or other MIME entity
+ directly from a network-based stream.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+ The cancellation token.
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ When a custom stream implementation also implements this interface,
+ writing a or
+ to the custom stream will opt to use this interface
+ instead of the normal
+ API to write data to the stream.
+ This is really useful when writing a message or other MIME entity
+ directly to a network-based stream.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+ The cancellation token
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+ The cancellation token.
+
+
+
+ A stream useful for measuring the amount of data written.
+
+
+ A keeps track of the number of bytes
+ that have been written to it. This is useful, for example, when you
+ need to know how large a is without
+ actually writing it to disk or into a memory buffer.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ A is not readable.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ A is always writable.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ A is always seekable.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not reading and writing to the stream can timeout.
+
+
+ Writing to a cannot timeout.
+
+ true if reading and writing to the stream can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ The length of a indicates the
+ number of bytes that have been written to it.
+
+ The length of the stream in bytes.
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ Since it is possible to seek within a ,
+ it is possible that the position will not always be identical to the
+ length of the stream, but typically it will be.
+
+ The position of the stream.
+
+ An I/O error occurred.
+
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reading from a is not supported.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Increments the property by the number of bytes written.
+ If the updated position is greater than the current length of the stream, then
+ the property will be updated to be identical to the
+ position.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Updates the within the stream.
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ is not a valid .
+
+
+ The stream has been disposed.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Since a does not actually do anything other than
+ count bytes, this method is a no-op.
+
+
+ The stream has been disposed.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Sets the to the specified value and updates
+ to the specified value if (and only if)
+ the current position is greater than the new length value.
+
+ The desired length of the stream in bytes.
+
+ is out of range.
+
+
+ The stream has been disposed.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ An efficient memory stream implementation that sacrifices the ability to
+ get access to the internal byte buffer in order to drastically improve
+ performance.
+
+
+ Instead of resizing an internal byte array, the
+ chains blocks of non-contiguous memory. This helps improve performance by avoiding
+ unneeded copying of data from the old array to the newly allocated array as well
+ as the zeroing of the newly allocated array.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with an initial memory block
+ of 2048 bytes.
+
+
+
+
+ Copies the memory stream into a byte array.
+
+
+ Copies all of the stream data into a newly allocated byte array.
+
+ The array.
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ The is always readable.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ The is always writable.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ The is always seekable.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not reading and writing to the stream can timeout.
+
+
+ The does not support timing out.
+
+ true if reading and writing to the stream can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ Gets the length of the stream, in bytes.
+
+ The length of the stream, in bytes.
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ Gets or sets the current position within the stream.
+
+ The position of the stream.
+
+ An I/O error occurred.
+
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Writes the entire buffer to the stream and advances the current position
+ within the stream by the number of bytes written, adding memory blocks as
+ needed in order to contain the newly written bytes.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Sets the position within the current stream.
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ is not a valid .
+
+
+ The stream has been disposed.
+
+
+ An I/O error occurred.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ This method does not do anything.
+
+
+ The stream has been disposed.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Sets the length of the stream.
+
+ The desired length of the stream in bytes.
+
+ is out of range.
+
+
+ The stream has been disposed.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ A filter that armors lines beginning with "From " by encoding the 'F' with the
+ Quoted-Printable encoding.
+
+
+ From-armoring is a workaround to prevent receiving clients (or servers)
+ that uses the mbox file format for local storage from munging the line
+ by prepending a ">", as is typical with the mbox format.
+ This armoring technique ensures that the receiving client will still
+ be able to verify S/MIME signatures.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A filter that can be used to determine the most efficient Content-Transfer-Encoding.
+
+
+ Keeps track of the content that gets passed through the filter in order to
+ determine the most efficient to use.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the best encoding given the specified constraints.
+
+
+ Gets the best encoding given the specified constraints.
+
+ The best encoding.
+ The encoding constraint.
+ The maximum allowable line length (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Filters the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Filters the specified input, flushing all internally buffered data to the output.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A charset filter for incrementally converting text streams from
+ one charset encoding to another.
+
+
+ Incrementally converts text from one charset encoding to another.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new to convert text from the specified
+ source encoding into the target charset encoding.
+
+ Source encoding name.
+ Target encoding name.
+
+ is null.
+ -or-
+ is null.
+
+
+ The is not supported by the system.
+ -or-
+ The is not supported by the system.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new to convert text from the specified
+ source encoding into the target charset encoding.
+
+ Source code page.
+ Target code page.
+
+ is less than zero or greater than 65535.
+ -or-
+ is less than zero or greater than 65535.
+
+
+ The is not supported by the system.
+ -or-
+ The is not supported by the system.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new to convert text from the specified
+ source encoding into the target charset encoding.
+
+ Source encoding.
+ Target encoding.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets the source encoding.
+
+
+ Gets the source encoding.
+
+ The source encoding.
+
+
+
+ Gets the target encoding.
+
+
+ Gets the target encoding.
+
+ The target encoding.
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A filter for decoding MIME content.
+
+
+ Uses a to incrementally decode data.
+
+
+
+
+ Gets the decoder used by this filter.
+
+
+ Gets the decoder used by this filter.
+
+ The decoder.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new using the specified decoder.
+
+ A specific decoder for the filter to use.
+
+ is null.
+
+
+
+
+ Create a filter that will decode the specified encoding.
+
+
+ Creates a new for the specified encoding.
+
+ A new decoder filter.
+ The encoding to create a filter for.
+
+
+
+ Create a filter that will decode the specified encoding.
+
+
+ Creates a new for the specified encoding.
+
+ A new decoder filter.
+ The name of the encoding to create a filter for.
+
+ is null.
+
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A filter that will convert from Windows/DOS line endings to Unix line endings.
+
+
+ Converts from Windows/DOS line endings to Unix line endings.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ Ensure that the stream ends with a new line.
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A filter for encoding MIME content.
+
+
+ Uses a to incrementally encode data.
+
+
+
+
+ Gets the encoder used by this filter.
+
+
+ Gets the encoder used by this filter.
+
+ The encoder.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new using the specified encoder.
+
+ A specific encoder for the filter to use.
+
+
+
+ Create a filter that will encode using specified encoding.
+
+
+ Creates a new for the specified encoding.
+
+ A new encoder filter.
+ The encoding to create a filter for.
+
+
+
+ Create a filter that will encode using specified encoding.
+
+
+ Creates a new for the specified encoding.
+
+ A new encoder filter.
+ The name of the encoding to create a filter for.
+
+ is null.
+
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ An interface for incrementally filtering data.
+
+
+ An interface for incrementally filtering data.
+
+
+
+
+ Filters the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+
+
+ Filters the specified input, flushing all internally buffered data to the output.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A base implementation for MIME filters.
+
+
+ A base implementation for MIME filters.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the output buffer.
+
+
+ Gets the output buffer.
+
+ The output buffer.
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Filters the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Filters the specified input, flushing all internally buffered data to the output.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ Saves the remaining input for the next round of processing.
+
+
+ Saves the remaining input for the next round of processing.
+
+ The input buffer.
+ The starting index of the buffer to save.
+ The length of the buffer to save, starting at .
+
+
+
+ Ensures that the output buffer is greater than or equal to the specified size.
+
+
+ Ensures that the output buffer is greater than or equal to the specified size.
+
+ The minimum size needed.
+ If set to true, the current output should be preserved.
+
+
+
+ A filter that simply passes data through without any processing.
+
+
+ Passes data through without any processing.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Filters the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+
+
+ Filters the specified input, flushing all internally buffered data to the output.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A filter for stripping trailing whitespace from lines in a textual stream.
+
+
+ Strips trailing whitespace from lines in a textual stream.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A filter that will convert from Unix line endings to Windows/DOS line endings.
+
+
+ Converts from Unix line endings to Windows/DOS line endings.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ Ensure that the stream ends with a new line.
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A flowed text to HTML converter.
+
+
+ Used to convert flowed text (as described in rfc3676) into HTML.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new flowed text to HTML converter.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set whether the trailing space on a wrapped line should be deleted.
+
+
+ Gets or sets whether the trailing space on a wrapped line should be deleted.
+ The flowed text format defines a Content-Type parameter called "delsp" which can
+ have a value of "yes" or "no". If the parameter exists and the value is "yes", then
+ should be set to true, otherwise
+ should be set to false.
+
+
+
+
+ true if the trailing space on a wrapped line should be deleted; otherwise, false.
+
+
+
+ Get or set the text that will be appended to the end of the output.
+
+
+ Gets or sets the text that will be appended to the end of the output.
+ The footer must be set before conversion begins.
+
+ The footer.
+
+
+
+ Get or set the footer format.
+
+
+ Gets or sets the footer format.
+
+ The footer format.
+
+
+
+ Get or set text that will be prepended to the beginning of the output.
+
+
+ Gets or sets the text that will be prepended to the beginning of the output.
+ The header must be set before conversion begins.
+
+ The header.
+
+
+
+ Get or set the header format.
+
+
+ Gets or sets the header format.
+
+ The header format.
+
+
+
+ Get or set the method to use for custom
+ filtering of HTML tags and content.
+
+
+ Get or set the method to use for custom
+ filtering of HTML tags and content.
+
+ The html tag callback.
+
+
+
+ Get or set whether or not the converter should only output an HTML fragment.
+
+
+ Gets or sets whether or not the converter should only output an HTML fragment.
+
+ true if the converter should only output an HTML fragment; otherwise, false.
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ A flowed text to text converter.
+
+
+ Unwraps the flowed text format described in rfc3676.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new flowed text to text converter.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set whether the trailing space on a wrapped line should be deleted.
+
+
+ Gets or sets whether the trailing space on a wrapped line should be deleted.
+ The flowed text format defines a Content-Type parameter called "delsp" which can
+ have a value of "yes" or "no". If the parameter exists and the value is "yes", then
+ should be set to true, otherwise
+ should be set to false.
+
+ true if the trailing space on a wrapped line should be deleted; otherwise, false.
+
+
+
+ Get or set the text that will be appended to the end of the output.
+
+
+ Gets or sets the text that will be appended to the end of the output.
+ The footer must be set before conversion begins.
+
+ The footer.
+
+
+
+ Get or set text that will be prepended to the beginning of the output.
+
+
+ Gets or sets the text that will be prepended to the beginning of the output.
+ The header must be set before conversion begins.
+
+ The header.
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ An enumeration of possible header and footer formats.
+
+
+ An enumeration of possible header and footer formats.
+
+
+
+
+ The header or footer contains plain text.
+
+
+
+
+ The header or footer contains properly formatted HTML.
+
+
+
+
+ An HTML attribute.
+
+
+ An HTML attribute.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new HTML attribute with the given id and value.
+
+ The attribute identifier.
+ The attribute value.
+
+ is not a valid value.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new HTML attribute with the given name and value.
+
+ The attribute name.
+ The attribute value.
+
+ is null.
+
+
+
+
+ Get the HTML attribute identifier.
+
+
+ Gets the HTML attribute identifier.
+
+
+
+
+ The attribute identifier.
+
+
+
+ Get the name of the attribute.
+
+
+ Gets the name of the attribute.
+
+
+
+
+ The name of the attribute.
+
+
+
+ Get the value of the attribute.
+
+
+ Gets the value of the attribute.
+
+
+
+
+ The value of the attribute.
+
+
+
+ A readonly collection of HTML attributes.
+
+
+ A readonly collection of HTML attributes.
+
+
+
+
+ An empty attribute collection.
+
+
+ An empty attribute collection.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ A collection of attributes.
+
+
+
+ Get the number of attributes in the collection.
+
+
+ Gets the number of attributes in the collection.
+
+ The number of attributes in the collection.
+
+
+
+ Get the at the specified index.
+
+
+ Gets the at the specified index.
+
+ The HTML attribute at the specified index.
+ The index.
+
+ is out of range.
+
+
+
+
+ Gets an enumerator for the attribute collection.
+
+
+ Gets an enumerator for the attribute collection.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the attribute collection.
+
+
+ Gets an enumerator for the attribute collection.
+
+ The enumerator.
+
+
+
+ HTML attribute identifiers.
+
+
+ HTML attribute identifiers.
+
+
+
+
+ An unknown HTML attribute identifier.
+
+
+
+
+ The "abbr" attribute.
+
+
+
+
+ The "accept" attribute.
+
+
+
+
+ The "accept-charset" attribute.
+
+
+
+
+ The "accesskey" attribute.
+
+
+
+
+ The "action" attribute.
+
+
+
+
+ The "align" attribute.
+
+
+
+
+ The "alink" attribute.
+
+
+
+
+ The "alt" attribute.
+
+
+
+
+ The "archive" attribute.
+
+
+
+
+ The "axis" attribute.
+
+
+
+
+ The "background" attribute.
+
+
+
+
+ The "bgcolor" attribute.
+
+
+
+
+ The "border" attribute.
+
+
+
+
+ The "cellpadding" attribute.
+
+
+
+
+ The "cellspacing" attribute.
+
+
+
+
+ The "char" attribute.
+
+
+
+
+ The "charoff" attribute.
+
+
+
+
+ The "charset" attribute.
+
+
+
+
+ The "checked" attribute.
+
+
+
+
+ The "cite" attribute.
+
+
+
+
+ The "class" attribute.
+
+
+
+
+ The "classid" attribute.
+
+
+
+
+ The "clear" attribute.
+
+
+
+
+ The "code" attribute.
+
+
+
+
+ The "codebase" attribute.
+
+
+
+
+ The "codetype" attribute.
+
+
+
+
+ The "color" attribute.
+
+
+
+
+ The "cols" attribute.
+
+
+
+
+ The "colspan" attribute.
+
+
+
+
+ The "compact" attribute.
+
+
+
+
+ The "content" attribute.
+
+
+
+
+ The "coords" attribute.
+
+
+
+
+ The "data" attribute.
+
+
+
+
+ The "datetime" attribute.
+
+
+
+
+ The "declare" attribute.
+
+
+
+
+ The "defer" attribute.
+
+
+
+
+ The "dir" attribute.
+
+
+
+
+ The "disabled" attribute.
+
+
+
+
+ The "dynsrc" attribute.
+
+
+
+
+ The "enctype" attribute.
+
+
+
+
+ The "face" attribute.
+
+
+
+
+ The "for" attribute.
+
+
+
+
+ The "frame" attribute.
+
+
+
+
+ The "frameborder" attribute.
+
+
+
+
+ The "headers" attribute.
+
+
+
+
+ The "height" attribute.
+
+
+
+
+ The "href" attribute.
+
+
+
+
+ The "hreflang" attribute.
+
+
+
+
+ The "hspace" attribute.
+
+
+
+
+ The "http-equiv" attribute.
+
+
+
+
+ The "id" attribute.
+
+
+
+
+ The "ismap" attribute.
+
+
+
+
+ The "label" attribute.
+
+
+
+
+ The "lang" attribute.
+
+
+
+
+ The "language" attribute.
+
+
+
+
+ The "leftmargin" attribute.
+
+
+
+
+ The "link" attribute.
+
+
+
+
+ The "longdesc" attribute.
+
+
+
+
+ The "lowsrc" attribute.
+
+
+
+
+ The "marginheight" attribute.
+
+
+
+
+ The "marginwidth" attribute.
+
+
+
+
+ The "maxlength" attribute.
+
+
+
+
+ The "media" attribute.
+
+
+
+
+ The "method" attribute.
+
+
+
+
+ The "multiple" attribute.
+
+
+
+
+ The "name" attribute.
+
+
+
+
+ The "nohref" attribute.
+
+
+
+
+ The "noresize" attribute.
+
+
+
+
+ The "noshade" attribute.
+
+
+
+
+ The "nowrap" attribute.
+
+
+
+
+ The "object" attribute.
+
+
+
+
+ The "profile" attribute.
+
+
+
+
+ The "prompt" attribute.
+
+
+
+
+ The "readonly" attribute.
+
+
+
+
+ The "rel" attribute.
+
+
+
+
+ The "rev" attribute.
+
+
+
+
+ The "rows" attribute.
+
+
+
+
+ The "rowspan" attribute.
+
+
+
+
+ The "rules" attribute.
+
+
+
+
+ The "scheme" attribute.
+
+
+
+
+ The "scope" attribute.
+
+
+
+
+ The "scrolling" attribute.
+
+
+
+
+ The "selected" attribute.
+
+
+
+
+ The "shape" attribute.
+
+
+
+
+ The "size" attribute.
+
+
+
+
+ The "span" attribute.
+
+
+
+
+ The "src" attribute.
+
+
+
+
+ The "standby" attribute.
+
+
+
+
+ The "start" attribute.
+
+
+
+
+ The "style" attribute.
+
+
+
+
+ The "summary" attribute.
+
+
+
+
+ The "tabindex" attribute.
+
+
+
+
+ The "target" attribute.
+
+
+
+
+ The "text" attribute.
+
+
+
+
+ The "title" attribute.
+
+
+
+
+ The "topmargin" attribute.
+
+
+
+
+ The "type" attribute.
+
+
+
+
+ The "usemap" attribute.
+
+
+
+
+ The "valign" attribute.
+
+
+
+
+ The "value" attribute.
+
+
+
+
+ The "valuetype" attribute.
+
+
+
+
+ The "version" attribute.
+
+
+
+
+ The "vlink" attribute.
+
+
+
+
+ The "vspace" attribute.
+
+
+
+
+ The "width" attribute.
+
+
+
+
+ The "xmlns" attribute.
+
+
+
+
+ extension methods.
+
+
+ extension methods.
+
+
+
+
+ Converts the enum value into the equivalent attribute name.
+
+
+ Converts the enum value into the equivalent attribute name.
+
+ The attribute name.
+ The enum value.
+
+
+
+ Converts the attribute name into the equivalent attribute id.
+
+
+ Converts the attribute name into the equivalent attribute id.
+
+ The attribute id.
+ The attribute name.
+
+
+
+ An HTML entity decoder.
+
+
+ An HTML entity decoder.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Push the specified character into the HTML entity decoder.
+
+
+ Pushes the specified character into the HTML entity decoder.
+ The first character pushed MUST be the '&' character.
+
+ true if the character was accepted; otherwise, false.
+ The character.
+
+ is the first character being pushed and was not the '&' character.
+
+
+
+
+ Get the decoded entity value.
+
+
+ Gets the decoded entity value.
+
+ The value.
+
+
+
+ Reset the entity decoder.
+
+
+ Resets the entity decoder.
+
+
+
+
+ An HTML namespace.
+
+
+ An HTML namespace.
+
+
+
+
+ The namespace is "http://www.w3.org/1999/xhtml".
+
+
+
+
+ The namespace is "http://www.w3.org/1998/Math/MathML".
+
+
+
+
+ The namespace is "http://www.w3.org/2000/svg".
+
+
+
+
+ The namespace is "http://www.w3.org/1999/xlink".
+
+
+
+
+ The namespace is "http://www.w3.org/XML/1998/namespace".
+
+
+
+
+ The namespace is "http://www.w3.org/2000/xmlns/".
+
+
+
+
+ extension methods.
+
+
+ extension methods.
+
+
+
+
+ Converts the enum value into the equivalent namespace url.
+
+
+ Converts the enum value into the equivalent namespace url.
+
+ The tag name.
+ The enum value.
+
+
+
+ Converts the tag name into the equivalent tag id.
+
+
+ Converts the tag name into the equivalent tag id.
+
+ The tag id.
+ The namespace.
+
+
+
+ An HTML tag callback delegate.
+
+
+ The delegate is called when a converter
+ is ready to write a new HTML tag, allowing developers to customize
+ whether the tag gets written at all, which attributes get written, etc.
+
+
+
+
+ The HTML tag context.
+ The HTML writer.
+
+
+
+ An HTML tag context.
+
+
+ An HTML tag context used with the delegate.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The HTML tag identifier.
+
+ is invalid.
+
+
+
+
+ Get the HTML tag attributes.
+
+
+ Gets the HTML tag attributes.
+
+
+
+
+ The attributes.
+
+
+
+ Get or set whether or not the end tag should be deleted.
+
+
+ Gets or sets whether or not the end tag should be deleted.
+
+ true if the end tag should be deleted; otherwise, false.
+
+
+
+ Get or set whether or not the tag should be deleted.
+
+
+ Gets or sets whether or not the tag should be deleted.
+
+ true if the tag should be deleted; otherwise, false.
+
+
+
+ Get or set whether or not the should be invoked for the end tag.
+
+
+ Gets or sets whether or not the should be invoked for the end tag.
+
+ true if the callback should be invoked for end tag; otherwise, false.
+
+
+
+ Get whether or not the tag is an empty element.
+
+
+ Gets whether or not the tag is an empty element.
+
+ true if the tag is an empty element; otherwise, false.
+
+
+
+ Get whether or not the tag is an end tag.
+
+
+ Gets whether or not the tag is an end tag.
+
+
+
+
+ true if the tag is an end tag; otherwise, false.
+
+
+
+ Get or set whether or not the inner content of the tag should be suppressed.
+
+
+ Gets or sets whether or not the inner content of the tag should be suppressed.
+
+ true if the inner content should be suppressed; otherwise, false.
+
+
+
+ Get the HTML tag identifier.
+
+
+ Gets the HTML tag identifier.
+
+
+
+
+ The HTML tag identifier.
+
+
+
+ Get the HTML tag name.
+
+
+ Gets the HTML tag name.
+
+
+
+
+ The HTML tag name.
+
+
+
+ Write the HTML tag.
+
+
+ Writes the HTML tag to the given .
+
+ The HTML writer.
+
+ is null.
+
+
+
+
+ Write the HTML tag.
+
+
+ Writes the HTML tag to the given .
+
+
+
+
+ The HTML writer.
+ true if the should also be written; otherwise, false.
+
+ is null.
+
+
+
+
+ HTML tag identifiers.
+
+
+ HTML tag identifiers.
+
+
+
+
+ An unknown HTML tag identifier.
+
+
+
+
+ The HTML <a> tag.
+
+
+
+
+ The HTML <abbr> tag.
+
+
+
+
+ The HTML <acronym> tag.
+
+
+
+
+ The HTML <address> tag.
+
+
+
+
+ The HTML <applet> tag.
+
+
+
+
+ The HTML <area> tag.
+
+
+
+
+ The HTML <article> tag.
+
+
+
+
+ The HTML <aside> tag.
+
+
+
+
+ The HTML <audio> tag.
+
+
+
+
+ The HTML <b> tag.
+
+
+
+
+ The HTML <base> tag.
+
+
+
+
+ The HTML <basefont> tag.
+
+
+
+
+ The HTML <bdi> tag.
+
+
+
+
+ The HTML <bdo> tag.
+
+
+
+
+ The HTML <bgsound> tag.
+
+
+
+
+ The HTML <big> tag.
+
+
+
+
+ The HTML <blink> tag.
+
+
+
+
+ The HTML <blockquote> tag.
+
+
+
+
+ The HTML <body> tag.
+
+
+
+
+ The HTML <br> tag.
+
+
+
+
+ The HTML <button> tag.
+
+
+
+
+ The HTML <canvas> tag.
+
+
+
+
+ The HTML <caption> tag.
+
+
+
+
+ The HTML <center> tag.
+
+
+
+
+ The HTML <cite> tag.
+
+
+
+
+ The HTML <code> tag.
+
+
+
+
+ The HTML <col> tag.
+
+
+
+
+ The HTML <colgroup> tag.
+
+
+
+
+ The HTML <command> tag.
+
+
+
+
+ The HTML comment tag.
+
+
+
+
+ The HTML <datalist> tag.
+
+
+
+
+ The HTML <dd> tag.
+
+
+
+
+ The HTML <del> tag.
+
+
+
+
+ The HTML <details> tag.
+
+
+
+
+ The HTML <dfn> tag.
+
+
+
+
+ The HTML <dialog> tag.
+
+
+
+
+ The HTML <dir> tag.
+
+
+
+
+ The HTML <div> tag.
+
+
+
+
+ The HTML <dl> tag.
+
+
+
+
+ The HTML <dt> tag.
+
+
+
+
+ The HTML <em> tag.
+
+
+
+
+ The HTML <embed> tag.
+
+
+
+
+ The HTML <fieldset> tag.
+
+
+
+
+ The HTML <figcaption> tag.
+
+
+
+
+ The HTML <figure> tag.
+
+
+
+
+ The HTML <font> tag.
+
+
+
+
+ The HTML <footer> tag.
+
+
+
+
+ The HTML <form> tag.
+
+
+
+
+ The HTML <frame> tag.
+
+
+
+
+ The HTML <frameset> tag.
+
+
+
+
+ The HTML <h1> tag.
+
+
+
+
+ The HTML <h2> tag.
+
+
+
+
+ The HTML <h3> tag.
+
+
+
+
+ The HTML <h4> tag.
+
+
+
+
+ The HTML <h5> tag.
+
+
+
+
+ The HTML <h6> tag.
+
+
+
+
+ The HTML <head> tag.
+
+
+
+
+ The HTML <header> tag.
+
+
+
+
+ The HTML <hr> tag.
+
+
+
+
+ The HTML <html> tag.
+
+
+
+
+ The HTML <i> tag.
+
+
+
+
+ The HTML <iframe> tag.
+
+
+
+
+ The HTML <image> tag.
+
+
+
+
+ The HTML <input> tag.
+
+
+
+
+ The HTML <ins> tag.
+
+
+
+
+ The HTML <isindex> tag.
+
+
+
+
+ The HTML <kbd> tag.
+
+
+
+
+ The HTML <keygen> tag.
+
+
+
+
+ The HTML <label> tag.
+
+
+
+
+ The HTML <legend> tag.
+
+
+
+
+ The HTML <li> tag.
+
+
+
+
+ The HTML <link> tag.
+
+
+
+
+ The HTML <listing> tag.
+
+
+
+
+ The HTML <main> tag.
+
+
+
+
+ The HTML <map> tag.
+
+
+
+
+ The HTML <mark> tag.
+
+
+
+
+ The HTML <marquee> tag.
+
+
+
+
+ The HTML <menu> tag.
+
+
+
+
+ The HTML <menuitem> tag.
+
+
+
+
+ The HTML <meta> tag.
+
+
+
+
+ The HTML <meter> tag.
+
+
+
+
+ The HTML <nav> tag.
+
+
+
+
+ The HTML <nextid> tag.
+
+
+
+
+ The HTML <nobr> tag.
+
+
+
+
+ The HTML <noembed> tag.
+
+
+
+
+ The HTML <noframes> tag.
+
+
+
+
+ The HTML <noscript> tag.
+
+
+
+
+ The HTML <object> tag.
+
+
+
+
+ The HTML <ol> tag.
+
+
+
+
+ The HTML <optgroup> tag.
+
+
+
+
+ The HTML <option> tag.
+
+
+
+
+ The HTML <output> tag.
+
+
+
+
+ The HTML <p> tag.
+
+
+
+
+ The HTML <param> tag.
+
+
+
+
+ The HTML <plaintext> tag.
+
+
+
+
+ The HTML <pre> tag.
+
+
+
+
+ The HTML <progress> tag.
+
+
+
+
+ The HTML <q> tag.
+
+
+
+
+ The HTML <rp> tag.
+
+
+
+
+ The HTML <rt> tag.
+
+
+
+
+ The HTML <ruby> tag.
+
+
+
+
+ The HTML <s> tag.
+
+
+
+
+ The HTML <samp> tag.
+
+
+
+
+ The HTML <script> tag.
+
+
+
+
+ The HTML <section> tag.
+
+
+
+
+ The HTML <select> tag.
+
+
+
+
+ The HTML <small> tag.
+
+
+
+
+ The HTML <source> tag.
+
+
+
+
+ The HTML <span> tag.
+
+
+
+
+ The HTML <strike> tag.
+
+
+
+
+ The HTML <strong> tag.
+
+
+
+
+ The HTML <style> tag.
+
+
+
+
+ The HTML <sub> tag.
+
+
+
+
+ The HTML <summary> tag.
+
+
+
+
+ The HTML <sup> tag.
+
+
+
+
+ The HTML <table> tag.
+
+
+
+
+ The HTML <tbody> tag.
+
+
+
+
+ The HTML <td> tag.
+
+
+
+
+ The HTML <textarea> tag.
+
+
+
+
+ The HTML <tfoot> tag.
+
+
+
+
+ The HTML <th> tag.
+
+
+
+
+ The HTML <thread> tag.
+
+
+
+
+ The HTML <time> tag.
+
+
+
+
+ The HTML <title> tag.
+
+
+
+
+ The HTML <tr> tag.
+
+
+
+
+ The HTML <track> tag.
+
+
+
+
+ The HTML <tt> tag.
+
+
+
+
+ The HTML <u> tag.
+
+
+
+
+ The HTML <ul> tag.
+
+
+
+
+ The HTML <var> tag.
+
+
+
+
+ The HTML <video> tag.
+
+
+
+
+ The HTML <wbr> tag.
+
+
+
+
+ The HTML <xml> tag.
+
+
+
+
+ The HTML <xmp> tag.
+
+
+
+
+ extension methods.
+
+
+ extension methods.
+
+
+
+
+ Converts the enum value into the equivalent tag name.
+
+
+ Converts the enum value into the equivalent tag name.
+
+ The tag name.
+ The enum value.
+
+
+
+ Converts the tag name into the equivalent tag id.
+
+
+ Converts the tag name into the equivalent tag id.
+
+ The tag id.
+ The tag name.
+
+
+
+ Determines whether or not the HTML tag is an empty element.
+
+
+ Determines whether or not the HTML tag is an empty element.
+
+ true if the tag is an empty element; otherwise, false.
+ Identifier.
+
+
+
+ Determines whether or not the HTML tag is a formatting element.
+
+
+ Determines whether or not the HTML tag is a formatting element.
+
+ true if the HTML tag is a formatting element; otherwise, false.
+ The HTML tag identifier.
+
+
+
+ An HTML to HTML converter.
+
+
+ Used to convert HTML into HTML.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new HTML to HTML converter.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set whether or not executable scripts should be stripped from the output.
+
+
+ Gets or sets whether or not executable scripts should be stripped from the output.
+
+ true if executable scripts should be filtered; otherwise, false.
+
+
+
+ Get or set the text that will be appended to the end of the output.
+
+
+ Gets or sets the text that will be appended to the end of the output.
+ The footer must be set before conversion begins.
+
+ The footer.
+
+
+
+ Get or set the footer format.
+
+
+ Gets or sets the footer format.
+
+ The footer format.
+
+
+
+ Get or set text that will be prepended to the beginning of the output.
+
+
+ Gets or sets the text that will be prepended to the beginning of the output.
+ The header must be set before conversion begins.
+
+ The header.
+
+
+
+ Get or set the header format.
+
+
+ Gets or sets the header format.
+
+ The header format.
+
+
+
+ Get or set the method to use for custom
+ filtering of HTML tags and content.
+
+
+ Get or set the method to use for custom
+ filtering of HTML tags and content.
+
+ The html tag callback.
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ An abstract HTML token class.
+
+
+ An abstract HTML token class.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The kind of token.
+
+
+
+ Get the kind of HTML token that this object represents.
+
+
+ Gets the kind of HTML token that this object represents.
+
+ The kind of token.
+
+
+
+ Write the HTML token to a .
+
+
+ Writes the HTML token to a .
+
+ The output.
+
+ is null.
+
+
+
+
+ Returns a that represents the current .
+
+
+ Returns a that represents the current .
+
+ A that represents the current .
+
+
+
+ An HTML comment token.
+
+
+ An HTML comment token.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The comment text.
+ true if the comment is bogus; otherwise, false.
+
+ is null.
+
+
+
+
+ Get the comment.
+
+
+ Gets the comment.
+
+ The comment.
+
+
+
+ Get whether or not the comment is a bogus comment.
+
+
+ Gets whether or not the comment is a bogus comment.
+
+ true if the comment is bogus; otherwise, false.
+
+
+
+ Write the HTML comment to a .
+
+
+ Writes the HTML comment to a .
+
+ The output.
+
+ is null.
+
+
+
+
+ An HTML token constisting of character data.
+
+
+ An HTML token consisting of character data.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The kind of character data.
+ The character data.
+
+ is not a valid .
+
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The character data.
+
+ is null.
+
+
+
+
+ Get the character data.
+
+
+ Gets the character data.
+
+ The character data.
+
+
+
+ Write the HTML character data to a .
+
+
+ Writes the HTML character data to a ,
+ encoding it if it isn't already encoded.
+
+ The output.
+
+ is null.
+
+
+
+
+ An HTML token constisting of [CDATA[.
+
+
+ An HTML token consisting of [CDATA[.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The character data.
+
+ is null.
+
+
+
+
+ Write the HTML character data to a .
+
+
+ Writes the HTML character data to a ,
+ encoding it if it isn't already encoded.
+
+ The output.
+
+ is null.
+
+
+
+
+ An HTML token constisting of script data.
+
+
+ An HTML token consisting of script data.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The script data.
+
+ is null.
+
+
+
+
+ Write the HTML script data to a .
+
+
+ Writes the HTML script data to a ,
+ encoding it if it isn't already encoded.
+
+ The output.
+
+ is null.
+
+
+
+
+ An HTML tag token.
+
+
+ An HTML tag token.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The name of the tag.
+ The attributes.
+ true if the tag is an empty element; otherwise, false.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The name of the tag.
+ true if the tag is an end tag; otherwise, false.
+
+ is null.
+
+
+
+
+ Get the attributes.
+
+
+ Gets the attributes.
+
+ The attributes.
+
+
+
+ Get the HTML tag identifier.
+
+
+ Gets the HTML tag identifier.
+
+ The HTML tag identifier.
+
+
+
+ Get whether or not the tag is an empty element.
+
+
+ Gets whether or not the tag is an empty element.
+
+ true if the tag is an empty element; otherwise, false.
+
+
+
+ Get whether or not the tag is an end tag.
+
+
+ Gets whether or not the tag is an end tag.
+
+ true if the tag is an end tag; otherwise, false.
+
+
+
+ Get the name of the tag.
+
+
+ Gets the name of the tag.
+
+ The name.
+
+
+
+ Write the HTML tag to a .
+
+
+ Writes the HTML tag to a .
+
+ The output.
+
+ is null.
+
+
+
+
+ An HTML DOCTYPE token.
+
+
+ An HTML DOCTYPE token.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Get whether or not quirks-mode should be forced.
+
+
+ Gets whether or not quirks-mode should be forced.
+
+ true if quirks-mode should be forced; otherwise, false.
+
+
+
+ Get or set the DOCTYPE name.
+
+
+ Gets or sets the DOCTYPE name.
+
+ The name.
+
+
+
+ Get or set the public identifier.
+
+
+ Gets or sets the public identifier.
+
+ The public identifier.
+
+
+
+ Get the public keyword that was used.
+
+
+ Gets the public keyword that was used.
+
+ The public keyword or null if it wasn't used.
+
+
+
+ Get or set the system identifier.
+
+
+ Gets or sets the system identifier.
+
+ The system identifier.
+
+
+
+ Get the system keyword that was used.
+
+
+ Gets the system keyword that was used.
+
+ The system keyword or null if it wasn't used.
+
+
+
+ Write the DOCTYPE tag to a .
+
+
+ Writes the DOCTYPE tag to a .
+
+ The output.
+
+ is null.
+
+
+
+
+ An HTML tokenizer.
+
+
+ Tokenizes HTML text, emitting an for each token it encounters.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The .
+
+
+
+ Get or set whether or not the tokenizer should decode character references.
+
+
+ Gets or sets whether or not the tokenizer should decode character references.
+ Character references in attribute values will still be decoded
+ even if this value is set to false.
+
+ true if character references should be decoded; otherwise, false.
+
+
+
+ Get the current HTML namespace detected by the tokenizer.
+
+
+ Gets the current HTML namespace detected by the tokenizer.
+
+ The html namespace.
+
+
+
+ Gets the current line number.
+
+
+ This property is most commonly used for error reporting, but can be called
+ at any time. The starting value for this property is 1.
+ Combined with , a value of 1,1 indicates
+ the start of the document.
+
+ The current line number.
+
+
+
+ Gets the current line position.
+
+
+ This property is most commonly used for error reporting, but can be called
+ at any time. The starting value for this property is 1.
+ Combined with , a value of 1,1 indicates
+ the start of the document.
+
+ The current line number.
+
+
+
+ Get the current state of the tokenizer.
+
+
+ Gets the current state of the tokenizer.
+
+ The current state of the tokenizer.
+
+
+
+ Create a DOCTYPE token.
+
+
+ Creates a DOCTYPE token.
+
+ The DOCTYPE token.
+
+
+
+ Create an HTML comment token.
+
+
+ Creates an HTML comment token.
+
+ The HTML comment token.
+ The comment.
+ true if the comment is bogus; otherwise, false.
+
+
+
+ Create an HTML character data token.
+
+
+ Creates an HTML character data token.
+
+ The HTML character data token.
+ The character data.
+
+
+
+ Create an HTML character data token.
+
+
+ Creates an HTML character data token.
+
+ The HTML character data token.
+ The character data.
+
+
+
+ Create an HTML script data token.
+
+
+ Creates an HTML script data token.
+
+ The HTML script data token.
+ The script data.
+
+
+
+ Create an HTML tag token.
+
+
+ Creates an HTML tag token.
+
+ The HTML tag token.
+ The tag name.
+ true if the tag is an end tag; otherwise, false.
+
+
+
+ Create an attribute.
+
+
+ Creates an attribute.
+
+ The attribute.
+ THe attribute name.
+
+
+
+ Reads the next token.
+
+
+ Reads the next token.
+
+ true if the next token was read; otherwise, false.
+ THe token that was read.
+
+
+
+ The HTML tokenizer state.
+
+
+ The HTML tokenizer state.
+
+
+
+
+ The data state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#data-state.
+
+
+
+
+ The character reference in data state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#character-reference-in-data-state.
+
+
+
+
+ The RCDATA state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rcdata-state.
+
+
+
+
+ The character reference in RCDATA state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#character-reference-in-rcdata-state.
+
+
+
+
+ The RAWTEXT state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rawtext-state.
+
+
+
+
+ The script data state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-state.
+
+
+
+
+ The PLAINTEXT state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#plaintext-state.
+
+
+
+
+ The tag open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#tag-open-state.
+
+
+
+
+ The end tag open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#end-tag-open-state.
+
+
+
+
+ The tag name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#tag-name-state.
+
+
+
+
+ The RCDATA less-than state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rcdata-less-than-sign-state.
+
+
+
+
+ The RCDATA end tag open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rcdata-end-tag-open-state.
+
+
+
+
+ The RCDATA end tag name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rcdata-end-tag-name-state.
+
+
+
+
+ The RAWTEXT less-than state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rawtext-less-than-sign-state.
+
+
+
+
+ The RAWTEXT end tag open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rawtext-end-tag-open-state.
+
+
+
+
+ The RAWTEXT end tag name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rawtext-end-tag-name-state.
+
+
+
+
+ The script data less-than state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-less-than-sign-state.
+
+
+
+
+ The script data end tag open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-end-tag-open-state.
+
+
+
+
+ The script data end tag name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-end-tag-name-state.
+
+
+
+
+ The script data escape start state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escape-start-state.
+
+
+
+
+ The script data escape start state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escape-start-dash-state.
+
+
+
+
+ The script data escaped state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escaped-state.
+
+
+
+
+ The script data escaped dash state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escaped-dash-state.
+
+
+
+
+ The script data escaped dash dash state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escaped-dash-dash-state.
+
+
+
+
+ The script data escaped less-than state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escaped-less-than-sign-state.
+
+
+
+
+ The script data escaped end tag open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escaped-end-tag-open-state.
+
+
+
+
+ The script data escaped end tag name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escaped-end-tag-name-state.
+
+
+
+
+ The script data double escape start state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-double-escape-start-state.
+
+
+
+
+ The script data double escaped state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-double-escaped-state.
+
+
+
+
+ The script data double escaped dash state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-double-escaped-dash-state.
+
+
+
+
+ The script data double escaped dash dash state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-double-escaped-dash-dash-state.
+
+
+
+
+ The script data double escaped less-than state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-double-escaped-less-than-sign-state.
+
+
+
+
+ The script data double escape end state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-double-escape-end-state.
+
+
+
+
+ The before attribute name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#before-attribute-name-state.
+
+
+
+
+ The attribute name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#attribute-name-state.
+
+
+
+
+ The after attribute name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-attribute-name-state.
+
+
+
+
+ The beforw attribute value state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#before-attribute-value-state.
+
+
+
+
+ The attribute value quoted state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#attribute-value-(double-quoted)-state.
+
+
+
+
+ The attribute value unquoted state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#attribute-value-(unquoted)-state.
+
+
+
+
+ The character reference in attribute value state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#character-reference-in-attribute-value-state.
+
+
+
+
+ The after attribute value quoted state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-attribute-value-(quoted)-state.
+
+
+
+
+ The self-closing start tag state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#self-closing-start-tag-state.
+
+
+
+
+ The bogus comment state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#bogus-comment-state.
+
+
+
+
+ The markup declaration open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#markup-declaration-open-state.
+
+
+
+
+ The comment start state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#comment-start-state.
+
+
+
+
+ The comment start dash state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#comment-start-dash-state.
+
+
+
+
+ The comment state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#comment-state.
+
+
+
+
+ The comment end dash state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#comment-end-dash-state.
+
+
+
+
+ The comment end state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#comment-end-state.
+
+
+
+
+ The comment end bang state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#comment-end-bang-state.
+
+
+
+
+ The DOCTYPE state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#doctype-state.
+
+
+
+
+ The before DOCTYPE name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#before-doctype-name-state.
+
+
+
+
+ The DOCTYPE name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#doctype-name-state.
+
+
+
+
+ The after DOCTYPE name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-doctype-name-state.
+
+
+
+
+ The after DOCTYPE public keyword state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-doctype-public-keyword-state.
+
+
+
+
+ The before DOCTYPE public identifier state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#before-doctype-public-identifier-state.
+
+
+
+
+ The DOCTYPE public identifier quoted state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#doctype-public-identifier-(double-quoted)-state.
+
+
+
+
+ The after DOCTYPE public identifier state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-doctype-public-identifier-state.
+
+
+
+
+ The between DOCTYPE public and system identifiers state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#between-doctype-public-and-system-identifiers-state.
+
+
+
+
+ The after DOCTYPE system keyword state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-doctype-system-keyword-state.
+
+
+
+
+ The before DOCTYPE system identifier state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#before-doctype-system-identifier-state.
+
+
+
+
+ The DOCTYPE system identifier quoted state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#doctype-system-identifier-(double-quoted)-state.
+
+
+
+
+ The after DOCTYPE system identifier state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-doctype-system-identifier-state.
+
+
+
+
+ The bogus DOCTYPE state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#bogus-doctype-state.
+
+
+
+
+ The CDATA section state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#cdata-section-state.
+
+
+
+
+ The end of file state.
+
+
+
+
+ The kinds of tokens that the can emit.
+
+
+ The kinds of tokens that the can emit.
+
+
+
+
+ A token consisting of [CDATA[.
+
+
+
+
+ An HTML comment token.
+
+
+
+
+ A token consisting of character data.
+
+
+
+
+ An HTML DOCTYPE token.
+
+
+
+
+ A token consisting of script data.
+
+
+
+
+ An HTML tag token.
+
+
+
+
+ A collection of HTML-related utility methods.
+
+
+ A collection of HTML-related utility methods.
+
+
+
+
+ Encode an HTML attribute value.
+
+
+ Encodes an HTML attribute value.
+
+ The to output the result.
+ The attribute value to encode.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+ The character to use for quoting the attribute value.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the value.
+
+
+ is not a valid quote character.
+
+
+
+
+ Encode an HTML attribute value.
+
+
+ Encodes an HTML attribute value.
+
+ The encoded attribute value.
+ The attribute value to encode.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+ The character to use for quoting the attribute value.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the value.
+
+
+ is not a valid quote character.
+
+
+
+
+ Encode an HTML attribute value.
+
+
+ Encodes an HTML attribute value.
+
+ The to output the result.
+ The attribute value to encode.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+ The character to use for quoting the attribute value.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the value.
+
+
+ is not a valid quote character.
+
+
+
+
+ Encode an HTML attribute value.
+
+
+ Encodes an HTML attribute value.
+
+ The to output the result.
+ The attribute value to encode.
+ The character to use for quoting the attribute value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a valid quote character.
+
+
+
+
+ Encode an HTML attribute value.
+
+
+ Encodes an HTML attribute value.
+
+ The encoded attribute value.
+ The attribute value to encode.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+ The character to use for quoting the attribute value.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the value.
+
+
+ is not a valid quote character.
+
+
+
+
+ Encode an HTML attribute value.
+
+
+ Encodes an HTML attribute value.
+
+ The encoded attribute value.
+ The attribute value to encode.
+ The character to use for quoting the attribute value.
+
+ is null.
+
+
+ is not a valid quote character.
+
+
+
+
+ Encode HTML character data.
+
+
+ Encodes HTML character data.
+
+ The to output the result.
+ The character data to encode.
+ The starting index of the character data.
+ The number of characters in the data.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the data.
+
+
+
+
+ Encode HTML character data.
+
+
+ Encodes HTML character data.
+
+ THe encoded character data.
+ The character data to encode.
+ The starting index of the character data.
+ The number of characters in the data.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the data.
+
+
+
+
+ Encode HTML character data.
+
+
+ Encodes HTML character data.
+
+ The to output the result.
+ The character data to encode.
+ The starting index of the character data.
+ The number of characters in the data.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the data.
+
+
+
+
+ Encode HTML character data.
+
+
+ Encodes HTML character data.
+
+ The to output the result.
+ The character data to encode.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Encode HTML character data.
+
+
+ Encodes HTML character data.
+
+ THe encoded character data.
+ The character data to encode.
+ The starting index of the character data.
+ The number of characters in the data.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the data.
+
+
+
+
+ Encode HTML character data.
+
+
+ Encodes HTML character data.
+
+ THe encoded character data.
+ The character data to encode.
+
+ is null.
+
+
+
+
+ Decode HTML character data.
+
+
+ Decodes HTML character data.
+
+ The to output the result.
+ The character data to decode.
+ The starting index of the character data.
+ The number of characters in the data.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the data.
+
+
+
+
+ Decode HTML character data.
+
+
+ Decodes HTML character data.
+
+ The to output the result.
+ The character data to decode.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Decode HTML character data.
+
+
+ Decodes HTML character data.
+
+ The decoded character data.
+ The character data to decode.
+ The starting index of the character data.
+ The number of characters in the data.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the data.
+
+
+
+
+ Decode HTML character data.
+
+
+ Decodes HTML character data.
+
+ The decoded character data.
+ The character data to decode.
+
+ is null.
+
+
+
+
+ An HTML writer.
+
+
+ An HTML writer.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The output stream.
+ The encoding to use for the output.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The output text writer.
+
+ is null.
+
+
+
+
+ Releas unmanaged resources and perform other cleanup operations before the
+ is reclaimed by garbage collection.
+
+
+ Releases unmanaged resources and performs other cleanup operations before the
+ is reclaimed by garbage collection.
+
+
+
+
+ Get the current state of the writer.
+
+
+ Gets the current state of the writer.
+
+ The state of the writer.
+
+
+
+ Write the attribute to the output stream.
+
+
+ Writes the attribute to the output stream.
+
+ The attribute identifier.
+ A buffer containing the attribute value.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+
+ is not a valid HTML attribute identifier.
+
+
+ is null.
+
+
+ is less than zero or greater than the length of
+ .
+ -or-
+ and do not specify
+ a valid range in the .
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute to the output stream.
+
+
+ Writes the attribute to the output stream.
+
+ The attribute name.
+ A buffer containing the attribute value.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is less than zero or greater than the length of
+ .
+ -or-
+ and do not specify
+ a valid range in the .
+
+
+ is an invalid attribute name.
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute to the output stream.
+
+
+ Writes the attribute to the output stream.
+
+ The attribute identifier.
+ The attribute value.
+
+ is not a valid HTML attribute identifier.
+
+
+ is null.
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute to the output stream.
+
+
+ Writes the attribute to the output stream.
+
+
+
+
+ The attribute name.
+ The attribute value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is an invalid attribute name.
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute to the output stream.
+
+
+ Writes the attribute to the output stream.
+
+
+
+
+ The attribute.
+
+ is null.
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute name to the output stream.
+
+
+ Writes the attribute name to the output stream.
+
+ The attribute identifier.
+
+ is not a valid HTML attribute identifier.
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute name to the output stream.
+
+
+ Writes the attribute name to the output stream.
+
+
+
+
+ The attribute name.
+
+ is null.
+
+
+ is an invalid attribute name.
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute value to the output stream.
+
+
+ Writes the attribute value to the output stream.
+
+ A buffer containing the attribute value.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+
+ is null.
+
+
+ is less than zero or greater than the length of
+ .
+ -or-
+ and do not specify
+ a valid range in the .
+
+
+ The is not in a state that allows writing attribute values.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute value to the output stream.
+
+
+ Writes the attribute value to the output stream.
+
+
+
+
+ The attribute value.
+
+ is null.
+
+
+ The is not in a state that allows writing attribute values.
+
+
+ The has been disposed.
+
+
+
+
+ Write an empty element tag.
+
+
+ Writes an empty element tag.
+
+ The HTML tag identifier.
+
+ is not a valid HTML tag identifier.
+
+
+ The has been disposed.
+
+
+
+
+ Write an empty element tag.
+
+
+ Writes an empty element tag.
+
+ The name of the HTML tag.
+
+ is null.
+
+
+ is not a valid HTML tag.
+
+
+ The has been disposed.
+
+
+
+
+ Write an end tag.
+
+
+ Writes an end tag.
+
+ The HTML tag identifier.
+
+ is not a valid HTML tag identifier.
+
+
+ The has been disposed.
+
+
+
+
+ Write an end tag.
+
+
+ Writes an end tag.
+
+ The name of the HTML tag.
+
+ is null.
+
+
+ is not a valid HTML tag.
+
+
+ The has been disposed.
+
+
+
+
+ Write a buffer containing HTML markup directly to the output, without escaping special characters.
+
+
+ Writes a buffer containing HTML markup directly to the output, without escaping special characters.
+
+ The buffer containing HTML markup.
+ The index of the first character to write.
+ The number of characters to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of
+ .
+ -or-
+ and do not specify
+ a valid range in the .
+
+
+ The has been disposed.
+
+
+
+
+ Write a string containing HTML markup directly to the output, without escaping special characters.
+
+
+ Writes a string containing HTML markup directly to the output, without escaping special characters.
+
+ The string containing HTML markup.
+
+ is null.
+
+
+ The has been disposed.
+
+
+
+
+ Write a start tag.
+
+
+ Writes a start tag.
+
+ The HTML tag identifier.
+
+ is not a valid HTML tag identifier.
+
+
+ The has been disposed.
+
+
+
+
+ Write a start tag.
+
+
+ Writes a start tag.
+
+ The name of the HTML tag.
+
+ is null.
+
+
+ is not a valid HTML tag.
+
+
+ The has been disposed.
+
+
+
+
+ Write text to the output stream, escaping special characters.
+
+
+ Writes text to the output stream, escaping special characters.
+
+ The text buffer.
+ The index of the first character to write.
+ The number of characters to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of
+ .
+ -or-
+ and do not specify
+ a valid range in the .
+
+
+ The has been disposed.
+
+
+
+
+ Write text to the output stream, escaping special characters.
+
+
+ Writes text to the output stream, escaping special characters.
+
+ The text.
+
+ is null.
+
+
+ The has been disposed.
+
+
+
+
+ Write a token to the output stream.
+
+
+ Writes a token that was emitted by the
+ to the output stream.
+
+ The HTML token.
+
+ is null.
+
+
+ The has been disposed.
+
+
+
+
+ Flush any remaining state to the output stream.
+
+
+ Flushes any remaining state to the output stream.
+
+
+ The has been disposed.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases any unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ Releases all resource used by the object.
+
+ Call when you are finished using the . The
+ method leaves the in an unusable state. After calling
+ , you must release all references to the so the garbage
+ collector can reclaim the memory that the was occupying.
+
+
+
+ An enumeration of possible states of a .
+
+
+ An enumeration of possible states of a .
+
+
+
+
+ The is not within a tag. In this state, the
+ can only write a tag or text.
+
+
+
+
+ The is inside a tag but has not started to write an attribute. In this
+ state, the can write an attribute, another tag, or text.
+
+
+
+
+ The is inside an attribute. In this state, the
+ can append a value to the current attribute, start the next attribute, or write another tag or text.
+
+
+
+
+ An abstract class for converting text from one format to another.
+
+
+ An abstract class for converting text from one format to another.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Get or set whether the encoding of the input is detected from the byte order mark or
+ determined by the property.
+
+
+ Gets or sets whether the encoding of the input is detected from the byte order mark or
+ determined by the property.
+
+ true if detect encoding from byte order mark; otherwise, false.
+
+
+
+ Get or set the input encoding.
+
+
+ Gets or sets the input encoding.
+
+ The input encoding.
+
+ is null.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get or set the output encoding.
+
+
+ Gets or sets the output encoding.
+
+ The output encoding.
+
+ is null.
+
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set the size of the input stream buffer.
+
+
+ Gets or sets the size of the input stream buffer.
+
+ The size of the input stream buffer.
+
+ is less than or equal to 0.
+
+
+
+
+ Get or set the size of the output stream buffer.
+
+
+ Gets or sets the size of the output stream buffer.
+
+ The size of the output stream buffer.
+
+ is less than or equal to 0.
+
+
+
+
+ Convert the contents of from the to the
+ and writes the resulting text to .
+
+
+ Converts the contents of from the to the
+ and writes the resulting text to .
+
+ The source stream.
+ The destination stream.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The source stream.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Convert the contents of from the to the
+ and writes the resulting text to .
+
+
+ Converts the contents of from the to the
+ and writes the resulting text to .
+
+ The text reader.
+ The destination stream.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Convert text from the to the .
+
+
+ Converts text from the to the .
+
+
+
+
+ The converted text.
+ The text to convert.
+
+ is null.
+
+
+
+
+ An enumeration of text formats.
+
+
+ An enumeration of text formats.
+
+
+
+
+ The plain text format.
+
+
+
+
+ The flowed text format (as described in rfc3676).
+
+
+
+
+ The HTML text format.
+
+
+
+
+ The enriched text format.
+
+
+
+
+ The compressed rich text format.
+
+
+
+
+ The rich text format.
+
+
+
+
+ A text to flowed text converter.
+
+
+ Wraps text to conform with the flowed text format described in rfc3676.
+ The Content-Type header for the wrapped output text should be set to
+ text/plain; format=flowed; delsp=yes.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new text to flowed text converter.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set the text that will be appended to the end of the output.
+
+
+ Gets or sets the text that will be appended to the end of the output.
+ The footer must be set before conversion begins.
+
+ The footer.
+
+
+
+ Get or set text that will be prepended to the beginning of the output.
+
+
+ Gets or sets the text that will be prepended to the beginning of the output.
+ The header must be set before conversion begins.
+
+ The header.
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ A text to HTML converter.
+
+
+ Used to convert plain text into HTML.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new text to HTML converter.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set the text that will be appended to the end of the output.
+
+
+ Gets or sets the text that will be appended to the end of the output.
+ The footer must be set before conversion begins.
+
+ The footer.
+
+
+
+ Get or set the footer format.
+
+
+ Gets or sets the footer format.
+
+ The footer format.
+
+
+
+ Get or set text that will be prepended to the beginning of the output.
+
+
+ Gets or sets the text that will be prepended to the beginning of the output.
+ The header must be set before conversion begins.
+
+ The header.
+
+
+
+ Get or set the header format.
+
+
+ Gets or sets the header format.
+
+ The header format.
+
+
+
+ Get or set the method to use for custom
+ filtering of HTML tags and content.
+
+
+ Get or set the method to use for custom
+ filtering of HTML tags and content.
+
+ The html tag callback.
+
+
+
+ Get or set whether or not the converter should only output an HTML fragment.
+
+
+ Gets or sets whether or not the converter should only output an HTML fragment.
+
+ true if the converter should only output an HTML fragment; otherwise, false.
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ A text to text converter.
+
+
+ A text to text converter.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new text to text converter.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set the text that will be appended to the end of the output.
+
+
+ Gets or sets the text that will be appended to the end of the output.
+ The footer must be set before conversion begins.
+
+ The footer.
+
+
+
+ Get or set the footer format.
+
+
+ Gets or sets the footer format.
+
+ The footer format.
+
+
+
+ Get or set text that will be prepended to the beginning of the output.
+
+
+ Gets or sets the text that will be prepended to the beginning of the output.
+ The header must be set before conversion begins.
+
+ The header.
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ An Aho-Corasick Trie graph.
+
+
+ An Aho-Corasick Trie graph.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ true if searching should ignore case; otherwise, false.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Add the specified search pattern.
+
+
+ Adds the specified search pattern.
+
+ The search pattern.
+
+ is null.
+
+
+ cannot be an empty string.
+
+
+
+
+ Search the text for any of the patterns added to the trie.
+
+
+ Searches the text for any of the patterns added to the trie.
+
+ The first index of a matched pattern if successful; otherwise, -1.
+ The text to search.
+ The starting index of the text.
+ The number of characters to search, starting at .
+ The pattern that was matched.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the string.
+
+
+
+
+ Search the text for any of the patterns added to the trie.
+
+
+ Searches the text for any of the patterns added to the trie.
+
+ The first index of a matched pattern if successful; otherwise, -1.
+ The text to search.
+ The starting index of the text.
+ The pattern that was matched.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Search the text for any of the patterns added to the trie.
+
+
+ Searches the text for any of the patterns added to the trie.
+
+ The first index of a matched pattern if successful; otherwise, -1.
+ The text to search.
+ The pattern that was matched.
+
+ is null.
+
+
+
+
+ A filter to decompress a compressed RTF stream.
+
+
+ Used to decompress a compressed RTF stream.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new converter filter.
+
+
+
+
+ Gets the compression mode.
+
+
+ At least 12 bytes from the stream must be processed before this property value will
+ be accurate.
+
+ The compression mode.
+
+
+
+ Gets a value indicating whether the crc32 is valid.
+
+
+ Until all data has been processed, this property will always return false.
+
+ true if the crc32 is valid; otherwise, false.
+
+
+
+ Filter the specified input.
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ Length.
+ Output index.
+ Output length.
+ If set to true flush.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A RTF compression mode.
+
+
+ A RTF compression mode.
+
+
+
+
+ The compression mode is not known.
+
+
+
+
+ The RTF stream is not compressed.
+
+
+
+
+ The RTF stream is compressed.
+
+
+
+
+ The TNEF attach flags.
+
+
+ The enum contains a list of possible values for
+ the property.
+
+
+
+
+ No AttachFlags set.
+
+
+
+
+ The attachment is invisible in HTML bodies.
+
+
+
+
+ The attachment is invisible in RTF bodies.
+
+
+
+
+ The attachment is referenced (and rendered) by the HTML body.
+
+
+
+
+ The TNEF attach method.
+
+
+ The enum contains a list of possible values for
+ the property.
+
+
+
+
+ No AttachMethod specified.
+
+
+
+
+ The attachment is a binary blob and SHOULD appear in the
+ attribute.
+
+
+
+
+ The attachment is an embedded TNEF message stream and MUST appear
+ in the property of the
+ attribute.
+
+
+
+
+ The attachment is an OLE stream and MUST appear
+ in the property of the
+ attribute.
+
+
+
+
+ A TNEF attribute level.
+
+
+ A TNEF attribute level.
+
+
+
+
+ The attribute is a message-level attribute.
+
+
+
+
+ The attribute is an attachment-level attribute.
+
+
+
+
+ A TNEF attribute tag.
+
+
+ A TNEF attribute tag.
+
+
+
+
+ A Null TNEF attribute.
+
+
+
+
+ The Owner TNEF attribute.
+
+
+
+
+ The SentFor TNEF attribute.
+
+
+
+
+ The Delegate TNEF attribute.
+
+
+
+
+ The OriginalMessageClass TNEF attribute.
+
+
+
+
+ The DateStart TNEF attribute.
+
+
+
+
+ The DateEnd TNEF attribute.
+
+
+
+
+ The AidOwner TNEF attribute.
+
+
+
+
+ The RequestResponse TNEF attribute.
+
+
+
+
+ The From TNEF attribute.
+
+
+
+
+ The Subject TNEF attribute.
+
+
+
+
+ The DateSent TNEF attribute.
+
+
+
+
+ The DateReceived TNEF attribute.
+
+
+
+
+ The MessageStatus TNEF attribute.
+
+
+
+
+ The MessageClass TNEF attribute.
+
+
+
+
+ The MessageId TNEF attribute.
+
+
+
+
+ The ParentId TNEF attribute.
+
+
+
+
+ The ConversationId TNEF attribute.
+
+
+
+
+ The Body TNEF attribute.
+
+
+
+
+ The Priority TNEF attribute.
+
+
+
+
+ The AttachData TNEF attribute.
+
+
+
+
+ The AttachTitle TNEF attribute.
+
+
+
+
+ The AttachMetaFile TNEF attribute.
+
+
+
+
+ The AttachCreateDate TNEF attribute.
+
+
+
+
+ The AttachModifyDate TNEF attribute.
+
+
+
+
+ The DateModified TNEF attribute.
+
+
+
+
+ The AttachTransportFilename TNEF attribute.
+
+
+
+
+ The AttachRenderData TNEF attribute.
+
+
+
+
+ The MapiProperties TNEF attribute.
+
+
+
+
+ The RecipientTable TNEF attribute.
+
+
+
+
+ The Attachment TNEF attribute.
+
+
+
+
+ The TnefVersion TNEF attribute.
+
+
+
+
+ The OemCodepage TNEF attribute.
+
+
+
+
+ A TNEF compliance mode.
+
+
+ A TNEF compliance mode.
+
+
+
+
+ Use a loose compliance mode, attempting to ignore invalid or corrupt data.
+
+
+
+
+ Use a very strict compliance mode, aborting the parser at the first sign of
+ invalid or corrupted data.
+
+
+
+
+ A bitfield of potential TNEF compliance issues.
+
+
+ A bitfield of potential TNEF compliance issues.
+
+
+
+
+ The TNEF stream has no errors.
+
+
+
+
+ The TNEF stream has too many attributes.
+
+
+
+
+ The TNEF stream has one or more invalid attributes.
+
+
+
+
+ The TNEF stream has one or more attributes with invalid checksums.
+
+
+
+
+ The TNEF stream has one more more attributes with an invalid length.
+
+
+
+
+ The TNEF stream has one or more attributes with an invalid level.
+
+
+
+
+ The TNEF stream has one or more attributes with an invalid value.
+
+
+
+
+ The TNEF stream has one or more attributes with an invalid date value.
+
+
+
+
+ The TNEF stream has one or more invalid MessageClass attributes.
+
+
+
+
+ The TNEF stream has one or more invalid MessageCodepage attributes.
+
+
+
+
+ The TNEF stream has one or more invalid property lengths.
+
+
+
+
+ The TNEF stream has one or more invalid row counts.
+
+
+
+
+ The TNEF stream has an invalid signature value.
+
+
+
+
+ The TNEF stream has an invalid version value.
+
+
+
+
+ The TNEF stream is nested too deeply.
+
+
+
+
+ The TNEF stream is truncated.
+
+
+
+
+ The TNEF stream has one or more unsupported property types.
+
+
+
+
+ A TNEF exception.
+
+
+ A occurs when when a TNEF stream is found to be
+ corrupted and cannot be read any futher.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The serialization info.
+ The stream context.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The error message.
+ The inner exception.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The error message.
+
+
+
+ A TNEF name identifier.
+
+
+ A TNEF name identifier.
+
+
+
+
+ Gets the property set GUID.
+
+
+ Gets the property set GUID.
+
+ The property set GUID.
+
+
+
+ Gets the kind of TNEF name identifier.
+
+
+ Gets the kind of TNEF name identifier.
+
+ The kind of identifier.
+
+
+
+ Gets the name, if available.
+
+
+ If the is , then this property will be available.
+
+ The name.
+
+
+
+ Gets the identifier, if available.
+
+
+ If the is , then this property will be available.
+
+ The identifier.
+
+
+
+ Initializes a new instance of the struct.
+
+
+ Creates a new with the specified integer identifier.
+
+ The property set GUID.
+ The identifier.
+
+
+
+ Initializes a new instance of the struct.
+
+
+ Creates a new with the specified string identifier.
+
+ The property set GUID.
+ The name.
+
+
+
+ Serves as a hash function for a object.
+
+
+ Serves as a hash function for a object.
+
+ A hash code for this instance that is suitable for use in hashing algorithms
+ and data structures such as a hash table.
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Determines whether the specified is equal to the current .
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ The kind of TNEF name identifier.
+
+
+ The kind of TNEF name identifier.
+
+
+
+
+ The property name is an integer.
+
+
+
+
+ The property name is a string.
+
+
+
+
+ A MIME part containing Microsoft TNEF data.
+
+
+ Represents an application/ms-tnef or application/vnd.ms-tnef part.
+ TNEF (Transport Neutral Encapsulation Format) attachments are most often
+ sent by Microsoft Outlook clients.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with a Content-Type of application/vnd.ms-tnef
+ and a Content-Disposition value of "attachment" and a filename paremeter with a
+ value of "winmail.dat".
+
+
+
+
+ Converts the TNEF content into a .
+
+
+ TNEF data often contains properties that map to
+ headers. TNEF data also often contains file attachments which will be
+ mapped to MIME parts.
+
+ A message representing the TNEF data in MIME format.
+
+ The property is null.
+
+
+
+
+ Extracts the embedded attachments from the TNEF data.
+
+
+ Parses the TNEF data and extracts all of the embedded file attachments.
+
+ The attachments.
+
+ The property is null.
+
+
+
+
+ A TNEF property identifier.
+
+
+ A TNEF property identifier.
+
+
+
+
+ The MAPI property PR_AB_DEFAULT_DIR.
+
+
+
+
+ The MAPI property PR_AB_DEFAULT_PAB.
+
+
+
+
+ The MAPI property PR_AB_PROVIDER_ID.
+
+
+
+
+ The MAPI property PR_AB_PROVIDERS.
+
+
+
+
+ The MAPI property PR_AB_SEARCH_PATH.
+
+
+
+
+ The MAPI property PR_AB_SEARCH_PATH_UPDATE.
+
+
+
+
+ The MAPI property PR_ACCESS.
+
+
+
+
+ The MAPI property PR_ACCESS_LEVEL.
+
+
+
+
+ The MAPI property PR_ACCOUNT.
+
+
+
+
+ The MAPI property PR_ACKNOWLEDGEMENT_MODE.
+
+
+
+
+ The MAPI property PR_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ALTERNATE_RECIPIENT.
+
+
+
+
+ The MAPI property PR_ALTERNATE_RECIPIENT_ALLOWED.
+
+
+
+
+ The MAPI property PR_ANR.
+
+
+
+
+ The MAPI property PR_ASSISTANT.
+
+
+
+
+ The MAPI property PR_ASSISTANT_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_ASSOC_CONTENT_COUNT.
+
+
+
+
+ The MAPI property PR_ATTACH_ADDITIONAL_INFO.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_BASE.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_ID.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_LOCATION.
+
+
+
+
+ The MAPI property PR_ATTACH_DATA_BIN or PR_ATTACH_DATA_OBJ.
+
+
+
+
+ The MAPI property PR_ATTACH_DISPOSITION.
+
+
+
+
+ The MAPI property PR_ATTACH_ENCODING.
+
+
+
+
+ The MAPI property PR_ATTACH_EXTENSION.
+
+
+
+
+ The MAPI property PR_ATTACH_FILENAME.
+
+
+
+
+ The MAPI property PR_ATTACH_FLAGS.
+
+
+
+
+ The MAPI property PR_ATTACH_LONG_FILENAME.
+
+
+
+
+ The MAPI property PR_ATTACH_LONG_PATHNAME.
+
+
+
+
+ The MAPI property PR_ATTACHMENT_X400_PARAMETERS.
+
+
+
+
+ The MAPI property PR_ATTACH_METHOD.
+
+
+
+
+ The MAPI property PR_ATTACH_MIME_SEQUENCE.
+
+
+
+
+ The MAPI property PR_ATTACH_MIME_TAG.
+
+
+
+
+ The MAPI property PR_ATTACH_NETSCAPE_MAC_INFO.
+
+
+
+
+ The MAPI property PR_ATTACH_NUM.
+
+
+
+
+ The MAPI property PR_ATTACH_PATHNAME.
+
+
+
+
+ The MAPI property PR_ATTACH_RENDERING.
+
+
+
+
+ The MAPI property PR_ATTACH_SIZE.
+
+
+
+
+ The MAPI property PR_ATTACH_TAG.
+
+
+
+
+ The MAPI property PR_ATTACH_TRANSPORT_NAME.
+
+
+
+
+ The MAPI property PR_AUTHORIZING_USERS.
+
+
+
+
+ The MAPI property PR_AUTO_FORWARDED.
+
+
+
+
+ The MAPI property PR_AUTO_FORWARDING_COMMENT.
+
+
+
+
+ The MAPI property PR_AUTO_RESPONSE_SUPPRESS.
+
+
+
+
+ The MAPI property PR_BEEPER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BIRTHDAY.
+
+
+
+
+ The MAPI property PR_BODY.
+
+
+
+
+ The MAPI property PR_BODY_CONTENT_ID.
+
+
+
+
+ The MAPI property PR_BODY_CONTENT_LOCATION.
+
+
+
+
+ The MAPI property PR_BODY_CRC.
+
+
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_BUSINESS_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS_HOME_PAGE.
+
+
+
+
+ The MAPI property PR_CALLBACK_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CAR_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CELLULAR_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CHILDRENS_NAMES.
+
+
+
+
+ The MAPI property PR_CLIENT_SUBMIT_TIME.
+
+
+
+
+ The MAPI property PR_COMMENT.
+
+
+
+
+ The MAPI property PR_COMMON_VIEWS_ENTRYID.
+
+
+
+
+ The MAPI property PR_COMPANY_MAIN_PHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_COMPANY_NAME.
+
+
+
+
+ The MAPI property PR_COMPUTER_NETWORK_NAME.
+
+
+
+
+ The MAPI property PR_CONTACT_ADDRTYPES.
+
+
+
+
+ The MAPI property PR_CONTACT_DEFAULT_ADDRESS_INDEX.
+
+
+
+
+ The MAPI property PR_CONTACT_EMAIL_ADDRESSES.
+
+
+
+
+ The MAPI property PR_CONTACT_ENTRYIDS.
+
+
+
+
+ The MAPI property PR_CONTACT_VERSION.
+
+
+
+
+ The MAPI property PR_CONTAINER_CLASS.
+
+
+
+
+ The MAPI property PR_CONTAINER_CONTENTS.
+
+
+
+
+ The MAPI property PR_CONTAINER_FLAGS.
+
+
+
+
+ The MAPI property PR_CONTAINER_HIERARCHY.
+
+
+
+
+ The MAPI property PR_CONTAINER_MODIFY_VERSION.
+
+
+
+
+ The MAPI property PR_CONTENT_CONFIDENTIALITY_ALGORITHM_ID.
+
+
+
+
+ The MAPI property PR_CONTENT_CORRELATOR.
+
+
+
+
+ The MAPI property PR_CONTENT_COUNT.
+
+
+
+
+ The MAPI property PR_CONTENT_IDENTIFIER.
+
+
+
+
+ The MAPI property PR_CONTENT_INTEGRITY_CHECK.
+
+
+
+
+ The MAPI property PR_CONTENT_LENGTH.
+
+
+
+
+ The MAPI property PR_CONTENT_RETURN_REQUESTED.
+
+
+
+
+ The MAPI property PR_CONTENTS_SORT_ORDER.
+
+
+
+
+ The MAPI property PR_CONTENT_UNREAD.
+
+
+
+
+ The MAPI property PR_CONTROL_FLAGS.
+
+
+
+
+ The MAPI property PR_CONTROL_ID.
+
+
+
+
+ The MAPI property PR_CONTROL_STRUCTURE.
+
+
+
+
+ The MAPI property PR_CONTROL_TYPE.
+
+
+
+
+ The MAPI property PR_CONVERSATION_INDEX.
+
+
+
+
+ The MAPI property PR_CONVERSATION_KEY.
+
+
+
+
+ The MAPI property PR_CONVERSATION_TOPIC.
+
+
+
+
+ The MAPI property PR_CONVERSATION_EITS.
+
+
+
+
+ The MAPI property PR_CONVERSION_PROHIBITED.
+
+
+
+
+ The MAPI property PR_CONVERSION_WITH_LOSS_PROHIBITED.
+
+
+
+
+ The MAPI property PR_CONVERTED_EITS.
+
+
+
+
+ The MAPI property PR_CORRELATE.
+
+
+
+
+ The MAPI property PR_CORRELATE_MTSID.
+
+
+
+
+ The MAPI property PR_COUNTRY.
+
+
+
+
+ The MAPI property PR_CREATE_TEMPLATES.
+
+
+
+
+ The MAPI property PR_CREATION_TIME.
+
+
+
+
+ The MAPI property PR_CREATION_VERSION.
+
+
+
+
+ The MAPI property PR_CURRENT_VERSION.
+
+
+
+
+ The MAPI property PR_CUSTOMER_ID.
+
+
+
+
+ The MAPI property PR_DEFAULT_PROFILE.
+
+
+
+
+ The MAPI property PR_DEFAULT_STORE.
+
+
+
+
+ The MAPI property PR_DEFAULT_VIEW_ENTRYID.
+
+
+
+
+ The MAPI property PR_DEF_CREATE_DL.
+
+
+
+
+ The MAPI property PR_DEF_CREATE_MAILUSER.
+
+
+
+
+ The MAPI property PR_DEFERRED_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_DELEGATION.
+
+
+
+
+ The MAPI property PR_DELETE_AFTER_SUBMIT.
+
+
+
+
+ The MAPI property PR_DELIVER_TIME.
+
+
+
+
+ The MAPI property PR_DELIVERY_POINT.
+
+
+
+
+ The MAPI property PR_DELTAX.
+
+
+
+
+ The MAPI property PR_DELTAY.
+
+
+
+
+ The MAPI property PR_DEPARTMENT_NAME.
+
+
+
+
+ The MAPI property PR_DEPTH.
+
+
+
+
+ The MAPI property PR_DETAILS_TABLE.
+
+
+
+
+ The MAPI property PR_DISCARD_REASON.
+
+
+
+
+ The MAPI property PR_DISCLOSE_RECIPIENTS.
+
+
+
+
+ The MAPI property PR_DISCLOSURE_OF_RECIPIENTS.
+
+
+
+
+ The MAPI property PR_DISCRETE_VALUES.
+
+
+
+
+ The MAPI property PR_DISC_VAL.
+
+
+
+
+ The MAPI property PR_DISPLAY_BCC.
+
+
+
+
+ The MAPI property PR_DISPLAY_CC.
+
+
+
+
+ The MAPI property PR_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_DISPLAY_NAME_PREFIX.
+
+
+
+
+ The MAPI property PR_DISPLAY_TO.
+
+
+
+
+ The MAPI property PR_DISPLAY_TYPE.
+
+
+
+
+ The MAPI property PR_DL_EXPANSION_HISTORY.
+
+
+
+
+ The MAPI property PR_DL_EXPANSION_PROHIBITED.
+
+
+
+
+ The MAPI property PR_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_END_DATE.
+
+
+
+
+ The MAPI property PR_ENTRYID.
+
+
+
+
+ The MAPI property PR_EXPAND_BEGIN_TIME.
+
+
+
+
+ The MAPI property PR_EXPANDED_BEGIN_TIME.
+
+
+
+
+ The MAPI property PR_EXPANDED_END_TIME.
+
+
+
+
+ The MAPI property PR_EXPAND_END_TIME.
+
+
+
+
+ The MAPI property PR_EXPIRY_TIME.
+
+
+
+
+ The MAPI property PR_EXPLICIT_CONVERSION.
+
+
+
+
+ The MAPI property PR_FILTERING_HOOKS.
+
+
+
+
+ The MAPI property PR_FINDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_FOLDER_ASSOCIATED_CONTENTS.
+
+
+
+
+ The MAPI property PR_FOLDER_TYPE.
+
+
+
+
+ The MAPI property PR_FORM_CATEGORY.
+
+
+
+
+ The MAPI property PR_FORM_CATEGORY_SUB.
+
+
+
+
+ The MAPI property PR_FORM_CLSID.
+
+
+
+
+ The MAPI property PR_FORM_CONTACT_NAME.
+
+
+
+
+ The MAPI property PR_FORM_DESIGNER_GUID.
+
+
+
+
+ The MAPI property PR_FORM_DESIGNER_NAME.
+
+
+
+
+ The MAPI property PR_FORM_HIDDEN.
+
+
+
+
+ The MAPI property PR_FORM_HOST_MAP.
+
+
+
+
+ The MAPI property PR_FORM_MESSAGE_BEHAVIOR.
+
+
+
+
+ The MAPI property PR_FORM_VERSION.
+
+
+
+
+ The MAPI property PR_FTP_SITE.
+
+
+
+
+ The MAPI property PR_GENDER.
+
+
+
+
+ The MAPI property PR_GENERATION.
+
+
+
+
+ The MAPI property PR_GIVEN_NAME.
+
+
+
+
+ The MAPI property PR_GOVERNMENT_ID_NUMBER.
+
+
+
+
+ The MAPI property PR_HASTTACH.
+
+
+
+
+ The MAPI property PR_HEADER_FOLDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_HOBBIES.
+
+
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_HOME_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_ICON.
+
+
+
+
+ The MAPI property PR_IDENTITY_DISPLAY.
+
+
+
+
+ The MAPI property PR_IDENTITY_ENTRYID.
+
+
+
+
+ The MAPI property PR_IDENTITY_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IMPLICIT_CONVERSION_PROHIBITED.
+
+
+
+
+ The MAPI property PR_IMPORTANCE.
+
+
+
+
+ The MAPI property PR_INCOMPLETE_COPY.
+
+
+
+
+ The Internet mail override charset.
+
+
+
+
+ The Internet mail override format.
+
+
+
+
+ The MAPI property PR_INITIAL_DETAILS_PANE.
+
+
+
+
+ The MAPI property PR_INITIALS.
+
+
+
+
+ The MAPI property PR_IN_REPLY_TO_ID.
+
+
+
+
+ The MAPI property PR_INSTANCE_KEY.
+
+
+
+
+ The MAPI property PR_INTERNET_APPROVED.
+
+
+
+
+ The MAPI property PR_INTERNET_ARTICLE_NUMBER.
+
+
+
+
+ The MAPI property PR_INTERNET_CONTROL.
+
+
+
+
+ The MAPI property PR_INTERNET_CPID.
+
+
+
+
+ The MAPI property PR_INTERNET_DISTRIBUTION.
+
+
+
+
+ The MAPI property PR_INTERNET_FOLLOWUP_TO.
+
+
+
+
+ The MAPI property PR_INTERNET_LINES.
+
+
+
+
+ The MAPI property PR_INTERNET_MESSAGE_ID.
+
+
+
+
+ The MAPI property PR_INTERNET_NEWSGROUPS.
+
+
+
+
+ The MAPI property PR_INTERNET_NNTP_PATH.
+
+
+
+
+ The MAPI property PR_INTERNET_ORGANIZATION.
+
+
+
+
+ The MAPI property PR_INTERNET_PRECEDENCE.
+
+
+
+
+ The MAPI property PR_INTERNET_REFERENCES.
+
+
+
+
+ The MAPI property PR_IPM_ID.
+
+
+
+
+ The MAPI property PR_IPM_OUTBOX_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_OUTBOX_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IPM_RETURN_REQUESTED.
+
+
+
+
+ The MAPI property PR_IPM_SENTMAIL_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_SENTMAIL_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IPM_SUBTREE_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_SUBTREE_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IPM_WASTEBASKET_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_WASTEBASKET_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ISDN_NUMBER.
+
+
+
+
+ The MAPI property PR_KEYWORD.
+
+
+
+
+ The MAPI property PR_LANGUAGE.
+
+
+
+
+ The MAPI property PR_LANGUAGES.
+
+
+
+
+ The MAPI property PR_LAST_MODIFICATION_TIME.
+
+
+
+
+ The MAPI property PR_LATEST_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_LIST_HELP.
+
+
+
+
+ The MAPI property PR_LIST_SUBSCRIBE.
+
+
+
+
+ The MAPI property PR_LIST_UNSUBSCRIBE.
+
+
+
+
+ The MAPI property PR_LOCALITY.
+
+
+
+
+ The MAPI property PR_LOCALLY_DELIVERED.
+
+
+
+
+ The MAPI property PR_LOCATION.
+
+
+
+
+ The MAPI property PR_LOCK_BRANCH_ID.
+
+
+
+
+ The MAPI property PR_LOCK_DEPTH.
+
+
+
+
+ The MAPI property PR_LOCK_ENLISTMENT_CONTEXT.
+
+
+
+
+ The MAPI property PR_LOCK_EXPIRY_TIME.
+
+
+
+
+ The MAPI property PR_LOCK_PERSISTENT.
+
+
+
+
+ The MAPI property PR_LOCK_RESOURCE_DID.
+
+
+
+
+ The MAPI property PR_LOCK_RESOURCE_FID.
+
+
+
+
+ The MAPI property PR_LOCK_RESOURCE_MID.
+
+
+
+
+ The MAPI property PR_LOCK_SCOPE.
+
+
+
+
+ The MAPI property PR_LOCK_TIMEOUT.
+
+
+
+
+ The MAPI property PR_LOCK_TYPE.
+
+
+
+
+ The MAPI property PR_MAIL_PERMISSION.
+
+
+
+
+ The MAPI property PR_MANAGER_NAME.
+
+
+
+
+ The MAPI property PR_MAPPING_SIGNATURE.
+
+
+
+
+ The MAPI property PR_MDB_PROVIDER.
+
+
+
+
+ The MAPI property PR_MESSAGE_ATTACHMENTS.
+
+
+
+
+ The MAPI property PR_MESSAGE_CC_ME.
+
+
+
+
+ The MAPI property PR_MESSAGE_CLASS.
+
+
+
+
+ The MAPI property PR_MESSAGE_CODEPAGE.
+
+
+
+
+ The MAPI property PR_MESSAGE_DELIVERY_ID.
+
+
+
+
+ The MAPI property PR_MESSAGE_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_MESSAGE_DOWNLOAD_TIME.
+
+
+
+
+ The MAPI property PR_MESSAGE_FLAGS.
+
+
+
+
+ The MAPI property PR_MESSAGE_RECIPIENTS.
+
+
+
+
+ The MAPI property PR_MESSAGE_RECIP_ME.
+
+
+
+
+ The MAPI property PR_MESSAGE_SECURITY_LABEL.
+
+
+
+
+ The MAPI property PR_MESSAGE_SIZE.
+
+
+
+
+ The MAPI property PR_MESSAGE_SUBMISSION_ID.
+
+
+
+
+ The MAPI property PR_MESSAGE_TOKEN.
+
+
+
+
+ The MAPI property PR_MESSAGE_TO_ME.
+
+
+
+
+ The MAPI property PR_MHS_COMMON_NAME.
+
+
+
+
+ The MAPI property PR_MIDDLE_NAME.
+
+
+
+
+ The MAPI property PR_MINI_ICON.
+
+
+
+
+ The MAPI property PR_MOBILE_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_MODIFY_VERSION.
+
+
+
+
+ The MAPI property PR_MSG_STATUS.
+
+
+
+
+ The MAPI property PR_NDR_DIAG_CODE.
+
+
+
+
+ The MAPI property PR_NDR_REASON_CODE.
+
+
+
+
+ The MAPI property PR_NDR_STATUS_CODE.
+
+
+
+
+ The MAPI property PR_NEWSGROUP_NAME.
+
+
+
+
+ The MAPI property PR_NICKNAME.
+
+
+
+
+ The MAPI property PR_NNTP_XREF.
+
+
+
+
+ The MAPI property PR_NON_RECEIPT_NOTIFICATION_REQUESTED.
+
+
+
+
+ The MAPI property PR_NON_RECEIPT_REASON.
+
+
+
+
+ The MAPI property PR_NORMALIZED_SUBJECT.
+
+
+
+
+ The MAPI property PR_NT_SECURITY_DESCRIPTOR.
+
+
+
+
+ The MAPI property PR_NULL.
+
+
+
+
+ The MAPI property PR_OBJECT_TYPE.
+
+
+
+
+ The MAPI property PR_OBSOLETE_IPMS.
+
+
+
+
+ The MAPI property PR_OFFICE2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OFFICE_LOCATION.
+
+
+
+
+ The MAPI property PR_OFFICE_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OOF_REPLY_TIME.
+
+
+
+
+ The MAPI property PR_ORGANIZATIONAL_ID_NUMBER.
+
+
+
+
+ The MAPI property PR_ORIG_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_BCC.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_CC.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_TO.
+
+
+
+
+ The MAPI property PR_ORIGINAL_EITS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ADRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIPIENT_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENSITIVITY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SUBJECT.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SUBMIT_TIME.
+
+
+
+
+ The MAPI property PR_ORIGINATING_MTA_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_AND_DL_EXPANSION_HISTORY.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_DELIVERY_REPORT_REQUESTED.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_NON_DELIVERY_REPORT_REQUESTED.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_REQUESTED_ALTERNATE_RECIPIENT.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_RETURN_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGIN_CHECK.
+
+
+
+
+ The MAPI property PR_ORIG_MESSAGE_CLASS.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_OTHER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OWNER_APPT_ID.
+
+
+
+
+ The MAPI property PR_OWN_STORE_ENTRYID.
+
+
+
+
+ The MAPI property PR_PAGER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_PARENT_DISPLAY.
+
+
+
+
+ The MAPI property PR_PARENT_ENTRYID.
+
+
+
+
+ The MAPI property PR_PARENT_KEY.
+
+
+
+
+ The MAPI property PR_PERSONAL_HOME_PAGE.
+
+
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_BUREAU_FAX_DELIVERY.
+
+
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_MODE.
+
+
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_REPORT_REQUEST.
+
+
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_ADDRESS.
+
+
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_ADDRESS_REQUESTED.
+
+
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_PROHIBITED.
+
+
+
+
+ The MAPI property PR_PHYSICAL_RENDITION_ATTRIBUTES.
+
+
+
+
+ The MAPI property PR_POSTAL_ADDRESS.
+
+
+
+
+ The MAPI property PR_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_POST_FOLDER_ENTRIES.
+
+
+
+
+ The MAPI property PR_POST_FOLDER_NAMES.
+
+
+
+
+ The MAPI property PR_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_POST_REPLY_DENIED.
+
+
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_ENTRIES.
+
+
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_NAMES.
+
+
+
+
+ The MAPI property PR_PREFERRED_BY_NAME.
+
+
+
+
+ The MAPI property PR_PREPROCESS.
+
+
+
+
+ The MAPI property PR_PRIMARY_CAPABILITY.
+
+
+
+
+ The MAPI property PR_PRIMARY_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_PRIMARY_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_PRIORITY.
+
+
+
+
+ The MAPI property PR_PROFESSION.
+
+
+
+
+ The MAPI property PR_PROFILE_NAME.
+
+
+
+
+ The MAPI property PR_PROOF_OF_DELIVERY.
+
+
+
+
+ The MAPI property PR_PROOF_OF_DELIVERY_REQUESTED.
+
+
+
+
+ The MAPI property PR_PROOF_OF_SUBMISSION.
+
+
+
+
+ The MAPI property PR_PROOF_OF_SUBMISSION_REQUESTED.
+
+
+
+
+ The MAPI property PR_PROP_ID_SECURE_MAX.
+
+
+
+
+ The MAPI property PR_PROP_ID_SECURE_MIN.
+
+
+
+
+ The MAPI property PR_PROVIDER_DISPLAY.
+
+
+
+
+ The MAPI property PR_PROVIDER_DLL_NAME.
+
+
+
+
+ The MAPI property PR_PROVIDER_ORDINAL.
+
+
+
+
+ The MAPI property PR_PROVIDER_SUBMIT_TIME.
+
+
+
+
+ The MAPI property PR_PROVIDER_UID.
+
+
+
+
+ The MAPI property PR_PUID.
+
+
+
+
+ The MAPI property PR_RADIO_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ENTRYID.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_READ_RECEIPT_ENTRYID.
+
+
+
+
+ The MAPI property PR_READ_RECEIPT_REQUESTED.
+
+
+
+
+ The MAPI property PR_READ_RECEIPT_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_RECEIPT_TIME.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_ENTRYID.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_NAME.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_RECEIVE_FOLDER_SETTINGS.
+
+
+
+
+ The MAPI property PR_RECIPIENT_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_RECIPIENT_NUMBER_FOR_ADVICE.
+
+
+
+
+ The MAPI property PR_RECIPIENT_REASSIGNMENT_PROHIBITED.
+
+
+
+
+ The MAPI property PR_RECIPIENT_STATUS.
+
+
+
+
+ The MAPI property PR_RECIPIENT_TYPE.
+
+
+
+
+ The MAPI property PR_RECORD_KEY.
+
+
+
+
+ The MAPI property PR_REDIRECTION_HISTORY.
+
+
+
+
+ The MAPI property PR_REFERRED_BY_NAME.
+
+
+
+
+ The MAPI property PR_REGISTERED_MAIL_TYPE.
+
+
+
+
+ The MAPI property PR_RELATED_IPMS.
+
+
+
+
+ The MAPI property PR_REMOTE_PROGRESS.
+
+
+
+
+ The MAPI property PR_REMOTE_PROGRESS_TEXT.
+
+
+
+
+ The MAPI property PR_REMOTE_VALIDATE_OK.
+
+
+
+
+ The MAPI property PR_RENDERING_POSITION.
+
+
+
+
+ The MAPI property PR_REPLY_RECIPIENT_ENTRIES.
+
+
+
+
+ The MAPI property PR_REPLY_RECIPIENT_NAMES.
+
+
+
+
+ The MAPI property PR_REPLY_REQUESTED.
+
+
+
+
+ The MAPI property PR_REPLY_TIME.
+
+
+
+
+ The MAPI property PR_REPORT_ENTRYID.
+
+
+
+
+ The MAPI property PR_REPORTING_DLL_NAME.
+
+
+
+
+ The MAPI property PR_REPORTING_MTA_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_REPORT_NAME.
+
+
+
+
+ The MAPI property PR_REPORT_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_REPORT_TAG.
+
+
+
+
+ The MAPI property PR_REPORT_TEXT.
+
+
+
+
+ The MAPI property PR_REPORT_TIME.
+
+
+
+
+ The MAPI property PR_REQUESTED_DELIVERY_METHOD.
+
+
+
+
+ The MAPI property PR_RESOURCE_FLAGS.
+
+
+
+
+ The MAPI property PR_RESOURCE_METHODS.
+
+
+
+
+ The MAPI property PR_RESOURCE_PATH.
+
+
+
+
+ The MAPI property PR_RESOURCE_TYPE.
+
+
+
+
+ The MAPI property PR_RESPONSE_REQUESTED.
+
+
+
+
+ The MAPI property PR_RESPONSIBILITY.
+
+
+
+
+ The MAPI property PR_RETURNED_IPM.
+
+
+
+
+ The MAPI property PR_ROWID.
+
+
+
+
+ The MAPI property PR_ROW_TYPE.
+
+
+
+
+ The MAPI property PR_RTF_COMPRESSED.
+
+
+
+
+ The MAPI property PR_RTF_IN_SYNC.
+
+
+
+
+ The MAPI property PR_SYNC_BODY_COUNT.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_BODY_CRC.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_BODY_TAG.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_PREFIX_COUNT.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_TRAILING_COUNT.
+
+
+
+
+ The MAPI property PR_SEARCH.
+
+
+
+
+ The MAPI property PR_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_SECURITY.
+
+
+
+
+ The MAPI property PR_SELECTABLE.
+
+
+
+
+ The MAPI property PR_SENDER_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_SENDER_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_SENDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_SENDER_NAME.
+
+
+
+
+ The MAPI property PR_SENDER_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_SEND_INTERNET_ENCODING.
+
+
+
+
+ The MAPI property PR_SEND_RECALL_REPORT.
+
+
+
+
+ The MAPI property PR_SEND_RICH_INFO.
+
+
+
+
+ The MAPI property PR_SENSITIVITY.
+
+
+
+
+ The MAPI property PR_SENTMAIL_ENTRYID.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_ENTRYID.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_SERVICE_DELETE_FILES.
+
+
+
+
+ The MAPI property PR_SERVICE_DLL_NAME.
+
+
+
+
+ The MAPI property PR_SERVICE_ENTRY_NAME.
+
+
+
+
+ The MAPI property PR_SERVICE_EXTRA_UIDS.
+
+
+
+
+ The MAPI property PR_SERVICE_NAME.
+
+
+
+
+ The MAPI property PR_SERVICES.
+
+
+
+
+ The MAPI property PR_SERVICE_SUPPORT_FILES.
+
+
+
+
+ The MAPI property PR_SERVICE_UID.
+
+
+
+
+ The MAPI property PR_SEVEN_BIT_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_SMTP_ADDRESS.
+
+
+
+
+ The MAPI property PR_SPOOLER_STATUS.
+
+
+
+
+ The MAPI property PR_SPOUSE_NAME.
+
+
+
+
+ The MAPI property PR_START_DATE.
+
+
+
+
+ The MAPI property PR_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_STATUS.
+
+
+
+
+ The MAPI property PR_STATUS_CODE.
+
+
+
+
+ The MAPI property PR_STATUS_STRING.
+
+
+
+
+ The MAPI property PR_STORE_ENTRYID.
+
+
+
+
+ The MAPI property PR_STORE_PROVIDERS.
+
+
+
+
+ The MAPI property PR_STORE_RECORD_KEY.
+
+
+
+
+ The MAPI property PR_STORE_STATE.
+
+
+
+
+ The MAPI property PR_STORE_SUPPORT_MASK.
+
+
+
+
+ The MAPI property PR_STREET_ADDRESS.
+
+
+
+
+ The MAPI property PR_SUBFOLDERS.
+
+
+
+
+ The MAPI property PR_SUBJECT.
+
+
+
+
+ The MAPI property PR_SUBJECT_IPM.
+
+
+
+
+ The MAPI property PR_SUBJECT_PREFIX.
+
+
+
+
+ The MAPI property PR_SUBMIT_FLAGS.
+
+
+
+
+ The MAPI property PR_SUPERSEDES.
+
+
+
+
+ The MAPI property PR_SUPPLEMENTARY_INFO.
+
+
+
+
+ The MAPI property PR_SURNAME.
+
+
+
+
+ The MAPI property PR_TELEX_NUMBER.
+
+
+
+
+ The MAPI property PR_TEMPLATEID.
+
+
+
+
+ The MAPI property PR_TITLE.
+
+
+
+
+ The MAPI property PR_TNEF_CORRELATION_KEY.
+
+
+
+
+ The MAPI property PR_TRANSMITABLE_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_TRANSPORT_KEY.
+
+
+
+
+ The MAPI property PR_TRANSPORT_MESSAGE_HEADERS.
+
+
+
+
+ The MAPI property PR_TRANSPORT_PROVIDERS.
+
+
+
+
+ The MAPI property PR_TRANSPORT_STATUS.
+
+
+
+
+ The MAPI property PR_TTYTDD_PHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_TYPE_OF_MTS_USER.
+
+
+
+
+ The MAPI property PR_USER_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_USER_X509_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_VALID_FOLDER_MASK.
+
+
+
+
+ The MAPI property PR_VIEWS_ENTRYID.
+
+
+
+
+ The MAPI property PR_WEDDING_ANNIVERSARY.
+
+
+
+
+ The MAPI property PR_X400_CONTENT_TYPE.
+
+
+
+
+ The MAPI property PR_X400_DEFERRED_DELIVERY_CANCEL.
+
+
+
+
+ The MAPI property PR_XPOS.
+
+
+
+
+ The MAPI property PR_YPOS.
+
+
+
+
+ A TNEF property reader.
+
+
+ A TNEF property reader.
+
+
+
+
+ Gets a value indicating whether the current property is an embedded TNEF message.
+
+
+ Gets a value indicating whether the current property is an embedded TNEF message.
+
+ true if the current property is an embedded TNEF message; otherwise, false.
+
+
+
+ Gets a value indicating whether or not the current property has multiple values.
+
+
+ Gets a value indicating whether or not the current property has multiple values.
+
+ true if the current property has multiple values; otherwise, false.
+
+
+
+ Gets a value indicating whether or not the current property is a named property.
+
+
+ Gets a value indicating whether or not the current property is a named property.
+
+ true if the current property is a named property; otherwise, false.
+
+
+
+ Gets a value indicating whether the current property contains object values.
+
+
+ Gets a value indicating whether the current property contains object values.
+
+ true if the current property contains object values; otherwise, false.
+
+
+
+ Gets the number of properties available.
+
+
+ Gets the number of properties available.
+
+ The property count.
+
+
+
+ Gets the property name identifier.
+
+
+ Gets the property name identifier.
+
+ The property name identifier.
+
+
+
+ Gets the property tag.
+
+
+ Gets the property tag.
+
+ The property tag.
+
+
+
+ Gets the length of the raw value.
+
+
+ Gets the length of the raw value.
+
+ The length of the raw value.
+
+
+
+ Gets the raw value stream offset.
+
+
+ Gets the raw value stream offset.
+
+ The raw value stream offset.
+
+
+
+ Gets the number of table rows available.
+
+
+ Gets the number of table rows available.
+
+ The row count.
+
+
+
+ Gets the number of values available.
+
+
+ Gets the number of values available.
+
+ The value count.
+
+
+
+ Gets the type of the value.
+
+
+ Gets the type of the value.
+
+ The type of the value.
+
+
+
+ Gets the embedded TNEF message reader.
+
+
+ Gets the embedded TNEF message reader.
+
+ The embedded TNEF message reader.
+
+ The property does not contain any more values.
+ -or-
+ The property value is not an embedded message.
+
+
+
+
+ Gets the raw value of the attribute or property as a stream.
+
+
+ Gets the raw value of the attribute or property as a stream.
+
+ The raw value stream.
+
+ The property does not contain any more values.
+
+
+
+
+ Advances to the next MAPI property.
+
+
+ Advances to the next MAPI property.
+
+ true if there is another property available to be read; otherwise false.
+
+ The TNEF data is corrupt or invalid.
+
+
+
+
+ Advances to the next table row of properties.
+
+
+ Advances to the next table row of properties.
+
+ true if there is another row available to be read; otherwise false.
+
+ The TNEF data is corrupt or invalid.
+
+
+
+
+ Advances to the next value in the TNEF stream.
+
+
+ Advances to the next value in the TNEF stream.
+
+ true if there is another value available to be read; otherwise false.
+
+ The TNEF data is corrupt or invalid.
+
+
+
+
+ Reads the raw attribute or property value as a sequence of bytes.
+
+
+ Reads the raw attribute or property value as a sequence of bytes.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ An I/O error occurred.
+
+
+
+
+ Reads the raw attribute or property value as a sequence of unicode characters.
+
+
+ Reads the raw attribute or property value as a sequence of unicode characters.
+
+ The total number of characters read into the buffer. This can be less than the number of characters
+ requested if that many bytes are not currently available, or zero (0) if the end of the stream has been
+ reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of characters to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain characters starting
+ at the specified .
+
+
+ An I/O error occurred.
+
+
+
+
+ Reads the value.
+
+
+ Reads an attribute or property value as its native type.
+
+ The value.
+
+ There are no more values to read or the value could not be read.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a boolean.
+
+
+ Reads any integer-based attribute or property value as a boolean.
+
+ The value as a boolean.
+
+ There are no more values to read or the value could not be read as a boolean.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a byte array.
+
+
+ Reads any string, binary blob, Class ID, or Object attribute or property value as a byte array.
+
+ The value as a byte array.
+
+ There are no more values to read or the value could not be read as a byte array.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a date and time.
+
+
+ Reads any date and time attribute or property value as a .
+
+ The value as a date and time.
+
+ There are no more values to read or the value could not be read as a date and time.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a double.
+
+
+ Reads any numeric attribute or property value as a double.
+
+ The value as a double.
+
+ There are no more values to read or the value could not be read as a double.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a float.
+
+
+ Reads any numeric attribute or property value as a float.
+
+ The value as a float.
+
+ There are no more values to read or the value could not be read as a float.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a GUID.
+
+
+ Reads any Class ID value as a GUID.
+
+ The value as a GUID.
+
+ There are no more values to read or the value could not be read as a GUID.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a 16-bit integer.
+
+
+ Reads any integer-based attribute or property value as a 16-bit integer.
+
+ The value as a 16-bit integer.
+
+ There are no more values to read or the value could not be read as a 16-bit integer.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a 32-bit integer.
+
+
+ Reads any integer-based attribute or property value as a 32-bit integer.
+
+ The value as a 32-bit integer.
+
+ There are no more values to read or the value could not be read as a 32-bit integer.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a 64-bit integer.
+
+
+ Reads any integer-based attribute or property value as a 64-bit integer.
+
+ The value as a 64-bit integer.
+
+ There are no more values to read or the value could not be read as a 64-bit integer.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a string.
+
+
+ Reads any string or binary blob values as a string.
+
+ The value as a string.
+
+ There are no more values to read or the value could not be read as a string.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Serves as a hash function for a object.
+
+
+ Serves as a hash function for a object.
+
+ A hash code for this instance that is suitable for use in hashing algorithms
+ and data structures such as a hash table.
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Determines whether the specified is equal to the current .
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ A TNEF property tag.
+
+
+ A TNEF property tag.
+
+
+
+
+ The MAPI property PR_AB_DEFAULT_DIR.
+
+
+ The MAPI property PR_AB_DEFAULT_DIR.
+
+
+
+
+ The MAPI property PR_AB_DEFAULT_PAB.
+
+
+ The MAPI property PR_AB_DEFAULT_PAD.
+
+
+
+
+ The MAPI property PR_AB_PROVIDER_ID.
+
+
+ The MAPI property PR_AB_PROVIDER_ID.
+
+
+
+
+ The MAPI property PR_AB_PROVIDERS.
+
+
+ The MAPI property PR_AB_PROVIDERS.
+
+
+
+
+ The MAPI property PR_AB_SEARCH_PATH.
+
+
+ The MAPI property PR_AB_SEARCH_PATH.
+
+
+
+
+ The MAPI property PR_AB_SEARCH_PATH_UPDATE.
+
+
+ The MAPI property PR_AB_SEARCH_PATH_UPDATE.
+
+
+
+
+ The MAPI property PR_ACCESS.
+
+
+ The MAPI property PR_ACCESS.
+
+
+
+
+ The MAPI property PR_ACCESS_LEVEL.
+
+
+ The MAPI property PR_ACCESS_LEVEL.
+
+
+
+
+ The MAPI property PR_ACCOUNT.
+
+
+ The MAPI property PR_ACCOUNT.
+
+
+
+
+ The MAPI property PR_ACCOUNT.
+
+
+ The MAPI property PR_ACCOUNT.
+
+
+
+
+ The MAPI property PR_ACKNOWLEDGEMENT_MODE.
+
+
+ The MAPI property PR_ACKNOWLEDGEMENT_MODE.
+
+
+
+
+ The MAPI property PR_ADDRTYPE.
+
+
+ The MAPI property PR_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ADDRTYPE.
+
+
+ The MAPI property PR_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ALTERNATE_RECIPIENT.
+
+
+ The MAPI property PR_ALTERNATE_RECIPIENT.
+
+
+
+
+ The MAPI property PR_ALTERNATE_RECIPIENT_ALLOWED.
+
+
+ The MAPI property PR_ALTERNATE_RECIPIENT_ALLOWED.
+
+
+
+
+ The MAPI property PR_ANR.
+
+
+ The MAPI property PR_ANR.
+
+
+
+
+ The MAPI property PR_ANR.
+
+
+ The MAPI property PR_ANR.
+
+
+
+
+ The MAPI property PR_ASSISTANT.
+
+
+ The MAPI property PR_ASSISTANT.
+
+
+
+
+ The MAPI property PR_ASSISTANT.
+
+
+ The MAPI property PR_ASSISTANT.
+
+
+
+
+ The MAPI property PR_ASSISTANT_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_ASSISTANT_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_ASSISTANT_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_ASSISTANT_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_ASSOC_CONTENT_COUNT.
+
+
+ The MAPI property PR_ASSOC_CONTENT_COUNT.
+
+
+
+
+ The MAPI property PR_ATTACH_ADDITIONAL_INFO.
+
+
+ The MAPI property PR_ATTACH_ADDITIONAL_INFO.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_BASE.
+
+
+ The MAPI property PR_ATTACH_CONTENT_BASE.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_BASE.
+
+
+ The MAPI property PR_ATTACH_CONTENT_BASE.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_ID.
+
+
+ The MAPI property PR_ATTACH_CONTENT_ID.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_ID.
+
+
+ The MAPI property PR_ATTACH_CONTENT_ID.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_LOCATION.
+
+
+ The MAPI property PR_ATTACH_CONTENT_LOCATION.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_LOCATION.
+
+
+ The MAPI property PR_ATTACH_CONTENT_LOCATION.
+
+
+
+
+ The MAPI property PR_ATTACH_DATA.
+
+
+ The MAPI property PR_ATTACH_DATA.
+
+
+
+
+ The MAPI property PR_ATTACH_DATA.
+
+
+ The MAPI property PR_ATTACH_DATA.
+
+
+
+
+ The MAPI property PR_ATTACH_DISPOSITION.
+
+
+ The MAPI property PR_ATTACH_DISPOSITION.
+
+
+
+
+ The MAPI property PR_ATTACH_DISPOSITION.
+
+
+ The MAPI property PR_ATTACH_DISPOSITION.
+
+
+
+
+ The MAPI property PR_ATTACH_ENCODING.
+
+
+ The MAPI property PR_ATTACH_ENCODING.
+
+
+
+
+ The MAPI property PR_ATTACH_EXTENSION.
+
+
+ The MAPI property PR_ATTACH_EXTENSION.
+
+
+
+
+ The MAPI property PR_ATTACH_EXTENSION.
+
+
+ The MAPI property PR_ATTACH_EXTENSION.
+
+
+
+
+ The MAPI property PR_ATTACH_FILENAME.
+
+
+ The MAPI property PR_ATTACH_FILENAME.
+
+
+
+
+ The MAPI property PR_ATTACH_FILENAME.
+
+
+ The MAPI property PR_ATTACH_FILENAME.
+
+
+
+
+ The MAPI property PR_ATTACH_FLAGS.
+
+
+ The MAPI property PR_ATTACH_FLAGS.
+
+
+
+
+ The MAPI property PR_ATTACH_LONG_FILENAME.
+
+
+ The MAPI property PR_ATTACH_LONG_FILENAME.
+
+
+
+
+ The MAPI property PR_ATTACH_LONG_FILENAME.
+
+
+ The MAPI property PR_ATTACH_LONG_FILENAME.
+
+
+
+
+ The MAPI property PR_ATTACH_LONG_PATHNAME.
+
+
+ The MAPI property PR_ATTACH_LONG_PATHNAME.
+
+
+
+
+ The MAPI property PR_ATTACH_LONG_PATHNAME.
+
+
+ The MAPI property PR_ATTACH_LONG_PATHNAME.
+
+
+
+
+ The MAPI property PR_ATTACHMENT_X400_PARAMETERS.
+
+
+ The MAPI property PR_ATTACHMENT_X400_PARAMETERS.
+
+
+
+
+ The MAPI property PR_ATTACH_METHOD.
+
+
+ The MAPI property PR_ATTACH_METHOD.
+
+
+
+
+ The MAPI property PR_ATTACH_MIME_SEQUENCE.
+
+
+ The MAPI property PR_ATTACH_MIME_SEQUENCE.
+
+
+
+
+ The MAPI property PR_ATTACH_MIME_TAG.
+
+
+ The MAPI property PR_ATTACH_MIME_TAG.
+
+
+
+
+ The MAPI property PR_ATTACH_MIME_TAG.
+
+
+ The MAPI property PR_ATTACH_MIME_TAG.
+
+
+
+
+ The MAPI property PR_ATTACH_NETSCAPE_MAC_INFO.
+
+
+ The MAPI property PR_ATTACH_NETSCAPE_MAC_INFO.
+
+
+
+
+ The MAPI property PR_ATTACH_NUM.
+
+
+ The MAPI property PR_ATTACH_NUM.
+
+
+
+
+ The MAPI property PR_ATTACH_PATHNAME.
+
+
+ The MAPI property PR_ATTACH_PATHNAME.
+
+
+
+
+ The MAPI property PR_ATTACH_PATHNAME.
+
+
+ The MAPI property PR_ATTACH_PATHNAME.
+
+
+
+
+ The MAPI property PR_ATTACH_RENDERING.
+
+
+ The MAPI property PR_ATTACH_RENDERING.
+
+
+
+
+ The MAPI property PR_ATTACH_SIZE.
+
+
+ The MAPI property PR_ATTACH_SIZE.
+
+
+
+
+ The MAPI property PR_ATTACH_TAG.
+
+
+ The MAPI property PR_ATTACH_TAG.
+
+
+
+
+ The MAPI property PR_ATTACH_TRANSPORT_NAME.
+
+
+ The MAPI property PR_ATTACH_TRANSPORT_NAME.
+
+
+
+
+ The MAPI property PR_ATTACH_TRANSPORT_NAME.
+
+
+ The MAPI property PR_ATTACH_TRANSPORT_NAME.
+
+
+
+
+ The MAPI property PR_AUTHORIZING_USERS.
+
+
+ The MAPI property PR_AUTHORIZING_USERS.
+
+
+
+
+ The MAPI property PR_AUTOFORWARDED.
+
+
+ The MAPI property PR_AUTOFORWARDED.
+
+
+
+
+ The MAPI property PR_AUTOFORWARDING_COMMENT.
+
+
+ The MAPI property PR_AUTOFORWARDING_COMMENT.
+
+
+
+
+ The MAPI property PR_AUTOFORWARDING_COMMENT.
+
+
+ The MAPI property PR_AUTOFORWARDING_COMMENT.
+
+
+
+
+ The MAPI property PR_AUTORESPONSE_SUPPRESS.
+
+
+ The MAPI property PR_AUTORESPONSE_SUPPRESS.
+
+
+
+
+ The MAPI property PR_BEEPER_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_BEEPER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BEEPER_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_BEEPER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BIRTHDAY.
+
+
+ The MAPI property PR_BIRTHDAY.
+
+
+
+
+ The MAPI property PR_BODY.
+
+
+ The MAPI property PR_BODY.
+
+
+
+
+ The MAPI property PR_BODY.
+
+
+ The MAPI property PR_BODY.
+
+
+
+
+ The MAPI property PR_BODY_CONTENT_ID.
+
+
+ The MAPI property PR_BODY_CONTENT_ID.
+
+
+
+
+ The MAPI property PR_BODY_CONTENT_ID.
+
+
+ The MAPI property PR_BODY_CONTENT_ID.
+
+
+
+
+ The MAPI property PR_BODY_CONTENT_LOCATION.
+
+
+ The MAPI property PR_BODY_CONTENT_LOCATION.
+
+
+
+
+ The MAPI property PR_BODY_CONTENT_LOCATION.
+
+
+ The MAPI property PR_BODY_CONTENT_LOCATION.
+
+
+
+
+ The MAPI property PR_BODY_CRC.
+
+
+ The MAPI property PR_BODY_CRC.
+
+
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_CITY.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_CITY.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_COUNTRY.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_COUNTRY.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_CODE.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_CODE.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_STREET.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_STREET.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_STREET.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_STREET.
+
+
+
+
+ The MAPI property PR_BUSINESS_FAX_NUMBER.
+
+
+ The MAPI property PR_BUSINESS_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS_FAX_NUMBER.
+
+
+ The MAPI property PR_BUSINESS_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS_HOME_PAGE.
+
+
+ The MAPI property PR_BUSINESS_HOME_PAGE.
+
+
+
+
+ The MAPI property PR_BUSINESS_HOME_PAGE.
+
+
+ The MAPI property PR_BUSINESS_HOME_PAGE.
+
+
+
+
+ The MAPI property PR_CALLBACK_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_CALLBACK_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CALLBACK_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_CALLBACK_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CAR_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_CAR_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CAR_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_CAR_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CHILDRENS_NAMES.
+
+
+ The MAPI property PR_CHILDRENS_NAMES.
+
+
+
+
+ The MAPI property PR_CHILDRENS_NAMES.
+
+
+ The MAPI property PR_CHILDRENS_NAMES.
+
+
+
+
+ The MAPI property PR_CLIENT_SUBMIT_TIME.
+
+
+ The MAPI property PR_CLIENT_SUBMIT_TIME.
+
+
+
+
+ The MAPI property PR_COMMENT.
+
+
+ The MAPI property PR_COMMENT.
+
+
+
+
+ The MAPI property PR_COMMENT.
+
+
+ The MAPI property PR_COMMENT.
+
+
+
+
+ The MAPI property PR_COMMON_VIEWS_ENTRYID.
+
+
+ The MAPI property PR_COMMON_VIEWS_ENTRYID.
+
+
+
+
+ The MAPI property PR_COMPANY_MAIN_PHONE_NUMBER.
+
+
+ The MAPI property PR_COMPANY_MAIN_PHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_COMPANY_MAIN_PHONE_NUMBER.
+
+
+ The MAPI property PR_COMPANY_MAIN_PHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_COMPANY_NAME.
+
+
+ The MAPI property PR_COMPANY_NAME.
+
+
+
+
+ The MAPI property PR_COMPANY_NAME.
+
+
+ The MAPI property PR_COMPANY_NAME.
+
+
+
+
+ The MAPI property PR_COMPUTER_NETWORK_NAME.
+
+
+ The MAPI property PR_COMPUTER_NETWORK_NAME.
+
+
+
+
+ The MAPI property PR_COMPUTER_NETWORK_NAME.
+
+
+ The MAPI property PR_COMPUTER_NETWORK_NAME.
+
+
+
+
+ The MAPI property PR_CONTACT_ADDRTYPES.
+
+
+ The MAPI property PR_CONTACT_ADDRTYPES.
+
+
+
+
+ The MAPI property PR_CONTACT_ADDRTYPES.
+
+
+ The MAPI property PR_CONTACT_ADDRTYPES.
+
+
+
+
+ The MAPI property PR_CONTACT_DEFAULT_ADDRESS_INDEX.
+
+
+ The MAPI property PR_CONTACT_DEFAULT_ADDRESS_INDEX.
+
+
+
+
+ The MAPI property PR_CONTACT_EMAIL_ADDRESSES.
+
+
+ The MAPI property PR_CONTACT_EMAIL_ADDRESSES.
+
+
+
+
+ The MAPI property PR_CONTACT_EMAIL_ADDRESSES.
+
+
+ The MAPI property PR_CONTACT_EMAIL_ADDRESSES.
+
+
+
+
+ The MAPI property PR_CONTACT_ENTRYIDS.
+
+
+ The MAPI property PR_CONTACT_ENTRYIDS.
+
+
+
+
+ The MAPI property PR_CONTACT_VERSION.
+
+
+ The MAPI property PR_CONTACT_VERSION.
+
+
+
+
+ The MAPI property PR_CONTAINER_CLASS.
+
+
+ The MAPI property PR_CONTAINER_CLASS.
+
+
+
+
+ The MAPI property PR_CONTAINER_CLASS.
+
+
+ The MAPI property PR_CONTAINER_CLASS.
+
+
+
+
+ The MAPI property PR_CONTAINER_CONTENTS.
+
+
+ The MAPI property PR_CONTAINER_CONTENTS.
+
+
+
+
+ The MAPI property PR_CONTAINER_FLAGS.
+
+
+ The MAPI property PR_CONTAINER_FLAGS.
+
+
+
+
+ The MAPI property PR_CONTAINER_HIERARCHY.
+
+
+ The MAPI property PR_CONTAINER_HIERARCHY.
+
+
+
+
+ The MAPI property PR_CONTAINER_MODIFY_VERSION.
+
+
+ The MAPI property PR_CONTAINER_MODIFY_VERSION.
+
+
+
+
+ The MAPI property PR_CONTENT_CONFIDENTIALITY_ALGORITHM_ID.
+
+
+ The MAPI property PR_CONTENT_CONFIDENTIALITY_ALGORITHM_ID.
+
+
+
+
+ The MAPI property PR_CONTENT_CORRELATOR.
+
+
+ The MAPI property PR_CONTENT_CORRELATOR.
+
+
+
+
+ The MAPI property PR_CONTENT_COUNT.
+
+
+ The MAPI property PR_CONTENT_COUNT.
+
+
+
+
+ The MAPI property PR_CONTENT_IDENTIFIER.
+
+
+ The MAPI property PR_CONTENT_IDENTIFIER.
+
+
+
+
+ The MAPI property PR_CONTENT_IDENTIFIER.
+
+
+ The MAPI property PR_CONTENT_IDENTIFIER.
+
+
+
+
+ The MAPI property PR_CONTENT_INTEGRITY_CHECK.
+
+
+ The MAPI property PR_CONTENT_INTEGRITY_CHECK.
+
+
+
+
+ The MAPI property PR_CONTENT_LENGTH.
+
+
+ The MAPI property PR_CONTENT_LENGTH.
+
+
+
+
+ The MAPI property PR_CONTENT_RETURN_REQUESTED.
+
+
+ The MAPI property PR_CONTENT_RETURN_REQUESTED.
+
+
+
+
+ The MAPI property PR_CONTENTS_SORT_ORDER.
+
+
+ The MAPI property PR_CONTENTS_SORT_ORDER.
+
+
+
+
+ The MAPI property PR_CONTENT_UNREAD.
+
+
+ The MAPI property PR_CONTENT_UNREAD.
+
+
+
+
+ The MAPI property PR_CONTROL_FLAGS.
+
+
+ The MAPI property PR_CONTROL_FLAGS.
+
+
+
+
+ The MAPI property PR_CONTROL_ID.
+
+
+ The MAPI property PR_CONTROL_ID.
+
+
+
+
+ The MAPI property PR_CONTROL_STRUCTURE.
+
+
+ The MAPI property PR_CONTROL_STRUCTURE.
+
+
+
+
+ The MAPI property PR_CONTROL_TYPE.
+
+
+ The MAPI property PR_CONTROL_TYPE.
+
+
+
+
+ The MAPI property PR_CONVERSATION_INDEX.
+
+
+ The MAPI property PR_CONVERSATION_INDEX.
+
+
+
+
+ The MAPI property PR_CONVERSATION_KEY.
+
+
+ The MAPI property PR_CONVERSATION_KEY.
+
+
+
+
+ The MAPI property PR_CONVERSATION_TOPIC.
+
+
+ The MAPI property PR_CONVERSATION_TOPIC.
+
+
+
+
+ The MAPI property PR_CONVERSATION_TOPIC.
+
+
+ The MAPI property PR_CONVERSATION_TOPIC.
+
+
+
+
+ The MAPI property PR_CONVERSION_EITS.
+
+
+ The MAPI property PR_CONVERSION_EITS.
+
+
+
+
+ The MAPI property PR_CONVERSION_PROHIBITED.
+
+
+ The MAPI property PR_CONVERSION_PROHIBITED.
+
+
+
+
+ The MAPI property PR_CONVERSION_WITH_LOSS_PROHIBITED.
+
+
+ The MAPI property PR_CONVERSION_WITH_LOSS_PROHIBITED.
+
+
+
+
+ The MAPI property PR_CONVERTED_EITS.
+
+
+ The MAPI property PR_CONVERTED_EITS.
+
+
+
+
+ The MAPI property PR_CORRELATE.
+
+
+ The MAPI property PR_CORRELATE.
+
+
+
+
+ The MAPI property PR_CORRELATE_MTSID.
+
+
+ The MAPI property PR_CORRELATE_MTSID.
+
+
+
+
+ The MAPI property PR_COUNTRY.
+
+
+ The MAPI property PR_COUNTRY.
+
+
+
+
+ The MAPI property PR_COUNTRY.
+
+
+ The MAPI property PR_COUNTRY.
+
+
+
+
+ The MAPI property PR_CREATE_TEMPLATES.
+
+
+ The MAPI property PR_CREATE_TEMPLATES.
+
+
+
+
+ The MAPI property PR_CREATION_TIME.
+
+
+ The MAPI property PR_CREATION_TIME.
+
+
+
+
+ The MAPI property PR_CREATION_VERSION.
+
+
+ The MAPI property PR_CREATION_VERSION.
+
+
+
+
+ The MAPI property PR_CURRENT_VERSION.
+
+
+ The MAPI property PR_CURRENT_VERSION.
+
+
+
+
+ The MAPI property PR_CUSTOMER_ID.
+
+
+ The MAPI property PR_CUSTOMER_ID.
+
+
+
+
+ The MAPI property PR_CUSTOMER_ID.
+
+
+ The MAPI property PR_CUSTOMER_ID.
+
+
+
+
+ The MAPI property PR_DEFAULT_PROFILE.
+
+
+ The MAPI property PR_DEFAULT_PROFILE.
+
+
+
+
+ The MAPI property PR_DEFAULT_STORE.
+
+
+ The MAPI property PR_DEFAULT_STORE.
+
+
+
+
+ The MAPI property PR_DEFAULT_VIEW_ENTRYID.
+
+
+ The MAPI property PR_DEFAULT_VIEW_ENTRYID.
+
+
+
+
+ The MAPI property PR_DEF_CREATE_DL.
+
+
+ The MAPI property PR_DEF_CREATE_DL.
+
+
+
+
+ The MAPI property PR_DEF_CREATE_MAILUSER.
+
+
+ The MAPI property PR_DEF_CREATE_MAILUSER.
+
+
+
+
+ The MAPI property PR_DEFERRED_DELIVERY_TIME.
+
+
+ The MAPI property PR_DEFERRED_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_DELEGATION.
+
+
+ The MAPI property PR_DELEGATION.
+
+
+
+
+ The MAPI property PR_DELETE_AFTER_SUBMIT.
+
+
+ The MAPI property PR_DELETE_AFTER_SUBMIT.
+
+
+
+
+ The MAPI property PR_DELIVER_TIME.
+
+
+ The MAPI property PR_DELIVER_TIME.
+
+
+
+
+ The MAPI property PR_DELIVERY_POINT.
+
+
+ The MAPI property PR_DELIVERY_POINT.
+
+
+
+
+ The MAPI property PR_DELTAX.
+
+
+ The MAPI property PR_DELTAX.
+
+
+
+
+ The MAPI property PR_DELTAY.
+
+
+ The MAPI property PR_DELTAY.
+
+
+
+
+ The MAPI property PR_DEPARTMENT_NAME.
+
+
+ The MAPI property PR_DEPARTMENT_NAME.
+
+
+
+
+ The MAPI property PR_DEPARTMENT_NAME.
+
+
+ The MAPI property PR_DEPARTMENT_NAME.
+
+
+
+
+ The MAPI property PR_DEPTH.
+
+
+ The MAPI property PR_DEPTH.
+
+
+
+
+ The MAPI property PR_DETAILS_TABLE.
+
+
+ The MAPI property PR_DETAILS_TABLE.
+
+
+
+
+ The MAPI property PR_DISCARD_REASON.
+
+
+ The MAPI property PR_DISCARD_REASON.
+
+
+
+
+ The MAPI property PR_DISCLOSE_RECIPIENTS.
+
+
+ The MAPI property PR_DISCLOSE_RECIPIENTS.
+
+
+
+
+ The MAPI property PR_DISCLOSURE_OF_RECIPIENTS.
+
+
+ The MAPI property PR_DISCLOSURE_OF_RECIPIENTS.
+
+
+
+
+ The MAPI property PR_DISCRETE_VALUES.
+
+
+ The MAPI property PR_DISCRETE_VALUES.
+
+
+
+
+ The MAPI property PR_DISC_VAL.
+
+
+ The MAPI property PR_DISC_VAL.
+
+
+
+
+ The MAPI property PR_DISPLAY_BCC.
+
+
+ The MAPI property PR_DISPLAY_BCC.
+
+
+
+
+ The MAPI property PR_DISPLAY_BCC.
+
+
+ The MAPI property PR_DISPLAY_BCC.
+
+
+
+
+ The MAPI property PR_DISPLAY_CC.
+
+
+ The MAPI property PR_DISPLAY_CC.
+
+
+
+
+ The MAPI property PR_DISPLAY_CC.
+
+
+ The MAPI property PR_DISPLAY_CC.
+
+
+
+
+ The MAPI property PR_DISPLAY_NAME.
+
+
+ The MAPI property PR_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_DISPLAY_NAME.
+
+
+ The MAPI property PR_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_DISPLAY_NAME_PREFIX.
+
+
+ The MAPI property PR_DISPLAY_NAME_PREFIX.
+
+
+
+
+ The MAPI property PR_DISPLAY_NAME_PREFIX.
+
+
+ The MAPI property PR_DISPLAY_NAME_PREFIX.
+
+
+
+
+ The MAPI property PR_DISPLAY_TO.
+
+
+ The MAPI property PR_DISPLAY_TO.
+
+
+
+
+ The MAPI property PR_DISPLAY_TO.
+
+
+ The MAPI property PR_DISPLAY_TO.
+
+
+
+
+ The MAPI property PR_DISPLAY_TYPE.
+
+
+ The MAPI property PR_DISPLAY_TYPE.
+
+
+
+
+ The MAPI property PR_DL_EXPANSION_HISTORY.
+
+
+ The MAPI property PR_DL_EXPANSION_HISTORY.
+
+
+
+
+ The MAPI property PR_DL_EXPANSION_PROHIBITED.
+
+
+ The MAPI property PR_DL_EXPANSION_PROHIBITED.
+
+
+
+
+ The MAPI property PR_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_END_DATE.
+
+
+ The MAPI property PR_END_DATE.
+
+
+
+
+ The MAPI property PR_ENTRYID.
+
+
+ The MAPI property PR_ENTRYID.
+
+
+
+
+ The MAPI property PR_EXPAND_BEGIN_TIME.
+
+
+ The MAPI property PR_EXPAND_BEGIN_TIME.
+
+
+
+
+ The MAPI property PR_EXPANDED_BEGIN_TIME.
+
+
+ The MAPI property PR_EXPANDED_BEGIN_TIME.
+
+
+
+
+ The MAPI property PR_EXPANDED_END_TIME.
+
+
+ The MAPI property PR_EXPANDED_END_TIME.
+
+
+
+
+ The MAPI property PR_EXPAND_END_TIME.
+
+
+ The MAPI property PR_EXPAND_END_TIME.
+
+
+
+
+ The MAPI property PR_EXPIRY_TIME.
+
+
+ The MAPI property PR_EXPIRY_TIME.
+
+
+
+
+ The MAPI property PR_EXPLICIT_CONVERSION.
+
+
+ The MAPI property PR_EXPLICIT_CONVERSION.
+
+
+
+
+ The MAPI property PR_FILTERING_HOOKS.
+
+
+ The MAPI property PR_FILTERING_HOOKS.
+
+
+
+
+ The MAPI property PR_FINDER_ENTRYID.
+
+
+ The MAPI property PR_FINDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_FOLDER_ASSOCIATED_CONTENTS.
+
+
+ The MAPI property PR_FOLDER_ASSOCIATED_CONTENTS.
+
+
+
+
+ The MAPI property PR_FOLDER_TYPE.
+
+
+ The MAPI property PR_FOLDER_TYPE.
+
+
+
+
+ The MAPI property PR_FORM_CATEGORY.
+
+
+ The MAPI property PR_FORM_CATEGORY.
+
+
+
+
+ The MAPI property PR_FORM_CATEGORY.
+
+
+ The MAPI property PR_FORM_CATEGORY.
+
+
+
+
+ The MAPI property PR_FORM_CATEGORY_SUB.
+
+
+ The MAPI property PR_FORM_CATEGORY_SUB.
+
+
+
+
+ The MAPI property PR_FORM_CATEGORY_SUB.
+
+
+ The MAPI property PR_FORM_CATEGORY_SUB.
+
+
+
+
+ The MAPI property PR_FORM_CLSID.
+
+
+ The MAPI property PR_FORM_CLSID.
+
+
+
+
+ The MAPI property PR_FORM_CONTACT_NAME.
+
+
+ The MAPI property PR_FORM_CONTACT_NAME.
+
+
+
+
+ The MAPI property PR_FORM_CONTACT_NAME.
+
+
+ The MAPI property PR_FORM_CONTACT_NAME.
+
+
+
+
+ The MAPI property PR_FORM_DESIGNER_GUID.
+
+
+ The MAPI property PR_FORM_DESIGNER_GUID.
+
+
+
+
+ The MAPI property PR_FORM_DESIGNER_NAME.
+
+
+ The MAPI property PR_FORM_DESIGNER_NAME.
+
+
+
+
+ The MAPI property PR_FORM_DESIGNER_NAME.
+
+
+ The MAPI property PR_FORM_DESIGNER_NAME.
+
+
+
+
+ The MAPI property PR_FORM_HIDDEN.
+
+
+ The MAPI property PR_FORM_HIDDEN.
+
+
+
+
+ The MAPI property PR_FORM_HOST_MAP.
+
+
+ The MAPI property PR_FORM_HOST_MAP.
+
+
+
+
+ The MAPI property PR_FORM_MESSAGE_BEHAVIOR.
+
+
+ The MAPI property PR_FORM_MESSAGE_BEHAVIOR.
+
+
+
+
+ The MAPI property PR_FORM_VERSION.
+
+
+ The MAPI property PR_FORM_VERSION.
+
+
+
+
+ The MAPI property PR_FORM_VERSION.
+
+
+ The MAPI property PR_FORM_VERSION.
+
+
+
+
+ The MAPI property PR_FTP_SITE.
+
+
+ The MAPI property PR_FTP_SITE.
+
+
+
+
+ The MAPI property PR_FTP_SITE.
+
+
+ The MAPI property PR_FTP_SITE.
+
+
+
+
+ The MAPI property PR_GENDER.
+
+
+ The MAPI property PR_GENDER.
+
+
+
+
+ The MAPI property PR_GENERATION.
+
+
+ The MAPI property PR_GENERATION.
+
+
+
+
+ The MAPI property PR_GENERATION.
+
+
+ The MAPI property PR_GENERATION.
+
+
+
+
+ The MAPI property PR_GIVEN_NAME.
+
+
+ The MAPI property PR_GIVEN_NAME.
+
+
+
+
+ The MAPI property PR_GIVEN_NAME.
+
+
+ The MAPI property PR_GIVEN_NAME.
+
+
+
+
+ The MAPI property PR_GOVERNMENT_ID_NUMBER.
+
+
+ The MAPI property PR_GOVERNMENT_ID_NUMBER.
+
+
+
+
+ The MAPI property PR_GOVERNMENT_ID_NUMBER.
+
+
+ The MAPI property PR_GOVERNMENT_ID_NUMBER.
+
+
+
+
+ The MAPI property PR_HASATTACH.
+
+
+ The MAPI property PR_HASATTACH.
+
+
+
+
+ The MAPI property PR_HEADER_FOLDER_ENTRYID.
+
+
+ The MAPI property PR_HEADER_FOLDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_HOBBIES.
+
+
+ The MAPI property PR_HOBBIES.
+
+
+
+
+ The MAPI property PR_HOBBIES.
+
+
+ The MAPI property PR_HOBBIES.
+
+
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_CITY.
+
+
+ The MAPI property PR_HOME_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_CITY.
+
+
+ The MAPI property PR_HOME_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_COUNTRY.
+
+
+ The MAPI property PR_HOME_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_COUNTRY.
+
+
+ The MAPI property PR_HOME_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_POSTAL_CODE.
+
+
+ The MAPI property PR_HOME_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_POSTAL_CODE.
+
+
+ The MAPI property PR_HOME_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_POST_OFFICE_BOX.
+
+
+ The MAPI property PR_HOME_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_POST_OFFICE_BOX.
+
+
+ The MAPI property PR_HOME_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_STATE_OR_PROVINCE.
+
+
+ The MAPI property PR_HOME_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_STATE_OR_PROVINCE.
+
+
+ The MAPI property PR_HOME_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_STREET.
+
+
+ The MAPI property PR_HOME_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_STREET.
+
+
+ The MAPI property PR_HOME_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_HOME_FAX_NUMBER.
+
+
+ The MAPI property PR_HOME_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME_FAX_NUMBER.
+
+
+ The MAPI property PR_HOME_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_HOME_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_HOME_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_ICON.
+
+
+ The MAPI property PR_ICON.
+
+
+
+
+ The MAPI property PR_IDENTITY_DISPLAY.
+
+
+ The MAPI property PR_IDENTITY_DISPLAY.
+
+
+
+
+ The MAPI property PR_IDENTITY_DISPLAY.
+
+
+ The MAPI property PR_IDENTITY_DISPLAY.
+
+
+
+
+ The MAPI property PR_IDENTITY_ENTRYID.
+
+
+ The MAPI property PR_IDENTITY_ENTRYID.
+
+
+
+
+ The MAPI property PR_IDENTITY_SEARCH_KEY.
+
+
+ The MAPI property PR_IDENTITY_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IMPLICIT_CONVERSION_PROHIBITED.
+
+
+ The MAPI property PR_IMPLICIT_CONVERSION_PROHIBITED.
+
+
+
+
+ The MAPI property PR_IMPORTANCE.
+
+
+ The MAPI property PR_IMPORTANCE.
+
+
+
+
+ The MAPI property PR_INCOMPLETE_COPY.
+
+
+ The MAPI property PR_INCOMPLETE_COPY.
+
+
+
+
+ The Internet mail override charset.
+
+
+ The Internet mail override charset.
+
+
+
+
+ The Internet mail override format.
+
+
+ The Internet mail override format.
+
+
+
+
+ The MAPI property PR_INITIAL_DETAILS_PANE.
+
+
+ The MAPI property PR_INITIAL_DETAILS_PANE.
+
+
+
+
+ The MAPI property PR_INITIALS.
+
+
+ The MAPI property PR_INITIALS.
+
+
+
+
+ The MAPI property PR_INITIALS.
+
+
+ The MAPI property PR_INITIALS.
+
+
+
+
+ The MAPI property PR_IN_REPLY_TO_ID.
+
+
+ The MAPI property PR_IN_REPLY_TO_ID.
+
+
+
+
+ The MAPI property PR_IN_REPLY_TO_ID.
+
+
+ The MAPI property PR_IN_REPLY_TO_ID.
+
+
+
+
+ The MAPI property PR_INSTANCE_KEY.
+
+
+ The MAPI property PR_INSTANCE_KEY.
+
+
+
+
+ The MAPI property PR_INTERNET_APPROVED.
+
+
+ The MAPI property PR_INTERNET_APPROVED.
+
+
+
+
+ The MAPI property PR_INTERNET_APPROVED.
+
+
+ The MAPI property PR_INTERNET_APPROVED.
+
+
+
+
+ The MAPI property PR_INTERNET_ARTICLE_NUMBER.
+
+
+ The MAPI property PR_INTERNET_ARTICLE_NUMBER.
+
+
+
+
+ The MAPI property PR_INTERNET_CONTROL.
+
+
+ The MAPI property PR_INTERNET_CONTROL.
+
+
+
+
+ The MAPI property PR_INTERNET_CONTROL.
+
+
+ The MAPI property PR_INTERNET_CONTROL.
+
+
+
+
+ The MAPI property PR_INTERNET_CPID.
+
+
+ The MAPI property PR_INTERNET_CPID.
+
+
+
+
+ The MAPI property PR_INTERNET_DISTRIBUTION.
+
+
+ The MAPI property PR_INTERNET_DISTRIBUTION.
+
+
+
+
+ The MAPI property PR_INTERNET_DISTRIBUTION.
+
+
+ The MAPI property PR_INTERNET_DISTRIBUTION.
+
+
+
+
+ The MAPI property PR_INTERNET_FOLLOWUP_TO.
+
+
+ The MAPI property PR_INTERNET_FOLLOWUP_TO.
+
+
+
+
+ The MAPI property PR_INTERNET_FOLLOWUP_TO.
+
+
+ The MAPI property PR_INTERNET_FOLLOWUP_TO.
+
+
+
+
+ The MAPI property PR_INTERNET_LINES.
+
+
+ The MAPI property PR_INTERNET_LINES.
+
+
+
+
+ The MAPI property PR_INTERNET_MESSAGE_ID.
+
+
+ The MAPI property PR_INTERNET_MESSAGE_ID.
+
+
+
+
+ The MAPI property PR_INTERNET_MESSAGE_ID.
+
+
+ The MAPI property PR_INTERNET_MESSAGE_ID.
+
+
+
+
+ The MAPI property PR_INTERNET_NEWSGROUPS.
+
+
+ The MAPI property PR_INTERNET_NEWSGROUPS.
+
+
+
+
+ The MAPI property PR_INTERNET_NEWSGROUPS.
+
+
+ The MAPI property PR_INTERNET_NEWSGROUPS.
+
+
+
+
+ The MAPI property PR_INTERNET_NNTP_PATH.
+
+
+ The MAPI property PR_INTERNET_NNTP_PATH.
+
+
+
+
+ The MAPI property PR_INTERNET_NNTP_PATH.
+
+
+ The MAPI property PR_INTERNET_NNTP_PATH.
+
+
+
+
+ The MAPI property PR_INTERNET_ORGANIZATION.
+
+
+ The MAPI property PR_INTERNET_ORGANIZATION.
+
+
+
+
+ The MAPI property PR_INTERNET_ORGANIZATION.
+
+
+ The MAPI property PR_INTERNET_ORGANIZATION.
+
+
+
+
+ The MAPI property PR_INTERNET_PRECEDENCE.
+
+
+ The MAPI property PR_INTERNET_PRECEDENCE.
+
+
+
+
+ The MAPI property PR_INTERNET_PRECEDENCE.
+
+
+ The MAPI property PR_INTERNET_PRECEDENCE.
+
+
+
+
+ The MAPI property PR_INTERNET_REFERENCES.
+
+
+ The MAPI property PR_INTERNET_REFERENCES.
+
+
+
+
+ The MAPI property PR_INTERNET_REFERENCES.
+
+
+ The MAPI property PR_INTERNET_REFERENCES.
+
+
+
+
+ The MAPI property PR_IPM_ID.
+
+
+ The MAPI property PR_IPM_ID.
+
+
+
+
+ The MAPI property PR_IPM_OUTBOX_ENTRYID.
+
+
+ The MAPI property PR_IPM_OUTBOX_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_OUTBOX_SEARCH_KEY.
+
+
+ The MAPI property PR_IPM_OUTBOX_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IPM_RETURN_REQUESTED.
+
+
+ The MAPI property PR_IPM_RETURN_REQUESTED.
+
+
+
+
+ The MAPI property PR_IPM_SENTMAIL_ENTRYID.
+
+
+ The MAPI property PR_IPM_SENTMAIL_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_SENTMAIL_SEARCH_KEY.
+
+
+ The MAPI property PR_IPM_SENTMAIL_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IPM_SUBTREE_ENTRYID.
+
+
+ The MAPI property PR_IPM_SUBTREE_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_SUBTREE_SEARCH_KEY.
+
+
+ The MAPI property PR_IPM_SUBTREE_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IPM_WASTEBASKET_ENTRYID.
+
+
+ The MAPI property PR_IPM_WASTEBASKET_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_WASTEBASKET_SEARCH_KEY.
+
+
+ The MAPI property PR_IPM_WASTEBASKET_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ISDN_NUMBER.
+
+
+ The MAPI property PR_ISDN_NUMBER.
+
+
+
+
+ The MAPI property PR_ISDN_NUMBER.
+
+
+ The MAPI property PR_ISDN_NUMBER.
+
+
+
+
+ The MAPI property PR_KEYWORD.
+
+
+ The MAPI property PR_KEYWORD.
+
+
+
+
+ The MAPI property PR_KEYWORD.
+
+
+ The MAPI property PR_KEYWORD.
+
+
+
+
+ The MAPI property PR_LANGUAGE.
+
+
+ The MAPI property PR_LANGUAGE.
+
+
+
+
+ The MAPI property PR_LANGUAGE.
+
+
+ The MAPI property PR_LANGUAGE.
+
+
+
+
+ The MAPI property PR_LANGUAGES.
+
+
+ The MAPI property PR_LANGUAGES.
+
+
+
+
+ The MAPI property PR_LANGUAGES.
+
+
+ The MAPI property PR_LANGUAGES.
+
+
+
+
+ The MAPI property PR_LAST_MODIFICATION_TIME.
+
+
+ The MAPI property PR_LAST_MODIFICATION_TIME.
+
+
+
+
+ The MAPI property PR_LATEST_DELIVERY_TIME.
+
+
+ The MAPI property PR_LATEST_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_LIST_HELP.
+
+
+ The MAPI property PR_LIST_HELP.
+
+
+
+
+ The MAPI property PR_LIST_HELP.
+
+
+ The MAPI property PR_LIST_HELP.
+
+
+
+
+ The MAPI property PR_LIST_SUBSCRIBE.
+
+
+ The MAPI property PR_LIST_SUBSCRIBE.
+
+
+
+
+ The MAPI property PR_LIST_SUBSCRIBE.
+
+
+ The MAPI property PR_LIST_SUBSCRIBE.
+
+
+
+
+ The MAPI property PR_LIST_UNSUBSCRIBE.
+
+
+ The MAPI property PR_LIST_UNSUBSCRIBE.
+
+
+
+
+ The MAPI property PR_LIST_UNSUBSCRIBE.
+
+
+ The MAPI property PR_LIST_UNSUBSCRIBE.
+
+
+
+
+ The MAPI property PR_LOCALITY.
+
+
+ The MAPI property PR_LOCALITY.
+
+
+
+
+ The MAPI property PR_LOCALITY.
+
+
+ The MAPI property PR_LOCALITY.
+
+
+
+
+ The MAPI property PR_LOCATION.
+
+
+ The MAPI property PR_LOCATION.
+
+
+
+
+ The MAPI property PR_LOCATION.
+
+
+ The MAPI property PR_LOCATION.
+
+
+
+
+ The MAPI property PR_LOCK_BRANCH_ID.
+
+
+ The MAPI property PR_LOCK_BRANCH_ID.
+
+
+
+
+ The MAPI property PR_LOCK_DEPTH.
+
+
+ The MAPI property PR_LOCK_DEPTH.
+
+
+
+
+ The MAPI property PR_LOCK_ENLISTMENT_CONTEXT.
+
+
+ The MAPI property PR_LOCK_ENLISTMENT_CONTEXT.
+
+
+
+
+ The MAPI property PR_LOCK_EXPIRY_TIME.
+
+
+ The MAPI property PR_LOCK_EXPIRY_TIME.
+
+
+
+
+ The MAPI property PR_LOCK_PERSISTENT.
+
+
+ The MAPI property PR_LOCK_PERSISTENT.
+
+
+
+
+ The MAPI property PR_LOCK_RESOURCE_DID.
+
+
+ The MAPI property PR_LOCK_RESOURCE_DID.
+
+
+
+
+ The MAPI property PR_LOCK_RESOURCE_FID.
+
+
+ The MAPI property PR_LOCK_RESOURCE_FID.
+
+
+
+
+ The MAPI property PR_LOCK_RESOURCE_MID.
+
+
+ The MAPI property PR_LOCK_RESOURCE_MID.
+
+
+
+
+ The MAPI property PR_LOCK_SCOPE.
+
+
+ The MAPI property PR_LOCK_SCOPE.
+
+
+
+
+ The MAPI property PR_LOCK_TIMEOUT.
+
+
+ The MAPI property PR_LOCK_TIMEOUT.
+
+
+
+
+ The MAPI property PR_LOCK_TYPE.
+
+
+ The MAPI property PR_LOCK_TYPE.
+
+
+
+
+ The MAPI property PR_MAIL_PERMISSION.
+
+
+ The MAPI property PR_MAIL_PERMISSION.
+
+
+
+
+ The MAPI property PR_MANAGER_NAME.
+
+
+ The MAPI property PR_MANAGER_NAME.
+
+
+
+
+ The MAPI property PR_MANAGER_NAME.
+
+
+ The MAPI property PR_MANAGER_NAME.
+
+
+
+
+ The MAPI property PR_MAPPING_SIGNATURE.
+
+
+ The MAPI property PR_MAPPING_SIGNATURE.
+
+
+
+
+ The MAPI property PR_MDB_PROVIDER.
+
+
+ The MAPI property PR_MDB_PROVIDER.
+
+
+
+
+ The MAPI property PR_MESSAGE_ATTACHMENTS.
+
+
+ The MAPI property PR_MESSAGE_ATTACHMENTS.
+
+
+
+
+ The MAPI property PR_MESSAGE_CC_ME.
+
+
+ The MAPI property PR_MESSAGE_CC_ME.
+
+
+
+
+ The MAPI property PR_MESSAGE_CLASS.
+
+
+ The MAPI property PR_MESSAGE_CLASS.
+
+
+
+
+ The MAPI property PR_MESSAGE_CLASS.
+
+
+ The MAPI property PR_MESSAGE_CLASS.
+
+
+
+
+ The MAPI property PR_MESSAGE_CODEPAGE.
+
+
+ The MAPI property PR_MESSAGE_CODEPAGE.
+
+
+
+
+ The MAPI property PR_MESSAGE_DELIVERY_ID.
+
+
+ The MAPI property PR_MESSAGE_DELIVERY_ID.
+
+
+
+
+ The MAPI property PR_MESSAGE_DELIVERY_TIME.
+
+
+ The MAPI property PR_MESSAGE_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_MESSAGE_DOWNLOAD_TIME.
+
+
+ The MAPI property PR_MESSAGE_DOWNLOAD_TIME.
+
+
+
+
+ The MAPI property PR_MESSAGE_FLAGS.
+
+
+ The MAPI property PR_MESSAGE_FLAGS.
+
+
+
+
+ The MAPI property PR_MESSAGE_RECIPIENTS.
+
+
+ The MAPI property PR_MESSAGE_RECIPIENTS.
+
+
+
+
+ The MAPI property PR_MESSAGE_RECIP_ME.
+
+
+ The MAPI property PR_MESSAGE_RECIP_ME.
+
+
+
+
+ The MAPI property PR_MESSAGE_SECURITY_LABEL.
+
+
+ The MAPI property PR_MESSAGE_SECURITY_LABEL.
+
+
+
+
+ The MAPI property PR_MESSAGE_SIZE.
+
+
+ The MAPI property PR_MESSAGE_SIZE.
+
+
+
+
+ The MAPI property PR_MESSAGE_SUBMISSION_ID.
+
+
+ The MAPI property PR_MESSAGE_SUBMISSION_ID.
+
+
+
+
+ The MAPI property PR_MESSAGE_TOKEN.
+
+
+ The MAPI property PR_MESSAGE_TOKEN.
+
+
+
+
+ The MAPI property PR_MESSAGE_TO_ME.
+
+
+ The MAPI property PR_MESSAGE_TO_ME.
+
+
+
+
+ The MAPI property PR_MHS_COMMON_NAME.
+
+
+ The MAPI property PR_MHS_COMMON_NAME.
+
+
+
+
+ The MAPI property PR_MHS_COMMON_NAME.
+
+
+ The MAPI property PR_MHS_COMMON_NAME.
+
+
+
+
+ The MAPI property PR_MIDDLE_NAME.
+
+
+ The MAPI property PR_MIDDLE_NAME.
+
+
+
+
+ The MAPI property PR_MIDDLE_NAME.
+
+
+ The MAPI property PR_MIDDLE_NAME.
+
+
+
+
+ The MAPI property PR_MINI_ICON.
+
+
+ The MAPI property PR_MINI_ICON.
+
+
+
+
+ The MAPI property PR_MOBILE_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_MOBILE_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_MOBILE_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_MOBILE_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_MODIFY_VERSION.
+
+
+ The MAPI property PR_MODIFY_VERSION.
+
+
+
+
+ The MAPI property PR_MSG_STATUS.
+
+
+ The MAPI property PR_MSG_STATUS.
+
+
+
+
+ The MAPI property PR_NDR_DIAG_CODE.
+
+
+ The MAPI property PR_NDR_DIAG_CODE.
+
+
+
+
+ The MAPI property PR_NDR_REASON_CODE.
+
+
+ The MAPI property PR_NDR_REASON_CODE.
+
+
+
+
+ The MAPI property PR_NDR_STATUS_CODE.
+
+
+ The MAPI property PR_NDR_STATUS_CODE.
+
+
+
+
+ The MAPI property PR_NEWSGROUP_NAME.
+
+
+ The MAPI property PR_NEWSGROUP_NAME.
+
+
+
+
+ The MAPI property PR_NEWSGROUP_NAME.
+
+
+ The MAPI property PR_NEWSGROUP_NAME.
+
+
+
+
+ The MAPI property PR_NICKNAME.
+
+
+ The MAPI property PR_NICKNAME.
+
+
+
+
+ The MAPI property PR_NICKNAME.
+
+
+ The MAPI property PR_NICKNAME.
+
+
+
+
+ The MAPI property PR_NNTP_XREF.
+
+
+ The MAPI property PR_NNTP_XREF.
+
+
+
+
+ The MAPI property PR_NNTP_XREF.
+
+
+ The MAPI property PR_NNTP_XREF.
+
+
+
+
+ The MAPI property PR_NON_RECEIPT_NOTIFICATION_REQUESTED.
+
+
+ The MAPI property PR_NON_RECEIPT_NOTIFICATION_REQUESTED.
+
+
+
+
+ The MAPI property PR_NON_RECEIPT_REASON.
+
+
+ The MAPI property PR_NON_RECEIPT_REASON.
+
+
+
+
+ The MAPI property PR_NORMALIZED_SUBJECT.
+
+
+ The MAPI property PR_NORMALIZED_SUBJECT.
+
+
+
+
+ The MAPI property PR_NORMALIZED_SUBJECT.
+
+
+ The MAPI property PR_NORMALIZED_SUBJECT.
+
+
+
+
+ The MAPI property PR_NT_SECURITY_DESCRIPTOR.
+
+
+ The MAPI property PR_NT_SECURITY_DESCRIPTOR.
+
+
+
+
+ The MAPI property PR_NULL.
+
+
+ The MAPI property PR_NULL.
+
+
+
+
+ The MAPI property PR_OBJECT_TYPE.
+
+
+ The MAPI property PR_OBJECT_TYPE.
+
+
+
+
+ The MAPI property PR_OBSOLETE_IPMS.
+
+
+ The MAPI property PR_OBSOLETE_IPMS.
+
+
+
+
+ The MAPI property PR_OFFICE2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_OFFICE2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OFFICE2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_OFFICE2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OFFICE_LOCATION.
+
+
+ The MAPI property PR_OFFICE_LOCATION.
+
+
+
+
+ The MAPI property PR_OFFICE_LOCATION.
+
+
+ The MAPI property PR_OFFICE_LOCATION.
+
+
+
+
+ The MAPI property PR_OFFICE_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_OFFICE_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OFFICE_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_OFFICE_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OOF_REPLY_TYPE.
+
+
+ The MAPI property PR_OOF_REPLY_TYPE.
+
+
+
+
+ The MAPI property PR_ORGANIZATIONAL_ID_NUMBER.
+
+
+ The MAPI property PR_ORGANIZATIONAL_ID_NUMBER.
+
+
+
+
+ The MAPI property PR_ORGANIZATIONAL_ID_NUMBER.
+
+
+ The MAPI property PR_ORGANIZATIONAL_ID_NUMBER.
+
+
+
+
+ The MAPI property PR_ORIG_ENTRYID.
+
+
+ The MAPI property PR_ORIG_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ENTRYID.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_NAME.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_NAME.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_SEARCH_KEY.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DELIVERY_TIME.
+
+
+ The MAPI property PR_ORIGINAL_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_BCC.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_BCC.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_BCC.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_BCC.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_CC.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_CC.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_CC.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_CC.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_NAME.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_NAME.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_TO.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_TO.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_TO.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_TO.
+
+
+
+
+ The MAPI property PR_ORIGINAL_EITS.
+
+
+ The MAPI property PR_ORIGINAL_EITS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_ENTRYID.
+
+
+ The MAPI property PR_ORIGINAL_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ENTRYID.
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIPIENT_NAME.
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIPIENT_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SEARCH_KEY.
+
+
+ The MAPI property PR_ORIGINAL_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ENTRYID.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_NAME.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_NAME.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_SEARCH_KEY.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENSITIVITY.
+
+
+ The MAPI property PR_ORIGINAL_SENSITIVITY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ENTRYID.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_NAME.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_NAME.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_SEARCH_KEY.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SUBJECT.
+
+
+ The MAPI property PR_ORIGINAL_SUBJECT.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SUBJECT.
+
+
+ The MAPI property PR_ORIGINAL_SUBJECT.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SUBMIT_TIME.
+
+
+ The MAPI property PR_ORIGINAL_SUBMIT_TIME.
+
+
+
+
+ The MAPI property PR_ORIGINATING_MTA_CERTIFICATE.
+
+
+ The MAPI property PR_ORIGINATING_MTA_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_AND_DL_EXPANSION_HISTORY.
+
+
+ The MAPI property PR_ORIGINATOR_AND_DL_EXPANSION_HISTORY.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_CERTIFICATE.
+
+
+ The MAPI property PR_ORIGINATOR_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_DELIVERY_REPORT_REQUESTED.
+
+
+ The MAPI property PR_ORIGINATOR_DELIVERY_REPORT_REQUESTED.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_NON_DELIVERY_REPORT_REQUESTED.
+
+
+ The MAPI property PR_ORIGINATOR_NON_DELIVERY_REPORT_REQUESTED.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_REQUESTED_ALTERNATE_RECIPIENT.
+
+
+ The MAPI property PR_ORIGINATOR_REQUESTED_ALTERNATE_RECIPIENT.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_RETURN_ADDRESS.
+
+
+ The MAPI property PR_ORIGINATOR_RETURN_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGIN_CHECK.
+
+
+ The MAPI property PR_ORIGIN_CHECK.
+
+
+
+
+ The MAPI property PR_ORIG_MESSAGE_CLASS.
+
+
+ The MAPI property PR_ORIG_MESSAGE_CLASS.
+
+
+
+
+ The MAPI property PR_ORIG_MESSAGE_CLASS.
+
+
+ The MAPI property PR_ORIG_MESSAGE_CLASS.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_CITY.
+
+
+ The MAPI property PR_OTHER_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_CITY.
+
+
+ The MAPI property PR_OTHER_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_COUNTRY.
+
+
+ The MAPI property PR_OTHER_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_COUNTRY.
+
+
+ The MAPI property PR_OTHER_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_POSTAL_CODE.
+
+
+ The MAPI property PR_OTHER_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_POSTAL_CODE.
+
+
+ The MAPI property PR_OTHER_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_POST_OFFICE_BOX.
+
+
+ The MAPI property PR_OTHER_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_POST_OFFICE_BOX.
+
+
+ The MAPI property PR_OTHER_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_STATE_OR_PROVINCE.
+
+
+ The MAPI property PR_OTHER_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_STATE_OR_PROVINCE.
+
+
+ The MAPI property PR_OTHER_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_STREET.
+
+
+ The MAPI property PR_OTHER_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_STREET.
+
+
+ The MAPI property PR_OTHER_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_OTHER_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_OTHER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OTHER_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_OTHER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OWNER_APPT_ID.
+
+
+ The MAPI property PR_OWNER_APPT_ID.
+
+
+
+
+ The MAPI property PR_OWN_STORE_ENTRYID.
+
+
+ The MAPI property PR_OWN_STORE_ENTRYID.
+
+
+
+
+ The MAPI property PR_PAGER_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_PAGER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_PAGER_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_PAGER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_PARENT_DISPLAY.
+
+
+ The MAPI property PR_PARENT_DISPLAY.
+
+
+
+
+ The MAPI property PR_PARENT_DISPLAY.
+
+
+ The MAPI property PR_PARENT_DISPLAY.
+
+
+
+
+ The MAPI property PR_PARENT_ENTRYID.
+
+
+ The MAPI property PR_PARENT_ENTRYID.
+
+
+
+
+ The MAPI property PR_PARENT_KEY.
+
+
+ The MAPI property PR_PARENT_KEY.
+
+
+
+
+ The MAPI property PR_PERSONAL_HOME_PAGE.
+
+
+ The MAPI property PR_PERSONAL_HOME_PAGE.
+
+
+
+
+ The MAPI property PR_PERSONAL_HOME_PAGE.
+
+
+ The MAPI property PR_PERSONAL_HOME_PAGE.
+
+
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_BUREAU_FAX_DELIVERY.
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_BUREAU_FAX_DELIVERY.
+
+
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_MODE.
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_MODE.
+
+
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_REPORT_REQUEST.
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_REPORT_REQUEST.
+
+
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_ADDRESS.
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_ADDRESS.
+
+
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_ADDRESS_REQUESTED.
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_ADDRESS_REQUESTED.
+
+
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_PROHIBITED.
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_PROHIBITED.
+
+
+
+
+ The MAPI property PR_PHYSICAL_RENDITION_ATTRIBUTES.
+
+
+ The MAPI property PR_PHYSICAL_RENDITION_ATTRIBUTES.
+
+
+
+
+ The MAPI property PR_POSTAL_ADDRESS.
+
+
+ The MAPI property PR_POSTAL_ADDRESS.
+
+
+
+
+ The MAPI property PR_POSTAL_ADDRESS.
+
+
+ The MAPI property PR_POSTAL_ADDRESS.
+
+
+
+
+ The MAPI property PR_POSTAL_CODE.
+
+
+ The MAPI property PR_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_POSTAL_CODE.
+
+
+ The MAPI property PR_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_POST_FOLDER_ENTRIES.
+
+
+ The MAPI property PR_POST_FOLDER_ENTRIES.
+
+
+
+
+ The MAPI property PR_POST_FOLDER_NAMES.
+
+
+ The MAPI property PR_POST_FOLDER_NAMES.
+
+
+
+
+ The MAPI property PR_POST_FOLDER_NAMES.
+
+
+ The MAPI property PR_POST_FOLDER_NAMES.
+
+
+
+
+ The MAPI property PR_POST_OFFICE_BOX.
+
+
+ The MAPI property PR_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_POST_OFFICE_BOX.
+
+
+ The MAPI property PR_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_POST_REPLY_DENIED.
+
+
+ The MAPI property PR_POST_REPLY_DENIED.
+
+
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_ENTRIES.
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_ENTRIES.
+
+
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_NAMES.
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_NAMES.
+
+
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_NAMES.
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_NAMES.
+
+
+
+
+ The MAPI property PR_PREFERRED_BY_NAME.
+
+
+ The MAPI property PR_PREFERRED_BY_NAME.
+
+
+
+
+ The MAPI property PR_PREFERRED_BY_NAME.
+
+
+ The MAPI property PR_PREFERRED_BY_NAME.
+
+
+
+
+ The MAPI property PR_PREPROCESS.
+
+
+ The MAPI property PR_PREPROCESS.
+
+
+
+
+ The MAPI property PR_PRIMARY_CAPABILITY.
+
+
+ The MAPI property PR_PRIMARY_CAPABILITY.
+
+
+
+
+ The MAPI property PR_PRIMARY_FAX_NUMBER.
+
+
+ The MAPI property PR_PRIMARY_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_PRIMARY_FAX_NUMBER.
+
+
+ The MAPI property PR_PRIMARY_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_PRIMARY_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_PRIMARY_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_PRIMARY_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_PRIMARY_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_PRIORITY.
+
+
+ The MAPI property PR_PRIORITY.
+
+
+
+
+ The MAPI property PR_PROFESSION.
+
+
+ The MAPI property PR_PROFESSION.
+
+
+
+
+ The MAPI property PR_PROFESSION.
+
+
+ The MAPI property PR_PROFESSION.
+
+
+
+
+ The MAPI property PR_PROFILE_NAME.
+
+
+ The MAPI property PR_PROFILE_NAME.
+
+
+
+
+ The MAPI property PR_PROFILE_NAME.
+
+
+ The MAPI property PR_PROFILE_NAME.
+
+
+
+
+ The MAPI property PR_PROOF_OF_DELIVERY.
+
+
+ The MAPI property PR_PROOF_OF_DELIVERY.
+
+
+
+
+ The MAPI property PR_PROOF_OF_DELIVERY_REQUESTED.
+
+
+ The MAPI property PR_PROOF_OF_DELIVERY_REQUESTED.
+
+
+
+
+ The MAPI property PR_PROOF_OF_SUBMISSION.
+
+
+ The MAPI property PR_PROOF_OF_SUBMISSION.
+
+
+
+
+ The MAPI property PR_PROOF_OF_SUBMISSION_REQUESTED.
+
+
+ The MAPI property PR_PROOF_OF_SUBMISSION_REQUESTED.
+
+
+
+
+ The MAPI property PR_PROVIDER_DISPLAY.
+
+
+ The MAPI property PR_PROVIDER_DISPLAY.
+
+
+
+
+ The MAPI property PR_PROVIDER_DISPLAY.
+
+
+ The MAPI property PR_PROVIDER_DISPLAY.
+
+
+
+
+ The MAPI property PR_PROVIDER_DLL_NAME.
+
+
+ The MAPI property PR_PROVIDER_DLL_NAME.
+
+
+
+
+ The MAPI property PR_PROVIDER_DLL_NAME.
+
+
+ The MAPI property PR_PROVIDER_DLL_NAME.
+
+
+
+
+ The MAPI property PR_PROVIDER_ORDINAL.
+
+
+ The MAPI property PR_PROVIDER_ORDINAL.
+
+
+
+
+ The MAPI property PR_PROVIDER_SUBMIT_TIME.
+
+
+ The MAPI property PR_PROVIDER_SUBMIT_TIME.
+
+
+
+
+ The MAPI property PR_PROVIDER_UID.
+
+
+ The MAPI property PR_PROVIDER_UID.
+
+
+
+
+ The MAPI property PR_PUID.
+
+
+ The MAPI property PR_PUID.
+
+
+
+
+ The MAPI property PR_RADIO_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_RADIO_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_RADIO_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_RADIO_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ADDRTYPE.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ADDRTYPE.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ENTRYID.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ENTRYID.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_NAME.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_NAME.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_SEARCH_KEY.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_READ_RECEIPT_ENTRYID.
+
+
+ The MAPI property PR_READ_RECEIPT_ENTRYID.
+
+
+
+
+ The MAPI property PR_READ_RECEIPT_REQUESTED.
+
+
+ The MAPI property PR_READ_RECEIPT_REQUESTED.
+
+
+
+
+ The MAPI property PR_READ_RECEIPT_SEARCH_KEY.
+
+
+ The MAPI property PR_READ_RECEIPT_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_RECEIPT_TIME.
+
+
+ The MAPI property PR_RECEIPT_TIME.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_ADDRTYPE.
+
+
+ The MAPI property PR_RECEIVED_BY_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_ADDRTYPE.
+
+
+ The MAPI property PR_RECEIVED_BY_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_RECEIVED_BY_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_RECEIVED_BY_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_ENTRYID.
+
+
+ The MAPI property PR_RECEIVED_BY_ENTRYID.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_NAME.
+
+
+ The MAPI property PR_RECEIVED_BY_NAME.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_NAME.
+
+
+ The MAPI property PR_RECEIVED_BY_NAME.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_SEARCH_KEY.
+
+
+ The MAPI property PR_RECEIVED_BY_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_RECEIVE_FOLDER_SETTINGS.
+
+
+ The MAPI property PR_RECEIVE_FOLDER_SETTINGS.
+
+
+
+
+ The MAPI property PR_RECIPIENT_CERTIFICATE.
+
+
+ The MAPI property PR_RECIPIENT_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_RECIPIENT_NUMBER_FOR_ADVICE.
+
+
+ The MAPI property PR_RECIPIENT_NUMBER_FOR_ADVICE.
+
+
+
+
+ The MAPI property PR_RECIPIENT_NUMBER_FOR_ADVICE.
+
+
+ The MAPI property PR_RECIPIENT_NUMBER_FOR_ADVICE.
+
+
+
+
+ The MAPI property PR_RECIPIENT_REASSIGNMENT_PROHIBITED.
+
+
+ The MAPI property PR_RECIPIENT_REASSIGNMENT_PROHIBITED.
+
+
+
+
+ The MAPI property PR_RECIPIENT_STATUS.
+
+
+ The MAPI property PR_RECIPIENT_STATUS.
+
+
+
+
+ The MAPI property PR_RECIPIENT_TYPE.
+
+
+ The MAPI property PR_RECIPIENT_TYPE.
+
+
+
+
+ The MAPI property PR_REDIRECTION_HISTORY.
+
+
+ The MAPI property PR_REDIRECTION_HISTORY.
+
+
+
+
+ The MAPI property PR_REFERRED_BY_NAME.
+
+
+ The MAPI property PR_REFERRED_BY_NAME.
+
+
+
+
+ The MAPI property PR_REFERRED_BY_NAME.
+
+
+ The MAPI property PR_REFERRED_BY_NAME.
+
+
+
+
+ The MAPI property PR_REGISTERED_MAIL_TYPE.
+
+
+ The MAPI property PR_REGISTERED_MAIL_TYPE.
+
+
+
+
+ The MAPI property PR_RELATED_IPMS.
+
+
+ The MAPI property PR_RELATED_IPMS.
+
+
+
+
+ The MAPI property PR_REMOTE_PROGRESS.
+
+
+ The MAPI property PR_REMOTE_PROGRESS.
+
+
+
+
+ The MAPI property PR_REMOTE_PROGRESS_TEXT.
+
+
+ The MAPI property PR_REMOTE_PROGRESS_TEXT.
+
+
+
+
+ The MAPI property PR_REMOTE_PROGRESS_TEXT.
+
+
+ The MAPI property PR_REMOTE_PROGRESS_TEXT.
+
+
+
+
+ The MAPI property PR_REMOTE_VALIDATE_OK.
+
+
+ The MAPI property PR_REMOTE_VALIDATE_OK.
+
+
+
+
+ The MAPI property PR_RENDERING_POSITION.
+
+
+ The MAPI property PR_RENDERING_POSITION.
+
+
+
+
+ The MAPI property PR_REPLY_RECIPIENT_ENTRIES.
+
+
+ The MAPI property PR_REPLY_RECIPIENT_ENTRIES.
+
+
+
+
+ The MAPI property PR_REPLY_RECIPIENT_NAMES.
+
+
+ The MAPI property PR_REPLY_RECIPIENT_NAMES.
+
+
+
+
+ The MAPI property PR_REPLY_RECIPIENT_NAMES.
+
+
+ The MAPI property PR_REPLY_RECIPIENT_NAMES.
+
+
+
+
+ The MAPI property PR_REPLY_REQUESTED.
+
+
+ The MAPI property PR_REPLY_REQUESTED.
+
+
+
+
+ The MAPI property PR_REPLY_TIME.
+
+
+ The MAPI property PR_REPLY_TIME.
+
+
+
+
+ The MAPI property PR_REPORT_ENTRYID.
+
+
+ The MAPI property PR_REPORT_ENTRYID.
+
+
+
+
+ The MAPI property PR_REPORTING_DL_NAME.
+
+
+ The MAPI property PR_REPORTING_DL_NAME.
+
+
+
+
+ The MAPI property PR_REPORTING_MTA_CERTIFICATE.
+
+
+ The MAPI property PR_REPORTING_MTA_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_REPORT_NAME.
+
+
+ The MAPI property PR_REPORT_NAME.
+
+
+
+
+ The MAPI property PR_REPORT_NAME.
+
+
+ The MAPI property PR_REPORT_NAME.
+
+
+
+
+ The MAPI property PR_REPORT_SEARCH_KEY.
+
+
+ The MAPI property PR_REPORT_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_REPORT_TAG.
+
+
+ The MAPI property PR_REPORT_TAG.
+
+
+
+
+ The MAPI property PR_REPORT_TEXT.
+
+
+ The MAPI property PR_REPORT_TEXT.
+
+
+
+
+ The MAPI property PR_REPORT_TEXT.
+
+
+ The MAPI property PR_REPORT_TEXT.
+
+
+
+
+ The MAPI property PR_REPORT_TIME.
+
+
+ The MAPI property PR_REPORT_TIME.
+
+
+
+
+ The MAPI property PR_REQUESTED_DELIVERY_METHOD.
+
+
+ The MAPI property PR_REQUESTED_DELIVERY_METHOD.
+
+
+
+
+ The MAPI property PR_RESOURCE_FLAGS.
+
+
+ The MAPI property PR_RESOURCE_FLAGS.
+
+
+
+
+ The MAPI property PR_RESOURCE_METHODS.
+
+
+ The MAPI property PR_RESOURCE_METHODS.
+
+
+
+
+ The MAPI property PR_RESOURCE_PATH.
+
+
+ The MAPI property PR_RESOURCE_PATH.
+
+
+
+
+ The MAPI property PR_RESOURCE_PATH.
+
+
+ The MAPI property PR_RESOURCE_PATH.
+
+
+
+
+ The MAPI property PR_RESOURCE_TYPE.
+
+
+ The MAPI property PR_RESOURCE_TYPE.
+
+
+
+
+ The MAPI property PR_RESPONSE_REQUESTED.
+
+
+ The MAPI property PR_RESPONSE_REQUESTED.
+
+
+
+
+ The MAPI property PR_RESPONSIBILITY.
+
+
+ The MAPI property PR_RESPONSIBILITY.
+
+
+
+
+ The MAPI property PR_RETURNED_IPM.
+
+
+ The MAPI property PR_RETURNED_IPM.
+
+
+
+
+ The MAPI property PR_ROWID.
+
+
+ The MAPI property PR_ROWID.
+
+
+
+
+ The MAPI property PR_ROW_TYPE.
+
+
+ The MAPI property PR_ROW_TYPE.
+
+
+
+
+ The MAPI property PR_RTF_COMPRESSED.
+
+
+ The MAPI property PR_RTF_COMPRESSED.
+
+
+
+
+ The MAPI property PR_RTF_IN_SYNC.
+
+
+ The MAPI property PR_RTF_IN_SYNC.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_BODY_COUNT.
+
+
+ The MAPI property PR_RTF_SYNC_BODY_COUNT.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_BODY_CRC.
+
+
+ The MAPI property PR_RTF_SYNC_BODY_CRC.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_BODY_TAG.
+
+
+ The MAPI property PR_RTF_SYNC_BODY_TAG.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_BODY_TAG.
+
+
+ The MAPI property PR_RTF_SYNC_BODY_TAG.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_PREFIX_COUNT.
+
+
+ The MAPI property PR_RTF_SYNC_PREFIX_COUNT.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_TRAILING_COUNT.
+
+
+ The MAPI property PR_RTF_SYNC_TRAILING_COUNT.
+
+
+
+
+ The MAPI property PR_SEARCH.
+
+
+ The MAPI property PR_SEARCH.
+
+
+
+
+ The MAPI property PR_SEARCH_KEY.
+
+
+ The MAPI property PR_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_SECURITY.
+
+
+ The MAPI property PR_SECURITY.
+
+
+
+
+ The MAPI property PR_SELECTABLE.
+
+
+ The MAPI property PR_SELECTABLE.
+
+
+
+
+ The MAPI property PR_SENDER_ADDRTYPE.
+
+
+ The MAPI property PR_SENDER_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_SENDER_ADDRTYPE.
+
+
+ The MAPI property PR_SENDER_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_SENDER_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_SENDER_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_SENDER_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_SENDER_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_SENDER_ENTRYID.
+
+
+ The MAPI property PR_SENDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_SENDER_NAME.
+
+
+ The MAPI property PR_SENDER_NAME.
+
+
+
+
+ The MAPI property PR_SENDER_NAME.
+
+
+ The MAPI property PR_SENDER_NAME.
+
+
+
+
+ The MAPI property PR_SENDER_SEARCH_KEY.
+
+
+ The MAPI property PR_SENDER_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_SEND_INTERNET_ENCODING.
+
+
+ The MAPI property PR_SEND_INTERNET_ENCODING.
+
+
+
+
+ The MAPI property PR_SEND_RECALL_REPORT
+
+
+ The MAPI property PR_SEND_RECALL_REPORT.
+
+
+
+
+ The MAPI property PR_SEND_RICH_INFO.
+
+
+ The MAPI property PR_SEND_RICH_INFO.
+
+
+
+
+ The MAPI property PR_SENSITIVITY.
+
+
+ The MAPI property PR_SENSITIVITY.
+
+
+
+
+ The MAPI property PR_SENTMAIL_ENTRYID.
+
+
+ The MAPI property PR_SENTMAIL_ENTRYID.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_ADDRTYPE.
+
+
+ The MAPI property PR_SENT_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_ADDRTYPE.
+
+
+ The MAPI property PR_SENT_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_ENTRYID.
+
+
+ The MAPI property PR_SENT_REPRESENTING_ENTRYID.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_NAME.
+
+
+ The MAPI property PR_SENT_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_NAME.
+
+
+ The MAPI property PR_SENT_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_SEARCH_KEY.
+
+
+ The MAPI property PR_SENT_REPRESENTING_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_SERVICE_DELETE_FILES.
+
+
+ The MAPI property PR_SERVICE_DELETE_FILES.
+
+
+
+
+ The MAPI property PR_SERVICE_DELETE_FILES.
+
+
+ The MAPI property PR_SERVICE_DELETE_FILES.
+
+
+
+
+ The MAPI property PR_SERVICE_DLL_NAME.
+
+
+ The MAPI property PR_SERVICE_DLL_NAME.
+
+
+
+
+ The MAPI property PR_SERVICE_DLL_NAME.
+
+
+ The MAPI property PR_SERVICE_DLL_NAME.
+
+
+
+
+ The MAPI property PR_SERVICE_ENTRY_NAME.
+
+
+ The MAPI property PR_SERVICE_ENTRY_NAME.
+
+
+
+
+ The MAPI property PR_SERVICE_EXTRA_UIDS.
+
+
+ The MAPI property PR_SERVICE_EXTRA_UIDS.
+
+
+
+
+ The MAPI property PR_SERVICE_NAME.
+
+
+ The MAPI property PR_SERVICE_NAME.
+
+
+
+
+ The MAPI property PR_SERVICE_NAME.
+
+
+ The MAPI property PR_SERVICE_NAME.
+
+
+
+
+ The MAPI property PR_SERVICES.
+
+
+ The MAPI property PR_SERVICES.
+
+
+
+
+ The MAPI property PR_SERVICE_SUPPORT_FILES.
+
+
+ The MAPI property PR_SERVICE_SUPPORT_FILES.
+
+
+
+
+ The MAPI property PR_SERVICE_SUPPORT_FILES.
+
+
+ The MAPI property PR_SERVICE_SUPPORT_FILES.
+
+
+
+
+ The MAPI property PR_SERVICE_UID.
+
+
+ The MAPI property PR_SERVICE_UID.
+
+
+
+
+ The MAPI property PR_SEVEN_BIT_DISPLAY_NAME.
+
+
+ The MAPI property PR_SEVEN_BIT_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_SMTP_ADDRESS.
+
+
+ The MAPI property PR_SMTP_ADDRESS.
+
+
+
+
+ The MAPI property PR_SMTP_ADDRESS.
+
+
+ The MAPI property PR_SMTP_ADDRESS.
+
+
+
+
+ The MAPI property PR_SPOOLER_STATUS.
+
+
+ The MAPI property PR_SPOOLER_STATUS.
+
+
+
+
+ The MAPI property PR_SPOUSE_NAME.
+
+
+ The MAPI property PR_SPOUSE_NAME.
+
+
+
+
+ The MAPI property PR_SPOUSE_NAME.
+
+
+ The MAPI property PR_SPOUSE_NAME.
+
+
+
+
+ The MAPI property PR_START_DATE.
+
+
+ The MAPI property PR_START_DATE.
+
+
+
+
+ The MAPI property PR_STATE_OR_PROVINCE.
+
+
+ The MAPI property PR_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_STATE_OR_PROVINCE.
+
+
+ The MAPI property PR_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_STATUS.
+
+
+ The MAPI property PR_STATUS.
+
+
+
+
+ The MAPI property PR_STATUS_CODE.
+
+
+ The MAPI property PR_STATUS_CODE.
+
+
+
+
+ The MAPI property PR_STATUS_STRING.
+
+
+ The MAPI property PR_STATUS_STRING.
+
+
+
+
+ The MAPI property PR_STATUS_STRING.
+
+
+ The MAPI property PR_STATUS_STRING.
+
+
+
+
+ The MAPI property PR_STORE_ENTRYID.
+
+
+ The MAPI property PR_STORE_ENTRYID.
+
+
+
+
+ The MAPI property PR_STORE_PROVIDERS.
+
+
+ The MAPI property PR_STORE_PROVIDERS.
+
+
+
+
+ The MAPI property PR_STORE_RECORD_KEY.
+
+
+ The MAPI property PR_STORE_RECORD_KEY.
+
+
+
+
+ The MAPI property PR_STORE_STATE.
+
+
+ The MAPI property PR_STORE_STATE.
+
+
+
+
+ The MAPI property PR_STORE_SUPPORT_MASK.
+
+
+ The MAPI property PR_STORE_SUPPORT_MASK.
+
+
+
+
+ The MAPI property PR_STREET_ADDRESS.
+
+
+ The MAPI property PR_STREET_ADDRESS.
+
+
+
+
+ The MAPI property PR_STREET_ADDRESS.
+
+
+ The MAPI property PR_STREET_ADDRESS.
+
+
+
+
+ The MAPI property PR_SUBFOLDERS.
+
+
+ The MAPI property PR_SUBFOLDERS.
+
+
+
+
+ The MAPI property PR_SUBJECT.
+
+
+ The MAPI property PR_SUBJECT.
+
+
+
+
+ The MAPI property PR_SUBJECT.
+
+
+ The MAPI property PR_SUBJECT.
+
+
+
+
+ The MAPI property PR_SUBJECT_IPM.
+
+
+ The MAPI property PR_SUBJECT_IPM.
+
+
+
+
+ The MAPI property PR_SUBJECT_PREFIX.
+
+
+ The MAPI property PR_SUBJECT_PREFIX.
+
+
+
+
+ The MAPI property PR_SUBJECT_PREFIX.
+
+
+ The MAPI property PR_SUBJECT_PREFIX.
+
+
+
+
+ The MAPI property PR_SUBMIT_FLAGS.
+
+
+ The MAPI property PR_SUBMIT_FLAGS.
+
+
+
+
+ The MAPI property PR_SUPERSEDES.
+
+
+ The MAPI property PR_SUPERSEDES.
+
+
+
+
+ The MAPI property PR_SUPERSEDES.
+
+
+ The MAPI property PR_SUPERSEDES.
+
+
+
+
+ The MAPI property PR_SUPPLEMENTARY_INFO.
+
+
+ The MAPI property PR_SUPPLEMENTARY_INFO.
+
+
+
+
+ The MAPI property PR_SUPPLEMENTARY_INFO.
+
+
+ The MAPI property PR_SUPPLEMENTARY_INFO.
+
+
+
+
+ The MAPI property PR_SURNAME.
+
+
+ The MAPI property PR_SURNAME.
+
+
+
+
+ The MAPI property PR_SURNAME.
+
+
+ The MAPI property PR_SURNAME.
+
+
+
+
+ The MAPI property PR_TELEX_NUMBER.
+
+
+ The MAPI property PR_TELEX_NUMBER.
+
+
+
+
+ The MAPI property PR_TELEX_NUMBER.
+
+
+ The MAPI property PR_TELEX_NUMBER.
+
+
+
+
+ The MAPI property PR_TEMPLATEID.
+
+
+ The MAPI property PR_TEMPLATEID.
+
+
+
+
+ The MAPI property PR_TITLE.
+
+
+ The MAPI property PR_TITLE.
+
+
+
+
+ The MAPI property PR_TITLE.
+
+
+ The MAPI property PR_TITLE.
+
+
+
+
+ The MAPI property PR_TNEF_CORRELATION_KEY.
+
+
+ The MAPI property PR_TNEF_CORRELATION_KEY.
+
+
+
+
+ The MAPI property PR_TRANSMITABLE_DISPLAY_NAME.
+
+
+ The MAPI property PR_TRANSMITABLE_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_TRANSMITABLE_DISPLAY_NAME.
+
+
+ The MAPI property PR_TRANSMITABLE_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_TRANSPORT_KEY.
+
+
+ The MAPI property PR_TRANSPORT_KEY.
+
+
+
+
+ The MAPI property PR_TRANSPORT_MESSAGE_HEADERS.
+
+
+ The MAPI property PR_TRANSPORT_MESSAGE_HEADERS.
+
+
+
+
+ The MAPI property PR_TRANSPORT_MESSAGE_HEADERS.
+
+
+ The MAPI property PR_TRANSPORT_MESSAGE_HEADERS.
+
+
+
+
+ The MAPI property PR_TRANSPORT_PROVIDERS.
+
+
+ The MAPI property PR_TRANSPORT_PROVIDERS.
+
+
+
+
+ The MAPI property PR_TRANSPORT_STATUS.
+
+
+ The MAPI property PR_TRANSPORT_STATUS.
+
+
+
+
+ The MAPI property PR_TTYDD_PHONE_NUMBER.
+
+
+ The MAPI property PR_TTYDD_PHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_TTYDD_PHONE_NUMBER.
+
+
+ The MAPI property PR_TTYDD_PHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_TYPE_OF_MTS_USER.
+
+
+ The MAPI property PR_TYPE_OF_MTS_USER.
+
+
+
+
+ The MAPI property PR_USER_CERTIFICATE.
+
+
+ The MAPI property PR_USER_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_USER_X509_CERTIFICATE.
+
+
+ The MAPI property PR_USER_X509_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_VALID_FOLDER_MASK.
+
+
+ The MAPI property PR_VALID_FOLDER_MASK.
+
+
+
+
+ The MAPI property PR_VIEWS_ENTRYID.
+
+
+ The MAPI property PR_VIEWS_ENTRYID.
+
+
+
+
+ The MAPI property PR_WEDDING_ANNIVERSARY.
+
+
+ The MAPI property PR_WEDDING_ANNIVERSARY.
+
+
+
+
+ The MAPI property PR_X400_CONTENT_TYPE.
+
+
+ The MAPI property PR_X400_CONTENT_TYPE.
+
+
+
+
+ The MAPI property PR_X400_DEFERRED_DELIVERY_CANCEL.
+
+
+ The MAPI property PR_X400_DEFERRED_DELIVERY_CANCEL.
+
+
+
+
+ The MAPI property PR_XPOS.
+
+
+ The MAPI property PR_XPOS.
+
+
+
+
+ The MAPI property PR_YPOS.
+
+
+ The MAPI property PR_YPOS.
+
+
+
+
+ Gets the property identifier.
+
+
+ Gets the property identifier.
+
+ The identifier.
+
+
+
+ Gets a value indicating whether or not the property contains multiple values.
+
+
+ Gets a value indicating whether or not the property contains multiple values.
+
+ true if the property contains multiple values; otherwise, false.
+
+
+
+ Gets a value indicating whether or not the property has a special name.
+
+
+ Gets a value indicating whether or not the property has a special name.
+
+ true if the property has a special name; otherwise, false.
+
+
+
+ Gets a value indicating whether the property value type is valid.
+
+
+ Gets a value indicating whether the property value type is valid.
+
+ true if the property value type is valid; otherwise, false.
+
+
+
+ Gets the property's value type (including the multi-valued bit).
+
+
+ Gets the property's value type (including the multi-valued bit).
+
+ The property's value type.
+
+
+
+ Gets the type of the value that the property contains.
+
+
+ Gets the type of the value that the property contains.
+
+ The type of the value.
+
+
+
+ Initializes a new instance of the struct.
+
+
+ Creates a new based on a 32-bit integer tag as read from
+ a TNEF stream.
+
+ The property tag.
+
+
+
+ Initializes a new instance of the struct.
+
+
+ Creates a new based on a
+ and .
+
+ The property identifier.
+ The property type.
+
+
+
+ Casts an integer tag value into a TNEF property tag.
+
+
+ Casts an integer tag value into a TNEF property tag.
+
+ A that represents the integer tag value.
+ The integer tag value.
+
+
+
+ Casts a TNEF property tag into a 32-bit integer value.
+
+
+ Casts a TNEF property tag into a 32-bit integer value.
+
+ A 32-bit integer value representing the TNEF property tag.
+ The TNEF property tag.
+
+
+
+ Serves as a hash function for a object.
+
+
+ Serves as a hash function for a object.
+
+ A hash code for this instance that is suitable for use in hashing algorithms
+ and data structures such as a hash table.
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Determines whether the specified is equal to the current .
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ Returns a that represents the current .
+
+
+ Returns a that represents the current .
+
+ A that represents the current .
+
+
+
+ Returns a new where the type has been changed to .
+
+
+ Returns a new where the type has been changed to .
+
+ The unicode equivalent of the property tag.
+
+
+
+ The type of value that a TNEF property contains.
+
+
+ The type of value that a TNEF property contains.
+
+
+
+
+ The type of the property is unspecified.
+
+
+
+
+ The property has a null value.
+
+
+
+
+ The property has a signed 16-bit value.
+
+
+
+
+ The property has a signed 32-bit value.
+
+
+
+
+ THe property has a 32-bit floating point value.
+
+
+
+
+ The property has a 64-bit floating point value.
+
+
+
+
+ The property has a 64-bit integer value representing 1/10000th of a monetary unit (i.e., 1/100th of a cent).
+
+
+
+
+ The property has a 64-bit integer value specifying the number of 100ns periods since Jan 1, 1601.
+
+
+
+
+ The property has a 32-bit error value.
+
+
+
+
+ The property has a boolean value.
+
+
+
+
+ The property has an embedded object value.
+
+
+
+
+ The property has a signed 64-bit value.
+
+
+
+
+ The property has a null-terminated 8-bit character string value.
+
+
+
+
+ The property has a null-terminated unicode character string value.
+
+
+
+
+ The property has a 64-bit integer value specifying the number of 100ns periods since Jan 1, 1601.
+
+
+
+
+ The property has an OLE GUID value.
+
+
+
+
+ The property has a binary blob value.
+
+
+
+
+ A flag indicating that the property contains multiple values.
+
+
+
+
+ A TNEF reader.
+
+
+ A TNEF reader.
+
+
+
+
+ Gets the attachment key value.
+
+
+ Gets the attachment key value.
+
+ The attachment key value.
+
+
+
+ Gets the current attribute's level.
+
+
+ Gets the current attribute's level.
+
+ The current attribute's level.
+
+
+
+ Gets the length of the current attribute's raw value.
+
+
+ Gets the length of the current attribute's raw value.
+
+ The length of the current attribute's raw value.
+
+
+
+ Gets the stream offset of the current attribute's raw value.
+
+
+ Gets the stream offset of the current attribute's raw value.
+
+ The stream offset of the current attribute's raw value.
+
+
+
+ Gets the current attribute's tag.
+
+
+ Gets the current attribute's tag.
+
+ The current attribute's tag.
+
+
+
+ Gets the compliance mode.
+
+
+ Gets the compliance mode.
+
+ The compliance mode.
+
+
+
+ Gets the current compliance status of the TNEF stream.
+
+
+ Gets the current compliance status of the TNEF stream.
+ As the reader progresses, this value may change if errors are encountered.
+
+ The compliance status.
+
+
+
+ Gets the message codepage.
+
+
+ Gets the message codepage.
+
+ The message codepage.
+
+
+
+ Gets the TNEF property reader.
+
+
+ Gets the TNEF property reader.
+
+ The TNEF property reader.
+
+
+
+ Gets the current stream offset.
+
+
+ Gets the current stream offset.
+
+ The stream offset.
+
+
+
+ Gets the TNEF version.
+
+
+ Gets the TNEF version.
+
+ The TNEF version.
+
+
+
+ Initializes a new instance of the class.
+
+
+ When reading a TNEF stream using the mode,
+ a will be thrown immediately at the first sign of
+ invalid or corrupted data.
+ When reading a TNEF stream using the mode,
+ however, compliance issues are accumulated in the
+ property, but exceptions are not raised unless the stream is too corrupted to continue.
+
+ The input stream.
+ The default message codepage.
+ The compliance mode.
+
+ is null.
+
+
+ is not a valid codepage.
+
+
+ is not a supported codepage.
+
+
+ The TNEF stream is corrupted or invalid.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new for the specified input stream.
+
+ The input stream.
+
+ is null.
+
+
+
+
+ Releases unmanaged resources and performs other cleanup operations before the
+ is reclaimed by garbage collection.
+
+
+ Releases unmanaged resources and performs other cleanup operations before the
+ is reclaimed by garbage collection.
+
+
+
+
+ Advances to the next attribute in the TNEF stream.
+
+
+ Advances to the next attribute in the TNEF stream.
+
+ true if there is another attribute available to be read; otherwise false.
+
+ The TNEF stream is corrupted or invalid.
+
+
+
+
+ Reads the raw attribute value data from the underlying TNEF stream.
+
+
+ Reads the raw attribute value data from the underlying TNEF stream.
+
+ The total number of bytes read into the buffer. This can be less than the number
+ of bytes requested if that many bytes are not available, or zero (0) if the end of the
+ value has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ An I/O error occurred.
+
+
+
+
+ Resets the compliance status.
+
+
+ Resets the compliance status.
+
+
+
+
+ Closes the TNEF reader and the underlying stream.
+
+
+ Closes the TNEF reader and the underlying stream.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ Releases all resource used by the object.
+
+ Call when you are finished using the . The
+ method leaves the in an unusable state. After calling
+ , you must release all references to the so the garbage
+ collector can reclaim the memory that the was occupying.
+
+
+
+ A stream for reading raw values from a or .
+
+
+ A stream for reading raw values from a or .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a stream for reading a raw value from the .
+
+ The .
+ The end offset.
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ The is always readable.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ Writing to a is not supported.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ Seeking within a is not supported.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ Getting the length of a is not supported.
+
+ The length of the stream in bytes.
+
+ The stream does not support seeking.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ Getting and setting the position of a is not supported.
+
+ The position of the stream.
+
+ The stream does not support seeking.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ The does not support writing.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ The stream does not support writing.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ The does not support seeking.
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ The stream does not support seeking.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ The does not support writing.
+
+
+ The stream does not support writing.
+
+
+
+
+ Sets the length of the stream.
+
+
+ The does not support setting the length.
+
+ The desired length of the stream in bytes.
+
+ The stream does not support setting the length.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ The underlying is not disposed.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ The 32-bit cyclic redundancy check (CRC) algorithm.
+
+
+ A cyclic redundancy check is a form of integrity check to make sure
+ that a block of data has not been corrupted.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new CRC32 context.
+
+ The initial value.
+
+
+
+ Clones the CRC32 context and state.
+
+
+ Clones the CRC32 context and state.
+
+
+
+
+ Gets the computed checksum.
+
+
+ Gets the computed checksum.
+
+ The checksum.
+
+
+
+ Updates the CRC based on the specified block of data.
+
+
+ Updates the CRC based on the specified block of data.
+
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+
+
+ Updates the CRC based on the specified byte.
+
+
+ Updates the CRC based on the specified byte.
+
+ The byte value.
+
+
+
+ Resets the checksum so that the context can be reused.
+
+
+ Resets the checksum so that the context can be reused.
+
+
+
+
+ Utility methods to parse and format rfc822 date strings.
+
+
+ Utility methods to parse and format rfc822 date strings.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed date.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed date.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the supplied buffer starting at the specified index.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed date.
+
+ is null.
+
+
+ is not within the range of the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the supplied buffer starting at the specified index.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed date.
+
+ is null.
+
+
+ is not within the range of the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the specified buffer.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed date.
+
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the specified buffer.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed date.
+
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the specified text.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input text.
+ The parsed date.
+
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the specified text.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input text.
+ The parsed date.
+
+ is null.
+
+
+
+
+ Formats the as an rfc822 date string.
+
+
+ Formats the date and time in the format specified by rfc822, suitable for use
+ in the Date header of MIME messages.
+
+ The formatted string.
+ The date.
+
+
+
+ MIME utility methods.
+
+
+ Various utility methods that don't belong anywhere else.
+
+
+
+
+ A string comparer that performs a case-insensitive ordinal string comparison.
+
+
+ A string comparer that performs a case-insensitive ordinal string comparison.
+
+
+
+
+ Generates a Message-Id.
+
+
+ Generates a new Message-Id using the supplied domain.
+
+ The message identifier.
+ A domain to use.
+
+ is null.
+
+
+ is invalid.
+
+
+
+
+ Generates a Message-Id.
+
+
+ Generates a new Message-Id using the local machine's domain.
+
+ The message identifier.
+
+
+
+ Enumerates the message-id references such as those that can be found in
+ the In-Reply-To or References header.
+
+
+ Incrementally parses Message-Ids (such as those from a References header
+ in a MIME message) from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The references.
+ The raw byte buffer to parse.
+ The index into the buffer to start parsing.
+ The length of the buffer to parse.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Enumerates the message-id references such as those that can be found in
+ the In-Reply-To or References header.
+
+
+ Incrementally parses Message-Ids (such as those from a References header
+ in a MIME message) from the specified text.
+
+ The references.
+ The text to parse.
+
+ is null.
+
+
+
+
+ Parses a Message-Id header value.
+
+
+ Parses the Message-Id value, returning the addr-spec portion of the msg-id token.
+
+ The addr-spec portion of the msg-id token.
+ The raw byte buffer to parse.
+ The index into the buffer to start parsing.
+ The length of the buffer to parse.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Parses a Message-Id header value.
+
+
+ Parses the Message-Id value, returning the addr-spec portion of the msg-id token.
+
+ The addr-spec portion of the msg-id token.
+ The text to parse.
+
+ is null.
+
+
+
+
+ Tries to parse a version from a header such as Mime-Version.
+
+
+ Parses a MIME version string from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the version was successfully parsed, false otherwise.
+ The raw byte buffer to parse.
+ The index into the buffer to start parsing.
+ The length of the buffer to parse.
+ The parsed version.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse a version from a header such as Mime-Version.
+
+
+ Parses a MIME version string from the specified text.
+
+ true, if the version was successfully parsed, false otherwise.
+ The text to parse.
+ The parsed version.
+
+ is null.
+
+
+
+
+ Tries to parse a version from a header such as Mime-Version.
+
+
+ Parses a MIME version string from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the version was successfully parsed, false otherwise.
+ The raw byte buffer to parse.
+ The index into the buffer to start parsing.
+ The length of the buffer to parse.
+ The parsed version.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse a version from a header such as Mime-Version.
+
+
+ Parses a MIME version string from the specified text.
+
+ true, if the version was successfully parsed, false otherwise.
+ The text to parse.
+ The parsed version.
+
+ is null.
+
+
+
+
+ Tries to parse the value of a Content-Transfer-Encoding header.
+
+
+ Parses a Content-Transfer-Encoding header value.
+
+ true, if the encoding was successfully parsed, false otherwise.
+ The text to parse.
+ The parsed encoding.
+
+ is null.
+
+
+
+
+ Quotes the specified text.
+
+
+ Quotes the specified text, enclosing it in double-quotes and escaping
+ any backslashes and double-quotes within.
+
+ The quoted text.
+ The text to quote.
+
+ is null.
+
+
+
+
+ Unquotes the specified text.
+
+
+ Unquotes the specified text, removing any escaped backslashes within.
+
+ The unquoted text.
+ The text to unquote.
+
+ is null.
+
+
+
+
+ An optimized version of StringComparer.OrdinalIgnoreCase.
+
+
+ An optimized version of StringComparer.OrdinalIgnoreCase.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Compare the input strings for equality.
+
+
+ Compares the input strings for equality.
+
+ trueif and refer to the same object,
+ or and are equal,
+ or and are null;
+ otherwise, false.
+ A string to compare to .
+ A string to compare to .
+
+
+
+ Get the hash code for the specified string.
+
+
+ Get the hash code for the specified string.
+
+ A 32-bit signed hash code calculated from the value of the parameter.
+ The string.
+
+ is null.
+
+
+
+
+ Utility methods for encoding and decoding rfc2047 encoded-word tokens.
+
+
+ Utility methods for encoding and decoding rfc2047 encoded-word tokens.
+
+
+
+
+ Decodes the phrase.
+
+
+ Decodes the phrase(s) starting at the given index and spanning across
+ the specified number of bytes using the supplied parser options.
+
+ The decoded phrase.
+ The parser options to use.
+ The phrase to decode.
+ The starting index.
+ The number of bytes to decode.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Decodes the phrase.
+
+
+ Decodes the phrase(s) starting at the given index and spanning across
+ the specified number of bytes using the default parser options.
+
+ The decoded phrase.
+ The phrase to decode.
+ The starting index.
+ The number of bytes to decode.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Decodes the phrase.
+
+
+ Decodes the phrase(s) within the specified buffer using the supplied parser options.
+
+ The decoded phrase.
+ The parser options to use.
+ The phrase to decode.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Decodes the phrase.
+
+
+ Decodes the phrase(s) within the specified buffer using the default parser options.
+
+ The decoded phrase.
+ The phrase to decode.
+
+ is null.
+
+
+
+
+ Decodes unstructured text.
+
+
+ Decodes the unstructured text buffer starting at the given index and spanning
+ across the specified number of bytes using the supplied parser options.
+
+ The decoded text.
+ The parser options to use.
+ The text to decode.
+ The starting index.
+ The number of bytes to decode.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Decodes unstructured text.
+
+
+ Decodes the unstructured text buffer starting at the given index and spanning
+ across the specified number of bytes using the default parser options.
+
+ The decoded text.
+ The text to decode.
+ The starting index.
+ The number of bytes to decode.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Decodes unstructured text.
+
+
+ Decodes the unstructured text buffer using the specified parser options.
+
+ The decoded text.
+ The parser options to use.
+ The text to decode.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Decodes unstructured text.
+
+
+ Decodes the unstructured text buffer using the default parser options.
+
+ The decoded text.
+ The text to decode.
+
+ is null.
+
+
+
+
+ Encodes the phrase.
+
+
+ Encodes the phrase according to the rules of rfc2047 using
+ the specified charset encoding and formatting options.
+
+ The encoded phrase.
+ The formatting options
+ The charset encoding.
+ The phrase to encode.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Encodes the phrase.
+
+
+ Encodes the phrase according to the rules of rfc2047 using
+ the specified charset encoding.
+
+ The encoded phrase.
+ The charset encoding.
+ The phrase to encode.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Encodes the unstructured text.
+
+
+ Encodes the unstructured text according to the rules of rfc2047
+ using the specified charset encoding and formatting options.
+
+ The encoded text.
+ The formatting options
+ The charset encoding.
+ The text to encode.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Encodes the unstructured text.
+
+
+ Encodes the unstructured text according to the rules of rfc2047
+ using the specified charset encoding.
+
+ The encoded text.
+ The charset encoding.
+ The text to encode.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ A collection of attachments.
+
+
+ The is only used when building a message body with a .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+ If is true, then the attachments
+ are treated as if they are linked to another .
+
+ If set to true; the attachments are treated as linked resources.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the number of attachments currently in the collection.
+
+
+ Indicates the number of attachments in the collection.
+
+ The number of attachments.
+
+
+
+ Gets whther or not the collection is read-only.
+
+
+ A is never read-only.
+
+ true if the collection is read only; otherwise, false.
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the at the specified index.
+
+ The attachment at the specified index.
+ The index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the specified data as an attachment using the supplied Content-Type.
+ The file name parameter is used to set the Content-Location.
+ For a list of known mime-types and their associated file extensions, see
+ http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types
+
+ The newly added attachment .
+ The name of the file.
+ The file data.
+ The mime-type of the file.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the specified data as an attachment using the supplied Content-Type.
+ The file name parameter is used to set the Content-Location.
+ For a list of known mime-types and their associated file extensions, see
+ http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types
+
+ The newly added attachment .
+ The name of the file.
+ The content stream.
+ The mime-type of the file.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+ -or-
+ The stream cannot be read.
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the data as an attachment, using the specified file name for deducing
+ the mime-type by extension and for setting the Content-Location.
+
+ The newly added attachment .
+ The name of the file.
+ The file data to attach.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the stream as an attachment, using the specified file name for deducing
+ the mime-type by extension and for setting the Content-Location.
+
+ The newly added attachment .
+ The name of the file.
+ The content stream.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+ -or-
+ The stream cannot be read
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the specified file as an attachment using the supplied Content-Type.
+ For a list of known mime-types and their associated file extensions, see
+ http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types
+
+ The newly added attachment .
+ The name of the file.
+ The mime-type of the file.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+ The specified file could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the specified file as an attachment.
+
+ The newly added attachment .
+ The name of the file.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the specified as an attachment.
+
+ The attachment.
+
+ is null.
+
+
+
+
+ Clears the attachment collection.
+
+
+ Removes all attachments from the collection.
+
+
+
+
+ Checks if the collection contains the specified attachment.
+
+
+ Determines whether or not the collection contains the specified attachment.
+
+ true if the specified attachment exists;
+ otherwise false.
+ The attachment.
+
+ is null.
+
+
+
+
+ Copies all of the attachments in the collection to the specified array.
+
+
+ Copies all of the attachments within the into the array,
+ starting at the specified array index.
+
+ The array to copy the attachments to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Gets the index of the requested attachment, if it exists.
+
+
+ Finds the index of the specified attachment, if it exists.
+
+ The index of the requested attachment; otherwise -1.
+ The attachment.
+
+ is null.
+
+
+
+
+ Inserts the specified attachment at the given index.
+
+
+ Inserts the attachment at the specified index.
+
+ The index to insert the attachment.
+ The attachment.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified attachment.
+
+
+ Removes the specified attachment.
+
+ true if the attachment was removed; otherwise false.
+ The attachment.
+
+ is null.
+
+
+
+
+ Removes the attachment at the specified index.
+
+
+ Removes the attachment at the specified index.
+
+ The index.
+
+ is out of range.
+
+
+
+
+ Gets an enumerator for the list of attachments.
+
+
+ Gets an enumerator for the list of attachments.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of attachments.
+
+
+ Gets an enumerator for the list of attachments.
+
+ The enumerator.
+
+
+
+ A message body builder.
+
+
+ is a helper class for building common MIME body structures.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the attachments.
+
+
+ Represents a collection of file attachments that will be included in the message.
+
+ The attachments.
+
+
+
+ Gets the linked resources.
+
+
+ Linked resources are a special type of attachment which are linked to from the .
+
+ The linked resources.
+
+
+
+ Gets or sets the text body.
+
+
+ Represents the plain-text formatted version of the message body.
+
+ The text body.
+
+
+
+ Gets or sets the html body.
+
+
+ Represents the html formatted version of the message body and may link to any of the .
+
+ The html body.
+
+
+
+ Constructs the message body based on the text-based bodies, the linked resources, and the attachments.
+
+
+ Combines the , , ,
+ and into the proper MIME structure suitable for display in many common
+ mail clients.
+
+ The message body.
+
+
+
+ A class representing a Content-Disposition header value.
+
+
+ The Content-Disposition header is a way for the originating client to
+ suggest to the receiving client whether to present the part to the user
+ as an attachment or as part of the content (inline).
+
+
+
+
+ The attachment disposition.
+
+
+ Indicates that the should be treated as an attachment.
+
+
+
+
+ The form-data disposition.
+
+
+ Indicates that the should be treated as form data.
+
+
+
+
+ The inline disposition.
+
+
+ Indicates that the should be rendered inline.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The disposition should either be
+ or .
+
+ The disposition.
+
+ is null.
+
+
+ is not "attachment" or "inline".
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This is identical to with a disposition
+ value of .
+
+
+
+
+ Gets or sets the disposition.
+
+
+ The disposition is typically either "attachment" or "inline".
+
+ The disposition.
+
+ is null.
+
+
+ is an invalid disposition value.
+
+
+
+
+ Gets or sets a value indicating whether the is an attachment.
+
+
+ A convenience property to determine if the entity should be considered an attachment or not.
+
+ true if the is an attachment; otherwise, false.
+
+
+
+ Gets the parameters.
+
+
+ In addition to specifying whether the entity should be treated as an
+ attachment vs displayed inline, the Content-Disposition header may also
+ contain parameters to provide further information to the receiving client
+ such as the file attributes.
+
+ The parameters.
+
+
+
+ Gets or sets the name of the file.
+
+
+ When set, this can provide a useful hint for a default file name for the
+ content when the user decides to save it to disk.
+
+ The name of the file.
+
+
+
+ Gets or sets the creation-date parameter.
+
+
+ Refers to the date and time that the content file was created on the
+ originating system. This parameter serves little purpose and is
+ typically not used by mail clients.
+
+ The creation date.
+
+
+
+ Gets or sets the modification-date parameter.
+
+
+ Refers to the date and time that the content file was last modified on
+ the originating system. This parameter serves little purpose and is
+ typically not used by mail clients.
+
+ The modification date.
+
+
+
+ Gets or sets the read-date parameter.
+
+
+ Refers to the date and time that the content file was last read on the
+ originating system. This parameter serves little purpose and is typically
+ not used by mail clients.
+
+ The read date.
+
+
+
+ Gets or sets the size parameter.
+
+
+ When set, the size parameter typically refers to the original size of the
+ content on disk. This parameter is rarely used by mail clients as it serves
+ little purpose.
+
+ The size.
+
+
+
+ Serializes the to a string,
+ optionally encoding the parameters.
+
+
+ Creates a string-representation of the ,
+ optionally encoding the parameters as they would be encoded for trabsport.
+
+ The serialized string.
+ The formatting options.
+ The charset to be used when encoding the parameter values.
+ If set to true, the parameter values will be encoded.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Serializes the to a string,
+ optionally encoding the parameters.
+
+
+ Creates a string-representation of the ,
+ optionally encoding the parameters as they would be encoded for trabsport.
+
+ The serialized string.
+ The charset to be used when encoding the parameter values.
+ If set to true, the parameter values will be encoded.
+
+ is null.
+
+
+
+
+ Returns a that represents the current
+ .
+
+
+ Creates a string-representation of the .
+
+ A that represents the current
+ .
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The parser options.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed disposition.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed disposition.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the specified index.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The parser options.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed disposition.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the specified index.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed disposition.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Disposition value from the specified buffer.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The parser options.
+ The input buffer.
+ The parsed disposition.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Disposition value from the specified buffer.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed disposition.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a Content-Disposition value from the supplied text.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The parser options.
+ The text to parse.
+ The parsed disposition.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a Content-Disposition value from the supplied text.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The text to parse.
+ The parsed disposition.
+
+ is null.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The parsed .
+ The parser options.
+ The input buffer.
+ The start index of the buffer.
+ The length of the buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The parsed .
+ The input buffer.
+ The start index of the buffer.
+ The length of the buffer.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the specified index.
+
+ The parsed .
+ The parser options.
+ The input buffer.
+ The start index of the buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the specified index.
+
+ The parsed .
+ The input buffer.
+ The start index of the buffer.
+
+ is null.
+
+
+ is out of range.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the supplied buffer.
+
+ The parsed .
+ The parser options.
+ The input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the supplied buffer.
+
+ The parsed .
+ The input buffer.
+
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified text into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the specified text.
+
+ The parsed .
+ The parser options.
+ The input text.
+
+ is null.
+ -or-
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified text into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the specified text.
+
+ The parsed .
+ The input text.
+
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ An enumeration of all supported content transfer encodings.
+ .
+
+
+ Some older mail software is unable to properly deal with
+ data outside of the ASCII range, so it is sometimes
+ necessary to encode the content of MIME entities.
+
+
+
+
+ The default encoding (aka no encoding at all).
+
+
+
+
+ The 7bit content transfer encoding.
+
+
+ This encoding should be restricted to textual content
+ in the US-ASCII range.
+
+
+
+
+ The 8bit content transfer encoding.
+
+
+ This encoding should be restricted to textual content
+ outside of the US-ASCII range but may not be supported
+ by all transport services such as older SMTP servers
+ that do not support the 8BITMIME extension.
+
+
+
+
+ The binary content transfer encoding.
+
+
+ This encoding is simply unencoded binary data. Typically not
+ supported by standard message transport services such as SMTP.
+
+
+
+
+ The base64 content transfer encoding.
+ .
+
+
+ This encoding is typically used for encoding binary data
+ or textual content in a largely 8bit charset encoding and
+ is supported by all message transport services.
+
+
+
+
+ The quoted printable content transfer encoding.
+ .
+
+
+ This encoding is used for textual content that is in a charset
+ that has a minority of characters outside of the US-ASCII range
+ (such as ISO-8859-1 and other single-byte charset encodings) and
+ is supported by all message transport services.
+
+
+
+
+ The uuencode content transfer encoding.
+ .
+
+
+ This is an obsolete encoding meant for encoding binary
+ data and has largely been superceeded by .
+
+
+
+
+ Encapsulates a content stream used by .
+
+
+ A represents the content of a .
+ The content has both a stream and an encoding (typically ).
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ When creating new s, the
+ should typically be unless the
+ has already been encoded.
+
+ The content stream.
+ The stream encoding.
+
+ is null.
+
+
+ does not support reading.
+ -or-
+ does not support seeking.
+
+
+
+
+ Gets or sets the content encoding.
+
+
+ If the was parsed from an existing stream, the
+ encoding will be identical to the ,
+ otherwise it will typically be .
+
+ The content encoding.
+
+
+
+ Gets the content stream.
+
+
+ Gets the content stream.
+
+ The stream.
+
+
+
+ Opens the decoded content stream.
+
+
+ Provides a means of reading the decoded content without having to first write it to another
+ stream using .
+
+ The decoded content stream.
+
+
+
+ Copies the content stream to the specified output stream.
+
+
+ This is equivalent to simply using to
+ copy the content stream to the output stream except that this method is
+ cancellable.
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Decodes the content stream into another stream.
+
+
+ Uses the to decode the content stream to the output stream.
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ A class representing a Content-Type header value.
+
+
+ The Content-Type header is a way for the originating client to
+ suggest to the receiving client the mime-type of the content and,
+ depending on that mime-type, presentation options such as charset.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new based on the media type and subtype provided.
+
+ Media type.
+ Media subtype.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets or sets the type of the media.
+
+
+ Represents the media type of the . Examples include
+ "text", "image", and "application". This string should
+ always be treated as case-insensitive.
+
+ The type of the media.
+
+ is null.
+
+
+
+
+ Gets or sets the media subtype.
+
+
+ Represents the media subtype of the . Examples include
+ "html", "jpeg", and "octet-stream". This string should
+ always be treated as case-insensitive.
+
+ The media subtype.
+
+ is null.
+
+
+
+
+ Gets the parameters.
+
+
+ In addition to the media type and subtype, the Content-Type header may also
+ contain parameters to provide further hints to the receiving client as to
+ how to process or display the content.
+
+ The parameters.
+
+
+
+ Gets or sets the boundary parameter.
+
+
+ This is a special parameter on entities, designating to the
+ parser a unique string that should be considered the boundary marker for each sub-part.
+
+ The boundary.
+
+
+
+ Gets or sets the charset parameter.
+
+
+ Text-based entities will often include a charset parameter
+ so that the receiving client can properly render the text.
+
+ The charset.
+
+
+
+ Gets or sets the format parameter.
+
+
+ The format parameter is typically use with text/plain
+ entities and will either have a value of "fixed" or "flowed".
+
+ The charset.
+
+
+
+ Gets the simple mime-type.
+
+
+ Gets the simple mime-type.
+
+ The mime-type.
+
+
+
+ Gets or sets the name parameter.
+
+
+ The name parameter is a way for the originiating client to suggest
+ to the receiving client a display-name for the content, which may
+ be used by the receiving client if it cannot display the actual
+ content to the user.
+
+ The name.
+
+
+
+ Checks if the this instance of matches
+ the specified media type and subtype.
+
+
+ If the specified or
+ are "*", they match anything.
+
+ true if the matches the
+ provided media type and subtype.
+ The media type.
+ The media subtype.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Checks if the this instance of matches
+ the specified MIME media type and subtype.
+
+
+ If the specified or
+ are "*", they match anything.
+
+ true if the matches the
+ provided media type and subtype.
+ The media type.
+ The media subtype.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Serializes the to a string,
+ optionally encoding the parameters.
+
+
+ Creates a string-representation of the , optionally encoding
+ the parameters as they would be encoded for transport.
+
+ The serialized string.
+ The formatting options.
+ The charset to be used when encoding the parameter values.
+ If set to true, the parameter values will be encoded.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Serializes the to a string,
+ optionally encoding the parameters.
+
+
+ Creates a string-representation of the , optionally encoding
+ the parameters as they would be encoded for transport.
+
+ The serialized string.
+ The charset to be used when encoding the parameter values.
+ If set to true, the parameter values will be encoded.
+
+ is null.
+
+
+
+
+ Returns a that represents the current
+ .
+
+
+ Creates a string-representation of the .
+
+ A that represents the current
+ .
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The parser options.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed content type.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed content type.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the specified index.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The parser options.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed content type.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the specified index.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed content type.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Type value from the specified buffer.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The parser options.
+ The input buffer.
+ The parsed content type.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Type value from the specified buffer.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed content type.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a Content-Type value from the specified text.
+
+ true, if the content type was successfully parsed, false otherwise.
+ THe parser options.
+ The text to parse.
+ The parsed content type.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a Content-Type value from the specified text.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The text to parse.
+ The parsed content type.
+
+ is null.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The parsed .
+ The parser options.
+ The input buffer.
+ The start index of the buffer.
+ The length of the buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The parsed .
+ The input buffer.
+ The start index of the buffer.
+ The length of the buffer.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the specified index.
+
+ The parsed .
+ The parser options.
+ The input buffer.
+ The start index of the buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the specified index.
+
+ The parsed .
+ The input buffer.
+ The start index of the buffer.
+
+ is null.
+
+
+ is out of range.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Type value from the specified buffer.
+
+ The parsed .
+ The parser options.
+ The input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Type value from the specified buffer.
+
+ The parsed .
+ The input buffer.
+
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified text into a new instance of the class.
+
+
+ Parses a Content-Type value from the specified text.
+
+ The parsed .
+ The parser options.
+ The text.
+
+ is null.
+ -or-
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified text into a new instance of the class.
+
+
+ Parses a Content-Type value from the specified text.
+
+ The parsed .
+ The text.
+
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ A domain list.
+
+
+ Represents a list of domains, such as those that an email was routed through.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new based on the domains provided.
+
+ A domain list.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the index of the requested domain, if it exists.
+
+
+ Finds the index of the specified domain, if it exists.
+
+ The index of the requested domain; otherwise -1.
+ The domain.
+
+ is null.
+
+
+
+
+ Insert the domain at the specified index.
+
+
+ Inserts the domain at the specified index in the list.
+
+ The index to insert the domain.
+ The domain to insert.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the domain at the specified index.
+
+
+ Removes the domain at the specified index.
+
+ The index.
+
+ is out of range.
+
+
+
+
+ Gets or sets the domain at the specified index.
+
+
+ Gets or sets the domain at the specified index.
+
+ The domain at the specified index.
+ The index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Add the specified domain.
+
+
+ Adds the specified domain to the end of the list.
+
+ The domain.
+
+ is null.
+
+
+
+
+ Clears the domain list.
+
+
+ Removes all of the domains in the list.
+
+
+
+
+ Checks if the contains the specified domain.
+
+
+ Determines whether or not the domain list contains the specified domain.
+
+ true if the specified domain is contained;
+ otherwise false.
+ The domain.
+
+ is null.
+
+
+
+
+ Copies all of the domains in the to the specified array.
+
+
+ Copies all of the domains within the into the array,
+ starting at the specified array index.
+
+ The array to copy the domains to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified domain.
+
+
+ Removes the first instance of the specified domain from the list if it exists.
+
+ true if the domain was removed; otherwise false.
+ The domain.
+
+ is null.
+
+
+
+
+ Gets the number of domains in the .
+
+
+ Indicates the number of domains in the list.
+
+ The number of domains.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Gets an enumerator for the list of domains.
+
+
+ Gets an enumerator for the list of domains.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of domains.
+
+
+ Gets an enumerator for the list of domains.
+
+ The enumerator.
+
+
+
+ Returns a string representation of the list of domains.
+
+
+ Each non-empty domain string will be prepended by an '@'.
+ If there are multiple domains in the list, they will be separated by a comma.
+
+ A string representing the .
+
+
+
+ Tries to parse a list of domains.
+
+
+ Attempts to parse a from the text buffer starting at the
+ specified index. The index will only be updated if a was
+ successfully parsed.
+
+ true if a was successfully parsed;
+ false otherwise.
+ The buffer to parse.
+ The index to start parsing.
+ An index of the end of the input.
+ A flag indicating whether or not an
+ exception should be thrown on error.
+ The parsed DomainList.
+
+
+
+ Tries to parse a list of domains.
+
+
+ Attempts to parse a from the supplied text. The index
+ will only be updated if a was successfully parsed.
+
+ true if a was successfully parsed;
+ false otherwise.
+ The text to parse.
+ The parsed DomainList.
+
+ is null.
+
+
+
+
+ A content encoding constraint.
+
+
+ Not all message transports support binary or 8-bit data, so it becomes
+ necessary to constrain the content encoding to a subset of the possible
+ Content-Transfer-Encoding values.
+
+
+
+
+ There are no encoding constraints, the content may contain any byte.
+
+
+
+
+ The content may contain bytes with the high bit set, but must not contain any zero-bytes.
+
+
+
+
+ The content may only contain bytes within the 7-bit ASCII range.
+
+
+
+
+ A New-Line format.
+
+
+ There are two commonly used line-endings used by modern Operating Systems.
+ Unix-based systems such as Linux and Mac OS use a single character ('\n' aka LF)
+ to represent the end of line where-as Windows (or DOS) uses a sequence of two
+ characters ("\r\n" aka CRLF). Most text-based network protocols such as SMTP,
+ POP3, and IMAP use the CRLF sequence as well.
+
+
+
+
+ The Unix New-Line format ("\n").
+
+
+
+
+ The DOS New-Line format ("\r\n").
+
+
+
+
+ Format options for serializing various MimeKit objects.
+
+
+ Represents the available options for formatting MIME messages
+ and entities when writing them to a stream.
+
+
+
+
+ The default formatting options.
+
+
+ If a custom is not passed to methods such as
+ ,
+ the default options will be used.
+
+
+
+
+ Gets the maximum line length used by the encoders. The encoders
+ use this value to determine where to place line breaks.
+
+
+ Specifies the maximum line length to use when line-wrapping headers.
+
+ The maximum line length.
+
+
+
+ Gets or sets the new-line format.
+
+
+ Specifies the new-line encoding to use when writing the message
+ or entity to a stream.
+
+ The new-line format.
+
+ cannot be changed.
+
+
+
+
+ Gets the message headers that should be hidden.
+
+
+ Specifies the set of headers that should be removed when
+ writing a to a stream.
+ This is primarily meant for the purposes of removing Bcc
+ and Resent-Bcc headers when sending via a transport such as
+ SMTP.
+
+ The message headers.
+
+
+
+ Gets or sets whether the new "Internationalized Email" formatting standards should be used.
+
+
+ The new "Internationalized Email" format is defined by
+ rfc6530 and
+ rfc6532.
+ This feature should only be used when formatting messages meant to be sent via
+ SMTP using the SMTPUTF8 extension (rfc6531)
+ or when appending messages to an IMAP folder via UTF8 APPEND
+ (rfc6855).
+
+ true if the new internationalized formatting should be used; otherwise, false.
+
+ cannot be changed.
+
+
+
+
+ Gets or sets whether the formatter should allow mixed charsets in the headers.
+
+
+ When this option is enabled, the MIME formatter will try to use US-ASCII and/or
+ ISO-8859-1 to encode headers when appropriate rather than being forced to use the
+ specified charset for all encoded-word tokens in order to maximize readability.
+ Unfortunately, mail clients like Outlook and Thunderbird do not treat
+ encoded-word tokens individually and assume that all tokens are encoded using the
+ charset declared in the first encoded-word token despite the specification
+ explicitly stating that each encoded-word token should be treated independently.
+ The Thunderbird bug can be tracked at
+
+ https://bugzilla.mozilla.org/show_bug.cgi?id=317263.
+
+ true if the formatter should be allowed to use ISO-8859-1 when encoding headers; otherwise, false.
+
+
+
+ The method to use for encoding Content-Type and Content-Disposition parameter values.
+
+
+ The method to use for encoding Content-Type and Content-Disposition parameter
+ values when the is set to
+ .
+ The MIME specifications specify that the proper method for encoding Content-Type
+ and Content-Disposition parameter values is the method described in
+ rfc2231. However, it is common for
+ some older email clients to improperly encode using the method described in
+ rfc2047 instead.
+
+ The parameter encoding method that will be used.
+
+ is not a valid value.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new set of formatting options for use with methods such as
+ .
+
+
+
+
+ Clones an instance of .
+
+
+ Clones the formatting options.
+
+ An exact copy of the .
+
+
+
+ Get the default formatting options in a thread-safe way.
+
+
+ Gets the default formatting options in a thread-safe way.
+
+ The default formatting options.
+
+
+
+ An address group, as specified by rfc0822.
+
+
+ Group addresses are rarely used anymore. Typically, if you see a group address,
+ it will be of the form: "undisclosed-recipients: ;".
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name and list of addresses. The
+ specified text encoding is used when encoding the name according to the rules of rfc2047.
+
+ The character encoding to be used for encoding the name.
+ The name of the group.
+ A list of addresses.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name and list of addresses.
+
+ The name of the group.
+ A list of addresses.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name. The specified
+ text encoding is used when encoding the name according to the rules of rfc2047.
+
+ The character encoding to be used for encoding the name.
+ The name of the group.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name.
+
+ The name of the group.
+
+
+
+ Clone the group address.
+
+
+ Clones the group address.
+
+ The cloned group address.
+
+
+
+ Gets the members of the group.
+
+
+ Represents the member addresses of the group. Typically the member addresses
+ will be of the variety, but it is possible
+ for groups to contain other groups.
+
+ The list of members.
+
+
+
+ Returns a string representation of the ,
+ optionally encoding it for transport.
+
+
+ Returns a string containing the formatted group of addresses. If the
+ parameter is true, then the name of the group and all member addresses will be encoded
+ according to the rules defined in rfc2047, otherwise the names will not be encoded at all and
+ will therefor only be suitable for display purposes.
+
+ A string representing the .
+ The formatting options.
+ If set to true, the will be encoded.
+
+ is null.
+
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Compares two group addresses to determine if they are identical or not.
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed group address.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed group address.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed group address.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed group address.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The parsed group address.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed group address.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The text.
+ The parsed group address.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The text.
+ The parsed group address.
+
+ is null.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The text.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The text.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ A class representing a Message or MIME header.
+
+
+ Represents a single header field and value pair.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message or entity header for the specified field and
+ value pair. The encoding is used to determine which charset to use
+ when encoding the value according to the rules of rfc2047.
+
+ The character encoding that should be used to
+ encode the header value.
+ The header identifier.
+ The value of the header.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a valid .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message or entity header for the specified field and
+ value pair. The encoding is used to determine which charset to use
+ when encoding the value according to the rules of rfc2047.
+
+ The charset that should be used to encode the
+ header value.
+ The header identifier.
+ The value of the header.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a valid .
+
+
+ is not supported.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message or entity header for the specified field and
+ value pair with the UTF-8 encoding.
+
+ The header identifier.
+ The value of the header.
+
+ is null.
+
+
+ is not a valid .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message or entity header for the specified field and
+ value pair. The encoding is used to determine which charset to use
+ when encoding the value according to the rules of rfc2047.
+
+ The character encoding that should be used
+ to encode the header value.
+ The name of the header field.
+ The value of the header.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message or entity header for the specified field and
+ value pair. The encoding is used to determine which charset to use
+ when encoding the value according to the rules of rfc2047.
+
+ The charset that should be used to encode the
+ header value.
+ The name of the header field.
+ The value of the header.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+ is not supported.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message or entity header for the specified field and
+ value pair with the UTF-8 encoding.
+
+ The name of the header field.
+ The value of the header.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Clone the header.
+
+
+ Clones the header, copying the current RawValue.
+
+ A copy of the header with its current state.
+
+
+
+ Gets the stream offset of the beginning of the header.
+
+
+ If the offset is set, it refers to the byte offset where it
+ was found in the stream it was parsed from.
+
+ The stream offset.
+
+
+
+ Gets the name of the header field.
+
+
+ Represents the field name of the header.
+
+ The name of the header field.
+
+
+
+ Gets the header identifier.
+
+
+ This property is mainly used for switch-statements for performance reasons.
+
+ The header identifier.
+
+
+
+ Gets the raw field name of the header.
+
+
+ Contains the raw field name of the header.
+
+ The raw field name of the header.
+
+
+
+ Gets the raw value of the header.
+
+
+ Contains the raw value of the header, before any decoding or charset conversion.
+
+ The raw value of the header.
+
+
+
+ Gets or sets the header value.
+
+
+ Represents the decoded header value and is suitable for displaying to the user.
+
+ The header value.
+
+ is null.
+
+
+
+
+ Gets the header value using the specified character encoding.
+
+
+ If the raw header value does not properly encode non-ASCII text, the decoder
+ will fall back to a default charset encoding. Sometimes, however, this
+ default charset fallback is wrong and the mail client may wish to override
+ that default charset on a per-header basis.
+ By using this method, the client is able to override the fallback charset
+ on a per-header basis.
+
+ The value.
+ The character encoding to use as a fallback.
+
+
+
+ Gets the header value using the specified charset.
+
+
+ If the raw header value does not properly encode non-ASCII text, the decoder
+ will fall back to a default charset encoding. Sometimes, however, this
+ default charset fallback is wrong and the mail client may wish to override
+ that default charset on a per-header basis.
+ By using this method, the client is able to override the fallback charset
+ on a per-header basis.
+
+ The value.
+ The charset to use as a fallback.
+
+
+
+ Sets the header value using the specified formatting options and character encoding.
+
+
+ When a particular charset is desired for encoding the header value
+ according to the rules of rfc2047, this method should be used
+ instead of the setter.
+
+ The formatting options.
+ A character encoding.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Sets the header value using the specified character encoding.
+
+
+ When a particular charset is desired for encoding the header value
+ according to the rules of rfc2047, this method should be used
+ instead of the setter.
+
+ A character encoding.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Sets the header value using the specified formatting options and charset.
+
+
+ When a particular charset is desired for encoding the header value
+ according to the rules of rfc2047, this method should be used
+ instead of the setter.
+
+ The formatting options.
+ A charset encoding.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ is not supported.
+
+
+
+
+ Sets the header value using the specified charset.
+
+
+ When a particular charset is desired for encoding the header value
+ according to the rules of rfc2047, this method should be used
+ instead of the setter.
+
+ A charset encoding.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not supported.
+
+
+
+
+ Returns a string representation of the header.
+
+
+ Formats the header field and value in a way that is suitable for display.
+
+ A string representing the .
+
+
+
+ Unfold the specified header value.
+
+
+ Unfolds the header value so that it becomes suitable for display.
+ Since is already unfolded, this method is really
+ only needed when working with raw header strings.
+
+ The unfolded header value.
+ The header text.
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a header from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the header was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed header.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a header from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the header was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed header.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a header from the supplied buffer starting at the specified index.
+
+ true, if the header was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed header.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a header from the supplied buffer starting at the specified index.
+
+ true, if the header was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed header.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a header from the specified buffer.
+
+ true, if the header was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The parsed header.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a header from the specified buffer.
+
+ true, if the header was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed header.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a header from the specified text.
+
+ true, if the header was successfully parsed, false otherwise.
+ The parser options to use.
+ The text to parse.
+ The parsed header.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a header from the specified text.
+
+ true, if the header was successfully parsed, false otherwise.
+ The text to parse.
+ The parsed header.
+
+ is null.
+
+
+
+
+ An enumeration of common header fields.
+
+
+ Comparing enum values is not only faster, but less error prone than
+ comparing strings.
+
+
+
+
+ The Ad-Hoc header field.
+
+
+
+
+ The Apparently-To header field.
+
+
+
+
+ The Approved header field.
+
+
+
+
+ The Article header field.
+
+
+
+
+ The Bcc header field.
+
+
+
+
+ The Bytes header field.
+
+
+
+
+ The Cc header field.
+
+
+
+
+ The Comments header field.
+
+
+
+
+ The Content-Base header field.
+
+
+
+
+ The Content-Class header field.
+
+
+
+
+ The Content-Description header field.
+
+
+
+
+ The Content-Disposition header field.
+
+
+
+
+ The Content-Duration header field.
+
+
+
+
+ The Content-Id header field.
+
+
+
+
+ The Content-Language header field.
+
+
+
+
+ The Content-Length header field.
+
+
+
+
+ The Content-Location header field.
+
+
+
+
+ The Content-Md5 header field.
+
+
+
+
+ The Content-Transfer-Encoding header field.
+
+
+
+
+ The Content-Type header field.
+
+
+
+
+ The Control header field.
+
+
+
+
+ The Date header field.
+
+
+
+
+ The Deferred-Delivery header field.
+
+
+
+
+ The Disposition-Notification-Options header field.
+
+
+
+
+ The Disposition-Notification-To header field.
+
+
+
+
+ The Distribution header field.
+
+
+
+
+ The DKIM-Signature header field.
+
+
+
+
+ The DomainKey-Signature header field.
+
+
+
+
+ The Encoding header field.
+
+
+
+
+ The Encrypted header field.
+
+
+
+
+ The Expires header field.
+
+
+
+
+ The Expiry-Date header field.
+
+
+
+
+ The Followup-To header field.
+
+
+
+
+ The From header field.
+
+
+
+
+ The Importance header field.
+
+
+
+
+ The In-Reply-To header field.
+
+
+
+
+ The Keywords header field.
+
+
+
+
+ The Lines header field.
+
+
+
+
+ The List-Help header field.
+
+
+
+
+ The List-Subscribe header field.
+
+
+
+
+ The List-Unsubscribe header field.
+
+
+
+
+ The Message-Id header field.
+
+
+
+
+ The MIME-Version header field.
+
+
+
+
+ The Newsgroups header field.
+
+
+
+
+ The Nntp-Posting-Host header field.
+
+
+
+
+ The Organization header field.
+
+
+
+
+ The Original-Recipient header field.
+
+
+
+
+ The Path header field.
+
+
+
+
+ The Precedence header field.
+
+
+
+
+ The Priority header field.
+
+
+
+
+ The Received header field.
+
+
+
+
+ The References header field.
+
+
+
+
+ The Reply-By header field.
+
+
+
+
+ The Reply-To header field.
+
+
+
+
+ The Resent-Bcc header field.
+
+
+
+
+ The Resent-Cc header field.
+
+
+
+
+ The Resent-Date header field.
+
+
+
+
+ The Resent-From header field.
+
+
+
+
+ The Resent-Message-Id header field.
+
+
+
+
+ The Resent-Reply-To header field.
+
+
+
+
+ The Resent-Sender header field.
+
+
+
+
+ The Resent-To header field.
+
+
+
+
+ The Return-Path header field.
+
+
+
+
+ The Return-Receipt-To header field.
+
+
+
+
+ The Sender header field.
+
+
+
+
+ The Sensitivity header field.
+
+
+
+
+ The Status header field.
+
+
+
+
+ The Subject header field.
+
+
+
+
+ The Summary header field.
+
+
+
+
+ The Supersedes header field.
+
+
+
+
+ The To header field.
+
+
+
+
+ The User-Agent header field.
+
+
+
+
+ The X-Mailer header field.
+
+
+
+
+ The X-MSMail-Priority header field.
+
+
+
+
+ The X-Priority header field.
+
+
+
+
+ The X-Status header field.
+
+
+
+
+ An unknown header field.
+
+
+
+
+ extension methods.
+
+
+ extension methods.
+
+
+
+
+ Converts the enum value into the equivalent header field name.
+
+
+ Converts the enum value into the equivalent header field name.
+
+ The header name.
+ The enum value.
+
+
+
+ A list of s.
+
+
+ Represents a list of headers as found in a
+ or .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new empty header list.
+
+
+
+
+ Adds a header with the specified field and value.
+
+
+ Adds a new header for the specified field and value pair.
+
+ The header identifier.
+ The header value.
+
+ is null.
+
+
+ is not a valid .
+
+
+
+
+ Adds a header with the specified field and value.
+
+
+ Adds a new header for the specified field and value pair.
+
+ The name of the header field.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Adds a header with the specified field and value.
+
+
+ Adds a new header for the specified field and value pair.
+
+ The header identifier.
+ The character encoding to use for the value.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a valid .
+
+
+
+
+ Adds a header with the specified field and value.
+
+
+ Adds a new header for the specified field and value pair.
+
+ The name of the header field.
+ The character encoding to use for the value.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Checks if the contains a header with the specified field name.
+
+
+ Determines whether or not the header list contains the specified header.
+
+ true if the requested header exists;
+ otherwise false.
+ The header identifier.
+
+ is not a valid .
+
+
+
+
+ Checks if the contains a header with the specified field name.
+
+
+ Determines whether or not the header list contains the specified header.
+
+ true if the requested header exists;
+ otherwise false.
+ The name of the header field.
+
+ is null.
+
+
+
+
+ Gets the index of the requested header, if it exists.
+
+
+ Finds the first index of the specified header, if it exists.
+
+ The index of the requested header; otherwise -1.
+ The header id.
+
+ is not a valid .
+
+
+
+
+ Gets the index of the requested header, if it exists.
+
+
+ Finds the first index of the specified header, if it exists.
+
+ The index of the requested header; otherwise -1.
+ The name of the header field.
+
+ is null.
+
+
+
+
+ Inserts a header with the specified field and value at the given index.
+
+
+ Inserts the header at the specified index in the list.
+
+ The index to insert the header.
+ The header identifier.
+ The header value.
+
+ is null.
+
+
+ is not a valid .
+ -or-
+ is out of range.
+
+
+
+
+ Inserts a header with the specified field and value at the given index.
+
+
+ Inserts the header at the specified index in the list.
+
+ The index to insert the header.
+ The name of the header field.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+ is out of range.
+
+
+
+
+ Inserts a header with the specified field and value at the given index.
+
+
+ Inserts the header at the specified index in the list.
+
+ The index to insert the header.
+ The header identifier.
+ The character encoding to use for the value.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a valid .
+ -or-
+ is out of range.
+
+
+
+
+ Inserts a header with the specified field and value at the given index.
+
+
+ Inserts the header at the specified index in the list.
+
+ The index to insert the header.
+ The name of the header field.
+ The character encoding to use for the value.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+ is out of range.
+
+
+
+
+ Gets the last index of the requested header, if it exists.
+
+
+ Finds the last index of the specified header, if it exists.
+
+ The last index of the requested header; otherwise -1.
+ The header id.
+
+ is not a valid .
+
+
+
+
+ Gets the last index of the requested header, if it exists.
+
+
+ Finds the last index of the specified header, if it exists.
+
+ The last index of the requested header; otherwise -1.
+ The name of the header field.
+
+ is null.
+
+
+
+
+ Removes the first occurance of the specified header field.
+
+
+ Removes the first occurance of the specified header field, if any exist.
+
+ true if the first occurance of the specified
+ header was removed; otherwise false.
+ The header identifier.
+
+ is is not a valid .
+
+
+
+
+ Removes the first occurance of the specified header field.
+
+
+ Removes the first occurance of the specified header field, if any exist.
+
+ true if the first occurance of the specified
+ header was removed; otherwise false.
+ The name of the header field.
+
+ is null.
+
+
+
+
+ Removes all of the headers matching the specified field name.
+
+
+ Removes all of the headers matching the specified field name.
+
+ The header identifier.
+
+ is not a valid .
+
+
+
+
+ Removes all of the headers matching the specified field name.
+
+
+ Removes all of the headers matching the specified field name.
+
+ The name of the header field.
+
+ is null.
+
+
+
+
+ Replaces all headers with identical field names with the single specified header.
+
+
+ Replaces all headers with identical field names with the single specified header.
+ If no headers with the specified field name exist, it is simply added.
+
+ The header identifier.
+ The character encoding to use for the value.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a valid .
+
+
+
+
+ Replaces all headers with identical field names with the single specified header.
+
+
+ Replaces all headers with identical field names with the single specified header.
+ If no headers with the specified field name exist, it is simply added.
+
+ The header identifier.
+ The header value.
+
+ is null.
+
+
+ is not a valid .
+
+
+
+
+ Replaces all headers with identical field names with the single specified header.
+
+
+ Replaces all headers with identical field names with the single specified header.
+ If no headers with the specified field name exist, it is simply added.
+
+ The name of the header field.
+ The character encoding to use for the value.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Replaces all headers with identical field names with the single specified header.
+
+
+ Replaces all headers with identical field names with the single specified header.
+ If no headers with the specified field name exist, it is simply added.
+
+ The name of the header field.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Gets or sets the value of the first occurance of a header
+ with the specified field name.
+
+
+ Gets or sets the value of the first occurance of a header
+ with the specified field name.
+
+ The value of the first occurrance of the specified header if it exists; otherwise null.
+ The header identifier.
+
+ is null.
+
+
+
+
+ Gets or sets the value of the first occurance of a header
+ with the specified field name.
+
+
+ Gets or sets the value of the first occurance of a header
+ with the specified field name.
+
+ The value of the first occurrance of the specified header if it exists; otherwise null.
+ The name of the header field.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes all of the headers to the output stream.
+
+ The formatting options.
+ The output stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes all of the headers to the output stream.
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Gets the number of headers in the list.
+
+
+ Gets the number of headers in the list.
+
+ The number of headers.
+
+
+
+ Gets whether or not the header list is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Adds the specified header.
+
+
+ Adds the specified header to the end of the header list.
+
+ The header to add.
+
+ is null.
+
+
+
+
+ Clears the header list.
+
+
+ Removes all of the headers from the list.
+
+
+
+
+ Checks if the contains the specified header.
+
+
+ Determines whether or not the header list contains the specified header.
+
+ true if the specified header is contained;
+ otherwise, false.
+ The header.
+
+ is null.
+
+
+
+
+ Copies all of the headers in the to the specified array.
+
+
+ Copies all of the headers within the into the array,
+ starting at the specified array index.
+
+ The array to copy the headers to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified header.
+
+
+ Removes the specified header from the list if it exists.
+
+ true if the specified header was removed;
+ otherwise false.
+ The header.
+
+ is null.
+
+
+
+
+ Replaces all headers with identical field names with the single specified header.
+
+
+ Replaces all headers with identical field names with the single specified header.
+ If no headers with the specified field name exist, it is simply added.
+
+ The header.
+
+ is null.
+
+
+
+
+ Gets the index of the requested header, if it exists.
+
+
+ Finds the index of the specified header, if it exists.
+
+ The index of the requested header; otherwise -1.
+ The header.
+
+ is null.
+
+
+
+
+ Inserts the specified header at the given index.
+
+
+ Inserts the header at the specified index in the list.
+
+ The index to insert the header.
+ The header.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the header at the specified index.
+
+
+ Removes the header at the specified index.
+
+ The index.
+
+ is out of range.
+
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the at the specified index.
+
+ The header at the specified index.
+ The index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Gets an enumerator for the list of headers.
+
+
+ Gets an enumerator for the list of headers.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of headers.
+
+
+ Gets an enumerator for the list of headers.
+
+ The enumerator.
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ specified .
+
+ The parsed list of headers.
+ The parser options.
+ The stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the headers.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ default .
+
+ The parsed list of headers.
+ The stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified file.
+
+
+ Loads a from the file at the give file path,
+ using the specified .
+
+ The parsed list of headers.
+ The parser options.
+ The name of the file to load.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the headers.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified file.
+
+
+ Loads a from the file at the give file path,
+ using the default .
+
+ The parsed list of headers.
+ The name of the file to load.
+ A cancellation token.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the headers.
+
+
+ An I/O error occurred.
+
+
+
+
+ Header list changed action.
+
+
+ Specifies the way that a was changed.
+
+
+
+
+ A header was added.
+
+
+
+
+ A header was changed.
+
+
+
+
+ A header was removed.
+
+
+
+
+ The header list was cleared.
+
+
+
+
+ A collection of groups.
+
+
+ A collection of groups used with
+ .
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the number of groups in the collection.
+
+
+ Gets the number of groups in the collection.
+
+ The number of groups.
+
+
+
+ Gets whether or not the header list collection is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the at the specified index.
+
+ The group of headers at the specified index.
+ The index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Adds the group of headers to the collection.
+
+
+ Adds the group of headers to the collection.
+
+ The group of headers.
+
+ is null.
+
+
+
+
+ Clears the header list collection.
+
+
+ Removes all of the groups from the collection.
+
+
+
+
+ Checks if the collection contains the specified group of headers.
+
+
+ Determines whether or not the collection contains the specified group of headers.
+
+ true if the specified group of headers is contained;
+ otherwise, false.
+ The group of headers.
+
+ is null.
+
+
+
+
+ Copies all of the header groups in the to the specified array.
+
+
+ Copies all of the header groups within the into the array,
+ starting at the specified array index.
+
+ The array to copy the headers to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified header group.
+
+
+ Removes the specified header group from the collection, if it exists.
+
+ true if the specified header group was removed;
+ otherwise false.
+ The group of headers.
+
+ is null.
+
+
+
+
+ Gets an enumerator for the groups of headers.
+
+
+ Gets an enumerator for the groups of headers.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the groups of headers.
+
+
+ Gets an enumerator for the groups of headers.
+
+ The enumerator.
+
+
+
+ An interface for content stream encapsulation as used by .
+
+
+ Implemented by .
+
+
+
+
+ Gets the content encoding.
+
+
+ If the is not encoded, this value will be
+ . Otherwise, it will be
+ set to the raw content encoding of the stream.
+
+ The encoding.
+
+
+
+ Gets the content stream.
+
+
+ Gets the content stream.
+
+ The stream.
+
+
+
+ Opens the decoded content stream.
+
+
+ Provides a means of reading the decoded content without having to first write it to another
+ stream using .
+
+ The decoded content stream.
+
+
+
+ Decodes the content stream into another stream.
+
+
+ If the content stream is encoded, this method will decode it into the
+ output stream using a suitable decoder.
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was cancelled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Copies the content stream to the specified output stream.
+
+
+ Copies the data from into .
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was cancelled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ An internet address, as specified by rfc0822.
+
+
+ A can be any type of address defined by the
+ original Internet Message specification.
+ There are effectively two (2) types of addresses: mailboxes and groups.
+ Mailbox addresses are what are most commonly known as email addresses and are
+ represented by the class.
+ Group addresses are themselves lists of addresses and are represented by the
+ class. While rare, it is still important to handle these
+ types of addresses. They typically only contain mailbox addresses, but may also
+ contain other group addresses.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes the and properties of the internet address.
+
+ The character encoding to be used for encoding the name.
+ The name of the mailbox or group.
+
+ is null.
+
+
+
+
+ Gets or sets the character encoding to use when encoding the name of the address.
+
+
+ The character encoding is used to convert the property, if it is set,
+ to a stream of bytes when encoding the internet address for transport.
+
+ The character encoding.
+
+ is null.
+
+
+
+
+ Gets or sets the display name of the address.
+
+
+ A name is optional and is typically set to the name of the person
+ or group that own the internet address.
+
+ The name of the address.
+
+
+
+ Clone the address.
+
+
+ Clones the address.
+
+ The cloned address.
+
+
+
+ Compares two internet addresses.
+
+
+ Compares two internet addresses for the purpose of sorting.
+
+ The sort order of the current internet address compared to the other internet address.
+ The internet address to compare to.
+
+ is null.
+
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Compares two internet addresses to determine if they are identical or not.
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ Returns a string representation of the ,
+ optionally encoding it for transport.
+
+
+ If the parameter is true, then this method will return
+ an encoded version of the internet address according to the rules described in rfc2047.
+ However, if the parameter is false, then this method will
+ return a string suitable only for display purposes.
+
+ A string representing the .
+ The formatting options.
+ If set to true, the will be encoded.
+
+ is null.
+
+
+
+
+ Returns a string representation of the ,
+ optionally encoding it for transport.
+
+
+ If the parameter is true, then this method will return
+ an encoded version of the internet address according to the rules described in rfc2047.
+ However, if the parameter is false, then this method will
+ return a string suitable only for display purposes.
+
+ A string representing the .
+ If set to true, the will be encoded.
+
+
+
+ Returns a string representation of a suitable for display.
+
+
+ The string returned by this method is suitable only for display purposes.
+
+ A string representing the .
+
+
+
+ Raises the internal changed event used by to keep headers in sync.
+
+
+ This method is called whenever a property of the internet address is changed.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed address.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed address.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed address.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed address.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The parsed address.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed address.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a single or . If the text contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The text.
+ The parsed address.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a single or . If the text contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The text.
+ The parsed address.
+
+ is null.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a single or . If the text contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The text.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a single or . If the text contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The text.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ A list of email addresses.
+
+
+ An may contain any number of addresses of any type
+ defined by the original Internet Message specification.
+ There are effectively two (2) types of addresses: mailboxes and groups.
+ Mailbox addresses are what are most commonly known as email addresses and are
+ represented by the class.
+ Group addresses are themselves lists of addresses and are represented by the
+ class. While rare, it is still important to handle these
+ types of addresses. They typically only contain mailbox addresses, but may also
+ contain other group addresses.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new containing the supplied addresses.
+
+ An initial list of addresses.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new, empty, .
+
+
+
+
+ Recursively gets all of the mailboxes contained within the .
+
+
+ This API is useful for collecting a flattened list of
+ recipients for use with sending via SMTP or for encrypting via S/MIME or PGP/MIME.
+
+ The mailboxes.
+
+
+
+ Gets the index of the specified address.
+
+
+ Finds the index of the specified address, if it exists.
+
+ The index of the specified address if found; otherwise -1.
+ The address to get the index of.
+
+ is null.
+
+
+
+
+ Inserts the address at the specified index.
+
+
+ Inserts the address at the specified index in the list.
+
+ The index to insert the address.
+ The address.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the address at the specified index.
+
+
+ Removes the address at the specified index.
+
+ The index of the address to remove.
+
+ is out of range.
+
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the at the specified index.
+
+ The internet address at the specified index.
+ The index of the address to get or set.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Gets the number of addresses in the .
+
+
+ Indicates the number of addresses in the list.
+
+ The number of addresses.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Adds the specified address.
+
+
+ Adds the specified address to the end of the address list.
+
+ The address.
+
+ is null.
+
+
+
+
+ Adds a collection of addresses.
+
+
+ Adds a range of addresses to the end of the address list.
+
+ A colelction of addresses.
+
+ is null.
+
+
+
+
+ Clears the address list.
+
+
+ Removes all of the addresses from the list.
+
+
+
+
+ Checks if the contains the specified address.
+
+
+ Determines whether or not the address list contains the specified address.
+
+ true if the specified address exists;
+ otherwise false.
+ The address.
+
+ is null.
+
+
+
+
+ Copies all of the addresses in the to the specified array.
+
+
+ Copies all of the addresses within the into the array,
+ starting at the specified array index.
+
+ The array to copy the addresses to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified address.
+
+
+ Removes the specified address.
+
+ true if the address was removed; otherwise false.
+ The address.
+
+ is null.
+
+
+
+
+ Gets an enumerator for the list of addresses.
+
+
+ Gets an enumerator for the list of addresses.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of addresses.
+
+
+ Gets an enumerator for the list of addresses.
+
+ The enumerator.
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Determines whether the specified is equal to the current .
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ Compares two internet address lists.
+
+
+ Compares two internet address lists for the purpose of sorting.
+
+ The sort order of the current internet address list compared to the other internet address list.
+ The internet address list to compare to.
+
+ is null.
+
+
+
+
+ Returns a string representation of the email addresses in the ,
+ optionally encoding them for transport.
+
+
+ If is true, each address in the list will be encoded
+ according to the rules defined in rfc2047.
+ If there are multiple addresses in the list, they will be separated by a comma.
+
+ A string representing the .
+ The formatting options.
+ If set to true, each in the list will be encoded.
+
+
+
+ Returns a string representation of the email addresses in the ,
+ optionally encoding them for transport.
+
+
+ If is true, each address in the list will be encoded
+ according to the rules defined in rfc2047.
+ If there are multiple addresses in the list, they will be separated by a comma.
+
+ A string representing the .
+ If set to true, each in the list will be encoded.
+
+
+
+ Returns a string representation of the email addresses in the .
+
+
+ If there are multiple addresses in the list, they will be separated by a comma.
+
+ A string representing the .
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed addresses.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed addresses.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the specified index.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed addresses.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the specified index.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed addresses.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the specified buffer.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The parsed addresses.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the specified buffer.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed addresses.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a list of addresses from the specified text.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The parser options to use.
+ The text.
+ The parsed addresses.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a list of addresses from the specified text.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The text.
+ The parsed addresses.
+
+ is null.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the specified index.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the specified index.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the specified buffer.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the specified buffer.
+
+ The parsed .
+ The input buffer.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a list of addresses from the specified text.
+
+ The parsed .
+ The parser options to use.
+ The text.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a list of addresses from the specified text.
+
+ The parsed .
+ The text.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Explicit cast to convert a to a
+ .
+
+
+ Casts a to a
+ in cases where you might want to make use of the System.Net.Mail APIs.
+
+ The equivalent .
+ The addresses.
+
+ contains one or more group addresses and cannot be converted.
+
+
+
+
+ Explicit cast to convert a
+ to a .
+
+
+ Casts a to a
+ in cases where you might want to make use of the the superior MimeKit APIs.
+
+ The equivalent .
+ The mail address.
+
+
+
+ A mailbox address, as specified by rfc822.
+
+
+ Represents a mailbox address (commonly referred to as an email address)
+ for a single recipient.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name, address and route. The
+ specified text encoding is used when encoding the name according to the rules of rfc2047.
+
+ The character encoding to be used for encoding the name.
+ The name of the mailbox.
+ The route of the mailbox.
+ The address of the mailbox.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name, address and route.
+
+ The name of the mailbox.
+ The route of the mailbox.
+ The address of the mailbox.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name and address. The
+ specified text encoding is used when encoding the name according to the rules of rfc2047.
+
+ The character encoding to be used for encoding the name.
+ The name of the mailbox.
+ The address of the mailbox.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name and address.
+
+ The name of the mailbox.
+ The address of the mailbox.
+
+ is null.
+
+
+
+
+ Clone the mailbox address.
+
+
+ Clones the mailbox address.
+
+ The cloned mailbox address.
+
+
+
+ Gets the mailbox route.
+
+
+ A route is convention that is rarely seen in modern email systems, but is supported
+ for compatibility with email archives.
+
+ The mailbox route.
+
+
+
+ Gets or sets the mailbox address.
+
+
+ Represents the actual email address and is in the form of "name@example.com".
+
+ The mailbox address.
+
+ is null.
+
+
+
+
+ Gets whether or not the address is an international address.
+
+
+ International addresses are addresses that contain international
+ characters in either their local-parts or their domains.
+ For more information, see section 3.2 of
+ rfc6532.
+
+ true if the address is an international address; otherwise, false.
+
+
+
+ Returns a string representation of the ,
+ optionally encoding it for transport.
+
+
+ Returns a string containing the formatted mailbox address. If the
+ parameter is true, then the mailbox name will be encoded according to the rules defined
+ in rfc2047, otherwise the name will not be encoded at all and will therefor only be suitable
+ for display purposes.
+
+ A string representing the .
+ The formatting options.
+ If set to true, the will be encoded.
+
+ is null.
+
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Compares two mailbox addresses to determine if they are identical or not.
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed mailbox address.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed mailbox address.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed mailbox address.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed mailbox address.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The parsed mailbox address.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed mailbox address.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The text.
+ The parsed mailbox address.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The text.
+ The parsed mailbox address.
+
+ is null.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The text.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The text.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Explicit cast to convert a to a
+ .
+
+
+ Casts a to a
+ in cases where you might want to make use of the System.Net.Mail APIs.
+
+ The equivalent .
+ The mailbox.
+
+
+
+ Explicit cast to convert a
+ to a .
+
+
+ Casts a to a
+ in cases where you might want to make use of the the superior MimeKit APIs.
+
+ The equivalent .
+ The mail address.
+
+
+
+ A message delivery status MIME part.
+
+
+ A message delivery status MIME part is a machine readable notification denoting the
+ delivery status of a message and has a MIME-type of message/delivery-status.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Get the groups of delivery status fields.
+
+
+ Gets the groups of delivery status fields. The first group of fields
+ contains the per-message fields while each of the following groups
+ contains fields that pertain to particular recipients of the message.
+
+ The fields.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ A message disposition notification MIME part.
+
+
+ A message disposition notification MIME part is a machine readable notification
+ denoting the disposition of a message once it has been successfully delivered
+ and has a MIME-type of message/disposition-notification.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Get the disposition notification fields.
+
+
+ Gets the disposition notification fields.
+
+ The fields.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ A list of Message-Ids.
+
+
+ Used by the property.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new, empty, .
+
+
+
+
+ Clones the .
+
+
+ Creates an exact copy of the .
+
+ An exact copy of the .
+
+
+
+ Gets the index of the requested Message-Id, if it exists.
+
+
+ Finds the index of the specified Message-Id, if it exists.
+
+ The index of the requested Message-Id; otherwise -1.
+ The Message-Id.
+
+ is null.
+
+
+
+
+ Insert the Message-Id at the specified index.
+
+
+ Inserts the Message-Id at the specified index in the list.
+
+ The index to insert the Message-Id.
+ The Message-Id to insert.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the Message-Id at the specified index.
+
+
+ Removes the Message-Id at the specified index.
+
+ The index.
+
+ is out of range.
+
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the Message-Id at the specified index.
+
+ The Message-Id at the specified index.
+ The index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Add the specified Message-Id.
+
+
+ Adds the specified Message-Id to the end of the list.
+
+ The Message-Id.
+
+ is null.
+
+
+
+
+ Add a collection of Message-Id items.
+
+
+ Adds a collection of Message-Id items to append to the list.
+
+ The Message-Id items to add.
+
+ is null.
+
+
+
+
+ Clears the Message-Id list.
+
+
+ Removes all of the Message-Ids in the list.
+
+
+
+
+ Checks if the contains the specified Message-Id.
+
+
+ Determines whether or not the list contains the specified Message-Id.
+
+ true if the specified Message-Id is contained;
+ otherwise false.
+ The Message-Id.
+
+ is null.
+
+
+
+
+ Copies all of the Message-Ids in the to the specified array.
+
+
+ Copies all of the Message-Ids within the into the array,
+ starting at the specified array index.
+
+ The array to copy the Message-Ids to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified Message-Id.
+
+
+ Removes the first instance of the specified Message-Id from the list if it exists.
+
+ true if the specified Message-Id was removed;
+ otherwise false.
+ The Message-Id.
+
+ is null.
+
+
+
+
+ Gets the number of Message-Ids in the .
+
+
+ Indicates the number of Message-Ids in the list.
+
+ The number of Message-Ids.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Gets an enumerator for the list of Message-Ids.
+
+
+ Gets an enumerator for the list of Message-Ids.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of Message-Ids.
+
+
+ Gets an enumerator for the list of Message-Ids.
+
+ The enumerator.
+
+
+
+ Returns a string representation of the list of Message-Ids.
+
+
+ Each Message-Id will be surrounded by angle brackets.
+ If there are multiple Message-Ids in the list, they will be separated by whitespace.
+
+ A string representing the .
+
+
+
+ An enumeration of message importance values.
+
+
+ Indicates the importance of a message.
+
+
+
+
+ The message is of low importance.
+
+
+
+
+ The message is of normal importance.
+
+
+
+
+ The message is of high importance.
+
+
+
+
+ A MIME part containing a as its content.
+
+
+ Represents MIME entities such as those with a Content-Type of message/rfc822 or message/news.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The message subtype.
+ An array of initialization parameters: headers and message parts.
+
+ is null.
+ -or-
+ is null.
+
+
+ contains more than one .
+ -or-
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new MIME message entity with the specified subtype.
+
+ The message subtype.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message/rfc822 MIME entity.
+
+
+
+
+ Gets or sets the message content.
+
+
+ Gets or sets the message content.
+
+ The message content.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Prepare the MIME entity for transport using the specified encoding constraints.
+
+
+ Prepares the MIME entity for transport using the specified encoding constraints.
+
+ The encoding constraint.
+ The maximum number of octets allowed per line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Writes the to the output stream.
+
+
+ Writes the MIME entity and its message to the output stream.
+
+ The formatting options.
+ The output stream.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ A MIME part containing a partial message as its content.
+
+
+ The "message/partial" MIME-type is used to split large messages into
+ multiple parts, typically to work around transport systems that have size
+ limitations (for example, some SMTP servers limit have a maximum message
+ size that they will accept).
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message/partial entity.
+ Three (3) parameters must be specified in the Content-Type header
+ of a message/partial: id, number, and total.
+ The "id" parameter is a unique identifier used to match the parts together.
+ The "number" parameter is the sequential (1-based) index of the partial message fragment.
+ The "total" parameter is the total number of pieces that make up the complete message.
+
+ The id value shared among the partial message parts.
+ The (1-based) part number for this partial message part.
+ The total number of partial message parts.
+
+ is null.
+
+
+ is less than 1.
+ -or-
+ is less than .
+
+
+
+
+ Gets the "id" parameter of the Content-Type header.
+
+
+ The "id" parameter is a unique identifier used to match the parts together.
+
+ The identifier.
+
+
+
+ Gets the "number" parameter of the Content-Type header.
+
+
+ The "number" parameter is the sequential (1-based) index of the partial message fragment.
+
+ The part number.
+
+
+
+ Gets the "total" parameter of the Content-Type header.
+
+
+ The "total" parameter is the total number of pieces that make up the complete message.
+
+ The total number of parts.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Splits the specified message into multiple messages.
+
+
+ Splits the specified message into multiple messages, each with a
+ message/partial body no larger than the max size specified.
+
+ An enumeration of partial messages.
+ The message.
+ The maximum size for each message body.
+
+ is null.
+
+
+ is less than 1.
+
+
+
+
+ Joins the specified message/partial parts into the complete message.
+
+
+ Combines all of the message/partial fragments into its original,
+ complete, message.
+
+ The re-combined message.
+ The parser options to use.
+ The list of partial message parts.
+
+ is null.
+ -or-
+ is null.
+
+
+ The last partial does not have a Total.
+ -or-
+ The number of partials provided does not match the expected count.
+ -or-
+ One or more partials is missing.
+
+
+
+
+ Joins the specified message/partial parts into the complete message.
+
+
+ Combines all of the message/partial fragments into its original,
+ complete, message.
+
+ The re-combined message.
+ The list of partial message parts.
+
+ is null.
+
+
+
+
+ An enumeration of message priority values.
+
+
+ Indicates the priority of a message.
+
+
+
+
+ The message has normal priority.
+
+
+
+
+ The message has non-urgent priority.
+
+
+
+
+ The message has urgent priority.
+
+
+
+
+ An abstract MIME entity.
+
+
+ A MIME entity is really just a node in a tree structure of MIME parts in a MIME message.
+ There are 3 basic types of entities: , ,
+ and (which is actually just a special variation of
+ who's content is another MIME message/document). All other types are
+ derivatives of one of those.
+
+
+
+
+ Initializes a new instance of the class
+ based on the .
+
+
+ Custom subclasses MUST implement this constructor
+ in order to register it using .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes the based on the provided media type and subtype.
+
+ The media type.
+ The media subtype.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes the to the one provided.
+
+ The content type.
+
+ is null.
+
+
+
+
+ Tries to use the given object to initialize the appropriate property.
+
+
+ Initializes the appropriate property based on the type of the object.
+
+ The object.
+ true if the object was recognized and used; false otherwise.
+
+
+
+ Gets the list of headers.
+
+
+ Represents the list of headers for a MIME part. Typically, the headers of
+ a MIME part will be various Content-* headers such as Content-Type or
+ Content-Disposition, but may include just about anything.
+
+ The list of headers.
+
+
+
+ Gets or sets the content disposition.
+
+
+ Represents the pre-parsed Content-Disposition header value, if present.
+ If the Content-Disposition header is not set, then this property will
+ be null.
+
+ The content disposition.
+
+
+
+ Gets the type of the content.
+
+
+ The Content-Type header specifies information about the type of content contained
+ within the MIME entity.
+
+ The type of the content.
+
+
+
+ Gets or sets the base content URI.
+
+
+ The Content-Base header specifies the base URI for the
+ in cases where the is a relative URI.
+ The Content-Base URI must be an absolute URI.
+ For more information, see rfc2110.
+
+ The base content URI or null.
+
+ is not an absolute URI.
+
+
+
+
+ Gets or sets the content location.
+
+
+ The Content-Location header specifies the URI for a MIME entity and can be
+ either absolute or relative.
+ Setting a Content-Location URI allows other objects
+ within the same multipart/related container to reference this part by URI. This
+ can be useful, for example, when constructing an HTML message body that needs to
+ reference image attachments.
+ For more information, see rfc2110.
+
+ The content location or null.
+
+
+
+ Gets or sets the content identifier.
+
+
+ The Content-Id header is used for uniquely identifying a particular entity and
+ uses the same syntax as the Message-Id header on MIME messages.
+ Setting a Content-Id allows other objects within the same
+ multipart/related container to reference this part by its unique identifier, typically
+ by using a "cid:" URI in an HTML-formatted message body. This can be useful, for example,
+ when the HTML-formatted message body needs to reference image attachments.
+
+ The content identifier.
+
+
+
+ Gets a value indicating whether this is an attachment.
+
+
+ If the Content-Disposition header is set and has a value of "attachment",
+ then this property returns true. Otherwise it is assumed that the
+ is not meant to be treated as an attachment.
+
+ true if this is an attachment; otherwise, false.
+
+
+
+ Returns a that represents the current .
+
+
+ Returns a that represents the current .
+
+ A that represents the current .
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Prepare the MIME entity for transport using the specified encoding constraints.
+
+
+ Prepares the MIME entity for transport using the specified encoding constraints.
+
+ The encoding constraint.
+ The maximum allowable length for a line (not counting the CRLF). Must be between 72 and 998 (inclusive).
+
+ is not between 72 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes the headers to the output stream, followed by a blank line.
+ Subclasses should override this method to write the content of the entity.
+
+ The formatting options.
+ The output stream.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes the headers to the output stream, followed by a blank line.
+ Subclasses should override this method to write the content of the entity.
+
+ The formatting options.
+ The output stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes the entity to the output stream.
+
+ The output stream.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes the entity to the output stream.
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified file.
+
+
+ Writes the to the specified file using the provided formatting options.
+
+ The formatting options.
+ The file.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The operation was canceled via the cancellation token.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to write to the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified file.
+
+
+ Writes the to the specified file using the provided formatting options.
+
+ The formatting options.
+ The file.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The operation was canceled via the cancellation token.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to write to the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified file.
+
+
+ Writes the to the specified file using the default formatting options.
+
+ The file.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The operation was canceled via the cancellation token.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to write to the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified file.
+
+
+ Writes the to the specified file using the default formatting options.
+
+ The file.
+ A cancellation token.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The operation was canceled via the cancellation token.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to write to the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Removes the header.
+
+
+ Removes all headers matching the specified name without
+ calling .
+
+ The name of the header.
+
+
+
+ Sets the header.
+
+
+ Sets the header to the specified value without
+ calling .
+
+ The name of the header.
+ The value of the header.
+
+
+
+ Sets the header using the raw value.
+
+
+ Sets the header to the specified value without
+ calling .
+
+ The name of the header.
+ The raw value of the header.
+
+
+
+ Called when the headers change in some way.
+
+
+ Whenever a header is added, changed, or removed, this method will
+ be called in order to allow custom subclasses
+ to update their state.
+ Overrides of this method should call the base method so that their
+ superclass may also update its own state.
+
+ The type of change.
+ The header being added, changed or removed.
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ specified .
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save mmeory usage, but also improve
+ performance.
+
+ The parsed MIME entity.
+ The parser options.
+ The stream.
+ true if the stream is persistent; otherwise false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ specified .
+
+ The parsed MIME entity.
+ The parser options.
+ The stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ default .
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save mmeory usage, but also improve
+ performance.
+
+ The parsed MIME entity.
+ The stream.
+ true if the stream is persistent; otherwise false.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ default .
+
+ The parsed MIME entity.
+ The stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified file.
+
+
+ Loads a from the file at the give file path,
+ using the specified .
+
+ The parsed entity.
+ The parser options.
+ The name of the file to load.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified file.
+
+
+ Loads a from the file at the give file path,
+ using the default .
+
+ The parsed entity.
+ The name of the file to load.
+ A cancellation token.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified content stream.
+
+
+ This method is mostly meant for use with APIs such as
+ where the headers are parsed separately from the content.
+
+ The parsed MIME entity.
+ The parser options.
+ The Content-Type of the stream.
+ The content stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified content stream.
+
+
+ This method is mostly meant for use with APIs such as
+ where the headers are parsed separately from the content.
+
+ The parsed MIME entity.
+ The Content-Type of the stream.
+ The content stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ MIME entity constructor arguments.
+
+
+ MIME entity constructor arguments.
+
+
+
+
+ The format of the MIME stream.
+
+
+ The format of the MIME stream.
+
+
+
+
+ The stream contains a single MIME entity or message.
+
+
+
+
+ The stream is in the Unix mbox format and may contain
+ more than a single message.
+
+
+
+
+ The default stream format.
+
+
+
+
+ An iterator for a MIME tree structure.
+
+
+ Walks the MIME tree structure of a in depth-first order.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new for the specified message.
+
+ The message.
+
+ is null.
+
+
+
+
+ Releases unmanaged resources and performs other cleanup operations before
+ the is reclaimed by garbage collection.
+
+
+ Releases unmanaged resources and performs other cleanup operations before
+ the is reclaimed by garbage collection.
+
+
+
+
+ Gets the top-level message.
+
+
+ Gets the top-level message.
+
+ The message.
+
+
+
+ Gets the parent of the current entity.
+
+
+ After an iterator is created or after the method is called,
+ the method must be called to advance the iterator to the
+ first entity of the message before reading the value of the Parent property;
+ otherwise, Parent throws a . Parent
+ also throws a if the last call to
+ returned false, which indicates the end of the message.
+ If the current entity is the top-level entity of the message, then the parent
+ will be null; otherwise the parent will be either be a
+ or a .
+
+ The parent entity.
+
+ Either has not been called or
+ has moved beyond the end of the message.
+
+
+
+
+ Gets the current entity.
+
+
+ After an iterator is created or after the method is called,
+ the method must be called to advance the iterator to the
+ first entity of the message before reading the value of the Current property;
+ otherwise, Current throws a . Current
+ also throws a if the last call to
+ returned false, which indicates the end of the message.
+
+ The current entity.
+
+ Either has not been called or
+ has moved beyond the end of the message.
+
+
+
+
+ Gets the current entity.
+
+
+ After an iterator is created or after the method is called,
+ the method must be called to advance the iterator to the
+ first entity of the message before reading the value of the Current property;
+ otherwise, Current throws a . Current
+ also throws a if the last call to
+ returned false, which indicates the end of the message.
+
+ The current entity.
+
+ Either has not been called or
+ has moved beyond the end of the message.
+
+
+
+
+ Gets the path specifier for the current entity.
+
+
+ After an iterator is created or after the method is called,
+ the method must be called to advance the iterator to the
+ first entity of the message before reading the value of the PathSpecifier property;
+ otherwise, PathSpecifier throws a .
+ PathSpecifier also throws a if the
+ last call to returned false, which indicates the end of
+ the message.
+
+ The path specifier.
+
+ Either has not been called or
+ has moved beyond the end of the message.
+
+
+
+
+ Gets the depth of the current entity.
+
+
+ After an iterator is created or after the method is called,
+ the method must be called to advance the iterator to the
+ first entity of the message before reading the value of the Depth property;
+ otherwise, Depth throws a . Depth
+ also throws a if the last call to
+ returned false, which indicates the end of the message.
+
+ The depth.
+
+ Either has not been called or
+ has moved beyond the end of the message.
+
+
+
+
+ Advances the iterator to the next depth-first entity of the tree structure.
+
+
+ After an iterator is created or after the method is called,
+ an iterator is positioned before the first entity of the message, and the first
+ call to the MoveNext method moves the iterator to the first entity of the message.
+ If MoveNext advances beyond the last entity of the message, MoveNext returns false.
+ When the iterator is at this position, subsequent calls to MoveNext also return
+ false until is called.
+
+ true if the iterator was successfully advanced to the next entity; otherwise, false.
+
+
+
+ Advances to the entity specified by the path specifier.
+
+
+ Advances the iterator to the entity specified by the path specifier which
+ must be in the same format as returned by .
+ If the iterator has already advanced beyond the entity at the specified
+ path, the iterator will and advance as normal.
+
+ true if advancing to the specified entity was successful; otherwise, false.
+ The path specifier.
+
+ is null.
+
+
+ is empty.
+
+
+ is in an invalid format.
+
+
+
+
+ Resets the iterator to its initial state.
+
+
+ Resets the iterator to its initial state.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ Releases all resources used by the object.
+
+ Call when you are finished using the . The
+ method leaves the in an unusable state. After
+ calling , you must release all references to the so
+ the garbage collector can reclaim the memory that the was occupying.
+
+
+
+ A MIME message.
+
+
+ A message consists of header fields and, optionally, a body.
+ The body of the message can either be plain text or it can be a
+ tree of MIME entities such as a text/plain MIME part and a collection
+ of file attachments.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ An array of initialization parameters: headers and message parts.
+
+ is null.
+
+
+ contains more than one .
+ -or-
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new MIME message, specifying details at creation time.
+
+ The list of addresses in the From header.
+ The list of addresses in the To header.
+ The subject of the message.
+ The body of the message.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new MIME message.
+
+
+
+
+ Gets or sets the mbox marker.
+
+
+ Set by the when parsing attached message/rfc822 parts
+ so that the message/rfc822 part can be reserialized back to its original form.
+
+ The mbox marker.
+
+
+
+ Gets the list of headers.
+
+
+ Represents the list of headers for a message. Typically, the headers of
+ a message will contain transmission headers such as From and To along
+ with metadata headers such as Subject and Date, but may include just
+ about anything.
+ To access any MIME headers other than
+ , you will need to access the
+ property of the .
+
+
+ The list of headers.
+
+
+
+ Get or set the value of the Importance header.
+
+
+ Gets or sets the value of the Importance header.
+
+ The importance.
+
+ is not a valid .
+
+
+
+
+ Get or set the value of the Priority header.
+
+
+ Gets or sets the value of the Priority header.
+
+ The priority.
+
+ is not a valid .
+
+
+
+
+ Gets or sets the address in the Sender header.
+
+
+ The sender may differ from the addresses in if
+ the message was sent by someone on behalf of someone else.
+
+ The address in the Sender header.
+
+
+
+ Gets or sets the address in the Resent-Sender header.
+
+
+ The resent sender may differ from the addresses in if
+ the message was sent by someone on behalf of someone else.
+
+ The address in the Resent-Sender header.
+
+
+
+ Gets the list of addresses in the From header.
+
+
+ The "From" header specifies the author(s) of the message.
+ If more than one is added to the
+ list of "From" addresses, the should be set to the
+ single of the personal actually sending
+ the message.
+
+ The list of addresses in the From header.
+
+
+
+ Gets the list of addresses in the Resent-From header.
+
+
+ The "Resent-From" header specifies the author(s) of the messagebeing
+ resent.
+ If more than one is added to the
+ list of "Resent-From" addresses, the should
+ be set to the single of the personal actually
+ sending the message.
+
+ The list of addresses in the Resent-From header.
+
+
+
+ Gets the list of addresses in the Reply-To header.
+
+
+ When the list of addresses in the Reply-To header is not empty,
+ it contains the address(es) where the author(s) of the message prefer
+ that replies be sent.
+ When the list of addresses in the Reply-To header is empty,
+ replies should be sent to the mailbox(es) specified in the From
+ header.
+
+ The list of addresses in the Reply-To header.
+
+
+
+ Gets the list of addresses in the Resent-Reply-To header.
+
+
+ When the list of addresses in the Resent-Reply-To header is not empty,
+ it contains the address(es) where the author(s) of the resent message prefer
+ that replies be sent.
+ When the list of addresses in the Resent-Reply-To header is empty,
+ replies should be sent to the mailbox(es) specified in the Resent-From
+ header.
+
+ The list of addresses in the Resent-Reply-To header.
+
+
+
+ Gets the list of addresses in the To header.
+
+
+ The addresses in the To header are the primary recipients of
+ the message.
+
+ The list of addresses in the To header.
+
+
+
+ Gets the list of addresses in the Resent-To header.
+
+
+ The addresses in the Resent-To header are the primary recipients of
+ the message.
+
+ The list of addresses in the Resent-To header.
+
+
+
+ Gets the list of addresses in the Cc header.
+
+
+ The addresses in the Cc header are secondary recipients of the message
+ and are usually not the individuals being directly addressed in the
+ content of the message.
+
+ The list of addresses in the Cc header.
+
+
+
+ Gets the list of addresses in the Resent-Cc header.
+
+
+ The addresses in the Resent-Cc header are secondary recipients of the message
+ and are usually not the individuals being directly addressed in the
+ content of the message.
+
+ The list of addresses in the Resent-Cc header.
+
+
+
+ Gets the list of addresses in the Bcc header.
+
+
+ Recipients in the Blind-Carpbon-Copy list will not be visible to
+ the other recipients of the message.
+
+ The list of addresses in the Bcc header.
+
+
+
+ Gets the list of addresses in the Resent-Bcc header.
+
+
+ Recipients in the Resent-Bcc list will not be visible to
+ the other recipients of the message.
+
+ The list of addresses in the Resent-Bcc header.
+
+
+
+ Gets or sets the subject of the message.
+
+
+ The Subject is typically a short string denoting the topic of the message.
+ Replies will often use "Re: " followed by the Subject of the original message.
+
+ The subject of the message.
+
+ is null.
+
+
+
+
+ Gets or sets the date of the message.
+
+
+ If the date is not explicitly set before the message is written to a stream,
+ the date will default to the exact moment when it is written to said stream.
+
+ The date of the message.
+
+
+
+ Gets or sets the Resent-Date of the message.
+
+
+ Gets or sets the Resent-Date of the message.
+
+ The Resent-Date of the message.
+
+
+
+ Gets or sets the list of references to other messages.
+
+
+ The References header contains a chain of Message-Ids back to the
+ original message that started the thread.
+
+ The references.
+
+
+
+ Gets or sets the Message-Id that this message is in reply to.
+
+
+ If the message is a reply to another message, it will typically
+ use the In-Reply-To header to specify the Message-Id of the
+ original message being replied to.
+
+ The message id that this message is in reply to.
+
+ is improperly formatted.
+
+
+
+
+ Gets or sets the message identifier.
+
+
+ The Message-Id is meant to be a globally unique identifier for
+ a message.
+ can be used
+ to generate this value.
+
+ The message identifier.
+
+ is null.
+
+
+ is improperly formatted.
+
+
+
+
+ Gets or sets the Resent-Message-Id header.
+
+
+ The Resent-Message-Id is meant to be a globally unique identifier for
+ a message.
+ can be used
+ to generate this value.
+
+ The Resent-Message-Id.
+
+ is null.
+
+
+ is improperly formatted.
+
+
+
+
+ Gets or sets the MIME-Version.
+
+
+ The MIME-Version header specifies the version of the MIME specification
+ that the message was created for.
+
+ The MIME version.
+
+ is null.
+
+
+
+
+ Gets or sets the body of the message.
+
+
+ The body of the message can either be plain text or it can be a
+ tree of MIME entities such as a text/plain MIME part and a collection
+ of file attachments.
+ For a convenient way of constructing message bodies, see the
+ class.
+
+ The body of the message.
+
+
+
+ Gets the text body of the message if it exists.
+
+
+ Gets the text content of the first text/plain body part that is found (in depth-first
+ search order) which is not an attachment.
+
+ The text body if it exists; otherwise, null.
+
+
+
+ Gets the html body of the message if it exists.
+
+
+ Gets the HTML-formatted body of the message if it exists.
+
+ The html body if it exists; otherwise, null.
+
+
+
+ Gets the text body in the specified format.
+
+
+ Gets the text body in the specified format, if it exists.
+
+ The text body in the desired format if it exists; otherwise, null.
+ The desired text format.
+
+
+
+ Gets the body parts of the message.
+
+
+ Traverses over the MIME tree, enumerating all of the objects,
+ but does not traverse into the bodies of attached messages.
+
+ The body parts.
+
+
+
+ Gets the attachments.
+
+
+ Traverses over the MIME tree, enumerating all of the objects that
+ have a Content-Disposition header set to "attachment".
+
+ The attachments.
+
+
+
+ Returns a that represents the current .
+
+
+ Returns a that represents the current .
+ Note: In general, the string returned from this method SHOULD NOT be used for serializing
+ the message to disk. It is recommended that you use instead.
+
+ A that represents the current .
+
+
+
+ Dispatches to the specific visit method for this MIME message.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Prepare the message for transport using the specified encoding constraints.
+
+
+ Prepares the message for transport using the specified encoding constraints.
+
+ The encoding constraint.
+ The maximum allowable length for a line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Writes the message to the specified output stream.
+
+
+ Writes the message to the output stream using the provided formatting options.
+
+ The formatting options.
+ The output stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the message to the specified output stream.
+
+
+ Writes the message to the output stream using the default formatting options.
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the message to the specified file.
+
+
+ Writes the message to the specified file using the provided formatting options.
+
+ The formatting options.
+ The file.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The operation was canceled via the cancellation token.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to write to the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the message to the specified file.
+
+
+ Writes the message to the specified file using the default formatting options.
+
+ The file.
+ A cancellation token.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The operation was canceled via the cancellation token.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to write to the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Digitally sign the message using a DomainKeys Identified Mail (DKIM) signature.
+
+
+ Digitally signs the message using a DomainKeys Identified Mail (DKIM) signature.
+
+ The formatting options.
+ The DKIM signer.
+ The list of header fields to sign.
+ The header canonicalization algorithm.
+ The body canonicalization algorithm.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ does not contain the 'From' header.
+ -or-
+ contains one or more of the following headers: Return-Path,
+ Received, Comments, Keywords, Bcc, Resent-Bcc, or DKIM-Signature.
+
+
+
+
+ Digitally sign the message using a DomainKeys Identified Mail (DKIM) signature.
+
+
+ Digitally signs the message using a DomainKeys Identified Mail (DKIM) signature.
+
+ The DKIM signer.
+ The headers to sign.
+ The header canonicalization algorithm.
+ The body canonicalization algorithm.
+
+ is null.
+ -or-
+ is null.
+
+
+ does not contain the 'From' header.
+ -or-
+ contains one or more of the following headers: Return-Path,
+ Received, Comments, Keywords, Bcc, Resent-Bcc, or DKIM-Signature.
+
+
+
+
+ Verify the specified DKIM-Signature header.
+
+
+ Verifies the specified DKIM-Signature header.
+
+ true if the DKIM-Signature is valid; otherwise, false.
+ The formatting options.
+ The DKIM-Signature header.
+ The public key locator service.
+ The cancellation token.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ is not a DKIM-Signature header.
+
+
+ The DKIM-Signature header value is malformed.
+
+
+ The operation was canceled via the cancellation token.
+
+
+
+
+ Verify the specified DKIM-Signature header.
+
+
+ Verifies the specified DKIM-Signature header.
+
+ true if the DKIM-Signature is valid; otherwise, false.
+ The DKIM-Signature header.
+ The public key locator service.
+ The cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a DKIM-Signature header.
+
+
+ The DKIM-Signature header value is malformed.
+
+
+ The operation was canceled via the cancellation token.
+
+
+
+
+ Sign the message using the specified cryptography context and digest algorithm.
+
+
+ If either of the Resent-Sender or Resent-From headers are set, then the message
+ will be signed using the Resent-Sender (or first mailbox in the Resent-From)
+ address as the signer address, otherwise the Sender or From address will be
+ used instead.
+
+ The cryptography context.
+ The digest algorithm.
+
+ is null.
+
+
+ The has not been set.
+ -or-
+ A sender has not been specified.
+
+
+ The was out of range.
+
+
+ The is not supported.
+
+
+ A signing certificate could not be found for the sender.
+
+
+ The private key could not be found for the sender.
+
+
+
+
+ Sign the message using the specified cryptography context and the SHA-1 digest algorithm.
+
+
+ If either of the Resent-Sender or Resent-From headers are set, then the message
+ will be signed using the Resent-Sender (or first mailbox in the Resent-From)
+ address as the signer address, otherwise the Sender or From address will be
+ used instead.
+
+ The cryptography context.
+
+ is null.
+
+
+ The has not been set.
+ -or-
+ A sender has not been specified.
+
+
+ A signing certificate could not be found for the sender.
+
+
+ The private key could not be found for the sender.
+
+
+
+
+ Encrypt the message to the sender and all of the recipients
+ using the specified cryptography context.
+
+
+ If either of the Resent-Sender or Resent-From headers are set, then the message
+ will be encrypted to all of the addresses specified in the Resent headers
+ (Resent-Sender, Resent-From, Resent-To, Resent-Cc, and Resent-Bcc),
+ otherwise the message will be encrypted to all of the addresses specified in
+ the standard address headers (Sender, From, To, Cc, and Bcc).
+
+ The cryptography context.
+
+ is null.
+
+
+ An unknown type of cryptography context was used.
+
+
+ The has not been set.
+ -or-
+ No recipients have been specified.
+
+
+ A certificate could not be found for one or more of the recipients.
+
+
+ The public key could not be found for one or more of the recipients.
+
+
+
+
+ Sign and encrypt the message to the sender and all of the recipients using
+ the specified cryptography context and the specified digest algorithm.
+
+
+ If either of the Resent-Sender or Resent-From headers are set, then the message
+ will be signed using the Resent-Sender (or first mailbox in the Resent-From)
+ address as the signer address, otherwise the Sender or From address will be
+ used instead.
+ Likewise, if either of the Resent-Sender or Resent-From headers are set, then the
+ message will be encrypted to all of the addresses specified in the Resent headers
+ (Resent-Sender, Resent-From, Resent-To, Resent-Cc, and Resent-Bcc),
+ otherwise the message will be encrypted to all of the addresses specified in
+ the standard address headers (Sender, From, To, Cc, and Bcc).
+
+ The cryptography context.
+ The digest algorithm.
+
+ is null.
+
+
+ An unknown type of cryptography context was used.
+
+
+ The was out of range.
+
+
+ The has not been set.
+ -or-
+ The sender has been specified.
+ -or-
+ No recipients have been specified.
+
+
+ The is not supported.
+
+
+ A certificate could not be found for the signer or one or more of the recipients.
+
+
+ The private key could not be found for the sender.
+
+
+ The public key could not be found for one or more of the recipients.
+
+
+
+
+ Sign and encrypt the message to the sender and all of the recipients using
+ the specified cryptography context and the SHA-1 digest algorithm.
+
+
+ If either of the Resent-Sender or Resent-From headers are set, then the message
+ will be signed using the Resent-Sender (or first mailbox in the Resent-From)
+ address as the signer address, otherwise the Sender or From address will be
+ used instead.
+ Likewise, if either of the Resent-Sender or Resent-From headers are set, then the
+ message will be encrypted to all of the addresses specified in the Resent headers
+ (Resent-Sender, Resent-From, Resent-To, Resent-Cc, and Resent-Bcc),
+ otherwise the message will be encrypted to all of the addresses specified in
+ the standard address headers (Sender, From, To, Cc, and Bcc).
+
+ The cryptography context.
+
+ is null.
+
+
+ An unknown type of cryptography context was used.
+
+
+ The has not been set.
+ -or-
+ The sender has been specified.
+ -or-
+ No recipients have been specified.
+
+
+ A certificate could not be found for the signer or one or more of the recipients.
+
+
+ The private key could not be found for the sender.
+
+
+ The public key could not be found for one or more of the recipients.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ specified .
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save mmeory usage, but also improve
+ performance.
+
+ The parsed message.
+ The parser options.
+ The stream.
+ true if the stream is persistent; otherwise false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ specified .
+
+ The parsed message.
+ The parser options.
+ The stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ default .
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save mmeory usage, but also improve
+ performance.
+
+ The parsed message.
+ The stream.
+ true if the stream is persistent; otherwise false.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ default .
+
+ The parsed message.
+ The stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified file.
+
+
+ Loads a from the file at the given path, using the
+ specified .
+
+ The parsed message.
+ The parser options.
+ The name of the file to load.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified file.
+
+
+ Loads a from the file at the given path, using the
+ default .
+
+ The parsed message.
+ The name of the file to load.
+ A cancellation token.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Creates a new from a .
+
+
+ Creates a new from a .
+
+ The equivalent .
+ The message.
+
+ is null.
+
+
+
+
+ Explicit cast to convert a to a
+ .
+
+
+ Allows creation of messages using Microsoft's System.Net.Mail APIs.
+
+ The equivalent .
+ The message.
+
+
+
+ A MIME message and entity parser.
+
+
+ A MIME parser is used to parse and
+ objects from arbitrary streams.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new that will parse the specified stream.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The stream to parse.
+ The format of the stream.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new that will parse the specified stream.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The stream to parse.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new that will parse the specified stream.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The parser options.
+ The stream to parse.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new that will parse the specified stream.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The parser options.
+ The stream to parse.
+ The format of the stream.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets a value indicating whether the parser has reached the end of the input stream.
+
+
+ Gets a value indicating whether the parser has reached the end of the input stream.
+
+ true if this parser has reached the end of the input stream;
+ otherwise, false.
+
+
+
+ Gets the current position of the parser within the stream.
+
+
+ Gets the current position of the parser within the stream.
+
+ The stream offset.
+
+
+
+ Gets the most recent mbox marker offset.
+
+
+ Gets the most recent mbox marker offset.
+
+ The mbox marker offset.
+
+
+
+ Gets the most recent mbox marker.
+
+
+ Gets the most recent mbox marker.
+
+ The mbox marker.
+
+
+
+ Sets the stream to parse.
+
+
+ Sets the stream to parse.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The parser options.
+ The stream to parse.
+ The format of the stream.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Sets the stream to parse.
+
+
+ Sets the stream to parse.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The parser options.
+ The stream to parse.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Sets the stream to parse.
+
+
+ Sets the stream to parse.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The stream to parse.
+ The format of the stream.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+
+
+
+
+ Sets the stream to parse.
+
+
+ Sets the stream to parse.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The stream to parse.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+
+
+
+
+ Parses a list of headers from the stream.
+
+
+ Parses a list of headers from the stream.
+
+ The parsed list of headers.
+ A cancellation token.
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the headers.
+
+
+ An I/O error occurred.
+
+
+
+
+ Parses an entity from the stream.
+
+
+ Parses an entity from the stream.
+
+ The parsed entity.
+ A cancellation token.
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Parses a message from the stream.
+
+
+ Parses a message from the stream.
+
+ The parsed message.
+ A cancellation token.
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the message.
+
+
+ An I/O error occurred.
+
+
+
+
+ Enumerates the messages in the stream.
+
+
+ This is mostly useful when parsing mbox-formatted streams.
+
+ The enumerator.
+
+
+
+ Enumerates the messages in the stream.
+
+
+ This is mostly useful when parsing mbox-formatted streams.
+
+ The enumerator.
+
+
+
+ A leaf-node MIME part that contains content such as the message body text or an attachment.
+
+
+ A leaf-node MIME part that contains content such as the message body text or an attachment.
+
+
+
+
+ Initializes a new instance of the class
+ based on the .
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class
+ with the specified media type and subtype.
+
+
+ Creates a new with the specified media type and subtype.
+
+ The media type.
+ The media subtype.
+ An array of initialization parameters: headers and part content.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ contains more than one or
+ .
+ -or-
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class
+ with the specified media type and subtype.
+
+
+ Creates a new with the specified media type and subtype.
+
+ The media type.
+ The media subtype.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class
+ with the specified content type.
+
+
+ Creates a new with the specified Content-Type value.
+
+ The content type.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class
+ with the specified content type.
+
+
+ Creates a new with the specified Content-Type value.
+
+ The content type.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Initializes a new instance of the class
+ with the default Content-Type of application/octet-stream.
+
+
+ Creates a new with a Content-Type of application/octet-stream.
+
+
+
+
+ Gets or sets the duration of the content if available.
+
+
+ The Content-Duration header specifies duration of timed media,
+ such as audio or video, in seconds.
+
+ The duration of the content.
+
+ is negative.
+
+
+
+
+ Gets or sets the md5sum of the content.
+
+
+ The Content-MD5 header specifies the base64-encoded MD5 checksum of the content
+ in its canonical format.
+ For more information, see http://www.ietf.org/rfc/rfc1864.txt
+
+ The md5sum of the content.
+
+
+
+ Gets or sets the content transfer encoding.
+
+
+ The Content-Transfer-Encoding header specifies an auxiliary encoding
+ that was applied to the content in order to allow it to pass through
+ mail transport mechanisms (such as SMTP) which may have limitations
+ in the byte ranges that it accepts. For example, many SMTP servers
+ do not accept data outside of the 7-bit ASCII range and so sending
+ binary attachments or even non-English text is not possible without
+ applying an encoding such as base64 or quoted-printable.
+
+ The content transfer encoding.
+
+
+
+ Gets or sets the name of the file.
+
+
+ First checks for the "filename" parameter on the Content-Disposition header. If
+ that does not exist, then the "name" parameter on the Content-Type header is used.
+ When setting the filename, both the "filename" parameter on the Content-Disposition
+ header and the "name" parameter on the Content-Type header are set.
+
+ The name of the file.
+
+
+
+ Gets or sets the MIME content.
+
+
+ Gets or sets the MIME content.
+
+ The MIME content.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Calculates the most efficient content encoding given the specified constraint.
+
+
+ If no is set, will be returned.
+
+ The most efficient content encoding.
+ The encoding constraint.
+ A cancellation token.
+
+ is not a valid value.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Calculates the most efficient content encoding given the specified constraint.
+
+
+ If no is set, will be returned.
+
+ The most efficient content encoding.
+ The encoding constraint.
+ The maximum allowable length for a line (not counting the CRLF). Must be between 72 and 998 (inclusive).
+ A cancellation token.
+
+ is not between 72 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Computes the MD5 checksum of the content.
+
+
+ Computes the MD5 checksum of the MIME content in its canonical
+ format and then base64-encodes the result.
+
+ The md5sum of the content.
+
+ The is null.
+
+
+
+
+ Verifies the Content-Md5 value against an independently computed md5sum.
+
+
+ Computes the MD5 checksum of the MIME content and compares it with the
+ value in the Content-MD5 header, returning true if and only if
+ the values match.
+
+ true, if content MD5 checksum was verified, false otherwise.
+
+
+
+ Prepare the MIME entity for transport using the specified encoding constraints.
+
+
+ Prepares the MIME entity for transport using the specified encoding constraints.
+
+ The encoding constraint.
+ The maximum number of octets allowed per line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes the MIME part to the output stream.
+
+ The formatting options.
+ The output stream.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Called when the headers change in some way.
+
+
+ Updates the , ,
+ and properties if the corresponding headers have changed.
+
+ The type of change.
+ The header being added, changed or removed.
+
+
+
+ A mapping of file name extensions to the corresponding MIME-type.
+
+
+ A mapping of file name extensions to the corresponding MIME-type.
+
+
+
+
+ Gets the MIME-type of the file.
+
+
+ Gets the MIME-type of the file based on the file extension.
+
+ The MIME-type.
+ The file name.
+
+ is null.
+
+
+
+
+ Represents a visitor for MIME trees.
+
+
+ This class is designed to be inherited to create more specialized classes whose
+ functionality requires traversing, examining or copying a MIME tree.
+
+
+
+
+
+
+
+ Dispatches the entity to one of the more specialized visit methods in this class.
+
+
+ Dispatches the entity to one of the more specialized visit methods in this class.
+
+ The MIME entity.
+
+
+
+ Dispatches the message to one of the more specialized visit methods in this class.
+
+
+ Dispatches the message to one of the more specialized visit methods in this class.
+
+ The MIME message.
+
+
+
+ Visit the application/pgp-encrypted MIME entity.
+
+
+ Visits the application/pgp-encrypted MIME entity.
+
+
+ The application/pgp-encrypted MIME entity.
+
+
+
+ Visit the application/pgp-signature MIME entity.
+
+
+ Visits the application/pgp-signature MIME entity.
+
+
+ The application/pgp-signature MIME entity.
+
+
+
+ Visit the application/pkcs7-mime MIME entity.
+
+
+ Visits the application/pkcs7-mime MIME entity.
+
+ The application/pkcs7-mime MIME entity.
+
+
+
+ Visit the application/pkcs7-signature MIME entity.
+
+
+ Visits the application/pkcs7-signature MIME entity.
+
+
+ The application/pkcs7-signature MIME entity.
+
+
+
+ Visit the message/disposition-notification MIME entity.
+
+
+ Visits the message/disposition-notification MIME entity.
+
+ The message/disposition-notification MIME entity.
+
+
+
+ Visit the message/delivery-status MIME entity.
+
+
+ Visits the message/delivery-status MIME entity.
+
+ The message/delivery-status MIME entity.
+
+
+
+ Visit the message contained within a message/rfc822 or message/news MIME entity.
+
+
+ Visits the message contained within a message/rfc822 or message/news MIME entity.
+
+ The message/rfc822 or message/news MIME entity.
+
+
+
+ Visit the message/rfc822 or message/news MIME entity.
+
+
+ Visits the message/rfc822 or message/news MIME entity.
+
+
+
+
+ The message/rfc822 or message/news MIME entity.
+
+
+
+ Visit the message/partial MIME entity.
+
+
+ Visits the message/partial MIME entity.
+
+ The message/partial MIME entity.
+
+
+
+ Visit the abstract MIME entity.
+
+
+ Visits the abstract MIME entity.
+
+ The MIME entity.
+
+
+
+ Visit the body of the message.
+
+
+ Visits the body of the message.
+
+ The message.
+
+
+
+ Visit the MIME message.
+
+
+ Visits the MIME message.
+
+ The MIME message.
+
+
+
+ Visit the abstract MIME part entity.
+
+
+ Visits the MIME part entity.
+
+
+
+
+ The MIME part entity.
+
+
+
+ Visit the children of a .
+
+
+ Visits the children of a .
+
+ Multipart.
+
+
+
+ Visit the abstract multipart MIME entity.
+
+
+ Visits the abstract multipart MIME entity.
+
+ The multipart MIME entity.
+
+
+
+ Visit the multipart/alternative MIME entity.
+
+
+ Visits the multipart/alternative MIME entity.
+
+
+
+
+ The multipart/alternative MIME entity.
+
+
+
+ Visit the multipart/encrypted MIME entity.
+
+
+ Visits the multipart/encrypted MIME entity.
+
+ The multipart/encrypted MIME entity.
+
+
+
+ Visit the multipart/related MIME entity.
+
+
+ Visits the multipart/related MIME entity.
+
+
+
+
+ The multipart/related MIME entity.
+
+
+
+ Visit the multipart/report MIME entity.
+
+
+ Visits the multipart/report MIME entity.
+
+
+
+
+ The multipart/report MIME entity.
+
+
+
+ Visit the multipart/signed MIME entity.
+
+
+ Visits the multipart/signed MIME entity.
+
+ The multipart/signed MIME entity.
+
+
+
+ Visit the text-based MIME part entity.
+
+
+ Visits the text-based MIME part entity.
+
+
+
+
+ The text-based MIME part entity.
+
+
+
+ Visit the Microsoft TNEF MIME part entity.
+
+
+ Visits the Microsoft TNEF MIME part entity.
+
+
+
+
+ The Microsoft TNEF MIME part entity.
+
+
+
+ A multipart MIME entity which may contain a collection of MIME entities.
+
+
+ All multipart MIME entities will have a Content-Type with a media type of "multipart".
+ The most common multipart MIME entity used in email is the "multipart/mixed" entity.
+ Four (4) initial subtypes were defined in the original MIME specifications: mixed, alternative,
+ digest, and parallel.
+ The "multipart/mixed" type is a sort of general-purpose container. When used in email, the
+ first entity is typically the "body" of the message while additional entities are most often
+ file attachments.
+ Speaking of message "bodies", the "multipart/alternative" type is used to offer a list of
+ alternative formats for the main body of the message (usually they will be "text/plain" and
+ "text/html"). These alternatives are in order of increasing faithfulness to the original document
+ (in other words, the last entity will be in a format that, when rendered, will most closely match
+ what the sending client's WYSISYG editor produced).
+ The "multipart/digest" type will typically contain a digest of MIME messages and is most
+ commonly used by mailing-list software.
+ The "multipart/parallel" type contains entities that are all meant to be shown (or heard)
+ in parallel.
+ Another commonly used type is the "multipart/related" type which contains, as one might expect,
+ inter-related MIME parts which typically reference each other via URIs based on the Content-Id and/or
+ Content-Location headers.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified subtype.
+
+ The multipart media sub-type.
+ An array of initialization parameters: headers and MIME entities.
+
+ is null.
+ -or-
+ is null.
+
+
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified subtype.
+
+ The multipart media sub-type.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with a ContentType of multipart/mixed.
+
+
+
+
+ Gets or sets the boundary.
+
+
+ Gets or sets the boundary parameter on the Content-Type header.
+
+ The boundary.
+
+ is null.
+
+
+
+
+ Gets or sets the preamble.
+
+
+ A multipart preamble appears before the first child entity of the
+ multipart and is typically used only in the top-level multipart
+ of the message to specify that the message is in MIME format and
+ therefore requires a MIME compliant email application to render
+ it correctly.
+
+ The preamble.
+
+
+
+ Gets or sets the epilogue.
+
+
+ A multipart epiloque is the text that appears after the closing boundary
+ of the multipart and is typically either empty or a single new line
+ character sequence.
+
+ The epilogue.
+
+
+
+ Gets or sets whether the end boundary should be written.
+
+
+ Gets or sets whether the end boundary should be written.
+
+ true if the end boundary should be written; otherwise, false.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Prepare the MIME entity for transport using the specified encoding constraints.
+
+
+ Prepares the MIME entity for transport using the specified encoding constraints.
+
+ The encoding constraint.
+ The maximum number of octets allowed per line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes the multipart MIME entity and its subparts to the output stream.
+
+ The formatting options.
+ The output stream.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Gets the number of parts in the multipart.
+
+
+ Indicates the number of parts in the multipart.
+
+ The number of parts in the multipart.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Adds the specified part.
+
+
+ Adds the specified part to the multipart.
+
+ The part to add.
+
+ is null.
+
+
+
+
+ Clears the multipart.
+
+
+ Removes all of the parts within the multipart.
+
+
+
+
+ Checks if the contains the specified part.
+
+
+ Determines whether or not the multipart contains the specified part.
+
+ true if the specified part exists;
+ otherwise false.
+ The part to check for.
+
+ is null.
+
+
+
+
+ Copies all of the entities in the to the specified array.
+
+
+ Copies all of the entities within the into the array,
+ starting at the specified array index.
+
+ The array to copy the headers to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified part.
+
+
+ Removes the specified part, if it exists within the multipart.
+
+ true if the part was removed; otherwise false.
+ The part to remove.
+
+ is null.
+
+
+
+
+ Gets the index of the specified part.
+
+
+ Finds the index of the specified part, if it exists.
+
+ The index of the specified part if found; otherwise -1.
+ The part.
+
+ is null.
+
+
+
+
+ Inserts the part at the specified index.
+
+
+ Inserts the part into the multipart at the specified index.
+
+ The index.
+ The part.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the part at the specified index.
+
+
+ Removes the part at the specified index.
+
+ The index.
+
+ is out of range.
+
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the at the specified index.
+
+ The entity at the specified index.
+ The index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Gets the enumerator for the children of the .
+
+
+ Gets the enumerator for the children of the .
+
+ The enumerator.
+
+
+
+ Gets the enumerator for the children of the .
+
+
+ Gets the enumerator for the children of the .
+
+ The enumerator.
+
+
+
+ A multipart/alternative MIME entity.
+
+
+ A multipart/alternative MIME entity contains, as one might expect, is used to offer a list of
+ alternative formats for the main body of the message (usually they will be "text/plain" and
+ "text/html"). These alternatives are in order of increasing faithfulness to the original document
+ (in other words, the last entity will be in a format that, when rendered, will most closely match
+ what the sending client's WYSISYG editor produced).
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new part.
+
+ An array of initialization parameters: headers and MIME entities.
+
+ is null.
+
+
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new part.
+
+
+
+
+ Get the text of the text/plain alternative.
+
+
+ Gets the text of the text/plain alternative, if it exists.
+
+ The text if a text/plain alternative exists; otherwise, null.
+
+
+
+ Get the HTML-formatted text of the text/html alternative.
+
+
+ Gets the HTML-formatted text of the text/html alternative, if it exists.
+
+ The HTML if a text/html alternative exists; otherwise, null.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Get the text body in the specified format.
+
+
+ Gets the text body in the specified format, if it exists.
+
+ The text body in the desired format if it exists; otherwise, null.
+ The desired text format.
+
+
+
+ A multipart/related MIME entity.
+
+
+ A multipart/related MIME entity contains, as one might expect, inter-related MIME parts which
+ typically reference each other via URIs based on the Content-Id and/or Content-Location headers.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new part.
+
+ An array of initialization parameters: headers and MIME entities.
+
+ is null.
+
+
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new part.
+
+
+
+
+ Gets or sets the root document of the multipart/related part and the appropriate Content-Type parameters.
+
+
+ Gets or sets the root document that references the other MIME parts within the multipart/related.
+ When getting the root document, the "start" parameter of the Content-Type header is used to
+ determine which of the parts is the root. If the "start" parameter does not exist or does not reference
+ any of the child parts, then the first child is assumed to be the root.
+ When setting the root document MIME part, the Content-Type header of the multipart/related part is also
+ updated with a appropriate "start" and "type" parameters.
+
+ The root MIME part.
+
+ is null.
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Checks if the contains a part matching the specified URI.
+
+
+ Determines whether or not the multipart/related entity contains a part matching the specified URI.
+
+ true if the specified part exists; otherwise false.
+ The URI of the MIME part.
+
+ is null.
+
+
+
+
+ Gets the index of the part matching the specified URI.
+
+
+ Finds the index of the part matching the specified URI, if it exists.
+ If the URI scheme is "cid", then matching is performed based on the Content-Id header
+ values, otherwise the Content-Location headers are used. If the provided URI is absolute and a child
+ part's Content-Location is relative, then then the child part's Content-Location URI will be combined
+ with the value of its Content-Base header, if available, otherwise it will be combined with the
+ multipart/related part's Content-Base header in order to produce an absolute URI that can be
+ compared with the provided absolute URI.
+
+ The index of the part matching the specified URI if found; otherwise -1.
+ The URI of the MIME part.
+
+ is null.
+
+
+
+
+ Opens a stream for reading the decoded content of the MIME part specified by the provided URI.
+
+
+ Opens a stream for reading the decoded content of the MIME part specified by the provided URI.
+
+ A stream for reading the decoded content of the MIME part specified by the provided URI.
+ The URI.
+ The mime-type of the content.
+ The charset of the content (if the content is text-based)
+
+ is null.
+
+
+ The MIME part for the specified URI could not be found.
+
+
+
+
+ Opens a stream for reading the decoded content of the MIME part specified by the provided URI.
+
+
+ Opens a stream for reading the decoded content of the MIME part specified by the provided URI.
+
+ A stream for reading the decoded content of the MIME part specified by the provided URI.
+ The URI.
+
+ is null.
+
+
+ The MIME part for the specified URI could not be found.
+
+
+
+
+ A multipart/report MIME entity.
+
+
+ A multipart/related MIME entity is a general container part for electronic mail
+ reports of any kind.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new part.
+
+ The type of the report.
+ An array of initialization parameters: headers and MIME entities.
+
+ is null.
+ -or-
+ is null.
+
+
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new part.
+
+
+ is null.
+
+
+
+
+ Gets or sets the type of the report.
+
+
+ Gets or sets the type of the report.
+ The report type should be the subtype of the second
+ of the multipart/report.
+
+ The type of the report.
+
+ is null.
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ A header parameter as found in the Content-Type and Content-Disposition headers.
+
+
+ Content-Type and Content-Disposition headers often have parameters that specify
+ further information about how to interpret the content.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new parameter with the specified name and value.
+
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+
+
+ contains illegal characters.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new parameter with the specified name and value.
+
+ The character encoding.
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ contains illegal characters.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new parameter with the specified name and value.
+
+ The character encoding.
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ contains illegal characters.
+
+
+ is not supported.
+
+
+
+
+ Gets the parameter name.
+
+
+ Gets the parameter name.
+
+ The parameter name.
+
+
+
+ Gets or sets the parameter value character encoding.
+
+
+ Gets or sets the parameter value character encoding.
+
+ The character encoding.
+
+
+
+ Gets or sets the parameter encoding method to use.
+
+
+ Gets or sets the parameter encoding method to use.
+ The MIME specifications specify that the proper method for encoding Content-Type
+ and Content-Disposition parameter values is the method described in
+ rfc2231. However, it is common for
+ some older email clients to improperly encode using the method described in
+ rfc2047 instead.
+ If set to , the encoding
+ method used will default to the value set on the .
+
+ The encoding method.
+
+ is not a valid value.
+
+
+
+
+ Gets or sets the parameter value.
+
+
+ Gets or sets the parameter value.
+
+ The parameter value.
+
+ is null.
+
+
+
+
+ Returns a string representation of the .
+
+
+ Formats the parameter name and value in the form name="value".
+
+ A string representation of the .
+
+
+
+ The method to use for encoding Content-Type and Content-Disposition parameter values.
+
+
+ The MIME specifications specify that the proper method for encoding Content-Type and
+ Content-Disposition parameter values is the method described in
+ rfc2231. However, it is common for
+ some older email clients to improperly encode using the method described in
+ rfc2047 instead.
+
+
+
+
+ Use the default encoding method set on the .
+
+
+
+
+ Use the encoding method described in rfc2231.
+
+
+
+
+ Use the encoding method described in rfc2047 (for compatibility with older,
+ non-rfc-compliant email clients).
+
+
+
+
+ A list of parameters, as found in the Content-Type and Content-Disposition headers.
+
+
+ Parameters are used by both and .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new parameter list.
+
+
+
+
+ Adds a parameter with the specified name and value.
+
+
+ Adds a new parameter to the list with the specified name and value.
+
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Adds a parameter with the specified name and value.
+
+
+ Adds a new parameter to the list with the specified name and value.
+
+ The character encoding.
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ contains illegal characters.
+
+
+
+
+ Adds a parameter with the specified name and value.
+
+
+ Adds a new parameter to the list with the specified name and value.
+
+ The character encoding.
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be empty.
+ -or-
+ contains illegal characters.
+
+
+ is not supported.
+
+
+
+
+ Checks if the contains a parameter with the specified name.
+
+
+ Determines whether or not the parameter list contains a parameter with the specified name.
+
+ true if the requested parameter exists;
+ otherwise false.
+ The parameter name.
+
+ is null.
+
+
+
+
+ Gets the index of the requested parameter, if it exists.
+
+
+ Finds the index of the parameter with the specified name, if it exists.
+
+ The index of the requested parameter; otherwise -1.
+ The parameter name.
+
+ is null.
+
+
+
+
+ Inserts a parameter with the specified name and value at the given index.
+
+
+ Inserts a new parameter with the given name and value at the specified index.
+
+ The index to insert the parameter.
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified parameter.
+
+
+ Removes the parameter with the specified name from the list, if it exists.
+
+ true if the specified parameter was removed;
+ otherwise false.
+ The parameter name.
+
+ is null.
+
+
+
+
+ Gets or sets the value of a parameter with the specified name.
+
+
+ Gets or sets the value of a parameter with the specified name.
+
+ The value of the specified parameter if it exists; otherwise null.
+ The parameter name.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Gets the parameter with the specified name.
+
+
+ Gets the parameter with the specified name.
+
+ true if the parameter exists; otherwise, false.
+ The parameter name.
+ The parameter.
+
+ is null.
+
+
+
+
+ Gets the value of the parameter with the specified name.
+
+
+ Gets the value of the parameter with the specified name.
+
+ true if the parameter exists; otherwise, false.
+ The parameter name.
+ The parameter value.
+
+ is null.
+
+
+
+
+ Gets the number of parameters in the .
+
+
+ Indicates the number of parameters in the list.
+
+ The number of parameters.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Adds the specified parameter.
+
+
+ Adds the specified parameter to the end of the list.
+
+ The parameter to add.
+
+ The is null.
+
+
+ A parameter with the same name as
+ already exists.
+
+
+
+
+ Clears the parameter list.
+
+
+ Removes all of the parameters from the list.
+
+
+
+
+ Checks if the contains the specified parameter.
+
+
+ Determines whether or not the parameter list contains the specified parameter.
+
+ true if the specified parameter is contained;
+ otherwise false.
+ The parameter.
+
+ The is null.
+
+
+
+
+ Copies all of the contained parameters to the specified array.
+
+
+ Copies all of the parameters within the into the array,
+ starting at the specified array index.
+
+ The array to copy the parameters to.
+ The index into the array.
+
+
+
+ Removes the specified parameter.
+
+
+ Removes the specified parameter from the list.
+
+ true if the specified parameter was removed;
+ otherwise false.
+ The parameter.
+
+ The is null.
+
+
+
+
+ Gets the index of the requested parameter, if it exists.
+
+
+ Finds the index of the specified parameter, if it exists.
+
+ The index of the requested parameter; otherwise -1.
+ The parameter.
+
+ The is null.
+
+
+
+
+ Inserts the specified parameter at the given index.
+
+
+ Inserts the parameter at the specified index in the list.
+
+ The index to insert the parameter.
+ The parameter.
+
+ The is null.
+
+
+ The is out of range.
+
+
+ A parameter with the same name as
+ already exists.
+
+
+
+
+ Removes the parameter at the specified index.
+
+
+ Removes the parameter at the specified index.
+
+ The index.
+
+ The is out of range.
+
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the at the specified index.
+
+ The parameter at the specified index.
+ The index.
+
+ The is null.
+
+
+ The is out of range.
+
+
+ A parameter with the same name as
+ already exists.
+
+
+
+
+ Gets an enumerator for the list of parameters.
+
+
+ Gets an enumerator for the list of parameters.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of parameters.
+
+
+ Gets an enumerator for the list of parameters.
+
+ The enumerator.
+
+
+
+ Returns a string representation of the parameters in the .
+
+
+ If there are multiple parameters in the list, they will be separated by a semicolon.
+
+ A string representing the .
+
+
+
+ A Parse exception as thrown by the various Parse methods in MimeKit.
+
+
+ A can be thrown by any of the Parse() methods
+ in MimeKit. Each exception instance will have a
+ which marks the byte offset of the token that failed to parse as well
+ as a which marks the byte offset where the error
+ occurred.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The serialization info.
+ The stream context.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The error message.
+ The byte offset of the token.
+ The byte offset of the error.
+ The inner exception.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The error message.
+ The byte offset of the token.
+ The byte offset of the error.
+
+
+
+ When overridden in a derived class, sets the
+ with information about the exception.
+
+
+ Sets the
+ with information about the exception.
+
+ The serialization info.
+ The streaming context.
+
+ is null.
+
+
+
+
+ Gets the byte index of the token that was malformed.
+
+
+ The token index is the byte offset at which the token started.
+
+ The byte index of the token.
+
+
+
+ Gets the index of the byte that caused the error.
+
+
+ The error index is the byte offset at which the parser encountered an error.
+
+ The index of the byte that caused error.
+
+
+
+ Parser options as used by as well as various Parse and TryParse methods in MimeKit.
+
+
+ allows you to change and/or override default parsing options used by methods such
+ as and others.
+
+
+
+
+ The default parser options.
+
+
+ If a is not supplied to or other Parse and TryParse
+ methods throughout MimeKit, will be used.
+
+
+
+
+ Gets or sets the compliance mode that should be used when parsing rfc822 addresses.
+
+
+ In general, you'll probably want this value to be
+ (the default) as it allows maximum interoperability with existing (broken) mail clients
+ and other mail software such as sloppily written perl scripts (aka spambots).
+ Even in mode, the address
+ parser is fairly liberal in what it accepts. Setting it to
+ just makes it try harder to deal with garbage input.
+
+ The RFC compliance mode.
+
+
+
+ Gets or sets the compliance mode that should be used when parsing Content-Type and Content-Disposition parameters.
+
+
+ In general, you'll probably want this value to be
+ (the default) as it allows maximum interoperability with existing (broken) mail clients
+ and other mail software such as sloppily written perl scripts (aka spambots).
+ Even in mode, the parameter
+ parser is fairly liberal in what it accepts. Setting it to
+ just makes it try harder to deal with garbage input.
+
+ The RFC compliance mode.
+
+
+
+ Gets or sets the compliance mode that should be used when decoding rfc2047 encoded words.
+
+
+ In general, you'll probably want this value to be
+ (the default) as it allows maximum interoperability with existing (broken) mail clients
+ and other mail software such as sloppily written perl scripts (aka spambots).
+
+ The RFC compliance mode.
+
+
+
+ Gets or sets a value indicating whether the Content-Length value should be
+ respected when parsing mbox streams.
+
+
+ For more details about why this may be useful, you can find more information
+ at
+ http://www.jwz.org/doc/content-length.html.
+
+ true if the Content-Length value should be respected;
+ otherwise, false.
+
+
+
+ Gets or sets the charset encoding to use as a fallback for 8bit headers.
+
+
+ and
+
+ use this charset encoding as a fallback when decoding 8bit text into unicode. The first
+ charset encoding attempted is UTF-8, followed by this charset encoding, before finally
+ falling back to iso-8859-1.
+
+ The charset encoding.
+
+
+
+ Initializes a new instance of the class.
+
+
+ By default, new instances of enable rfc2047 work-arounds
+ (which are needed for maximum interoperability with mail software used in the wild)
+ and do not respect the Content-Length header value.
+
+
+
+
+ Clones an instance of .
+
+
+ Clones a set of options, allowing you to change a specific option
+ without requiring you to change the original.
+
+ An identical copy of the current instance.
+
+
+
+ Registers the subclass for the specified mime-type.
+
+ The MIME type.
+ A custom subclass of .
+
+ Your custom class should not subclass
+ directly, but rather it should subclass
+ , ,
+ , or one of their derivatives.
+
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a subclass of ,
+ , or .
+ -or-
+ does not have a constructor that takes
+ only a argument.
+
+
+
+
+ An RFC compliance mode.
+
+
+ An RFC compliance mode.
+
+
+
+
+ Attempt to be much more liberal accepting broken and/or invalid formatting.
+
+
+
+
+ Do not attempt to be overly liberal in accepting broken and/or invalid formatting.
+
+
+
+
+ A Textual MIME part.
+
+
+ Unless overridden, all textual parts parsed by the ,
+ such as text/plain or text/html, will be represented by a .
+ For more information about text media types, see section 4.1 of
+ rfc2046.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the
+ class with the specified text subtype.
+
+
+ Creates a new with the specified subtype.
+
+ The media subtype.
+ An array of initialization parameters: headers, charset encoding and text.
+
+ is null.
+ -or-
+ is null.
+
+
+ contains more than one .
+ -or-
+ contains more than one .
+ -or-
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the
+ class with the specified text subtype.
+
+
+ Creates a new with the specified subtype.
+
+ The media subtype.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the
+ class with a Content-Type of text/plain.
+
+
+ Creates a default with a mime-type of text/plain.
+
+
+
+
+ Gets whether or not this text part contains enriched text.
+
+
+ Checks whether or not the text part's Content-Type is text/enriched or its
+ predecessor, text/richtext (not to be confused with text/rtf).
+
+ true if the text is enriched; otherwise, false.
+
+
+
+ Gets whether or not this text part contains flowed text.
+
+
+ Checks whether or not the text part's Content-Type is text/plain and
+ has a format parameter with a value of flowed.
+
+ true if the text is flowed; otherwise, false.
+
+
+
+ Gets whether or not this text part contains HTML.
+
+
+ Checks whether or not the text part's Content-Type is text/html.
+
+ true if the text is html; otherwise, false.
+
+
+
+ Gets whether or not this text part contains plain text.
+
+
+ Checks whether or not the text part's Content-Type is text/plain.
+
+ true if the text is html; otherwise, false.
+
+
+
+ Gets whether or not this text part contains RTF.
+
+
+ Checks whether or not the text part's Content-Type is text/rtf.
+
+ true if the text is RTF; otherwise, false.
+
+
+
+ Gets the decoded text content.
+
+
+ If the charset parameter on the
+ is set, it will be used in order to convert the raw content into unicode.
+ If that fails or if the charset parameter is not set, iso-8859-1 will be
+ used instead.
+ For more control, use
+ or .
+
+ The text.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Determines whether or not the text is in the specified format.
+
+
+ Determines whether or not the text is in the specified format.
+
+ true if the text is in the specified format; otherwise, false.
+ The text format.
+
+
+
+ Gets the decoded text content using the provided charset encoding to
+ override the charset specified in the Content-Type parameters.
+
+
+ Uses the provided charset encoding to convert the raw text content
+ into a unicode string, overriding any charset specified in the
+ Content-Type header.
+
+ The decoded text.
+ The charset encoding to use.
+
+ is null.
+
+
+
+
+ Gets the decoded text content using the provided charset to override
+ the charset specified in the Content-Type parameters.
+
+
+ Uses the provided charset encoding to convert the raw text content
+ into a unicode string, overriding any charset specified in the
+ Content-Type header.
+
+ The decoded text.
+ The charset encoding to use.
+
+ is null.
+
+
+ The is not supported.
+
+
+
+
+ Sets the text content and the charset parameter in the Content-Type header.
+
+
+ This method is similar to setting the property,
+ but allows specifying a charset encoding to use. Also updates the
+ property.
+
+ The charset encoding.
+ The text content.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Sets the text content and the charset parameter in the Content-Type header.
+
+
+ This method is similar to setting the property,
+ but allows specifying a charset encoding to use. Also updates the
+ property.
+
+ The charset encoding.
+ The text content.
+
+ is null.
+ -or-
+ is null.
+
+
+ The is not supported.
+
+
+
+
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU3/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU3/ExchangeDkimSigner.dll
index 49c743bb..a5b4b0c4 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU3/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU3/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU3/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU3/ExchangeDkimSigner.pdb
index 39456c57..46b6275e 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU3/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU3/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU4/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU4/ExchangeDkimSigner.dll
index 3e414c2e..1ca61cc6 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU4/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU4/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU4/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU4/ExchangeDkimSigner.pdb
index 4401b628..5bf1a65b 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU4/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU4/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU5/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU5/ExchangeDkimSigner.dll
index 5a7c46b5..b3793f37 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU5/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU5/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU5/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU5/ExchangeDkimSigner.pdb
index a332b81e..c7e5301a 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU5/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU5/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU6/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU6/ExchangeDkimSigner.dll
index 5142d218..cbdd2f6a 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU6/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU6/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU6/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU6/ExchangeDkimSigner.pdb
index b03b9a03..cef0df17 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU6/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU6/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU7/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU7/ExchangeDkimSigner.dll
index 8e1b9ac4..2ebd48a6 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU7/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU7/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU7/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU7/ExchangeDkimSigner.pdb
index a20207e7..5a0a30dc 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU7/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU7/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU8/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU8/ExchangeDkimSigner.dll
index 3232f8cd..c1c81006 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU8/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU8/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU8/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU8/ExchangeDkimSigner.pdb
index c6829638..9ff6092c 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU8/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU8/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU9/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU9/ExchangeDkimSigner.dll
index b601f424..52e4277a 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU9/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU9/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU9/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU9/ExchangeDkimSigner.pdb
index 9b678dec..46303db1 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU9/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU9/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 Preview/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 Preview/ExchangeDkimSigner.dll
index e2981a7b..2c47de6d 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 Preview/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 Preview/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 Preview/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 Preview/ExchangeDkimSigner.pdb
index 91f2ec63..6551e8f2 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 Preview/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 Preview/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 RTM/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 RTM/ExchangeDkimSigner.dll
index 4fa09f97..effa301f 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 RTM/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2016 RTM/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 RTM/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 RTM/ExchangeDkimSigner.pdb
index b61178d5..a8ef865b 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2016 RTM/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2016 RTM/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU1/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU1/ExchangeDkimSigner.dll
index 3b9a993a..7ff80ffc 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU1/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU1/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU1/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU1/ExchangeDkimSigner.pdb
index 046074ff..50fdcee7 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU1/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU1/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU2/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU2/ExchangeDkimSigner.dll
index 9eee3f6e..a04c3d03 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU2/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU2/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU2/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU2/ExchangeDkimSigner.pdb
index 76141f8a..6f56956e 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU2/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU2/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU3/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU3/ExchangeDkimSigner.dll
index dd771ea3..f5350f09 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU3/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU3/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU3/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU3/ExchangeDkimSigner.pdb
index 200d2187..3be6b65b 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU3/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU3/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU4/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU4/ExchangeDkimSigner.dll
index e6bb9a41..3669d500 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU4/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU4/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU4/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU4/ExchangeDkimSigner.pdb
index 66dfafa7..0662e9e2 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU4/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU4/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.dll
index 233af0ab..0ce3e9ab 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.pdb
index 9cf7f216..779d6485 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU6/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU6/ExchangeDkimSigner.dll
index 8e969270..64151044 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU6/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU6/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU6/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU6/ExchangeDkimSigner.pdb
index 0b9aefef..5ae161a9 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU6/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU6/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU7/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU7/ExchangeDkimSigner.dll
index 643a607e..3cea975e 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU7/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU7/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU7/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU7/ExchangeDkimSigner.pdb
index c773b69d..7b2f1e7c 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU7/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU7/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU8/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU8/ExchangeDkimSigner.dll
index 5d1f1e88..bb6ac33d 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU8/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU8/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU8/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU8/ExchangeDkimSigner.pdb
index de1432fb..168121b6 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU8/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU8/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/BouncyCastle.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/BouncyCastle.dll
new file mode 100644
index 00000000..17e4744b
Binary files /dev/null and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/BouncyCastle.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/BouncyCastle.xml b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/BouncyCastle.xml
new file mode 100644
index 00000000..d27354a2
--- /dev/null
+++ b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/BouncyCastle.xml
@@ -0,0 +1,24206 @@
+
+
+
+ BouncyCastle
+
+
+
+ Base class for both the compress and decompress classes.
+ Holds common arrays, and static data.
+
+ @author Keiron Liddle
+
+
+ An input stream that decompresses from the BZip2 format (with the file
+ header chars) to be read as any other stream.
+
+ @author Keiron Liddle
+
+ NB: note this class has been modified to read the leading BZ from the
+ start of the BZIP2 stream to make it compatible with other PGP programs.
+
+
+ An output stream that compresses into the BZip2 format (with the file
+ header chars) into another stream.
+
+ @author Keiron Liddle
+
+ TODO: Update to BZip2 1.0.1
+ NB: note this class has been modified to add a leading BZ to the
+ start of the BZIP2 stream to make it compatible with other PGP programs.
+
+
+
+ modified by Oliver Merkel, 010128
+
+
+
+ A simple class the hold and calculate the CRC for sanity checking
+ of the data.
+
+ @author Keiron Liddle
+
+
+ Return the DER encoding of the object, null if the DER encoding can not be made.
+
+ @return a DER byte array, null otherwise.
+
+
+ a general purpose ASN.1 decoder - note: this class differs from the
+ others in that it returns null after it has read the last object in
+ the stream. If an ASN.1 Null is encountered a Der/BER Null object is
+ returned.
+
+
+ Create an ASN1InputStream where no DER object will be longer than limit.
+
+ @param input stream containing ASN.1 encoded data.
+ @param limit maximum size of a DER encoded object.
+
+
+ Create an ASN1InputStream based on the input byte array. The length of DER objects in
+ the stream is automatically limited to the length of the input array.
+
+ @param input array containing ASN.1 encoded data.
+
+
+ build an object given its tag and the number of bytes to construct it from.
+
+
+ A Null object.
+
+
+ Create a base ASN.1 object from a byte array.
+ The byte array to parse.
+ The base ASN.1 object represented by the byte array.
+ If there is a problem parsing the data.
+
+
+ Read a base ASN.1 object from a stream.
+ The stream to parse.
+ The base ASN.1 object represented by the byte array.
+ If there is a problem parsing the data.
+
+
+ return an Octet string from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ return an Octet string from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ @param string the octets making up the octet string.
+
+
+ return an Asn1Sequence from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Return an ASN1 sequence from a tagged object. There is a special
+ case here, if an object appears to have been explicitly tagged on
+ reading but we were expecting it to be implicitly tagged in the
+ normal course of events it indicates that we lost the surrounding
+ sequence - so we need to add it back (this will happen if the tagged
+ object is a sequence that contains other sequences). If you are
+ dealing with implicitly tagged sequences you really should
+ be using this method.
+
+ @param obj the tagged object.
+ @param explicitly true if the object is meant to be explicitly tagged,
+ false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ return the object at the sequence position indicated by index.
+
+ @param index the sequence number (starting at zero) of the object
+ @return the object at the sequence position indicated by index.
+
+
+ return an ASN1Set from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Return an ASN1 set from a tagged object. There is a special
+ case here, if an object appears to have been explicitly tagged on
+ reading but we were expecting it to be implicitly tagged in the
+ normal course of events it indicates that we lost the surrounding
+ set - so we need to add it back (this will happen if the tagged
+ object is a sequence that contains other sequences). If you are
+ dealing with implicitly tagged sets you really should
+ be using this method.
+
+ @param obj the tagged object.
+ @param explicitly true if the object is meant to be explicitly tagged
+ false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ return the object at the set position indicated by index.
+
+ @param index the set number (starting at zero) of the object
+ @return the object at the set position indicated by index.
+
+
+ ASN.1 TaggedObject - in ASN.1 notation this is any object preceded by
+ a [n] where n is some number - these are assumed to follow the construction
+ rules (as with sequences).
+
+
+ @param tagNo the tag number for this object.
+ @param obj the tagged object.
+
+
+ @param explicitly true if the object is explicitly tagged.
+ @param tagNo the tag number for this object.
+ @param obj the tagged object.
+
+
+ return whether or not the object may be explicitly tagged.
+
+ Note: if the object has been read from an input stream, the only
+ time you can be sure if isExplicit is returning the true state of
+ affairs is if it returns false. An implicitly tagged object may appear
+ to be explicitly tagged, so you need to understand the context under
+ which the reading was done as well, see GetObject below.
+
+
+ return whatever was following the tag.
+
+ Note: tagged objects are generally context dependent if you're
+ trying to extract a tagged object you should be going via the
+ appropriate GetInstance method.
+
+
+ Return the object held in this tagged object as a parser assuming it has
+ the type of the passed in tag. If the object doesn't have a parser
+ associated with it, the base object is returned.
+
+
+ A BER Null object.
+
+
+ convert a vector of octet strings into a single byte string
+
+
+ The octets making up the octet string.
+
+
+ return the DER octets that make up this string.
+
+
+ create an empty sequence
+
+
+ create a sequence containing one object
+
+
+ create a sequence containing a vector of objects.
+
+
+ create an empty sequence
+
+
+ create a set containing one object
+
+
+ create a set containing a vector of objects.
+
+
+ BER TaggedObject - in ASN.1 notation this is any object preceded by
+ a [n] where n is some number - these are assumed to follow the construction
+ rules (as with sequences).
+
+
+ @param tagNo the tag number for this object.
+ @param obj the tagged object.
+
+
+ @param explicitly true if an explicitly tagged object.
+ @param tagNo the tag number for this object.
+ @param obj the tagged object.
+
+
+ create an implicitly tagged object that contains a zero
+ length sequence.
+
+
+ Class representing the DER-type External
+
+
+ Creates a new instance of DerExternal
+ See X.690 for more informations about the meaning of these parameters
+ @param directReference The direct reference or null
if not set.
+ @param indirectReference The indirect reference or null
if not set.
+ @param dataValueDescriptor The data value descriptor or null
if not set.
+ @param externalData The external data in its encoded form.
+
+
+ Creates a new instance of DerExternal.
+ See X.690 for more informations about the meaning of these parameters
+ @param directReference The direct reference or null
if not set.
+ @param indirectReference The indirect reference or null
if not set.
+ @param dataValueDescriptor The data value descriptor or null
if not set.
+ @param encoding The encoding to be used for the external data
+ @param externalData The external data
+
+
+ The encoding of the content. Valid values are
+
+ 0
single-ASN1-type
+ 1
OCTET STRING
+ 2
BIT STRING
+
+
+
+ Base class for an application specific object
+
+
+ Return the enclosed object assuming explicit tagging.
+
+ @return the resulting object
+ @throws IOException if reconstruction fails.
+
+
+ Return the enclosed object assuming implicit tagging.
+
+ @param derTagNo the type tag that should be applied to the object's contents.
+ @return the resulting object
+ @throws IOException if reconstruction fails.
+
+
+ Der BMPString object.
+
+
+ return a BMP string from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a BMP string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - byte encoded string.
+
+
+ basic constructor
+
+
+ return a Bit string from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a Bit string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ @param data the octets making up the bit string.
+ @param padBits the number of extra bits at the end of the string.
+
+
+ Return the octets contained in this BIT STRING, checking that this BIT STRING really
+ does represent an octet aligned string. Only use this method when the standard you are
+ following dictates that the BIT STRING will be octet aligned.
+
+ @return a copy of the octet aligned data.
+
+
+ @return the value of the bit string as an int (truncating if necessary)
+
+
+ return a bool from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a DerBoolean from the passed in bool.
+
+
+ return a Boolean from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ return an integer from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an Enumerated from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ Generalized time object.
+
+
+ return a generalized time from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a Generalized Time object from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ The correct format for this is YYYYMMDDHHMMSS[.f]Z, or without the Z
+ for local time, or Z+-HHMM on the end, for difference between local
+ time and UTC time. The fractional second amount f must consist of at
+ least one number with trailing zeroes removed.
+
+ @param time the time string.
+ @exception ArgumentException if string is an illegal format.
+
+
+ base constructor from a local time object
+
+
+ Return the time.
+ @return The time string as it appeared in the encoded object.
+
+
+ return the time - always in the form of
+ YYYYMMDDhhmmssGMT(+hh:mm|-hh:mm).
+
+ Normally in a certificate we would expect "Z" rather than "GMT",
+ however adding the "GMT" means we can just use:
+
+ dateF = new SimpleDateFormat("yyyyMMddHHmmssz");
+
+ To read in the time and Get a date which is compatible with our local
+ time zone.
+
+
+ return a Graphic String from the passed in object
+
+ @param obj a DerGraphicString or an object that can be converted into one.
+ @exception IllegalArgumentException if the object cannot be converted.
+ @return a DerGraphicString instance, or null.
+
+
+ return a Graphic String from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception IllegalArgumentException if the tagged object cannot
+ be converted.
+ @return a DerGraphicString instance, or null.
+
+
+ basic constructor - with bytes.
+ @param string the byte encoding of the characters making up the string.
+
+
+ Der IA5String object - this is an ascii string.
+
+
+ return a IA5 string from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an IA5 string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - with bytes.
+
+
+ basic constructor - without validation.
+
+
+ Constructor with optional validation.
+
+ @param string the base string to wrap.
+ @param validate whether or not to check the string.
+ @throws ArgumentException if validate is true and the string
+ contains characters that should not be in an IA5String.
+
+
+ return true if the passed in String can be represented without
+ loss as an IA5String, false otherwise.
+
+ @return true if in printable set, false otherwise.
+
+
+ return an integer from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an Integer from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param isExplicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ in some cases positive values Get crammed into a space,
+ that's not quite big enough...
+
+
+ A Null object.
+
+
+ Der NumericString object - this is an ascii string of characters {0,1,2,3,4,5,6,7,8,9, }.
+
+
+ return a Numeric string from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an Numeric string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - with bytes.
+
+
+ basic constructor - without validation..
+
+
+ Constructor with optional validation.
+
+ @param string the base string to wrap.
+ @param validate whether or not to check the string.
+ @throws ArgumentException if validate is true and the string
+ contains characters that should not be in a NumericString.
+
+
+ Return true if the string can be represented as a NumericString ('0'..'9', ' ')
+
+ @param str string to validate.
+ @return true if numeric, fale otherwise.
+
+
+ return an Oid from the passed in object
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an object Identifier from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ Return true if this oid is an extension of the passed in branch, stem.
+ @param stem the arc or branch that is a possible parent.
+ @return true if the branch is on the passed in stem, false otherwise.
+
+
+ The octets making up the octet string.
+
+
+ Der PrintableString object.
+
+
+ return a printable string from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a Printable string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - byte encoded string.
+
+
+ basic constructor - this does not validate the string
+
+
+ Constructor with optional validation.
+
+ @param string the base string to wrap.
+ @param validate whether or not to check the string.
+ @throws ArgumentException if validate is true and the string
+ contains characters that should not be in a PrintableString.
+
+
+ return true if the passed in String can be represented without
+ loss as a PrintableString, false otherwise.
+
+ @return true if in printable set, false otherwise.
+
+
+ create an empty sequence
+
+
+ create a sequence containing one object
+
+
+ create a sequence containing a vector of objects.
+
+
+ A Der encoded set object
+
+
+ create an empty set
+
+
+ @param obj - a single object that makes up the set.
+
+
+ @param v - a vector of objects making up the set.
+
+
+ Der T61String (also the teletex string) - 8-bit characters
+
+
+ return a T61 string from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an T61 string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - with bytes.
+
+
+ basic constructor - with string.
+
+
+ DER TaggedObject - in ASN.1 notation this is any object preceded by
+ a [n] where n is some number - these are assumed to follow the construction
+ rules (as with sequences).
+
+
+ @param tagNo the tag number for this object.
+ @param obj the tagged object.
+
+
+ @param explicitly true if an explicitly tagged object.
+ @param tagNo the tag number for this object.
+ @param obj the tagged object.
+
+
+ create an implicitly tagged object that contains a zero
+ length sequence.
+
+
+ UTC time object.
+
+
+ return an UTC Time from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an UTC Time from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ The correct format for this is YYMMDDHHMMSSZ (it used to be that seconds were
+ never encoded. When you're creating one of these objects from scratch, that's
+ what you want to use, otherwise we'll try to deal with whatever Gets read from
+ the input stream... (this is why the input format is different from the GetTime()
+ method output).
+
+ @param time the time string.
+
+
+ base constructor from a DateTime object
+
+
+ return the time as a date based on whatever a 2 digit year will return. For
+ standardised processing use ToAdjustedDateTime().
+
+ @return the resulting date
+ @exception ParseException if the date string cannot be parsed.
+
+
+ return the time as an adjusted date
+ in the range of 1950 - 2049.
+
+ @return a date in the range of 1950 to 2049.
+ @exception ParseException if the date string cannot be parsed.
+
+
+ return the time - always in the form of
+ YYMMDDhhmmssGMT(+hh:mm|-hh:mm).
+
+ Normally in a certificate we would expect "Z" rather than "GMT",
+ however adding the "GMT" means we can just use:
+
+ dateF = new SimpleDateFormat("yyMMddHHmmssz");
+
+ To read in the time and Get a date which is compatible with our local
+ time zone.
+
+ Note: In some cases, due to the local date processing, this
+ may lead to unexpected results. If you want to stick the normal
+ convention of 1950 to 2049 use the GetAdjustedTime() method.
+
+
+
+ Return a time string as an adjusted date with a 4 digit year.
+ This goes in the range of 1950 - 2049.
+
+
+
+ Der UTF8String object.
+
+
+ return an UTF8 string from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return an UTF8 string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - byte encoded string.
+
+
+ basic constructor
+
+
+ Der UniversalString object.
+
+
+ return a Universal string from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a Universal string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - byte encoded string.
+
+
+ return a Videotex String from the passed in object
+
+ @param obj a DERVideotexString or an object that can be converted into one.
+ @exception IllegalArgumentException if the object cannot be converted.
+ @return a DERVideotexString instance, or null.
+
+
+ return a Videotex String from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception IllegalArgumentException if the tagged object cannot
+ be converted.
+ @return a DERVideotexString instance, or null.
+
+
+ basic constructor - with bytes.
+ @param string the byte encoding of the characters making up the string.
+
+
+ Der VisibleString object.
+
+
+ return a Visible string from the passed in object.
+
+ @exception ArgumentException if the object cannot be converted.
+
+
+ return a Visible string from a tagged object.
+
+ @param obj the tagged object holding the object we want
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the tagged object cannot
+ be converted.
+
+
+ basic constructor - byte encoded string.
+
+
+ basic constructor
+
+
+ Marker interface for CHOICE objects - if you implement this in a roll-your-own
+ object, any attempt to tag the object implicitly will convert the tag to an
+ explicit one as the encoding rules require.
+
+ If you use this interface your class should also implement the getInstance
+ pattern which takes a tag object and the tagging mode used.
+
+
+
+ basic interface for Der string objects.
+
+
+ class for breaking up an Oid into it's component tokens, ala
+ java.util.StringTokenizer. We need this class as some of the
+ lightweight Java environment don't support classes like
+ StringTokenizer.
+
+
+ return the X9ECParameters object for the named curve represented by
+ the passed in object identifier. Null if the curve isn't present.
+
+ @param oid an object identifier representing a named curve, if present.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+
+ CAKeyUpdAnnContent ::= SEQUENCE {
+ oldWithNew CmpCertificate, -- old pub signed with new priv
+ newWithOld CmpCertificate, -- new pub signed with old priv
+ newWithNew CmpCertificate -- new pub signed with new priv
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertConfirmContent ::= SEQUENCE OF CertStatus
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertOrEncCert ::= CHOICE {
+ certificate [0] CMPCertificate,
+ encryptedCert [1] EncryptedValue
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertRepMessage ::= SEQUENCE {
+ caPubs [1] SEQUENCE SIZE (1..MAX) OF CMPCertificate
+ OPTIONAL,
+ response SEQUENCE OF CertResponse
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertResponse ::= SEQUENCE {
+ certReqId INTEGER,
+ -- to match this response with corresponding request (a value
+ -- of -1 is to be used if certReqId is not specified in the
+ -- corresponding request)
+ status PKIStatusInfo,
+ certifiedKeyPair CertifiedKeyPair OPTIONAL,
+ rspInfo OCTET STRING OPTIONAL
+ -- analogous to the id-regInfo-utf8Pairs string defined
+ -- for regInfo in CertReqMsg [CRMF]
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertStatus ::= SEQUENCE {
+ certHash OCTET STRING,
+ -- the hash of the certificate, using the same hash algorithm
+ -- as is used to create and verify the certificate signature
+ certReqId INTEGER,
+ -- to match this confirmation with the corresponding req/rep
+ statusInfo PKIStatusInfo OPTIONAL
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertifiedKeyPair ::= SEQUENCE {
+ certOrEncCert CertOrEncCert,
+ privateKey [0] EncryptedValue OPTIONAL,
+ -- see [CRMF] for comment on encoding
+ publicationInfo [1] PKIPublicationInfo OPTIONAL
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ Challenge ::= SEQUENCE {
+ owf AlgorithmIdentifier OPTIONAL,
+
+ -- MUST be present in the first Challenge; MAY be omitted in
+ -- any subsequent Challenge in POPODecKeyChallContent (if
+ -- omitted, then the owf used in the immediately preceding
+ -- Challenge is to be used).
+
+ witness OCTET STRING,
+ -- the result of applying the one-way function (owf) to a
+ -- randomly-generated INTEGER, A. [Note that a different
+ -- INTEGER MUST be used for each Challenge.]
+ challenge OCTET STRING
+ -- the encryption (under the public key for which the cert.
+ -- request is being made) of Rand, where Rand is specified as
+ -- Rand ::= SEQUENCE {
+ -- int INTEGER,
+ -- - the randomly-generated INTEGER A (above)
+ -- sender GeneralName
+ -- - the sender's name (as included in PKIHeader)
+ -- }
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+ Note: the addition of attribute certificates is a BC extension.
+
+
+
+ CMPCertificate ::= CHOICE {
+ x509v3PKCert Certificate
+ x509v2AttrCert [1] AttributeCertificate
+ }
+
+ Note: the addition of attribute certificates is a BC extension.
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CrlAnnContent ::= SEQUENCE OF CertificateList
+
+ @return a basic ASN.1 object representation.
+
+
+
+ ErrorMsgContent ::= SEQUENCE {
+ pKIStatusInfo PKIStatusInfo,
+ errorCode INTEGER OPTIONAL,
+ -- implementation-specific error codes
+ errorDetails PKIFreeText OPTIONAL
+ -- implementation-specific error details
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ GenMsgContent ::= SEQUENCE OF InfoTypeAndValue
+
+ @return a basic ASN.1 object representation.
+
+
+
+ GenRepContent ::= SEQUENCE OF InfoTypeAndValue
+
+ @return a basic ASN.1 object representation.
+
+
+ Example InfoTypeAndValue contents include, but are not limited
+ to, the following (un-comment in this ASN.1 module and use as
+ appropriate for a given environment):
+
+ id-it-caProtEncCert OBJECT IDENTIFIER ::= {id-it 1}
+ CAProtEncCertValue ::= CMPCertificate
+ id-it-signKeyPairTypes OBJECT IDENTIFIER ::= {id-it 2}
+ SignKeyPairTypesValue ::= SEQUENCE OF AlgorithmIdentifier
+ id-it-encKeyPairTypes OBJECT IDENTIFIER ::= {id-it 3}
+ EncKeyPairTypesValue ::= SEQUENCE OF AlgorithmIdentifier
+ id-it-preferredSymmAlg OBJECT IDENTIFIER ::= {id-it 4}
+ PreferredSymmAlgValue ::= AlgorithmIdentifier
+ id-it-caKeyUpdateInfo OBJECT IDENTIFIER ::= {id-it 5}
+ CAKeyUpdateInfoValue ::= CAKeyUpdAnnContent
+ id-it-currentCRL OBJECT IDENTIFIER ::= {id-it 6}
+ CurrentCRLValue ::= CertificateList
+ id-it-unsupportedOIDs OBJECT IDENTIFIER ::= {id-it 7}
+ UnsupportedOIDsValue ::= SEQUENCE OF OBJECT IDENTIFIER
+ id-it-keyPairParamReq OBJECT IDENTIFIER ::= {id-it 10}
+ KeyPairParamReqValue ::= OBJECT IDENTIFIER
+ id-it-keyPairParamRep OBJECT IDENTIFIER ::= {id-it 11}
+ KeyPairParamRepValue ::= AlgorithmIdentifer
+ id-it-revPassphrase OBJECT IDENTIFIER ::= {id-it 12}
+ RevPassphraseValue ::= EncryptedValue
+ id-it-implicitConfirm OBJECT IDENTIFIER ::= {id-it 13}
+ ImplicitConfirmValue ::= NULL
+ id-it-confirmWaitTime OBJECT IDENTIFIER ::= {id-it 14}
+ ConfirmWaitTimeValue ::= GeneralizedTime
+ id-it-origPKIMessage OBJECT IDENTIFIER ::= {id-it 15}
+ OrigPKIMessageValue ::= PKIMessages
+ id-it-suppLangTags OBJECT IDENTIFIER ::= {id-it 16}
+ SuppLangTagsValue ::= SEQUENCE OF UTF8String
+
+ where
+
+ id-pkix OBJECT IDENTIFIER ::= {
+ iso(1) identified-organization(3)
+ dod(6) internet(1) security(5) mechanisms(5) pkix(7)}
+ and
+ id-it OBJECT IDENTIFIER ::= {id-pkix 4}
+
+
+
+
+ InfoTypeAndValue ::= SEQUENCE {
+ infoType OBJECT IDENTIFIER,
+ infoValue ANY DEFINED BY infoType OPTIONAL
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ KeyRecRepContent ::= SEQUENCE {
+ status PKIStatusInfo,
+ newSigCert [0] CMPCertificate OPTIONAL,
+ caCerts [1] SEQUENCE SIZE (1..MAX) OF
+ CMPCertificate OPTIONAL,
+ keyPairHist [2] SEQUENCE SIZE (1..MAX) OF
+ CertifiedKeyPair OPTIONAL
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ OobCertHash ::= SEQUENCE {
+ hashAlg [0] AlgorithmIdentifier OPTIONAL,
+ certId [1] CertId OPTIONAL,
+ hashVal BIT STRING
+ -- hashVal is calculated over the Der encoding of the
+ -- self-signed certificate with the identifier certID.
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+ Creates a new PkiBody.
+ @param type one of the TYPE_* constants
+ @param content message content
+
+
+
+ PkiBody ::= CHOICE { -- message-specific body elements
+ ir [0] CertReqMessages, --Initialization Request
+ ip [1] CertRepMessage, --Initialization Response
+ cr [2] CertReqMessages, --Certification Request
+ cp [3] CertRepMessage, --Certification Response
+ p10cr [4] CertificationRequest, --imported from [PKCS10]
+ popdecc [5] POPODecKeyChallContent, --pop Challenge
+ popdecr [6] POPODecKeyRespContent, --pop Response
+ kur [7] CertReqMessages, --Key Update Request
+ kup [8] CertRepMessage, --Key Update Response
+ krr [9] CertReqMessages, --Key Recovery Request
+ krp [10] KeyRecRepContent, --Key Recovery Response
+ rr [11] RevReqContent, --Revocation Request
+ rp [12] RevRepContent, --Revocation Response
+ ccr [13] CertReqMessages, --Cross-Cert. Request
+ ccp [14] CertRepMessage, --Cross-Cert. Response
+ ckuann [15] CAKeyUpdAnnContent, --CA Key Update Ann.
+ cann [16] CertAnnContent, --Certificate Ann.
+ rann [17] RevAnnContent, --Revocation Ann.
+ crlann [18] CRLAnnContent, --CRL Announcement
+ pkiconf [19] PKIConfirmContent, --Confirmation
+ nested [20] NestedMessageContent, --Nested Message
+ genm [21] GenMsgContent, --General Message
+ genp [22] GenRepContent, --General Response
+ error [23] ErrorMsgContent, --Error Message
+ certConf [24] CertConfirmContent, --Certificate confirm
+ pollReq [25] PollReqContent, --Polling request
+ pollRep [26] PollRepContent --Polling response
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PkiConfirmContent ::= NULL
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PKIFailureInfo ::= BIT STRING {
+ badAlg (0),
+ -- unrecognized or unsupported Algorithm Identifier
+ badMessageCheck (1), -- integrity check failed (e.g., signature did not verify)
+ badRequest (2),
+ -- transaction not permitted or supported
+ badTime (3), -- messageTime was not sufficiently close to the system time, as defined by local policy
+ badCertId (4), -- no certificate could be found matching the provided criteria
+ badDataFormat (5),
+ -- the data submitted has the wrong format
+ wrongAuthority (6), -- the authority indicated in the request is different from the one creating the response token
+ incorrectData (7), -- the requester's data is incorrect (for notary services)
+ missingTimeStamp (8), -- when the timestamp is missing but should be there (by policy)
+ badPOP (9) -- the proof-of-possession failed
+ certRevoked (10),
+ certConfirmed (11),
+ wrongIntegrity (12),
+ badRecipientNonce (13),
+ timeNotAvailable (14),
+ -- the TSA's time source is not available
+ unacceptedPolicy (15),
+ -- the requested TSA policy is not supported by the TSA
+ unacceptedExtension (16),
+ -- the requested extension is not supported by the TSA
+ addInfoNotAvailable (17)
+ -- the additional information requested could not be understood
+ -- or is not available
+ badSenderNonce (18),
+ badCertTemplate (19),
+ signerNotTrusted (20),
+ transactionIdInUse (21),
+ unsupportedVersion (22),
+ notAuthorized (23),
+ systemUnavail (24),
+ systemFailure (25),
+ -- the request cannot be handled due to system failure
+ duplicateCertReq (26)
+
+
+
+ Basic constructor.
+
+
+ Return the number of string elements present.
+
+ @return number of elements present.
+
+
+ Return the UTF8STRING at index.
+
+ @param index index of the string of interest
+ @return the string at index.
+
+
+
+ PkiFreeText ::= SEQUENCE SIZE (1..MAX) OF UTF8String
+
+
+
+ Value for a "null" recipient or sender.
+
+
+
+ PkiHeader ::= SEQUENCE {
+ pvno INTEGER { cmp1999(1), cmp2000(2) },
+ sender GeneralName,
+ -- identifies the sender
+ recipient GeneralName,
+ -- identifies the intended recipient
+ messageTime [0] GeneralizedTime OPTIONAL,
+ -- time of production of this message (used when sender
+ -- believes that the transport will be "suitable"; i.e.,
+ -- that the time will still be meaningful upon receipt)
+ protectionAlg [1] AlgorithmIdentifier OPTIONAL,
+ -- algorithm used for calculation of protection bits
+ senderKID [2] KeyIdentifier OPTIONAL,
+ recipKID [3] KeyIdentifier OPTIONAL,
+ -- to identify specific keys used for protection
+ transactionID [4] OCTET STRING OPTIONAL,
+ -- identifies the transaction; i.e., this will be the same in
+ -- corresponding request, response, certConf, and PKIConf
+ -- messages
+ senderNonce [5] OCTET STRING OPTIONAL,
+ recipNonce [6] OCTET STRING OPTIONAL,
+ -- nonces used to provide replay protection, senderNonce
+ -- is inserted by the creator of this message; recipNonce
+ -- is a nonce previously inserted in a related message by
+ -- the intended recipient of this message
+ freeText [7] PKIFreeText OPTIONAL,
+ -- this may be used to indicate context-specific instructions
+ -- (this field is intended for human consumption)
+ generalInfo [8] SEQUENCE SIZE (1..MAX) OF
+ InfoTypeAndValue OPTIONAL
+ -- this may be used to convey context-specific information
+ -- (this field not primarily intended for human consumption)
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PKIHeader ::= SEQUENCE {
+ pvno INTEGER { cmp1999(1), cmp2000(2) },
+ sender GeneralName,
+ -- identifies the sender
+ recipient GeneralName,
+ -- identifies the intended recipient
+ messageTime [0] GeneralizedTime OPTIONAL,
+ -- time of production of this message (used when sender
+ -- believes that the transport will be "suitable"; i.e.,
+ -- that the time will still be meaningful upon receipt)
+ protectionAlg [1] AlgorithmIdentifier OPTIONAL,
+ -- algorithm used for calculation of protection bits
+ senderKID [2] KeyIdentifier OPTIONAL,
+ recipKID [3] KeyIdentifier OPTIONAL,
+ -- to identify specific keys used for protection
+ transactionID [4] OCTET STRING OPTIONAL,
+ -- identifies the transaction; i.e., this will be the same in
+ -- corresponding request, response, certConf, and PKIConf
+ -- messages
+ senderNonce [5] OCTET STRING OPTIONAL,
+ recipNonce [6] OCTET STRING OPTIONAL,
+ -- nonces used to provide replay protection, senderNonce
+ -- is inserted by the creator of this message; recipNonce
+ -- is a nonce previously inserted in a related message by
+ -- the intended recipient of this message
+ freeText [7] PKIFreeText OPTIONAL,
+ -- this may be used to indicate context-specific instructions
+ -- (this field is intended for human consumption)
+ generalInfo [8] SEQUENCE SIZE (1..MAX) OF
+ InfoTypeAndValue OPTIONAL
+ -- this may be used to convey context-specific information
+ -- (this field not primarily intended for human consumption)
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+ Creates a new PkiMessage.
+
+ @param header message header
+ @param body message body
+ @param protection message protection (may be null)
+ @param extraCerts extra certificates (may be null)
+
+
+
+ PkiMessage ::= SEQUENCE {
+ header PKIHeader,
+ body PKIBody,
+ protection [0] PKIProtection OPTIONAL,
+ extraCerts [1] SEQUENCE SIZE (1..MAX) OF CMPCertificate
+ OPTIONAL
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PkiMessages ::= SEQUENCE SIZE (1..MAX) OF PkiMessage
+
+ @return a basic ASN.1 object representation.
+
+
+ @param status
+
+
+ @param status
+ @param statusString
+
+
+
+ PkiStatusInfo ::= SEQUENCE {
+ status PKIStatus, (INTEGER)
+ statusString PkiFreeText OPTIONAL,
+ failInfo PkiFailureInfo OPTIONAL (BIT STRING)
+ }
+
+ PKIStatus:
+ granted (0), -- you got exactly what you asked for
+ grantedWithMods (1), -- you got something like what you asked for
+ rejection (2), -- you don't get it, more information elsewhere in the message
+ waiting (3), -- the request body part has not yet been processed, expect to hear more later
+ revocationWarning (4), -- this message contains a warning that a revocation is imminent
+ revocationNotification (5), -- notification that a revocation has occurred
+ keyUpdateWarning (6) -- update already done for the oldCertId specified in CertReqMsg
+
+ PkiFailureInfo:
+ badAlg (0), -- unrecognized or unsupported Algorithm Identifier
+ badMessageCheck (1), -- integrity check failed (e.g., signature did not verify)
+ badRequest (2), -- transaction not permitted or supported
+ badTime (3), -- messageTime was not sufficiently close to the system time, as defined by local policy
+ badCertId (4), -- no certificate could be found matching the provided criteria
+ badDataFormat (5), -- the data submitted has the wrong format
+ wrongAuthority (6), -- the authority indicated in the request is different from the one creating the response token
+ incorrectData (7), -- the requester's data is incorrect (for notary services)
+ missingTimeStamp (8), -- when the timestamp is missing but should be there (by policy)
+ badPOP (9) -- the proof-of-possession failed
+
+
+
+
+
+ PbmParameter ::= SEQUENCE {
+ salt OCTET STRING,
+ -- note: implementations MAY wish to limit acceptable sizes
+ -- of this string to values appropriate for their environment
+ -- in order to reduce the risk of denial-of-service attacks
+ owf AlgorithmIdentifier,
+ -- AlgId for a One-Way Function (SHA-1 recommended)
+ iterationCount INTEGER,
+ -- number of times the OWF is applied
+ -- note: implementations MAY wish to limit acceptable sizes
+ -- of this integer to values appropriate for their environment
+ -- in order to reduce the risk of denial-of-service attacks
+ mac AlgorithmIdentifier
+ -- the MAC AlgId (e.g., DES-MAC, Triple-DES-MAC [PKCS11],
+ } -- or HMAC [RFC2104, RFC2202])
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PollRepContent ::= SEQUENCE OF SEQUENCE {
+ certReqId INTEGER,
+ checkAfter INTEGER, -- time in seconds
+ reason PKIFreeText OPTIONAL
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PollReqContent ::= SEQUENCE OF SEQUENCE {
+ certReqId INTEGER
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PopoDecKeyChallContent ::= SEQUENCE OF Challenge
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PopoDecKeyRespContent ::= SEQUENCE OF INTEGER
+
+ @return a basic ASN.1 object representation.
+
+
+
+ ProtectedPart ::= SEQUENCE {
+ header PKIHeader,
+ body PKIBody
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ RevAnnContent ::= SEQUENCE {
+ status PKIStatus,
+ certId CertId,
+ willBeRevokedAt GeneralizedTime,
+ badSinceDate GeneralizedTime,
+ crlDetails Extensions OPTIONAL
+ -- extra CRL details (e.g., crl number, reason, location, etc.)
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ RevDetails ::= SEQUENCE {
+ certDetails CertTemplate,
+ -- allows requester to specify as much as they can about
+ -- the cert. for which revocation is requested
+ -- (e.g., for cases in which serialNumber is not available)
+ crlEntryDetails Extensions OPTIONAL
+ -- requested crlEntryExtensions
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ RevRepContent ::= SEQUENCE {
+ status SEQUENCE SIZE (1..MAX) OF PKIStatusInfo,
+ -- in same order as was sent in RevReqContent
+ revCerts [0] SEQUENCE SIZE (1..MAX) OF CertId OPTIONAL,
+ -- IDs for which revocation was requested
+ -- (same order as status)
+ crls [1] SEQUENCE SIZE (1..MAX) OF CertificateList OPTIONAL
+ -- the resulting CRLs (there may be more than one)
+ }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ RevReqContent ::= SEQUENCE OF RevDetails
+
+ @return a basic ASN.1 object representation.
+
+
+ return an Attribute object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Attribute ::= SEQUENCE {
+ attrType OBJECT IDENTIFIER,
+ attrValues SET OF AttributeValue
+ }
+
+
+
+ Return the first attribute matching the given OBJECT IDENTIFIER
+
+
+ Return all the attributes matching the OBJECT IDENTIFIER oid. The vector will be
+ empty if there are no attributes of the required type present.
+
+ @param oid type of attribute required.
+ @return a vector of all the attributes found of type oid.
+
+
+ Return a new table with the passed in attribute added.
+
+ @param attrType
+ @param attrValue
+ @return
+
+
+
+ Attributes ::=
+ SET SIZE(1..MAX) OF Attribute -- according to RFC 5652
+
+ @return
+
+
+ return an AuthEnvelopedData object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param isExplicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @throws ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an AuthEnvelopedData object from the given object.
+
+ @param obj the object we want converted.
+ @throws ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AuthEnvelopedData ::= SEQUENCE {
+ version CMSVersion,
+ originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+ recipientInfos RecipientInfos,
+ authEncryptedContentInfo EncryptedContentInfo,
+ authAttrs [1] IMPLICIT AuthAttributes OPTIONAL,
+ mac MessageAuthenticationCode,
+ unauthAttrs [2] IMPLICIT UnauthAttributes OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+
+ AuthEnvelopedData ::= SEQUENCE {
+ version CMSVersion,
+ originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+ recipientInfos RecipientInfos,
+ authEncryptedContentInfo EncryptedContentInfo,
+ authAttrs [1] IMPLICIT AuthAttributes OPTIONAL,
+ mac MessageAuthenticationCode,
+ unauthAttrs [2] IMPLICIT UnauthAttributes OPTIONAL }
+
+
+
+ return an AuthenticatedData object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param isExplicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @throws ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an AuthenticatedData object from the given object.
+
+ @param obj the object we want converted.
+ @throws ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AuthenticatedData ::= SEQUENCE {
+ version CMSVersion,
+ originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+ recipientInfos RecipientInfos,
+ macAlgorithm MessageAuthenticationCodeAlgorithm,
+ digestAlgorithm [1] DigestAlgorithmIdentifier OPTIONAL,
+ encapContentInfo EncapsulatedContentInfo,
+ authAttrs [2] IMPLICIT AuthAttributes OPTIONAL,
+ mac MessageAuthenticationCode,
+ unauthAttrs [3] IMPLICIT UnauthAttributes OPTIONAL }
+
+ AuthAttributes ::= SET SIZE (1..MAX) OF Attribute
+
+ UnauthAttributes ::= SET SIZE (1..MAX) OF Attribute
+
+ MessageAuthenticationCode ::= OCTET STRING
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AuthenticatedData ::= SEQUENCE {
+ version CMSVersion,
+ originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+ recipientInfos RecipientInfos,
+ macAlgorithm MessageAuthenticationCodeAlgorithm,
+ digestAlgorithm [1] DigestAlgorithmIdentifier OPTIONAL,
+ encapContentInfo EncapsulatedContentInfo,
+ authAttrs [2] IMPLICIT AuthAttributes OPTIONAL,
+ mac MessageAuthenticationCode,
+ unauthAttrs [3] IMPLICIT UnauthAttributes OPTIONAL }
+
+ AuthAttributes ::= SET SIZE (1..MAX) OF Attribute
+
+ UnauthAttributes ::= SET SIZE (1..MAX) OF Attribute
+
+ MessageAuthenticationCode ::= OCTET STRING
+
+
+
+ The other Revocation Info arc
+ id-ri OBJECT IDENTIFIER ::= { iso(1) identified-organization(3)
+ dod(6) internet(1) security(5) mechanisms(5) pkix(7) ri(16) }
+
+
+ RFC 3274 - CMS Compressed Data.
+
+ CompressedData ::= Sequence {
+ version CMSVersion,
+ compressionAlgorithm CompressionAlgorithmIdentifier,
+ encapContentInfo EncapsulatedContentInfo
+ }
+
+
+
+ return a CompressedData object from a tagged object.
+
+ @param ato the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a CompressedData object from the given object.
+
+ @param _obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ RFC 3274 - CMS Compressed Data.
+
+ CompressedData ::= SEQUENCE {
+ version CMSVersion,
+ compressionAlgorithm CompressionAlgorithmIdentifier,
+ encapContentInfo EncapsulatedContentInfo
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ContentInfo ::= Sequence {
+ contentType ContentType,
+ content
+ [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ContentInfo ::= SEQUENCE {
+ contentType ContentType,
+ content
+ [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL }
+
+
+
+ return an EncryptedContentInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ EncryptedContentInfo ::= Sequence {
+ contentType ContentType,
+ contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,
+ encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL
+ }
+
+
+
+
+ EncryptedContentInfo ::= SEQUENCE {
+ contentType ContentType,
+ contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,
+ encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL
+ }
+
+
+
+
+ EncryptedData ::= SEQUENCE {
+ version CMSVersion,
+ encryptedContentInfo EncryptedContentInfo,
+ unprotectedAttrs [1] IMPLICIT UnprotectedAttributes OPTIONAL }
+
+ @return a basic ASN.1 object representation.
+
+
+ return an EnvelopedData object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an EnvelopedData object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ EnvelopedData ::= Sequence {
+ version CMSVersion,
+ originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+ recipientInfos RecipientInfos,
+ encryptedContentInfo EncryptedContentInfo,
+ unprotectedAttrs [1] IMPLICIT UnprotectedAttributes OPTIONAL
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ EnvelopedData ::= SEQUENCE {
+ version CMSVersion,
+ originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+ recipientInfos RecipientInfos,
+ encryptedContentInfo EncryptedContentInfo,
+ unprotectedAttrs [1] IMPLICIT UnprotectedAttributes OPTIONAL
+ }
+
+
+
+ return a KekIdentifier object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a KekIdentifier object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ KekIdentifier ::= Sequence {
+ keyIdentifier OCTET STRING,
+ date GeneralizedTime OPTIONAL,
+ other OtherKeyAttribute OPTIONAL
+ }
+
+
+
+ return a KekRecipientInfo object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a KekRecipientInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ KekRecipientInfo ::= Sequence {
+ version CMSVersion, -- always set to 4
+ kekID KekIdentifier,
+ keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
+ encryptedKey EncryptedKey
+ }
+
+
+
+ return an KeyAgreeRecipientIdentifier object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param isExplicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an KeyAgreeRecipientIdentifier object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ KeyAgreeRecipientIdentifier ::= CHOICE {
+ issuerAndSerialNumber IssuerAndSerialNumber,
+ rKeyId [0] IMPLICIT RecipientKeyIdentifier
+ }
+
+
+
+ return a KeyAgreeRecipientInfo object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a KeyAgreeRecipientInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ * Produce an object suitable for an Asn1OutputStream.
+ *
+ * KeyAgreeRecipientInfo ::= Sequence {
+ * version CMSVersion, -- always set to 3
+ * originator [0] EXPLICIT OriginatorIdentifierOrKey,
+ * ukm [1] EXPLICIT UserKeyingMaterial OPTIONAL,
+ * keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
+ * recipientEncryptedKeys RecipientEncryptedKeys
+ * }
+ *
+ * UserKeyingMaterial ::= OCTET STRING
+ *
+
+
+ return a KeyTransRecipientInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ KeyTransRecipientInfo ::= Sequence {
+ version CMSVersion, -- always set to 0 or 2
+ rid RecipientIdentifier,
+ keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
+ encryptedKey EncryptedKey
+ }
+
+
+
+
+ MetaData ::= SEQUENCE {
+ hashProtected BOOLEAN,
+ fileName UTF8String OPTIONAL,
+ mediaType IA5String OPTIONAL,
+ otherMetaData Attributes OPTIONAL
+ }
+
+ @return
+
+
+ return an OriginatorIdentifierOrKey object from a tagged object.
+
+ @param o the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an OriginatorIdentifierOrKey object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OriginatorIdentifierOrKey ::= CHOICE {
+ issuerAndSerialNumber IssuerAndSerialNumber,
+ subjectKeyIdentifier [0] SubjectKeyIdentifier,
+ originatorKey [1] OriginatorPublicKey
+ }
+
+ SubjectKeyIdentifier ::= OCTET STRING
+
+
+
+ return an OriginatorInfo object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an OriginatorInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OriginatorInfo ::= Sequence {
+ certs [0] IMPLICIT CertificateSet OPTIONAL,
+ crls [1] IMPLICIT CertificateRevocationLists OPTIONAL
+ }
+
+
+
+ return an OriginatorPublicKey object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an OriginatorPublicKey object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OriginatorPublicKey ::= Sequence {
+ algorithm AlgorithmIdentifier,
+ publicKey BIT STRING
+ }
+
+
+
+ return an OtherKeyAttribute object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OtherKeyAttribute ::= Sequence {
+ keyAttrId OBJECT IDENTIFIER,
+ keyAttr ANY DEFINED BY keyAttrId OPTIONAL
+ }
+
+
+
+ return a OtherRecipientInfo object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a OtherRecipientInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OtherRecipientInfo ::= Sequence {
+ oriType OBJECT IDENTIFIER,
+ oriValue ANY DEFINED BY oriType }
+
+
+
+ return a OtherRevocationInfoFormat object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception IllegalArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a OtherRevocationInfoFormat object from the given object.
+
+ @param obj the object we want converted.
+ @exception IllegalArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an ASN1OutputStream.
+
+ OtherRevocationInfoFormat ::= SEQUENCE {
+ otherRevInfoFormat OBJECT IDENTIFIER,
+ otherRevInfo ANY DEFINED BY otherRevInfoFormat }
+
+
+
+ return a PasswordRecipientInfo object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param explicitly true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a PasswordRecipientInfo object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ PasswordRecipientInfo ::= Sequence {
+ version CMSVersion, -- Always set to 0
+ keyDerivationAlgorithm [0] KeyDerivationAlgorithmIdentifier
+ OPTIONAL,
+ keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
+ encryptedKey EncryptedKey }
+
+
+
+ return an RecipientEncryptedKey object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param isExplicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a RecipientEncryptedKey object from the given object.
+
+ @param obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ RecipientEncryptedKey ::= SEQUENCE {
+ rid KeyAgreeRecipientIdentifier,
+ encryptedKey EncryptedKey
+ }
+
+
+
+ return a RecipientIdentifier object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ RecipientIdentifier ::= CHOICE {
+ issuerAndSerialNumber IssuerAndSerialNumber,
+ subjectKeyIdentifier [0] SubjectKeyIdentifier
+ }
+
+ SubjectKeyIdentifier ::= OCTET STRING
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ RecipientInfo ::= CHOICE {
+ ktri KeyTransRecipientInfo,
+ kari [1] KeyAgreeRecipientInfo,
+ kekri [2] KekRecipientInfo,
+ pwri [3] PasswordRecipientInfo,
+ ori [4] OtherRecipientInfo }
+
+
+
+ return a RecipientKeyIdentifier object from a tagged object.
+
+ @param _ato the tagged object holding the object we want.
+ @param _explicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @exception ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return a RecipientKeyIdentifier object from the given object.
+
+ @param _obj the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ RecipientKeyIdentifier ::= Sequence {
+ subjectKeyIdentifier SubjectKeyIdentifier,
+ date GeneralizedTime OPTIONAL,
+ other OtherKeyAttribute OPTIONAL
+ }
+
+ SubjectKeyIdentifier ::= OCTET STRING
+
+
+
+
+ ScvpReqRes ::= SEQUENCE {
+ request [0] EXPLICIT ContentInfo OPTIONAL,
+ response ContentInfo }
+
+ @return the ASN.1 primitive representation.
+
+
+ a signed data object.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SignedData ::= Sequence {
+ version CMSVersion,
+ digestAlgorithms DigestAlgorithmIdentifiers,
+ encapContentInfo EncapsulatedContentInfo,
+ certificates [0] IMPLICIT CertificateSet OPTIONAL,
+ crls [1] IMPLICIT CertificateRevocationLists OPTIONAL,
+ signerInfos SignerInfos
+ }
+
+
+
+
+ SignedData ::= SEQUENCE {
+ version CMSVersion,
+ digestAlgorithms DigestAlgorithmIdentifiers,
+ encapContentInfo EncapsulatedContentInfo,
+ certificates [0] IMPLICIT CertificateSet OPTIONAL,
+ crls [1] IMPLICIT CertificateRevocationLists OPTIONAL,
+ signerInfos SignerInfos
+ }
+
+
+
+ return a SignerIdentifier object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SignerIdentifier ::= CHOICE {
+ issuerAndSerialNumber IssuerAndSerialNumber,
+ subjectKeyIdentifier [0] SubjectKeyIdentifier
+ }
+
+ SubjectKeyIdentifier ::= OCTET STRING
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SignerInfo ::= Sequence {
+ version Version,
+ SignerIdentifier sid,
+ digestAlgorithm DigestAlgorithmIdentifier,
+ authenticatedAttributes [0] IMPLICIT Attributes OPTIONAL,
+ digestEncryptionAlgorithm DigestEncryptionAlgorithmIdentifier,
+ encryptedDigest EncryptedDigest,
+ unauthenticatedAttributes [1] IMPLICIT Attributes OPTIONAL
+ }
+
+ EncryptedDigest ::= OCTET STRING
+
+ DigestAlgorithmIdentifier ::= AlgorithmIdentifier
+
+ DigestEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier
+
+
+
+ creates a time object from a given date - if the date is between 1950
+ and 2049 a UTCTime object is Generated, otherwise a GeneralizedTime
+ is used.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Time ::= CHOICE {
+ utcTime UTCTime,
+ generalTime GeneralizedTime }
+
+
+
+
+ TimeStampAndCRL ::= SEQUENCE {
+ timeStamp TimeStampToken, -- according to RFC 3161
+ crl CertificateList OPTIONAL -- according to RFC 5280
+ }
+
+ @return
+
+
+
+ TimeStampTokenEvidence ::=
+ SEQUENCE SIZE(1..MAX) OF TimeStampAndCrl
+
+ @return
+
+
+
+ TimeStampedData ::= SEQUENCE {
+ version INTEGER { v1(1) },
+ dataUri IA5String OPTIONAL,
+ metaData MetaData OPTIONAL,
+ content OCTET STRING OPTIONAL,
+ temporalEvidence Evidence
+ }
+
+ @return
+
+
+ return an AuthEnvelopedData object from a tagged object.
+
+ @param obj the tagged object holding the object we want.
+ @param isExplicit true if the object is meant to be explicitly
+ tagged false otherwise.
+ @throws ArgumentException if the object held by the
+ tagged object cannot be converted.
+
+
+ return an AuthEnvelopedData object from the given object.
+
+ @param obj the object we want converted.
+ @throws ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ MQVuserKeyingMaterial ::= SEQUENCE {
+ ephemeralPublicKey OriginatorPublicKey,
+ addedukm [0] EXPLICIT UserKeyingMaterial OPTIONAL }
+
+
+
+
+ AttributeTypeAndValue ::= SEQUENCE {
+ type OBJECT IDENTIFIER,
+ value ANY DEFINED BY type }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertId ::= SEQUENCE {
+ issuer GeneralName,
+ serialNumber INTEGER }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertReqMessages ::= SEQUENCE SIZE (1..MAX) OF CertReqMsg
+
+ @return a basic ASN.1 object representation.
+
+
+ Creates a new CertReqMsg.
+ @param certReq CertRequest
+ @param popo may be null
+ @param regInfo may be null
+
+
+
+ CertReqMsg ::= SEQUENCE {
+ certReq CertRequest,
+ pop ProofOfPossession OPTIONAL,
+ -- content depends upon key type
+ regInfo SEQUENCE SIZE(1..MAX) OF AttributeTypeAndValue OPTIONAL }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertRequest ::= SEQUENCE {
+ certReqId INTEGER, -- ID for matching request and reply
+ certTemplate CertTemplate, -- Selected fields of cert to be issued
+ controls Controls OPTIONAL } -- Attributes affecting issuance
+
+ @return a basic ASN.1 object representation.
+
+
+
+ CertTemplate ::= SEQUENCE {
+ version [0] Version OPTIONAL,
+ serialNumber [1] INTEGER OPTIONAL,
+ signingAlg [2] AlgorithmIdentifier OPTIONAL,
+ issuer [3] Name OPTIONAL,
+ validity [4] OptionalValidity OPTIONAL,
+ subject [5] Name OPTIONAL,
+ publicKey [6] SubjectPublicKeyInfo OPTIONAL,
+ issuerUID [7] UniqueIdentifier OPTIONAL,
+ subjectUID [8] UniqueIdentifier OPTIONAL,
+ extensions [9] Extensions OPTIONAL }
+
+ @return a basic ASN.1 object representation.
+
+
+ Sets the X.509 version. Note: for X509v3, use 2 here.
+
+
+ Sets the issuer unique ID (deprecated in X.509v3)
+
+
+ Sets the subject unique ID (deprecated in X.509v3)
+
+
+
+ CertTemplate ::= SEQUENCE {
+ version [0] Version OPTIONAL,
+ serialNumber [1] INTEGER OPTIONAL,
+ signingAlg [2] AlgorithmIdentifier OPTIONAL,
+ issuer [3] Name OPTIONAL,
+ validity [4] OptionalValidity OPTIONAL,
+ subject [5] Name OPTIONAL,
+ publicKey [6] SubjectPublicKeyInfo OPTIONAL,
+ issuerUID [7] UniqueIdentifier OPTIONAL,
+ subjectUID [8] UniqueIdentifier OPTIONAL,
+ extensions [9] Extensions OPTIONAL }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ Controls ::= SEQUENCE SIZE(1..MAX) OF AttributeTypeAndValue
+
+ @return a basic ASN.1 object representation.
+
+
+
+ EncKeyWithID ::= SEQUENCE {
+ privateKey PrivateKeyInfo,
+ identifier CHOICE {
+ string UTF8String,
+ generalName GeneralName
+ } OPTIONAL
+ }
+
+ @return
+
+
+
+ EncryptedKey ::= CHOICE {
+ encryptedValue EncryptedValue, -- deprecated
+ envelopedData [0] EnvelopedData }
+ -- The encrypted private key MUST be placed in the envelopedData
+ -- encryptedContentInfo encryptedContent OCTET STRING.
+
+
+
+
+ EncryptedValue ::= SEQUENCE {
+ intendedAlg [0] AlgorithmIdentifier OPTIONAL,
+ -- the intended algorithm for which the value will be used
+ symmAlg [1] AlgorithmIdentifier OPTIONAL,
+ -- the symmetric algorithm used to encrypt the value
+ encSymmKey [2] BIT STRING OPTIONAL,
+ -- the (encrypted) symmetric key used to encrypt the value
+ keyAlg [3] AlgorithmIdentifier OPTIONAL,
+ -- algorithm used to encrypt the symmetric key
+ valueHint [4] OCTET STRING OPTIONAL,
+ -- a brief description or identifier of the encValue content
+ -- (may be meaningful only to the sending entity, and used only
+ -- if EncryptedValue might be re-examined by the sending entity
+ -- in the future)
+ encValue BIT STRING }
+ -- the encrypted value itself
+
+ @return a basic ASN.1 object representation.
+
+
+
+ OptionalValidity ::= SEQUENCE {
+ notBefore [0] Time OPTIONAL,
+ notAfter [1] Time OPTIONAL } --at least one MUST be present
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PkiArchiveOptions ::= CHOICE {
+ encryptedPrivKey [0] EncryptedKey,
+ -- the actual value of the private key
+ keyGenParameters [1] KeyGenParameters,
+ -- parameters which allow the private key to be re-generated
+ archiveRemGenPrivKey [2] BOOLEAN }
+ -- set to TRUE if sender wishes receiver to archive the private
+ -- key of a key pair that the receiver generates in response to
+ -- this request; set to FALSE if no archival is desired.
+
+
+
+
+ PkiPublicationInfo ::= SEQUENCE {
+ action INTEGER {
+ dontPublish (0),
+ pleasePublish (1) },
+ pubInfos SEQUENCE SIZE (1..MAX) OF SinglePubInfo OPTIONAL }
+ -- pubInfos MUST NOT be present if action is "dontPublish"
+ -- (if action is "pleasePublish" and pubInfos is omitted,
+ -- "dontCare" is assumed)
+
+ @return a basic ASN.1 object representation.
+
+
+ Password-based MAC value for use with POPOSigningKeyInput.
+
+
+ Creates a new PKMACValue.
+ @param params parameters for password-based MAC
+ @param value MAC of the DER-encoded SubjectPublicKeyInfo
+
+
+ Creates a new PKMACValue.
+ @param aid CMPObjectIdentifiers.passwordBasedMAC, with PBMParameter
+ @param value MAC of the DER-encoded SubjectPublicKeyInfo
+
+
+
+ PKMACValue ::= SEQUENCE {
+ algId AlgorithmIdentifier,
+ -- algorithm value shall be PasswordBasedMac 1.2.840.113533.7.66.13
+ -- parameter value is PBMParameter
+ value BIT STRING }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ PopoPrivKey ::= CHOICE {
+ thisMessage [0] BIT STRING, -- Deprecated
+ -- possession is proven in this message (which contains the private
+ -- key itself (encrypted for the CA))
+ subsequentMessage [1] SubsequentMessage,
+ -- possession will be proven in a subsequent message
+ dhMAC [2] BIT STRING, -- Deprecated
+ agreeMAC [3] PKMACValue,
+ encryptedKey [4] EnvelopedData }
+
+
+
+ Creates a new Proof of Possession object for a signing key.
+ @param poposkIn the PopoSigningKeyInput structure, or null if the
+ CertTemplate includes both subject and publicKey values.
+ @param aid the AlgorithmIdentifier used to sign the proof of possession.
+ @param signature a signature over the DER-encoded value of poposkIn,
+ or the DER-encoded value of certReq if poposkIn is null.
+
+
+
+ PopoSigningKey ::= SEQUENCE {
+ poposkInput [0] PopoSigningKeyInput OPTIONAL,
+ algorithmIdentifier AlgorithmIdentifier,
+ signature BIT STRING }
+ -- The signature (using "algorithmIdentifier") is on the
+ -- DER-encoded value of poposkInput. NOTE: If the CertReqMsg
+ -- certReq CertTemplate contains the subject and publicKey values,
+ -- then poposkInput MUST be omitted and the signature MUST be
+ -- computed on the DER-encoded value of CertReqMsg certReq. If
+ -- the CertReqMsg certReq CertTemplate does not contain the public
+ -- key and subject values, then poposkInput MUST be present and
+ -- MUST be signed. This strategy ensures that the public key is
+ -- not present in both the poposkInput and CertReqMsg certReq
+ -- CertTemplate fields.
+
+ @return a basic ASN.1 object representation.
+
+
+ Creates a new PopoSigningKeyInput with sender name as authInfo.
+
+
+ Creates a new PopoSigningKeyInput using password-based MAC.
+
+
+ Returns the sender field, or null if authInfo is publicKeyMac
+
+
+ Returns the publicKeyMac field, or null if authInfo is sender
+
+
+
+ PopoSigningKeyInput ::= SEQUENCE {
+ authInfo CHOICE {
+ sender [0] GeneralName,
+ -- used only if an authenticated identity has been
+ -- established for the sender (e.g., a DN from a
+ -- previously-issued and currently-valid certificate
+ publicKeyMac PKMacValue },
+ -- used if no authenticated GeneralName currently exists for
+ -- the sender; publicKeyMac contains a password-based MAC
+ -- on the DER-encoded value of publicKey
+ publicKey SubjectPublicKeyInfo } -- from CertTemplate
+
+ @return a basic ASN.1 object representation.
+
+
+ Creates a ProofOfPossession with type raVerified.
+
+
+ Creates a ProofOfPossession for a signing key.
+
+
+ Creates a ProofOfPossession for key encipherment or agreement.
+ @param type one of TYPE_KEY_ENCIPHERMENT or TYPE_KEY_AGREEMENT
+
+
+
+ ProofOfPossession ::= CHOICE {
+ raVerified [0] NULL,
+ -- used if the RA has already verified that the requester is in
+ -- possession of the private key
+ signature [1] PopoSigningKey,
+ keyEncipherment [2] PopoPrivKey,
+ keyAgreement [3] PopoPrivKey }
+
+ @return a basic ASN.1 object representation.
+
+
+
+ SinglePubInfo ::= SEQUENCE {
+ pubMethod INTEGER {
+ dontCare (0),
+ x500 (1),
+ web (2),
+ ldap (3) },
+ pubLocation GeneralName OPTIONAL }
+
+ @return a basic ASN.1 object representation.
+
+
+ table of the available named parameters for GOST 3410-2001.
+
+
+ return the ECDomainParameters object for the given OID, null if it
+ isn't present.
+
+ @param oid an object identifier representing a named parameters, if present.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+
+ Gost28147-89-Parameters ::=
+ SEQUENCE {
+ iv Gost28147-89-IV,
+ encryptionParamSet OBJECT IDENTIFIER
+ }
+
+ Gost28147-89-IV ::= OCTET STRING (SIZE (8))
+
+
+
+ table of the available named parameters for GOST 3410-94.
+
+
+ return the GOST3410ParamSetParameters object for the given OID, null if it
+ isn't present.
+
+ @param oid an object identifier representing a named parameters, if present.
+
+
+ returns an enumeration containing the name strings for parameters
+ contained in this structure.
+
+
+
+ RFC 3126: 4.3.1 Certificate Values Attribute Definition
+
+ CertificateValues ::= SEQUENCE OF Certificate
+
+
+
+
+
+ CommitmentTypeIndication ::= SEQUENCE {
+ commitmentTypeId CommitmentTypeIdentifier,
+ commitmentTypeQualifier SEQUENCE SIZE (1..MAX) OF
+ CommitmentTypeQualifier OPTIONAL }
+
+
+
+ Commitment type qualifiers, used in the Commitment-Type-Indication attribute (RFC3126).
+
+
+ CommitmentTypeQualifier ::= SEQUENCE {
+ commitmentTypeIdentifier CommitmentTypeIdentifier,
+ qualifier ANY DEFINED BY commitmentTypeIdentifier OPTIONAL }
+
+
+
+ Creates a new CommitmentTypeQualifier
instance.
+
+ @param commitmentTypeIdentifier a CommitmentTypeIdentifier
value
+
+
+ Creates a new CommitmentTypeQualifier
instance.
+
+ @param commitmentTypeIdentifier a CommitmentTypeIdentifier
value
+ @param qualifier the qualifier, defined by the above field.
+
+
+ Creates a new CommitmentTypeQualifier
instance.
+
+ @param as CommitmentTypeQualifier
structure
+ encoded as an Asn1Sequence.
+
+
+ Returns a DER-encodable representation of this instance.
+
+ @return a Asn1Object
value
+
+
+
+ RFC 3126: 4.2.1 Complete Certificate Refs Attribute Definition
+
+ CompleteCertificateRefs ::= SEQUENCE OF OtherCertID
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ CompleteRevocationRefs ::= SEQUENCE OF CrlOcspRef
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ CrlIdentifier ::= SEQUENCE
+ {
+ crlissuer Name,
+ crlIssuedTime UTCTime,
+ crlNumber INTEGER OPTIONAL
+ }
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ CRLListID ::= SEQUENCE
+ {
+ crls SEQUENCE OF CrlValidatedID
+ }
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ CrlOcspRef ::= SEQUENCE {
+ crlids [0] CRLListID OPTIONAL,
+ ocspids [1] OcspListID OPTIONAL,
+ otherRev [2] OtherRevRefs OPTIONAL
+ }
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ CrlValidatedID ::= SEQUENCE {
+ crlHash OtherHash,
+ crlIdentifier CrlIdentifier OPTIONAL}
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ OcspIdentifier ::= SEQUENCE {
+ ocspResponderID ResponderID,
+ -- As in OCSP response data
+ producedAt GeneralizedTime
+ -- As in OCSP response data
+ }
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ OcspListID ::= SEQUENCE {
+ ocspResponses SEQUENCE OF OcspResponsesID
+ }
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ OcspResponsesID ::= SEQUENCE {
+ ocspIdentifier OcspIdentifier,
+ ocspRepHash OtherHash OPTIONAL
+ }
+
+
+
+
+
+
+ OtherCertID ::= SEQUENCE {
+ otherCertHash OtherHash,
+ issuerSerial IssuerSerial OPTIONAL
+ }
+
+
+
+
+
+
+ OtherHash ::= CHOICE {
+ sha1Hash OtherHashValue, -- This contains a SHA-1 hash
+ otherHash OtherHashAlgAndValue
+ }
+
+ OtherHashValue ::= OCTET STRING
+
+
+
+
+
+ Summary description for OtherHashAlgAndValue.
+
+
+
+ OtherHashAlgAndValue ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ hashValue OtherHashValue
+ }
+
+ OtherHashValue ::= OCTET STRING
+
+
+
+
+
+ RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition
+
+ OtherRevRefs ::= SEQUENCE
+ {
+ otherRevRefType OtherRevRefType,
+ otherRevRefs ANY DEFINED BY otherRevRefType
+ }
+
+ OtherRevRefType ::= OBJECT IDENTIFIER
+
+
+
+
+
+ RFC 3126: 4.3.2 Revocation Values Attribute Definition
+
+ OtherRevVals ::= SEQUENCE
+ {
+ otherRevValType OtherRevValType,
+ otherRevVals ANY DEFINED BY otherRevValType
+ }
+
+ OtherRevValType ::= OBJECT IDENTIFIER
+
+
+
+
+
+
+ OtherSigningCertificate ::= SEQUENCE {
+ certs SEQUENCE OF OtherCertID,
+ policies SEQUENCE OF PolicyInformation OPTIONAL
+ }
+
+
+
+
+
+ RFC 5126: 6.3.4. revocation-values Attribute Definition
+
+ RevocationValues ::= SEQUENCE {
+ crlVals [0] SEQUENCE OF CertificateList OPTIONAL,
+ ocspVals [1] SEQUENCE OF BasicOCSPResponse OPTIONAL,
+ otherRevVals [2] OtherRevVals OPTIONAL
+ }
+
+
+
+
+
+
+ SigPolicyQualifierInfo ::= SEQUENCE {
+ sigPolicyQualifierId SigPolicyQualifierId,
+ sigQualifier ANY DEFINED BY sigPolicyQualifierId
+ }
+
+ SigPolicyQualifierId ::= OBJECT IDENTIFIER
+
+
+
+
+
+
+ SignaturePolicyId ::= SEQUENCE {
+ sigPolicyIdentifier SigPolicyId,
+ sigPolicyHash SigPolicyHash,
+ sigPolicyQualifiers SEQUENCE SIZE (1..MAX) OF SigPolicyQualifierInfo OPTIONAL
+ }
+
+ SigPolicyId ::= OBJECT IDENTIFIER
+
+ SigPolicyHash ::= OtherHashAlgAndValue
+
+
+
+
+
+
+ SignaturePolicyIdentifier ::= CHOICE {
+ SignaturePolicyId SignaturePolicyId,
+ SignaturePolicyImplied SignaturePolicyImplied
+ }
+
+ SignaturePolicyImplied ::= NULL
+
+
+
+
+
+
+ SignerAttribute ::= SEQUENCE OF CHOICE {
+ claimedAttributes [0] ClaimedAttributes,
+ certifiedAttributes [1] CertifiedAttributes }
+
+ ClaimedAttributes ::= SEQUENCE OF Attribute
+ CertifiedAttributes ::= AttributeCertificate -- as defined in RFC 3281: see clause 4.1.
+
+
+
+ Signer-Location attribute (RFC3126).
+
+
+ SignerLocation ::= SEQUENCE {
+ countryName [0] DirectoryString OPTIONAL,
+ localityName [1] DirectoryString OPTIONAL,
+ postalAddress [2] PostalAddress OPTIONAL }
+
+ PostalAddress ::= SEQUENCE SIZE(1..6) OF DirectoryString
+
+
+
+
+ SignerLocation ::= SEQUENCE {
+ countryName [0] DirectoryString OPTIONAL,
+ localityName [1] DirectoryString OPTIONAL,
+ postalAddress [2] PostalAddress OPTIONAL }
+
+ PostalAddress ::= SEQUENCE SIZE(1..6) OF DirectoryString
+
+ DirectoryString ::= CHOICE {
+ teletexString TeletexString (SIZE (1..MAX)),
+ printableString PrintableString (SIZE (1..MAX)),
+ universalString UniversalString (SIZE (1..MAX)),
+ utf8String UTF8String (SIZE (1.. MAX)),
+ bmpString BMPString (SIZE (1..MAX)) }
+
+
+
+ constructor
+
+
+
+ ContentHints ::= SEQUENCE {
+ contentDescription UTF8String (SIZE (1..MAX)) OPTIONAL,
+ contentType ContentType }
+
+
+
+ Create from OCTET STRING whose octets represent the identifier.
+
+
+ Create from byte array representing the identifier.
+
+
+ The definition of ContentIdentifier is
+
+ ContentIdentifier ::= OCTET STRING
+
+ id-aa-contentIdentifier OBJECT IDENTIFIER ::= { iso(1)
+ member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9)
+ smime(16) id-aa(2) 7 }
+
+
+ constructor
+
+
+
+ EssCertID ::= SEQUENCE {
+ certHash Hash,
+ issuerSerial IssuerSerial OPTIONAL }
+
+
+
+
+ EssCertIDv2 ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier
+ DEFAULT {algorithm id-sha256},
+ certHash Hash,
+ issuerSerial IssuerSerial OPTIONAL
+ }
+
+ Hash ::= OCTET STRING
+
+ IssuerSerial ::= SEQUENCE {
+ issuer GeneralNames,
+ serialNumber CertificateSerialNumber
+ }
+
+
+
+ constructor
+
+
+
+ OtherCertID ::= SEQUENCE {
+ otherCertHash OtherHash,
+ issuerSerial IssuerSerial OPTIONAL }
+
+ OtherHash ::= CHOICE {
+ sha1Hash OCTET STRING,
+ otherHash OtherHashAlgAndValue }
+
+ OtherHashAlgAndValue ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ hashValue OCTET STRING }
+
+
+
+
+ constructors
+
+
+ The definition of OtherSigningCertificate is
+
+ OtherSigningCertificate ::= SEQUENCE {
+ certs SEQUENCE OF OtherCertID,
+ policies SEQUENCE OF PolicyInformation OPTIONAL
+ }
+
+ id-aa-ets-otherSigCert OBJECT IDENTIFIER ::= { iso(1)
+ member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9)
+ smime(16) id-aa(2) 19 }
+
+
+ constructors
+
+
+ The definition of SigningCertificate is
+
+ SigningCertificate ::= SEQUENCE {
+ certs SEQUENCE OF EssCertID,
+ policies SEQUENCE OF PolicyInformation OPTIONAL
+ }
+
+ id-aa-signingCertificate OBJECT IDENTIFIER ::= { iso(1)
+ member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9)
+ smime(16) id-aa(2) 12 }
+
+
+ The definition of SigningCertificateV2 is
+
+ SigningCertificateV2 ::= SEQUENCE {
+ certs SEQUENCE OF EssCertIDv2,
+ policies SEQUENCE OF PolicyInformation OPTIONAL
+ }
+
+ id-aa-signingCertificateV2 OBJECT IDENTIFIER ::= { iso(1)
+ member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9)
+ smime(16) id-aa(2) 47 }
+
+
+ The CscaMasterList object. This object can be wrapped in a
+ CMSSignedData to be published in LDAP.
+
+
+ CscaMasterList ::= SEQUENCE {
+ version CscaMasterListVersion,
+ certList SET OF Certificate }
+
+ CscaMasterListVersion :: INTEGER {v0(0)}
+
+
+
+ The DataGroupHash object.
+
+ DataGroupHash ::= SEQUENCE {
+ dataGroupNumber DataGroupNumber,
+ dataGroupHashValue OCTET STRING }
+
+ DataGroupNumber ::= INTEGER {
+ dataGroup1 (1),
+ dataGroup1 (2),
+ dataGroup1 (3),
+ dataGroup1 (4),
+ dataGroup1 (5),
+ dataGroup1 (6),
+ dataGroup1 (7),
+ dataGroup1 (8),
+ dataGroup1 (9),
+ dataGroup1 (10),
+ dataGroup1 (11),
+ dataGroup1 (12),
+ dataGroup1 (13),
+ dataGroup1 (14),
+ dataGroup1 (15),
+ dataGroup1 (16) }
+
+
+
+
+ The LDSSecurityObject object (V1.8).
+
+ LDSSecurityObject ::= SEQUENCE {
+ version LDSSecurityObjectVersion,
+ hashAlgorithm DigestAlgorithmIdentifier,
+ dataGroupHashValues SEQUENCE SIZE (2..ub-DataGroups) OF DataHashGroup,
+ ldsVersionInfo LDSVersionInfo OPTIONAL
+ -- if present, version MUST be v1 }
+
+ DigestAlgorithmIdentifier ::= AlgorithmIdentifier,
+
+ LDSSecurityObjectVersion :: INTEGER {V0(0)}
+
+
+
+
+ LDSVersionInfo ::= SEQUENCE {
+ ldsVersion PRINTABLE STRING
+ unicodeVersion PRINTABLE STRING
+ }
+
+ @return
+
+
+ The id-isismtt-cp-accredited OID indicates that the certificate is a
+ qualified certificate according to Directive 1999/93/EC of the European
+ Parliament and of the Council of 13 December 1999 on a Community
+ Framework for Electronic Signatures, which additionally conforms the
+ special requirements of the SigG and has been issued by an accredited CA.
+
+
+ Certificate extensionDate of certificate generation
+
+
+ DateOfCertGenSyntax ::= GeneralizedTime
+
+
+
+ Attribute to indicate that the certificate holder may sign in the name of
+ a third person. May also be used as extension in a certificate.
+
+
+ Attribute to indicate admissions to certain professions. May be used as
+ attribute in attribute certificate or as extension in a certificate
+
+
+ Monetary limit for transactions. The QcEuMonetaryLimit QC statement MUST
+ be used in new certificates in place of the extension/attribute
+ MonetaryLimit since January 1, 2004. For the sake of backward
+ compatibility with certificates already in use, SigG conforming
+ components MUST support MonetaryLimit (as well as QcEuLimitValue).
+
+
+ A declaration of majority. May be used as attribute in attribute
+ certificate or as extension in a certificate
+
+
+
+ Serial number of the smart card containing the corresponding private key
+
+
+ ICCSNSyntax ::= OCTET STRING (SIZE(8..20))
+
+
+
+
+ Reference for a file of a smartcard that stores the public key of this
+ certificate and that is used as �security anchor�.
+
+
+ PKReferenceSyntax ::= OCTET STRING (SIZE(20))
+
+
+
+ Some other restriction regarding the usage of this certificate. May be
+ used as attribute in attribute certificate or as extension in a
+ certificate.
+
+
+ RestrictionSyntax ::= DirectoryString (SIZE(1..1024))
+
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.Restriction
+
+
+
+ (Single)Request extension: Clients may include this extension in a
+ (single) Request to request the responder to send the certificate in the
+ response message along with the status information. Besides the LDAP
+ service, this extension provides another mechanism for the distribution
+ of certificates, which MAY optionally be provided by certificate
+ repositories.
+
+
+ RetrieveIfAllowed ::= BOOLEAN
+
+
+
+ SingleOCSPResponse extension: The certificate requested by the client by
+ inserting the RetrieveIfAllowed extension in the request, will be
+ returned in this extension.
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.Ocsp.RequestedCertificate
+
+
+ Base ObjectIdentifier for naming authorities
+
+
+ SingleOCSPResponse extension: Date, when certificate has been published
+ in the directory and status information has become available. Currently,
+ accrediting authorities enforce that SigG-conforming OCSP servers include
+ this extension in the responses.
+
+
+ CertInDirSince ::= GeneralizedTime
+
+
+
+ Hash of a certificate in OCSP.
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.Ocsp.CertHash
+
+
+
+ NameAtBirth ::= DirectoryString(SIZE(1..64)
+
+
+ Used in
+ {@link Org.BouncyCastle.Asn1.X509.SubjectDirectoryAttributes SubjectDirectoryAttributes}
+
+
+ Some other information of non-restrictive nature regarding the usage of
+ this certificate. May be used as attribute in atribute certificate or as
+ extension in a certificate.
+
+
+ AdditionalInformationSyntax ::= DirectoryString (SIZE(1..2048))
+
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.AdditionalInformationSyntax
+
+
+ Indicates that an attribute certificate exists, which limits the
+ usability of this public key certificate. Whenever verifying a signature
+ with the help of this certificate, the content of the corresponding
+ attribute certificate should be concerned. This extension MUST be
+ included in a PKC, if a corresponding attribute certificate (having the
+ PKC as base certificate) contains some attribute that restricts the
+ usability of the PKC too. Attribute certificates with restricting content
+ MUST always be included in the signed document.
+
+
+ LiabilityLimitationFlagSyntax ::= BOOLEAN
+
+
+
+ ISIS-MTT PROFILE: The responder may include this extension in a response to
+ send the hash of the requested certificate to the responder. This hash is
+ cryptographically bound to the certificate and serves as evidence that the
+ certificate is known to the responder (i.e. it has been issued and is present
+ in the directory). Hence, this extension is a means to provide a positive
+ statement of availability as described in T8.[8]. As explained in T13.[1],
+ clients may rely on this information to be able to validate signatures after
+ the expiry of the corresponding certificate. Hence, clients MUST support this
+ extension. If a positive statement of availability is to be delivered, this
+ extension syntax and OID MUST be used.
+
+
+
+ CertHash ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ certificateHash OCTET STRING
+ }
+
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type CertHash:
+
+
+ CertHash ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ certificateHash OCTET STRING
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from a given details.
+
+ @param hashAlgorithm The hash algorithm identifier.
+ @param certificateHash The hash of the whole DER encoding of the certificate.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ CertHash ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ certificateHash OCTET STRING
+ }
+
+
+ @return an Asn1Object
+
+
+ ISIS-MTT-Optional: The certificate requested by the client by inserting the
+ RetrieveIfAllowed extension in the request, will be returned in this
+ extension.
+
+ ISIS-MTT-SigG: The signature act allows publishing certificates only then,
+ when the certificate owner gives his isExplicit permission. Accordingly, there
+ may be �nondownloadable� certificates, about which the responder must provide
+ status information, but MUST NOT include them in the response. Clients may
+ get therefore the following three kind of answers on a single request
+ including the RetrieveIfAllowed extension:
+
+ - a) the responder supports the extension and is allowed to publish the
+ certificate: RequestedCertificate returned including the requested
+ certificate
+ - b) the responder supports the extension but is NOT allowed to publish
+ the certificate: RequestedCertificate returned including an empty OCTET
+ STRING
+ - c) the responder does not support the extension: RequestedCertificate is
+ not included in the response
+
+ Clients requesting RetrieveIfAllowed MUST be able to handle these cases. If
+ any of the OCTET STRING options is used, it MUST contain the DER encoding of
+ the requested certificate.
+
+
+ RequestedCertificate ::= CHOICE {
+ Certificate Certificate,
+ publicKeyCertificate [0] EXPLICIT OCTET STRING,
+ attributeCertificate [1] EXPLICIT OCTET STRING
+ }
+
+
+
+ Constructor from a given details.
+
+ Only one parameter can be given. All other must be null
.
+
+ @param certificate Given as Certificate
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ RequestedCertificate ::= CHOICE {
+ Certificate Certificate,
+ publicKeyCertificate [0] EXPLICIT OCTET STRING,
+ attributeCertificate [1] EXPLICIT OCTET STRING
+ }
+
+
+ @return an Asn1Object
+
+
+ Some other information of non-restrictive nature regarding the usage of this
+ certificate.
+
+
+ AdditionalInformationSyntax ::= DirectoryString (SIZE(1..2048))
+
+
+
+ Constructor from a given details.
+
+ @param information The describtion of the information.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ AdditionalInformationSyntax ::= DirectoryString (SIZE(1..2048))
+
+
+ @return an Asn1Object
+
+
+ Attribute to indicate admissions to certain professions.
+
+
+ AdmissionSyntax ::= SEQUENCE
+ {
+ admissionAuthority GeneralName OPTIONAL,
+ contentsOfAdmissions SEQUENCE OF Admissions
+ }
+
+ Admissions ::= SEQUENCE
+ {
+ admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+ namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+ professionInfos SEQUENCE OF ProfessionInfo
+ }
+
+ NamingAuthority ::= SEQUENCE
+ {
+ namingAuthorityId OBJECT IDENTIFIER OPTIONAL,
+ namingAuthorityUrl IA5String OPTIONAL,
+ namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+ }
+
+ ProfessionInfo ::= SEQUENCE
+ {
+ namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+ professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+ professionOIDs SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+ registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+ addProfessionInfo OCTET STRING OPTIONAL
+ }
+
+
+
+ ISIS-MTT PROFILE: The relatively complex structure of AdmissionSyntax
+ supports the following concepts and requirements:
+
+ - External institutions (e.g. professional associations, chambers, unions,
+ administrative bodies, companies, etc.), which are responsible for granting
+ and verifying professional admissions, are indicated by means of the data
+ field admissionAuthority. An admission authority is indicated by a
+ GeneralName object. Here an X.501 directory name (distinguished name) can be
+ indicated in the field directoryName, a URL address can be indicated in the
+ field uniformResourceIdentifier, and an object identifier can be indicated in
+ the field registeredId.
+ - The names of authorities which are responsible for the administration of
+ title registers are indicated in the data field namingAuthority. The name of
+ the authority can be identified by an object identifier in the field
+ namingAuthorityId, by means of a text string in the field
+ namingAuthorityText, by means of a URL address in the field
+ namingAuthorityUrl, or by a combination of them. For example, the text string
+ can contain the name of the authority, the country and the name of the title
+ register. The URL-option refers to a web page which contains lists with
+ officially registered professions (text and possibly OID) as well as
+ further information on these professions. Object identifiers for the
+ component namingAuthorityId are grouped under the OID-branch
+ id-isis-at-namingAuthorities and must be applied for.
+ - See http://www.teletrust.de/anwend.asp?Id=30200&Sprache=E_&HomePG=0
+ for an application form and http://www.teletrust.de/links.asp?id=30220,11
+ for an overview of registered naming authorities.
+ - By means of the data type ProfessionInfo certain professions,
+ specializations, disciplines, fields of activity, etc. are identified. A
+ profession is represented by one or more text strings, resp. profession OIDs
+ in the fields professionItems and professionOIDs and by a registration number
+ in the field registrationNumber. An indication in text form must always be
+ present, whereas the other indications are optional. The component
+ addProfessionInfo may contain additional applicationspecific information in
+ DER-encoded form.
+
+
+ By means of different namingAuthority-OIDs or profession OIDs hierarchies of
+ professions, specializations, disciplines, fields of activity, etc. can be
+ expressed. The issuing admission authority should always be indicated (field
+ admissionAuthority), whenever a registration number is presented. Still,
+ information on admissions can be given without indicating an admission or a
+ naming authority by the exclusive use of the component professionItems. In
+ this case the certification authority is responsible for the verification of
+ the admission information.
+
+
+
+ This attribute is single-valued. Still, several admissions can be captured in
+ the sequence structure of the component contentsOfAdmissions of
+ AdmissionSyntax or in the component professionInfos of Admissions. The
+ component admissionAuthority of AdmissionSyntax serves as default value for
+ the component admissionAuthority of Admissions. Within the latter component
+ the default value can be overwritten, in case that another authority is
+ responsible. The component namingAuthority of Admissions serves as a default
+ value for the component namingAuthority of ProfessionInfo. Within the latter
+ component the default value can be overwritten, in case that another naming
+ authority needs to be recorded.
+
+ The length of the string objects is limited to 128 characters. It is
+ recommended to indicate a namingAuthorityURL in all issued attribute
+ certificates. If a namingAuthorityURL is indicated, the field professionItems
+ of ProfessionInfo should contain only registered titles. If the field
+ professionOIDs exists, it has to contain the OIDs of the professions listed
+ in professionItems in the same order. In general, the field professionInfos
+ should contain only one entry, unless the admissions that are to be listed
+ are logically connected (e.g. they have been issued under the same admission
+ number).
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.Admissions
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.ProfessionInfo
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.NamingAuthority
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type ProcurationSyntax:
+
+
+ AdmissionSyntax ::= SEQUENCE
+ {
+ admissionAuthority GeneralName OPTIONAL,
+ contentsOfAdmissions SEQUENCE OF Admissions
+ }
+
+ Admissions ::= SEQUENCE
+ {
+ admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+ namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+ professionInfos SEQUENCE OF ProfessionInfo
+ }
+
+ NamingAuthority ::= SEQUENCE
+ {
+ namingAuthorityId OBJECT IDENTIFIER OPTIONAL,
+ namingAuthorityUrl IA5String OPTIONAL,
+ namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+ }
+
+ ProfessionInfo ::= SEQUENCE
+ {
+ namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+ professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+ professionOIDs SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+ registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+ addProfessionInfo OCTET STRING OPTIONAL
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from given details.
+
+ @param admissionAuthority The admission authority.
+ @param contentsOfAdmissions The admissions.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ AdmissionSyntax ::= SEQUENCE
+ {
+ admissionAuthority GeneralName OPTIONAL,
+ contentsOfAdmissions SEQUENCE OF Admissions
+ }
+
+ Admissions ::= SEQUENCE
+ {
+ admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+ namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+ professionInfos SEQUENCE OF ProfessionInfo
+ }
+
+ NamingAuthority ::= SEQUENCE
+ {
+ namingAuthorityId OBJECT IDENTIFIER OPTIONAL,
+ namingAuthorityUrl IA5String OPTIONAL,
+ namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+ }
+
+ ProfessionInfo ::= SEQUENCE
+ {
+ namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+ professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+ professionOIDs SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+ registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+ addProfessionInfo OCTET STRING OPTIONAL
+ }
+
+
+ @return an Asn1Object
+
+
+ @return Returns the admissionAuthority if present, null otherwise.
+
+
+ @return Returns the contentsOfAdmissions.
+
+
+ An Admissions structure.
+
+
+ Admissions ::= SEQUENCE
+ {
+ admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+ namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+ professionInfos SEQUENCE OF ProfessionInfo
+ }
+
+
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.AdmissionSyntax
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.ProfessionInfo
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.NamingAuthority
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type ProcurationSyntax:
+
+
+ Admissions ::= SEQUENCE
+ {
+ admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+ namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+ professionInfos SEQUENCE OF ProfessionInfo
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from a given details.
+
+ Parameter professionInfos
is mandatory.
+
+ @param admissionAuthority The admission authority.
+ @param namingAuthority The naming authority.
+ @param professionInfos The profession infos.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ Admissions ::= SEQUENCE
+ {
+ admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+ namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+ professionInfos SEQUENCE OF ProfessionInfo
+ }
+
+
+
+ @return an Asn1Object
+
+
+ A declaration of majority.
+
+
+ DeclarationOfMajoritySyntax ::= CHOICE
+ {
+ notYoungerThan [0] IMPLICIT INTEGER,
+ fullAgeAtCountry [1] IMPLICIT SEQUENCE
+ {
+ fullAge BOOLEAN DEFAULT TRUE,
+ country PrintableString (SIZE(2))
+ }
+ dateOfBirth [2] IMPLICIT GeneralizedTime
+ }
+
+
+ fullAgeAtCountry indicates the majority of the owner with respect to the laws
+ of a specific country.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ DeclarationOfMajoritySyntax ::= CHOICE
+ {
+ notYoungerThan [0] IMPLICIT INTEGER,
+ fullAgeAtCountry [1] IMPLICIT SEQUENCE
+ {
+ fullAge BOOLEAN DEFAULT TRUE,
+ country PrintableString (SIZE(2))
+ }
+ dateOfBirth [2] IMPLICIT GeneralizedTime
+ }
+
+
+ @return an Asn1Object
+
+
+ @return notYoungerThan if that's what we are, -1 otherwise
+
+
+ Monetary limit for transactions. The QcEuMonetaryLimit QC statement MUST be
+ used in new certificates in place of the extension/attribute MonetaryLimit
+ since January 1, 2004. For the sake of backward compatibility with
+ certificates already in use, components SHOULD support MonetaryLimit (as well
+ as QcEuLimitValue).
+
+ Indicates a monetary limit within which the certificate holder is authorized
+ to act. (This value DOES NOT express a limit on the liability of the
+ certification authority).
+
+
+ MonetaryLimitSyntax ::= SEQUENCE
+ {
+ currency PrintableString (SIZE(3)),
+ amount INTEGER,
+ exponent INTEGER
+ }
+
+
+ currency must be the ISO code.
+
+ value = amount�10*exponent
+
+
+ Constructor from a given details.
+
+
+ value = amount�10^exponent
+
+ @param currency The currency. Must be the ISO code.
+ @param amount The amount
+ @param exponent The exponent
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ MonetaryLimitSyntax ::= SEQUENCE
+ {
+ currency PrintableString (SIZE(3)),
+ amount INTEGER,
+ exponent INTEGER
+ }
+
+
+ @return an Asn1Object
+
+
+ Names of authorities which are responsible for the administration of title
+ registers.
+
+
+ NamingAuthority ::= SEQUENCE
+ {
+ namingAuthorityID OBJECT IDENTIFIER OPTIONAL,
+ namingAuthorityUrl IA5String OPTIONAL,
+ namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+ }
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.AdmissionSyntax
+
+
+
+ Profession OIDs should always be defined under the OID branch of the
+ responsible naming authority. At the time of this writing, the work group
+ �Recht, Wirtschaft, Steuern� (�Law, Economy, Taxes�) is registered as the
+ first naming authority under the OID id-isismtt-at-namingAuthorities.
+
+
+ Constructor from Asn1Sequence.
+
+
+
+ NamingAuthority ::= SEQUENCE
+ {
+ namingAuthorityID OBJECT IDENTIFIER OPTIONAL,
+ namingAuthorityUrl IA5String OPTIONAL,
+ namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ @return Returns the namingAuthorityID.
+
+
+ @return Returns the namingAuthorityText.
+
+
+ @return Returns the namingAuthorityUrl.
+
+
+ Constructor from given details.
+
+ All parameters can be combined.
+
+ @param namingAuthorityID ObjectIdentifier for naming authority.
+ @param namingAuthorityUrl URL for naming authority.
+ @param namingAuthorityText Textual representation of naming authority.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ NamingAuthority ::= SEQUENCE
+ {
+ namingAuthorityID OBJECT IDENTIFIER OPTIONAL,
+ namingAuthorityUrl IA5String OPTIONAL,
+ namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+ }
+
+
+ @return an Asn1Object
+
+
+ Attribute to indicate that the certificate holder may sign in the name of a
+ third person.
+
+ ISIS-MTT PROFILE: The corresponding ProcurationSyntax contains either the
+ name of the person who is represented (subcomponent thirdPerson) or a
+ reference to his/her base certificate (in the component signingFor,
+ subcomponent certRef), furthermore the optional components country and
+ typeSubstitution to indicate the country whose laws apply, and respectively
+ the type of procuration (e.g. manager, procuration, custody).
+
+
+ ISIS-MTT PROFILE: The GeneralName MUST be of type directoryName and MAY only
+ contain: - RFC3039 attributes, except pseudonym (countryName, commonName,
+ surname, givenName, serialNumber, organizationName, organizationalUnitName,
+ stateOrProvincename, localityName, postalAddress) and - SubjectDirectoryName
+ attributes (title, dateOfBirth, placeOfBirth, gender, countryOfCitizenship,
+ countryOfResidence and NameAtBirth).
+
+
+ ProcurationSyntax ::= SEQUENCE {
+ country [1] EXPLICIT PrintableString(SIZE(2)) OPTIONAL,
+ typeOfSubstitution [2] EXPLICIT DirectoryString (SIZE(1..128)) OPTIONAL,
+ signingFor [3] EXPLICIT SigningFor
+ }
+
+ SigningFor ::= CHOICE
+ {
+ thirdPerson GeneralName,
+ certRef IssuerSerial
+ }
+
+
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type ProcurationSyntax:
+
+
+ ProcurationSyntax ::= SEQUENCE {
+ country [1] EXPLICIT PrintableString(SIZE(2)) OPTIONAL,
+ typeOfSubstitution [2] EXPLICIT DirectoryString (SIZE(1..128)) OPTIONAL,
+ signingFor [3] EXPLICIT SigningFor
+ }
+
+ SigningFor ::= CHOICE
+ {
+ thirdPerson GeneralName,
+ certRef IssuerSerial
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from a given details.
+
+
+ Either generalName
or certRef
MUST be
+ null
.
+
+ @param country The country code whose laws apply.
+ @param typeOfSubstitution The type of procuration.
+ @param certRef Reference to certificate of the person who is represented.
+
+
+ Constructor from a given details.
+
+
+ Either generalName
or certRef
MUST be
+ null
.
+
+ @param country The country code whose laws apply.
+ @param typeOfSubstitution The type of procuration.
+ @param thirdPerson The GeneralName of the person who is represented.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ ProcurationSyntax ::= SEQUENCE {
+ country [1] EXPLICIT PrintableString(SIZE(2)) OPTIONAL,
+ typeOfSubstitution [2] EXPLICIT DirectoryString (SIZE(1..128)) OPTIONAL,
+ signingFor [3] EXPLICIT SigningFor
+ }
+
+ SigningFor ::= CHOICE
+ {
+ thirdPerson GeneralName,
+ certRef IssuerSerial
+ }
+
+
+ @return an Asn1Object
+
+
+ Professions, specializations, disciplines, fields of activity, etc.
+
+
+ ProfessionInfo ::= SEQUENCE
+ {
+ namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+ professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+ professionOids SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+ registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+ addProfessionInfo OCTET STRING OPTIONAL
+ }
+
+
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.AdmissionSyntax
+
+
+ Rechtsanw�ltin
+
+
+ Rechtsanwalt
+
+
+ Rechtsbeistand
+
+
+ Steuerberaterin
+
+
+ Steuerberater
+
+
+ Steuerbevollm�chtigte
+
+
+ Steuerbevollm�chtigter
+
+
+ Notarin
+
+
+ Notar
+
+
+ Notarvertreterin
+
+
+ Notarvertreter
+
+
+ Notariatsverwalterin
+
+
+ Notariatsverwalter
+
+
+ Wirtschaftspr�ferin
+
+
+ Wirtschaftspr�fer
+
+
+ Vereidigte Buchpr�ferin
+
+
+ Vereidigter Buchpr�fer
+
+
+ Patentanw�ltin
+
+
+ Patentanwalt
+
+
+ Constructor from Asn1Sequence.
+
+
+
+ ProfessionInfo ::= SEQUENCE
+ {
+ namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+ professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+ professionOids SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+ registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+ addProfessionInfo OCTET STRING OPTIONAL
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from given details.
+
+ professionItems
is mandatory, all other parameters are
+ optional.
+
+ @param namingAuthority The naming authority.
+ @param professionItems Directory strings of the profession.
+ @param professionOids DERObjectIdentfier objects for the
+ profession.
+ @param registrationNumber Registration number.
+ @param addProfessionInfo Additional infos in encoded form.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ ProfessionInfo ::= SEQUENCE
+ {
+ namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+ professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+ professionOids SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+ registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+ addProfessionInfo OCTET STRING OPTIONAL
+ }
+
+
+ @return an Asn1Object
+
+
+ @return Returns the addProfessionInfo.
+
+
+ @return Returns the namingAuthority.
+
+
+ @return Returns the professionItems.
+
+
+ @return Returns the professionOids.
+
+
+ @return Returns the registrationNumber.
+
+
+ Some other restriction regarding the usage of this certificate.
+
+
+ RestrictionSyntax ::= DirectoryString (SIZE(1..1024))
+
+
+
+ Constructor from DirectoryString.
+
+ The DirectoryString is of type RestrictionSyntax:
+
+
+ RestrictionSyntax ::= DirectoryString (SIZE(1..1024))
+
+
+ @param restriction A IAsn1String.
+
+
+ Constructor from a given details.
+
+ @param restriction The description of the restriction.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ RestrictionSyntax ::= DirectoryString (SIZE(1..1024))
+
+
+
+ @return an Asn1Object
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ cast5CBCParameters ::= Sequence {
+ iv OCTET STRING DEFAULT 0,
+ -- Initialization vector
+ keyLength Integer
+ -- Key length, in bits
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ IDEA-CBCPar ::= Sequence {
+ iv OCTET STRING OPTIONAL -- exactly 8 octets
+ }
+
+
+
+ The NetscapeCertType object.
+
+ NetscapeCertType ::= BIT STRING {
+ SSLClient (0),
+ SSLServer (1),
+ S/MIME (2),
+ Object Signing (3),
+ Reserved (4),
+ SSL CA (5),
+ S/MIME CA (6),
+ Object Signing CA (7) }
+
+
+
+ Basic constructor.
+
+ @param usage - the bitwise OR of the Key Usage flags giving the
+ allowed uses for the key.
+ e.g. (X509NetscapeCertType.sslCA | X509NetscapeCertType.smimeCA)
+
+
+ This is designed to parse
+ the PublicKeyAndChallenge created by the KEYGEN tag included by
+ Mozilla based browsers.
+
+ PublicKeyAndChallenge ::= SEQUENCE {
+ spki SubjectPublicKeyInfo,
+ challenge IA5STRING
+ }
+
+
+
+
+ Utility class for fetching curves using their NIST names as published in FIPS-PUB 186-3
+
+
+ return the X9ECParameters object for the named curve represented by
+ the passed in object identifier. Null if the curve isn't present.
+
+ @param oid an object identifier representing a named curve, if present.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+ From RFC 3657
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ BasicOcspResponse ::= Sequence {
+ tbsResponseData ResponseData,
+ signatureAlgorithm AlgorithmIdentifier,
+ signature BIT STRING,
+ certs [0] EXPLICIT Sequence OF Certificate OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ CertID ::= Sequence {
+ hashAlgorithm AlgorithmIdentifier,
+ issuerNameHash OCTET STRING, -- Hash of Issuer's DN
+ issuerKeyHash OCTET STRING, -- Hash of Issuers public key
+ serialNumber CertificateSerialNumber }
+
+
+
+ create a CertStatus object with a tag of zero.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ CertStatus ::= CHOICE {
+ good [0] IMPLICIT Null,
+ revoked [1] IMPLICIT RevokedInfo,
+ unknown [2] IMPLICIT UnknownInfo }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ CrlID ::= Sequence {
+ crlUrl [0] EXPLICIT IA5String OPTIONAL,
+ crlNum [1] EXPLICIT Integer OPTIONAL,
+ crlTime [2] EXPLICIT GeneralizedTime OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OcspRequest ::= Sequence {
+ tbsRequest TBSRequest,
+ optionalSignature [0] EXPLICIT Signature OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OcspResponse ::= Sequence {
+ responseStatus OcspResponseStatus,
+ responseBytes [0] EXPLICIT ResponseBytes OPTIONAL }
+
+
+
+ The OcspResponseStatus enumeration.
+
+ OcspResponseStatus ::= Enumerated {
+ successful (0), --Response has valid confirmations
+ malformedRequest (1), --Illegal confirmation request
+ internalError (2), --Internal error in issuer
+ tryLater (3), --Try again later
+ --(4) is not used
+ sigRequired (5), --Must sign the request
+ unauthorized (6) --Request unauthorized
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Request ::= Sequence {
+ reqCert CertID,
+ singleRequestExtensions [0] EXPLICIT Extensions OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ResponderID ::= CHOICE {
+ byName [1] Name,
+ byKey [2] KeyHash }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ResponseBytes ::= Sequence {
+ responseType OBJECT IDENTIFIER,
+ response OCTET STRING }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ResponseData ::= Sequence {
+ version [0] EXPLICIT Version DEFAULT v1,
+ responderID ResponderID,
+ producedAt GeneralizedTime,
+ responses Sequence OF SingleResponse,
+ responseExtensions [1] EXPLICIT Extensions OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ RevokedInfo ::= Sequence {
+ revocationTime GeneralizedTime,
+ revocationReason [0] EXPLICIT CRLReason OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ServiceLocator ::= Sequence {
+ issuer Name,
+ locator AuthorityInfoAccessSyntax OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Signature ::= Sequence {
+ signatureAlgorithm AlgorithmIdentifier,
+ signature BIT STRING,
+ certs [0] EXPLICIT Sequence OF Certificate OPTIONAL}
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SingleResponse ::= Sequence {
+ certID CertID,
+ certStatus CertStatus,
+ thisUpdate GeneralizedTime,
+ nextUpdate [0] EXPLICIT GeneralizedTime OPTIONAL,
+ singleExtensions [1] EXPLICIT Extensions OPTIONAL }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ TBSRequest ::= Sequence {
+ version [0] EXPLICIT Version DEFAULT v1,
+ requestorName [1] EXPLICIT GeneralName OPTIONAL,
+ requestList Sequence OF Request,
+ requestExtensions [2] EXPLICIT Extensions OPTIONAL }
+
+
+
+ return an Attribute object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Attr ::= Sequence {
+ attrType OBJECT IDENTIFIER,
+ attrValues Set OF AttributeValue
+ }
+
+
+
+ Pkcs10 Certfication request object.
+
+ CertificationRequest ::= Sequence {
+ certificationRequestInfo CertificationRequestInfo,
+ signatureAlgorithm AlgorithmIdentifier{{ SignatureAlgorithms }},
+ signature BIT STRING
+ }
+
+
+
+ Pkcs10 CertificationRequestInfo object.
+
+ CertificationRequestInfo ::= Sequence {
+ version Integer { v1(0) } (v1,...),
+ subject Name,
+ subjectPKInfo SubjectPublicKeyInfo{{ PKInfoAlgorithms }},
+ attributes [0] Attributes{{ CRIAttributes }}
+ }
+
+ Attributes { ATTRIBUTE:IOSet } ::= Set OF Attr{{ IOSet }}
+
+ Attr { ATTRIBUTE:IOSet } ::= Sequence {
+ type ATTRIBUTE.&id({IOSet}),
+ values Set SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{\@type})
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ContentInfo ::= Sequence {
+ contentType ContentType,
+ content
+ [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL }
+
+
+
+ The EncryptedData object.
+
+ EncryptedData ::= Sequence {
+ version Version,
+ encryptedContentInfo EncryptedContentInfo
+ }
+
+
+ EncryptedContentInfo ::= Sequence {
+ contentType ContentType,
+ contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,
+ encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL
+ }
+
+ EncryptedContent ::= OCTET STRING
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ EncryptedPrivateKeyInfo ::= Sequence {
+ encryptionAlgorithm AlgorithmIdentifier {{KeyEncryptionAlgorithms}},
+ encryptedData EncryptedData
+ }
+
+ EncryptedData ::= OCTET STRING
+
+ KeyEncryptionAlgorithms ALGORITHM-IDENTIFIER ::= {
+ ... -- For local profiles
+ }
+
+
+
+
+ MacData ::= SEQUENCE {
+ mac DigestInfo,
+ macSalt OCTET STRING,
+ iterations INTEGER DEFAULT 1
+ -- Note: The default is for historic reasons and its use is deprecated. A
+ -- higher value, like 1024 is recommended.
+
+ @return the basic DERObject construction.
+
+
+ the infamous Pfx from Pkcs12
+
+
+ write out an RSA private key with its associated information
+ as described in Pkcs8.
+
+ PrivateKeyInfo ::= Sequence {
+ version Version,
+ privateKeyAlgorithm AlgorithmIdentifier {{PrivateKeyAlgorithms}},
+ privateKey PrivateKey,
+ attributes [0] IMPLICIT Attributes OPTIONAL
+ }
+ Version ::= Integer {v1(0)} (v1,...)
+
+ PrivateKey ::= OCTET STRING
+
+ Attributes ::= Set OF Attr
+
+
+
+ The default version
+
+
+
+ RSAES-OAEP-params ::= SEQUENCE {
+ hashAlgorithm [0] OAEP-PSSDigestAlgorithms DEFAULT sha1,
+ maskGenAlgorithm [1] PKCS1MGFAlgorithms DEFAULT mgf1SHA1,
+ pSourceAlgorithm [2] PKCS1PSourceAlgorithms DEFAULT pSpecifiedEmpty
+ }
+
+ OAEP-PSSDigestAlgorithms ALGORITHM-IDENTIFIER ::= {
+ { OID id-sha1 PARAMETERS NULL }|
+ { OID id-sha256 PARAMETERS NULL }|
+ { OID id-sha384 PARAMETERS NULL }|
+ { OID id-sha512 PARAMETERS NULL },
+ ... -- Allows for future expansion --
+ }
+ PKCS1MGFAlgorithms ALGORITHM-IDENTIFIER ::= {
+ { OID id-mgf1 PARAMETERS OAEP-PSSDigestAlgorithms },
+ ... -- Allows for future expansion --
+ }
+ PKCS1PSourceAlgorithms ALGORITHM-IDENTIFIER ::= {
+ { OID id-pSpecified PARAMETERS OCTET STRING },
+ ... -- Allows for future expansion --
+ }
+
+ @return the asn1 primitive representing the parameters.
+
+
+ This outputs the key in Pkcs1v2 format.
+
+ RsaPrivateKey ::= Sequence {
+ version Version,
+ modulus Integer, -- n
+ publicExponent Integer, -- e
+ privateExponent Integer, -- d
+ prime1 Integer, -- p
+ prime2 Integer, -- q
+ exponent1 Integer, -- d mod (p-1)
+ exponent2 Integer, -- d mod (q-1)
+ coefficient Integer -- (inverse of q) mod p
+ }
+
+ Version ::= Integer
+
+ This routine is written to output Pkcs1 version 0, private keys.
+
+
+ The default version
+
+
+
+ RSASSA-PSS-params ::= SEQUENCE {
+ hashAlgorithm [0] OAEP-PSSDigestAlgorithms DEFAULT sha1,
+ maskGenAlgorithm [1] PKCS1MGFAlgorithms DEFAULT mgf1SHA1,
+ saltLength [2] INTEGER DEFAULT 20,
+ trailerField [3] TrailerField DEFAULT trailerFieldBC
+ }
+
+ OAEP-PSSDigestAlgorithms ALGORITHM-IDENTIFIER ::= {
+ { OID id-sha1 PARAMETERS NULL }|
+ { OID id-sha256 PARAMETERS NULL }|
+ { OID id-sha384 PARAMETERS NULL }|
+ { OID id-sha512 PARAMETERS NULL },
+ ... -- Allows for future expansion --
+ }
+
+ PKCS1MGFAlgorithms ALGORITHM-IDENTIFIER ::= {
+ { OID id-mgf1 PARAMETERS OAEP-PSSDigestAlgorithms },
+ ... -- Allows for future expansion --
+ }
+
+ TrailerField ::= INTEGER { trailerFieldBC(1) }
+
+ @return the asn1 primitive representing the parameters.
+
+
+ a Pkcs#7 signed data object.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SignedData ::= Sequence {
+ version Version,
+ digestAlgorithms DigestAlgorithmIdentifiers,
+ contentInfo ContentInfo,
+ certificates
+ [0] IMPLICIT ExtendedCertificatesAndCertificates
+ OPTIONAL,
+ crls
+ [1] IMPLICIT CertificateRevocationLists OPTIONAL,
+ signerInfos SignerInfos }
+
+
+
+ a Pkcs#7 signer info object.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SignerInfo ::= Sequence {
+ version Version,
+ issuerAndSerialNumber IssuerAndSerialNumber,
+ digestAlgorithm DigestAlgorithmIdentifier,
+ authenticatedAttributes [0] IMPLICIT Attributes OPTIONAL,
+ digestEncryptionAlgorithm DigestEncryptionAlgorithmIdentifier,
+ encryptedDigest EncryptedDigest,
+ unauthenticatedAttributes [1] IMPLICIT Attributes OPTIONAL
+ }
+
+ EncryptedDigest ::= OCTET STRING
+
+ DigestAlgorithmIdentifier ::= AlgorithmIdentifier
+
+ DigestEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier
+
+
+
+ the elliptic curve private key object from SEC 1
+
+
+ ECPrivateKey ::= SEQUENCE {
+ version INTEGER { ecPrivkeyVer1(1) } (ecPrivkeyVer1),
+ privateKey OCTET STRING,
+ parameters [0] Parameters OPTIONAL,
+ publicKey [1] BIT STRING OPTIONAL }
+
+
+ return the X9ECParameters object for the named curve represented by
+ the passed in object identifier. Null if the curve isn't present.
+
+ @param oid an object identifier representing a named curve, if present.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+ EllipticCurve OBJECT IDENTIFIER ::= {
+ iso(1) identified-organization(3) certicom(132) curve(0)
+ }
+
+
+ Handler class for dealing with S/MIME Capabilities
+
+
+ general preferences
+
+
+ encryption algorithms preferences
+
+
+ return an Attr object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ returns an ArrayList with 0 or more objects of all the capabilities
+ matching the passed in capability Oid. If the Oid passed is null the
+ entire set is returned.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SMIMECapabilities ::= Sequence OF SMIMECapability
+
+
+
+ general preferences
+
+
+ encryption algorithms preferences
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SMIMECapability ::= Sequence {
+ capabilityID OBJECT IDENTIFIER,
+ parameters ANY DEFINED BY capabilityID OPTIONAL
+ }
+
+
+
+ Handler for creating a vector S/MIME Capabilities
+
+
+ The SmimeEncryptionKeyPreference object.
+
+ SmimeEncryptionKeyPreference ::= CHOICE {
+ issuerAndSerialNumber [0] IssuerAndSerialNumber,
+ receipentKeyId [1] RecipientKeyIdentifier,
+ subjectAltKeyIdentifier [2] SubjectKeyIdentifier
+ }
+
+
+
+ @param sKeyId the subjectKeyIdentifier value (normally the X.509 one)
+
+
+ elliptic curves defined in "ECC Brainpool Standard Curves and Curve Generation"
+ http://www.ecc-brainpool.org/download/draft_pkix_additional_ecc_dp.txt
+
+
+ return the X9ECParameters object for the named curve represented by
+ the passed in object identifier. Null if the curve isn't present.
+
+ @param oid an object identifier representing a named curve, if present.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+
+ Accuracy ::= SEQUENCE {
+ seconds INTEGER OPTIONAL,
+ millis [0] INTEGER (1..999) OPTIONAL,
+ micros [1] INTEGER (1..999) OPTIONAL
+ }
+
+
+
+ @param o
+ @return a MessageImprint object.
+
+
+
+ MessageImprint ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ hashedMessage OCTET STRING }
+
+
+
+
+
+ TstInfo ::= SEQUENCE {
+ version INTEGER { v1(1) },
+ policy TSAPolicyId,
+ messageImprint MessageImprint,
+ -- MUST have the same value as the similar field in
+ -- TimeStampReq
+ serialNumber INTEGER,
+ -- Time-Stamping users MUST be ready to accommodate integers
+ -- up to 160 bits.
+ genTime GeneralizedTime,
+ accuracy Accuracy OPTIONAL,
+ ordering BOOLEAN DEFAULT FALSE,
+ nonce INTEGER OPTIONAL,
+ -- MUST be present if the similar field was present
+ -- in TimeStampReq. In that case it MUST have the same value.
+ tsa [0] GeneralName OPTIONAL,
+ extensions [1] IMPLICIT Extensions OPTIONAL }
+
+
+
+
+
+ TimeStampReq ::= SEQUENCE {
+ version INTEGER { v1(1) },
+ messageImprint MessageImprint,
+ --a hash algorithm OID and the hash value of the data to be
+ --time-stamped
+ reqPolicy TSAPolicyId OPTIONAL,
+ nonce INTEGER OPTIONAL,
+ certReq BOOLEAN DEFAULT FALSE,
+ extensions [0] IMPLICIT Extensions OPTIONAL
+ }
+
+
+
+
+ TimeStampResp ::= SEQUENCE {
+ status PkiStatusInfo,
+ timeStampToken TimeStampToken OPTIONAL }
+
+
+
+ dump a Der object as a formatted string with indentation
+
+ @param obj the Asn1Object to be dumped out.
+
+
+ dump out a DER object as a formatted string, in non-verbose mode
+
+ @param obj the Asn1Encodable to be dumped out.
+ @return the resulting string.
+
+
+ Dump out the object as a string
+
+ @param obj the Asn1Encodable to be dumped out.
+ @param verbose if true, dump out the contents of octet and bit strings.
+ @return the resulting string.
+
+
+
+ DirectoryString ::= CHOICE {
+ teletexString TeletexString (SIZE (1..MAX)),
+ printableString PrintableString (SIZE (1..MAX)),
+ universalString UniversalString (SIZE (1..MAX)),
+ utf8String UTF8String (SIZE (1..MAX)),
+ bmpString BMPString (SIZE (1..MAX)) }
+
+
+
+ The AccessDescription object.
+
+ AccessDescription ::= SEQUENCE {
+ accessMethod OBJECT IDENTIFIER,
+ accessLocation GeneralName }
+
+
+
+ create an AccessDescription with the oid and location provided.
+
+
+
+ @return the access method.
+
+
+
+ @return the access location
+
+
+
+ Return the OID in the Algorithm entry of this identifier.
+
+
+
+
+ Return the parameters structure in the Parameters entry of this identifier.
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AlgorithmIdentifier ::= Sequence {
+ algorithm OBJECT IDENTIFIER,
+ parameters ANY DEFINED BY algorithm OPTIONAL }
+
+
+
+
+ Don't use this one if you are trying to be RFC 3281 compliant.
+ Use it for v1 attribute certificates only.
+
+ Our GeneralNames structure
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AttCertIssuer ::= CHOICE {
+ v1Form GeneralNames, -- MUST NOT be used in this
+ -- profile
+ v2Form [0] V2Form -- v2 only
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AttCertValidityPeriod ::= Sequence {
+ notBeforeTime GeneralizedTime,
+ notAfterTime GeneralizedTime
+ }
+
+
+
+ return an Attr object from the given object.
+
+ @param o the object we want converted.
+ @exception ArgumentException if the object cannot be converted.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Attr ::= Sequence {
+ attrType OBJECT IDENTIFIER,
+ attrValues Set OF AttributeValue
+ }
+
+
+
+ @param obj
+ @return
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AttributeCertificate ::= Sequence {
+ acinfo AttributeCertificateInfo,
+ signatureAlgorithm AlgorithmIdentifier,
+ signatureValue BIT STRING
+ }
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ AttributeCertificateInfo ::= Sequence {
+ version AttCertVersion -- version is v2,
+ holder Holder,
+ issuer AttCertIssuer,
+ signature AlgorithmIdentifier,
+ serialNumber CertificateSerialNumber,
+ attrCertValidityPeriod AttCertValidityPeriod,
+ attributes Sequence OF Attr,
+ issuerUniqueID UniqueIdentifier OPTIONAL,
+ extensions Extensions OPTIONAL
+ }
+
+ AttCertVersion ::= Integer { v2(1) }
+
+
+
+ The AuthorityInformationAccess object.
+
+ id-pe-authorityInfoAccess OBJECT IDENTIFIER ::= { id-pe 1 }
+
+ AuthorityInfoAccessSyntax ::=
+ Sequence SIZE (1..MAX) OF AccessDescription
+ AccessDescription ::= Sequence {
+ accessMethod OBJECT IDENTIFIER,
+ accessLocation GeneralName }
+
+ id-ad OBJECT IDENTIFIER ::= { id-pkix 48 }
+ id-ad-caIssuers OBJECT IDENTIFIER ::= { id-ad 2 }
+ id-ad-ocsp OBJECT IDENTIFIER ::= { id-ad 1 }
+
+
+
+ create an AuthorityInformationAccess with the oid and location provided.
+
+
+ The AuthorityKeyIdentifier object.
+
+ id-ce-authorityKeyIdentifier OBJECT IDENTIFIER ::= { id-ce 35 }
+
+ AuthorityKeyIdentifier ::= Sequence {
+ keyIdentifier [0] IMPLICIT KeyIdentifier OPTIONAL,
+ authorityCertIssuer [1] IMPLICIT GeneralNames OPTIONAL,
+ authorityCertSerialNumber [2] IMPLICIT CertificateSerialNumber OPTIONAL }
+
+ KeyIdentifier ::= OCTET STRING
+
+
+
+
+ *
+ * Calulates the keyidentifier using a SHA1 hash over the BIT STRING
+ * from SubjectPublicKeyInfo as defined in RFC2459.
+ *
+ * Example of making a AuthorityKeyIdentifier:
+ *
+ * SubjectPublicKeyInfo apki = new SubjectPublicKeyInfo((ASN1Sequence)new ASN1InputStream(
+ * publicKey.getEncoded()).readObject());
+ * AuthorityKeyIdentifier aki = new AuthorityKeyIdentifier(apki);
+ *
+ *
+ *
+
+
+ create an AuthorityKeyIdentifier with the GeneralNames tag and
+ the serial number provided as well.
+
+
+ create an AuthorityKeyIdentifier with the GeneralNames tag and
+ the serial number provided.
+
+
+ create an AuthorityKeyIdentifier with a precomputed key identifier
+
+
+ create an AuthorityKeyIdentifier with a precomupted key identifier
+ and the GeneralNames tag and the serial number provided as well.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+
+ create a cA=true object for the given path length constraint.
+
+ @param pathLenConstraint
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ BasicConstraints := Sequence {
+ cA Boolean DEFAULT FALSE,
+ pathLenConstraint Integer (0..MAX) OPTIONAL
+ }
+
+
+
+ Return the distribution points making up the sequence.
+
+ @return DistributionPoint[]
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ CrlDistPoint ::= Sequence SIZE {1..MAX} OF DistributionPoint
+
+
+
+ The CRLNumber object.
+
+ CRLNumber::= Integer(0..MAX)
+
+
+
+ The CRLReason enumeration.
+
+ CRLReason ::= Enumerated {
+ unspecified (0),
+ keyCompromise (1),
+ cACompromise (2),
+ affiliationChanged (3),
+ superseded (4),
+ cessationOfOperation (5),
+ certificateHold (6),
+ removeFromCRL (8),
+ privilegeWithdrawn (9),
+ aACompromise (10)
+ }
+
+
+
+ CertPolicyId, used in the CertificatePolicies and PolicyMappings
+ X509V3 Extensions.
+
+
+ CertPolicyId ::= OBJECT IDENTIFIER
+
+
+
+ PKIX RFC-2459
+
+ The X.509 v2 CRL syntax is as follows. For signature calculation,
+ the data that is to be signed is ASN.1 Der encoded.
+
+
+ CertificateList ::= Sequence {
+ tbsCertList TbsCertList,
+ signatureAlgorithm AlgorithmIdentifier,
+ signatureValue BIT STRING }
+
+
+
+ This class helps to support crossCerfificatePairs in a LDAP directory
+ according RFC 2587
+
+
+ crossCertificatePairATTRIBUTE::={
+ WITH SYNTAX CertificatePair
+ EQUALITY MATCHING RULE certificatePairExactMatch
+ ID joint-iso-ccitt(2) ds(5) attributeType(4) crossCertificatePair(40)}
+
+
+ The forward elements of the crossCertificatePair attribute of a
+ CA's directory entry shall be used to store all, except self-issued
+ certificates issued to this CA. Optionally, the reverse elements of the
+ crossCertificatePair attribute, of a CA's directory entry may contain a
+ subset of certificates issued by this CA to other CAs. When both the forward
+ and the reverse elements are present in a single attribute value, issuer name
+ in one certificate shall match the subject name in the other and vice versa,
+ and the subject public key in one certificate shall be capable of verifying
+ the digital signature on the other certificate and vice versa.
+
+ When a reverse element is present, the forward element value and the reverse
+ element value need not be stored in the same attribute value; in other words,
+ they can be stored in either a single attribute value or two attribute
+ values.
+
+
+ CertificatePair ::= SEQUENCE {
+ forward [0] Certificate OPTIONAL,
+ reverse [1] Certificate OPTIONAL,
+ -- at least one of the pair shall be present -- }
+
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type CertificatePair:
+
+
+ CertificatePair ::= SEQUENCE {
+ forward [0] Certificate OPTIONAL,
+ reverse [1] Certificate OPTIONAL,
+ -- at least one of the pair shall be present -- }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from a given details.
+
+ @param forward Certificates issued to this CA.
+ @param reverse Certificates issued by this CA to other CAs.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ CertificatePair ::= SEQUENCE {
+ forward [0] Certificate OPTIONAL,
+ reverse [1] Certificate OPTIONAL,
+ -- at least one of the pair shall be present -- }
+
+
+ @return a DERObject
+
+
+ @return Returns the forward.
+
+
+ @return Returns the reverse.
+
+
+ Construct a CertificatePolicies object containing one PolicyInformation.
+
+ @param name the name to be contained.
+
+
+ Produce an object suitable for an ASN1OutputStream.
+
+ CertificatePolicies ::= SEQUENCE SIZE {1..MAX} OF PolicyInformation
+
+
+
+ The DigestInfo object.
+
+ DigestInfo::=Sequence{
+ digestAlgorithm AlgorithmIdentifier,
+ digest OCTET STRING }
+
+
+
+ DisplayText
class, used in
+ CertificatePolicies
X509 V3 extensions (in policy qualifiers).
+
+ It stores a string in a chosen encoding.
+
+ DisplayText ::= CHOICE {
+ ia5String IA5String (SIZE (1..200)),
+ visibleString VisibleString (SIZE (1..200)),
+ bmpString BMPString (SIZE (1..200)),
+ utf8String UTF8String (SIZE (1..200)) }
+
+ @see PolicyQualifierInfo
+ @see PolicyInformation
+
+
+ Constant corresponding to ia5String encoding.
+
+
+
+ Constant corresponding to bmpString encoding.
+
+
+
+ Constant corresponding to utf8String encoding.
+
+
+
+ Constant corresponding to visibleString encoding.
+
+
+
+ Describe constant DisplayTextMaximumSize
here.
+
+
+
+ Creates a new DisplayText
instance.
+
+ @param type the desired encoding type for the text.
+ @param text the text to store. Strings longer than 200
+ characters are truncated.
+
+
+ Creates a new DisplayText
instance.
+
+ @param text the text to encapsulate. Strings longer than 200
+ characters are truncated.
+
+
+ Creates a new DisplayText
instance.
+ Useful when reading back a DisplayText
class
+ from it's Asn1Encodable form.
+
+ @param contents an Asn1Encodable
instance.
+
+
+ Returns the stored string
object.
+
+ @return the stored text as a string
.
+
+
+ The DistributionPoint object.
+
+ DistributionPoint ::= Sequence {
+ distributionPoint [0] DistributionPointName OPTIONAL,
+ reasons [1] ReasonFlags OPTIONAL,
+ cRLIssuer [2] GeneralNames OPTIONAL
+ }
+
+
+
+ The DistributionPointName object.
+
+ DistributionPointName ::= CHOICE {
+ fullName [0] GeneralNames,
+ nameRelativeToCRLIssuer [1] RDN
+ }
+
+
+
+ The extendedKeyUsage object.
+
+ extendedKeyUsage ::= Sequence SIZE (1..MAX) OF KeyPurposeId
+
+
+
+ Returns all extended key usages.
+ The returned ArrayList contains DerObjectIdentifier instances.
+ @return An ArrayList with all key purposes.
+
+
+ The GeneralName object.
+
+ GeneralName ::= CHOICE {
+ otherName [0] OtherName,
+ rfc822Name [1] IA5String,
+ dNSName [2] IA5String,
+ x400Address [3] ORAddress,
+ directoryName [4] Name,
+ ediPartyName [5] EDIPartyName,
+ uniformResourceIdentifier [6] IA5String,
+ iPAddress [7] OCTET STRING,
+ registeredID [8] OBJECT IDENTIFIER}
+
+ OtherName ::= Sequence {
+ type-id OBJECT IDENTIFIER,
+ value [0] EXPLICIT ANY DEFINED BY type-id }
+
+ EDIPartyName ::= Sequence {
+ nameAssigner [0] DirectoryString OPTIONAL,
+ partyName [1] DirectoryString }
+
+
+
+ When the subjectAltName extension contains an Internet mail address,
+ the address MUST be included as an rfc822Name. The format of an
+ rfc822Name is an "addr-spec" as defined in RFC 822 [RFC 822].
+
+ When the subjectAltName extension contains a domain name service
+ label, the domain name MUST be stored in the dNSName (an IA5String).
+ The name MUST be in the "preferred name syntax," as specified by RFC
+ 1034 [RFC 1034].
+
+ When the subjectAltName extension contains a URI, the name MUST be
+ stored in the uniformResourceIdentifier (an IA5String). The name MUST
+ be a non-relative URL, and MUST follow the URL syntax and encoding
+ rules specified in [RFC 1738]. The name must include both a scheme
+ (e.g., "http" or "ftp") and a scheme-specific-part. The scheme-
+ specific-part must include a fully qualified domain name or IP
+ address as the host.
+
+ When the subjectAltName extension contains a iPAddress, the address
+ MUST be stored in the octet string in "network byte order," as
+ specified in RFC 791 [RFC 791]. The least significant bit (LSB) of
+ each octet is the LSB of the corresponding byte in the network
+ address. For IP Version 4, as specified in RFC 791, the octet string
+ MUST contain exactly four octets. For IP Version 6, as specified in
+ RFC 1883, the octet string MUST contain exactly sixteen octets [RFC
+ 1883].
+
+
+ Create a GeneralName for the given tag from the passed in string.
+
+ This constructor can handle:
+
+ - rfc822Name
+ - iPAddress
+ - directoryName
+ - dNSName
+ - uniformResourceIdentifier
+ - registeredID
+
+ For x400Address, otherName and ediPartyName there is no common string
+ format defined.
+
+ Note: A directory name can be encoded in different ways into a byte
+ representation. Be aware of this if the byte representation is used for
+ comparing results.
+
+
+ @param tag tag number
+ @param name string representation of name
+ @throws ArgumentException if the string encoding is not correct or
+ not supported.
+
+
+ Construct a GeneralNames object containing one GeneralName.
+ The name to be contained.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ GeneralNames ::= Sequence SIZE {1..MAX} OF GeneralName
+
+
+
+ Class for containing a restriction object subtrees in NameConstraints. See
+ RFC 3280.
+
+
+
+ GeneralSubtree ::= SEQUENCE
+ {
+ baseName GeneralName,
+ minimum [0] BaseDistance DEFAULT 0,
+ maximum [1] BaseDistance OPTIONAL
+ }
+
+
+ @see org.bouncycastle.asn1.x509.NameConstraints
+
+
+
+ Constructor from a given details.
+
+ According RFC 3280, the minimum and maximum fields are not used with any
+ name forms, thus minimum MUST be zero, and maximum MUST be absent.
+
+ If minimum is null
, zero is assumed, if
+ maximum is null
, maximum is absent.
+
+ @param baseName
+ A restriction.
+ @param minimum
+ Minimum
+
+ @param maximum
+ Maximum
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ GeneralSubtree ::= SEQUENCE
+ {
+ baseName GeneralName,
+ minimum [0] BaseDistance DEFAULT 0,
+ maximum [1] BaseDistance OPTIONAL
+ }
+
+
+ @return a DERObject
+
+
+ The Holder object.
+
+ For an v2 attribute certificate this is:
+
+
+ Holder ::= SEQUENCE {
+ baseCertificateID [0] IssuerSerial OPTIONAL,
+ -- the issuer and serial number of
+ -- the holder's Public Key Certificate
+ entityName [1] GeneralNames OPTIONAL,
+ -- the name of the claimant or role
+ objectDigestInfo [2] ObjectDigestInfo OPTIONAL
+ -- used to directly authenticate the holder,
+ -- for example, an executable
+ }
+
+
+
+ For an v1 attribute certificate this is:
+
+
+ subject CHOICE {
+ baseCertificateID [0] IssuerSerial,
+ -- associated with a Public Key Certificate
+ subjectName [1] GeneralNames },
+ -- associated with a name
+
+
+
+
+ Constructor for a holder for an v1 attribute certificate.
+
+ @param tagObj The ASN.1 tagged holder object.
+
+
+ Constructor for a holder for an v2 attribute certificate. *
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructs a holder from a IssuerSerial.
+ @param baseCertificateID The IssuerSerial.
+ @param version The version of the attribute certificate.
+
+
+ Returns 1 for v2 attribute certificates or 0 for v1 attribute
+ certificates.
+ @return The version of the attribute certificate.
+
+
+ Constructs a holder with an entityName for v2 attribute certificates or
+ with a subjectName for v1 attribute certificates.
+
+ @param entityName The entity or subject name.
+
+
+ Constructs a holder with an entityName for v2 attribute certificates or
+ with a subjectName for v1 attribute certificates.
+
+ @param entityName The entity or subject name.
+ @param version The version of the attribute certificate.
+
+
+ Constructs a holder from an object digest info.
+
+ @param objectDigestInfo The object digest info object.
+
+
+ Returns the entityName for an v2 attribute certificate or the subjectName
+ for an v1 attribute certificate.
+
+ @return The entityname or subjectname.
+
+
+ The Holder object.
+
+ Holder ::= Sequence {
+ baseCertificateID [0] IssuerSerial OPTIONAL,
+ -- the issuer and serial number of
+ -- the holder's Public Key Certificate
+ entityName [1] GeneralNames OPTIONAL,
+ -- the name of the claimant or role
+ objectDigestInfo [2] ObjectDigestInfo OPTIONAL
+ -- used to directly authenticate the holder,
+ -- for example, an executable
+ }
+
+
+
+ Implementation of IetfAttrSyntax
as specified by RFC3281.
+
+
+
+
+
+
+
+
+ IetfAttrSyntax ::= Sequence {
+ policyAuthority [0] GeneralNames OPTIONAL,
+ values Sequence OF CHOICE {
+ octets OCTET STRING,
+ oid OBJECT IDENTIFIER,
+ string UTF8String
+ }
+ }
+
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ IssuerSerial ::= Sequence {
+ issuer GeneralNames,
+ serial CertificateSerialNumber,
+ issuerUid UniqueIdentifier OPTIONAL
+ }
+
+
+
+
+ IssuingDistributionPoint ::= SEQUENCE {
+ distributionPoint [0] DistributionPointName OPTIONAL,
+ onlyContainsUserCerts [1] BOOLEAN DEFAULT FALSE,
+ onlyContainsCACerts [2] BOOLEAN DEFAULT FALSE,
+ onlySomeReasons [3] ReasonFlags OPTIONAL,
+ indirectCRL [4] BOOLEAN DEFAULT FALSE,
+ onlyContainsAttributeCerts [5] BOOLEAN DEFAULT FALSE }
+
+
+
+ Constructor from given details.
+
+ @param distributionPoint
+ May contain an URI as pointer to most current CRL.
+ @param onlyContainsUserCerts Covers revocation information for end certificates.
+ @param onlyContainsCACerts Covers revocation information for CA certificates.
+
+ @param onlySomeReasons
+ Which revocation reasons does this point cover.
+ @param indirectCRL
+ If true
then the CRL contains revocation
+ information about certificates ssued by other CAs.
+ @param onlyContainsAttributeCerts Covers revocation information for attribute certificates.
+
+
+ Constructor from Asn1Sequence
+
+
+ @return Returns the distributionPoint.
+
+
+ @return Returns the onlySomeReasons.
+
+
+ The KeyPurposeID object.
+
+ KeyPurposeID ::= OBJECT IDENTIFIER
+
+
+
+ The KeyUsage object.
+
+ id-ce-keyUsage OBJECT IDENTIFIER ::= { id-ce 15 }
+
+ KeyUsage ::= BIT STRING {
+ digitalSignature (0),
+ nonRepudiation (1),
+ keyEncipherment (2),
+ dataEncipherment (3),
+ keyAgreement (4),
+ keyCertSign (5),
+ cRLSign (6),
+ encipherOnly (7),
+ decipherOnly (8) }
+
+
+
+ Basic constructor.
+
+ @param usage - the bitwise OR of the Key Usage flags giving the
+ allowed uses for the key.
+ e.g. (KeyUsage.keyEncipherment | KeyUsage.dataEncipherment)
+
+
+ Constructor from a given details.
+
+ permitted and excluded are Vectors of GeneralSubtree objects.
+
+ @param permitted Permitted subtrees
+ @param excluded Excluded subtrees
+
+
+ NoticeReference
class, used in
+ CertificatePolicies
X509 V3 extensions
+ (in policy qualifiers).
+
+
+ NoticeReference ::= Sequence {
+ organization DisplayText,
+ noticeNumbers Sequence OF Integer }
+
+
+
+ @see PolicyQualifierInfo
+ @see PolicyInformation
+
+
+ Creates a new NoticeReference
instance.
+
+ @param organization a String
value
+ @param numbers a Vector
value
+
+
+ Creates a new NoticeReference
instance.
+
+ @param organization a String
value
+ @param noticeNumbers an ASN1EncodableVector
value
+
+
+ Creates a new NoticeReference
instance.
+
+ @param organization displayText
+ @param noticeNumbers an ASN1EncodableVector
value
+
+
+ Creates a new NoticeReference
instance.
+ Useful for reconstructing a NoticeReference
+ instance from its encodable/encoded form.
+
+ @param as an Asn1Sequence
value obtained from either
+ calling @{link ToAsn1Object()} for a NoticeReference
+ instance or from parsing it from a Der-encoded stream.
+
+
+ Describe ToAsn1Object
method here.
+
+ @return a Asn1Object
value
+
+
+ ObjectDigestInfo ASN.1 structure used in v2 attribute certificates.
+
+
+
+ ObjectDigestInfo ::= SEQUENCE {
+ digestedObjectType ENUMERATED {
+ publicKey (0),
+ publicKeyCert (1),
+ otherObjectTypes (2) },
+ -- otherObjectTypes MUST NOT
+ -- be used in this profile
+ otherObjectTypeID OBJECT IDENTIFIER OPTIONAL,
+ digestAlgorithm AlgorithmIdentifier,
+ objectDigest BIT STRING
+ }
+
+
+
+
+
+ The public key is hashed.
+
+
+ The public key certificate is hashed.
+
+
+ An other object is hashed.
+
+
+ Constructor from given details.
+
+ If digestedObjectType
is not {@link #publicKeyCert} or
+ {@link #publicKey} otherObjectTypeID
must be given,
+ otherwise it is ignored.
+
+ @param digestedObjectType The digest object type.
+ @param otherObjectTypeID The object type ID for
+ otherObjectDigest
.
+ @param digestAlgorithm The algorithm identifier for the hash.
+ @param objectDigest The hash value.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+
+
+ ObjectDigestInfo ::= SEQUENCE {
+ digestedObjectType ENUMERATED {
+ publicKey (0),
+ publicKeyCert (1),
+ otherObjectTypes (2) },
+ -- otherObjectTypes MUST NOT
+ -- be used in this profile
+ otherObjectTypeID OBJECT IDENTIFIER OPTIONAL,
+ digestAlgorithm AlgorithmIdentifier,
+ objectDigest BIT STRING
+ }
+
+
+
+
+ PolicyMappings V3 extension, described in RFC3280.
+
+ PolicyMappings ::= Sequence SIZE (1..MAX) OF Sequence {
+ issuerDomainPolicy CertPolicyId,
+ subjectDomainPolicy CertPolicyId }
+
+
+ @see RFC 3280, section 4.2.1.6
+
+
+ Creates a new PolicyMappings
instance.
+
+ @param seq an Asn1Sequence
constructed as specified
+ in RFC 3280
+
+
+ Creates a new PolicyMappings
instance.
+
+ @param mappings a HashMap
value that maps
+ string
oids
+ to other string
oids.
+
+
+ PolicyQualifierId, used in the CertificatePolicies
+ X509V3 extension.
+
+
+ id-qt OBJECT IDENTIFIER ::= { id-pkix 2 }
+ id-qt-cps OBJECT IDENTIFIER ::= { id-qt 1 }
+ id-qt-unotice OBJECT IDENTIFIER ::= { id-qt 2 }
+ PolicyQualifierId ::=
+ OBJECT IDENTIFIER ( id-qt-cps | id-qt-unotice )
+
+
+
+ Policy qualifiers, used in the X509V3 CertificatePolicies
+ extension.
+
+
+ PolicyQualifierInfo ::= Sequence {
+ policyQualifierId PolicyQualifierId,
+ qualifier ANY DEFINED BY policyQualifierId }
+
+
+
+ Creates a new PolicyQualifierInfo
instance.
+
+ @param policyQualifierId a PolicyQualifierId
value
+ @param qualifier the qualifier, defined by the above field.
+
+
+ Creates a new PolicyQualifierInfo
containing a
+ cPSuri qualifier.
+
+ @param cps the CPS (certification practice statement) uri as a
+ string
.
+
+
+ Creates a new PolicyQualifierInfo
instance.
+
+ @param as PolicyQualifierInfo
X509 structure
+ encoded as an Asn1Sequence.
+
+
+ Returns a Der-encodable representation of this instance.
+
+ @return a Asn1Object
value
+
+
+
+
+ PrivateKeyUsagePeriod ::= SEQUENCE
+ {
+ notBefore [0] GeneralizedTime OPTIONAL,
+ notAfter [1] GeneralizedTime OPTIONAL }
+
+
+
+
+ This outputs the key in Pkcs1v2 format.
+
+ RSAPublicKey ::= Sequence {
+ modulus Integer, -- n
+ publicExponent Integer, -- e
+ }
+
+
+
+ The ReasonFlags object.
+
+ ReasonFlags ::= BIT STRING {
+ unused(0),
+ keyCompromise(1),
+ cACompromise(2),
+ affiliationChanged(3),
+ superseded(4),
+ cessationOfOperation(5),
+ certficateHold(6)
+ }
+
+
+
+ @param reasons - the bitwise OR of the Key Reason flags giving the
+ allowed uses for the key.
+
+
+ Implementation of the RoleSyntax object as specified by the RFC3281.
+
+
+ RoleSyntax ::= SEQUENCE {
+ roleAuthority [0] GeneralNames OPTIONAL,
+ roleName [1] GeneralName
+ }
+
+
+
+ RoleSyntax factory method.
+ @param obj the object used to construct an instance of
+ RoleSyntax
. It must be an instance of RoleSyntax
+
or Asn1Sequence
.
+ @return the instance of RoleSyntax
built from the
+ supplied object.
+ @throws java.lang.ArgumentException if the object passed
+ to the factory is not an instance of RoleSyntax
or
+ Asn1Sequence
.
+
+
+ Constructor.
+ @param roleAuthority the role authority of this RoleSyntax.
+ @param roleName the role name of this RoleSyntax.
+
+
+ Constructor. Invoking this constructor is the same as invoking
+ new RoleSyntax(null, roleName)
.
+ @param roleName the role name of this RoleSyntax.
+
+
+ Utility constructor. Takes a string
argument representing
+ the role name, builds a GeneralName
to hold the role name
+ and calls the constructor that takes a GeneralName
.
+ @param roleName
+
+
+ Constructor that builds an instance of RoleSyntax
by
+ extracting the encoded elements from the Asn1Sequence
+ object supplied.
+ @param seq an instance of Asn1Sequence
that holds
+ the encoded elements used to build this RoleSyntax
.
+
+
+ Gets the role authority of this RoleSyntax.
+ @return an instance of GeneralNames
holding the
+ role authority of this RoleSyntax.
+
+
+ Gets the role name of this RoleSyntax.
+ @return an instance of GeneralName
holding the
+ role name of this RoleSyntax.
+
+
+ Gets the role name as a java.lang.string
object.
+ @return the role name of this RoleSyntax represented as a
+ string
object.
+
+
+ Gets the role authority as a string[]
object.
+ @return the role authority of this RoleSyntax represented as a
+ string[]
array.
+
+
+ Implementation of the method ToAsn1Object
as
+ required by the superclass ASN1Encodable
.
+
+
+ RoleSyntax ::= SEQUENCE {
+ roleAuthority [0] GeneralNames OPTIONAL,
+ roleName [1] GeneralName
+ }
+
+
+
+ This extension may contain further X.500 attributes of the subject. See also
+ RFC 3039.
+
+
+ SubjectDirectoryAttributes ::= Attributes
+ Attributes ::= SEQUENCE SIZE (1..MAX) OF Attribute
+ Attribute ::= SEQUENCE
+ {
+ type AttributeType
+ values SET OF AttributeValue
+ }
+
+ AttributeType ::= OBJECT IDENTIFIER
+ AttributeValue ::= ANY DEFINED BY AttributeType
+
+
+ @see org.bouncycastle.asn1.x509.X509Name for AttributeType ObjectIdentifiers.
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type SubjectDirectoryAttributes:
+
+
+ SubjectDirectoryAttributes ::= Attributes
+ Attributes ::= SEQUENCE SIZE (1..MAX) OF Attribute
+ Attribute ::= SEQUENCE
+ {
+ type AttributeType
+ values SET OF AttributeValue
+ }
+
+ AttributeType ::= OBJECT IDENTIFIER
+ AttributeValue ::= ANY DEFINED BY AttributeType
+
+
+ @param seq
+ The ASN.1 sequence.
+
+
+ Constructor from an ArrayList of attributes.
+
+ The ArrayList consists of attributes of type {@link Attribute Attribute}
+
+ @param attributes The attributes.
+
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ SubjectDirectoryAttributes ::= Attributes
+ Attributes ::= SEQUENCE SIZE (1..MAX) OF Attribute
+ Attribute ::= SEQUENCE
+ {
+ type AttributeType
+ values SET OF AttributeValue
+ }
+
+ AttributeType ::= OBJECT IDENTIFIER
+ AttributeValue ::= ANY DEFINED BY AttributeType
+
+
+ @return a DERObject
+
+
+ @return Returns the attributes.
+
+
+ The SubjectKeyIdentifier object.
+
+ SubjectKeyIdentifier::= OCTET STRING
+
+
+
+ Calculates the keyIdentifier using a SHA1 hash over the BIT STRING
+ from SubjectPublicKeyInfo as defined in RFC3280.
+
+ @param spki the subject public key info.
+
+
+ Return a RFC 3280 type 1 key identifier. As in:
+
+ (1) The keyIdentifier is composed of the 160-bit SHA-1 hash of the
+ value of the BIT STRING subjectPublicKey (excluding the tag,
+ length, and number of unused bits).
+
+ @param keyInfo the key info object containing the subjectPublicKey field.
+ @return the key identifier.
+
+
+ Return a RFC 3280 type 2 key identifier. As in:
+
+ (2) The keyIdentifier is composed of a four bit type field with
+ the value 0100 followed by the least significant 60 bits of the
+ SHA-1 hash of the value of the BIT STRING subjectPublicKey.
+
+ @param keyInfo the key info object containing the subjectPublicKey field.
+ @return the key identifier.
+
+
+ The object that contains the public key stored in a certficate.
+
+ The GetEncoded() method in the public keys in the JCE produces a DER
+ encoded one of these.
+
+
+ for when the public key is an encoded object - if the bitstring
+ can't be decoded this routine raises an IOException.
+
+ @exception IOException - if the bit string doesn't represent a Der
+ encoded object.
+
+
+ for when the public key is raw bits...
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ SubjectPublicKeyInfo ::= Sequence {
+ algorithm AlgorithmIdentifier,
+ publicKey BIT STRING }
+
+
+
+ PKIX RFC-2459 - TbsCertList object.
+
+ TbsCertList ::= Sequence {
+ version Version OPTIONAL,
+ -- if present, shall be v2
+ signature AlgorithmIdentifier,
+ issuer Name,
+ thisUpdate Time,
+ nextUpdate Time OPTIONAL,
+ revokedCertificates Sequence OF Sequence {
+ userCertificate CertificateSerialNumber,
+ revocationDate Time,
+ crlEntryExtensions Extensions OPTIONAL
+ -- if present, shall be v2
+ } OPTIONAL,
+ crlExtensions [0] EXPLICIT Extensions OPTIONAL
+ -- if present, shall be v2
+ }
+
+
+
+ The TbsCertificate object.
+
+ TbsCertificate ::= Sequence {
+ version [ 0 ] Version DEFAULT v1(0),
+ serialNumber CertificateSerialNumber,
+ signature AlgorithmIdentifier,
+ issuer Name,
+ validity Validity,
+ subject Name,
+ subjectPublicKeyInfo SubjectPublicKeyInfo,
+ issuerUniqueID [ 1 ] IMPLICIT UniqueIdentifier OPTIONAL,
+ subjectUniqueID [ 2 ] IMPLICIT UniqueIdentifier OPTIONAL,
+ extensions [ 3 ] Extensions OPTIONAL
+ }
+
+
+ Note: issuerUniqueID and subjectUniqueID are both deprecated by the IETF. This class
+ will parse them, but you really shouldn't be creating new ones.
+
+
+ Target structure used in target information extension for attribute
+ certificates from RFC 3281.
+
+
+ Target ::= CHOICE {
+ targetName [0] GeneralName,
+ targetGroup [1] GeneralName,
+ targetCert [2] TargetCert
+ }
+
+
+
+ The targetCert field is currently not supported and must not be used
+ according to RFC 3281.
+
+
+ Creates an instance of a Target from the given object.
+
+ obj
can be a Target or a {@link Asn1TaggedObject}
+
+ @param obj The object.
+ @return A Target instance.
+ @throws ArgumentException if the given object cannot be
+ interpreted as Target.
+
+
+ Constructor from Asn1TaggedObject.
+
+ @param tagObj The tagged object.
+ @throws ArgumentException if the encoding is wrong.
+
+
+ Constructor from given details.
+
+ Exactly one of the parameters must be not null
.
+
+ @param type the choice type to apply to the name.
+ @param name the general name.
+ @throws ArgumentException if type is invalid.
+
+
+ @return Returns the targetGroup.
+
+
+ @return Returns the targetName.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ Target ::= CHOICE {
+ targetName [0] GeneralName,
+ targetGroup [1] GeneralName,
+ targetCert [2] TargetCert
+ }
+
+
+ @return an Asn1Object
+
+
+ Target information extension for attributes certificates according to RFC
+ 3281.
+
+
+ SEQUENCE OF Targets
+
+
+
+
+ Creates an instance of a TargetInformation from the given object.
+
+ obj
can be a TargetInformation or a {@link Asn1Sequence}
+
+ @param obj The object.
+ @return A TargetInformation instance.
+ @throws ArgumentException if the given object cannot be interpreted as TargetInformation.
+
+
+ Constructor from a Asn1Sequence.
+
+ @param seq The Asn1Sequence.
+ @throws ArgumentException if the sequence does not contain
+ correctly encoded Targets elements.
+
+
+ Returns the targets in this target information extension.
+
+ The ArrayList is cloned before it is returned.
+
+ @return Returns the targets.
+
+
+ Constructs a target information from a single targets element.
+ According to RFC 3281 only one targets element must be produced.
+
+ @param targets A Targets instance.
+
+
+ According to RFC 3281 only one targets element must be produced. If
+ multiple targets are given they must be merged in
+ into one targets element.
+
+ @param targets An array with {@link Targets}.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ SEQUENCE OF Targets
+
+
+
+ According to RFC 3281 only one targets element must be produced. If
+ multiple targets are given in the constructor they are merged into one
+ targets element. If this was produced from a
+ {@link Org.BouncyCastle.Asn1.Asn1Sequence} the encoding is kept.
+
+ @return an Asn1Object
+
+
+ Targets structure used in target information extension for attribute
+ certificates from RFC 3281.
+
+
+ Targets ::= SEQUENCE OF Target
+
+ Target ::= CHOICE {
+ targetName [0] GeneralName,
+ targetGroup [1] GeneralName,
+ targetCert [2] TargetCert
+ }
+
+ TargetCert ::= SEQUENCE {
+ targetCertificate IssuerSerial,
+ targetName GeneralName OPTIONAL,
+ certDigestInfo ObjectDigestInfo OPTIONAL
+ }
+
+
+ @see org.bouncycastle.asn1.x509.Target
+ @see org.bouncycastle.asn1.x509.TargetInformation
+
+
+ Creates an instance of a Targets from the given object.
+
+ obj
can be a Targets or a {@link Asn1Sequence}
+
+ @param obj The object.
+ @return A Targets instance.
+ @throws ArgumentException if the given object cannot be interpreted as Target.
+
+
+ Constructor from Asn1Sequence.
+
+ @param targets The ASN.1 SEQUENCE.
+ @throws ArgumentException if the contents of the sequence are
+ invalid.
+
+
+ Constructor from given targets.
+
+ The ArrayList is copied.
+
+ @param targets An ArrayList
of {@link Target}s.
+ @see Target
+ @throws ArgumentException if the ArrayList contains not only Targets.
+
+
+ Returns the targets in an ArrayList
.
+
+ The ArrayList is cloned before it is returned.
+
+ @return Returns the targets.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ Targets ::= SEQUENCE OF Target
+
+
+ @return an Asn1Object
+
+
+ creates a time object from a given date - if the date is between 1950
+ and 2049 a UTCTime object is Generated, otherwise a GeneralizedTime
+ is used.
+
+
+
+ Return our time as DateTime.
+
+ A date time.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Time ::= CHOICE {
+ utcTime UTCTime,
+ generalTime GeneralizedTime }
+
+
+
+ UserNotice
class, used in
+ CertificatePolicies
X509 extensions (in policy
+ qualifiers).
+
+ UserNotice ::= Sequence {
+ noticeRef NoticeReference OPTIONAL,
+ explicitText DisplayText OPTIONAL}
+
+
+
+ @see PolicyQualifierId
+ @see PolicyInformation
+
+
+ Creates a new UserNotice
instance.
+
+ @param noticeRef a NoticeReference
value
+ @param explicitText a DisplayText
value
+
+
+ Creates a new UserNotice
instance.
+
+ @param noticeRef a NoticeReference
value
+ @param str the explicitText field as a string.
+
+
+ Creates a new UserNotice
instance.
+ Useful from reconstructing a UserNotice
instance
+ from its encodable/encoded form.
+
+ @param as an ASN1Sequence
value obtained from either
+ calling @{link toASN1Object()} for a UserNotice
+ instance or from parsing it from a DER-encoded stream.
+
+
+ Generator for Version 1 TbsCertificateStructures.
+
+ TbsCertificate ::= Sequence {
+ version [ 0 ] Version DEFAULT v1(0),
+ serialNumber CertificateSerialNumber,
+ signature AlgorithmIdentifier,
+ issuer Name,
+ validity Validity,
+ subject Name,
+ subjectPublicKeyInfo SubjectPublicKeyInfo,
+ }
+
+
+
+
+ Generator for Version 2 AttributeCertificateInfo
+
+ AttributeCertificateInfo ::= Sequence {
+ version AttCertVersion -- version is v2,
+ holder Holder,
+ issuer AttCertIssuer,
+ signature AlgorithmIdentifier,
+ serialNumber CertificateSerialNumber,
+ attrCertValidityPeriod AttCertValidityPeriod,
+ attributes Sequence OF Attr,
+ issuerUniqueID UniqueIdentifier OPTIONAL,
+ extensions Extensions OPTIONAL
+ }
+
+
+
+
+ @param attribute
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ V2Form ::= Sequence {
+ issuerName GeneralNames OPTIONAL,
+ baseCertificateID [0] IssuerSerial OPTIONAL,
+ objectDigestInfo [1] ObjectDigestInfo OPTIONAL
+ -- issuerName MUST be present in this profile
+ -- baseCertificateID and objectDigestInfo MUST NOT
+ -- be present in this profile
+ }
+
+
+
+ Generator for Version 2 TbsCertList structures.
+
+ TbsCertList ::= Sequence {
+ version Version OPTIONAL,
+ -- if present, shall be v2
+ signature AlgorithmIdentifier,
+ issuer Name,
+ thisUpdate Time,
+ nextUpdate Time OPTIONAL,
+ revokedCertificates Sequence OF Sequence {
+ userCertificate CertificateSerialNumber,
+ revocationDate Time,
+ crlEntryExtensions Extensions OPTIONAL
+ -- if present, shall be v2
+ } OPTIONAL,
+ crlExtensions [0] EXPLICIT Extensions OPTIONAL
+ -- if present, shall be v2
+ }
+
+
+ Note: This class may be subject to change
+
+
+ Generator for Version 3 TbsCertificateStructures.
+
+ TbsCertificate ::= Sequence {
+ version [ 0 ] Version DEFAULT v1(0),
+ serialNumber CertificateSerialNumber,
+ signature AlgorithmIdentifier,
+ issuer Name,
+ validity Validity,
+ subject Name,
+ subjectPublicKeyInfo SubjectPublicKeyInfo,
+ issuerUniqueID [ 1 ] IMPLICIT UniqueIdentifier OPTIONAL,
+ subjectUniqueID [ 2 ] IMPLICIT UniqueIdentifier OPTIONAL,
+ extensions [ 3 ] Extensions OPTIONAL
+ }
+
+
+
+
+ an X509Certificate structure.
+
+ Certificate ::= Sequence {
+ tbsCertificate TbsCertificate,
+ signatureAlgorithm AlgorithmIdentifier,
+ signature BIT STRING
+ }
+
+
+
+ The default converter for X509 DN entries when going from their
+ string value to ASN.1 strings.
+
+
+ Apply default conversion for the given value depending on the oid
+ and the character range of the value.
+
+ @param oid the object identifier for the DN entry
+ @param value the value associated with it
+ @return the ASN.1 equivalent for the string value.
+
+
+ an object for the elements in the X.509 V3 extension block.
+
+
+ Convert the value of the passed in extension to an object.
+ The extension to parse.
+ The object the value string contains.
+ If conversion is not possible.
+
+
+ Subject Directory Attributes
+
+
+ Subject Key Identifier
+
+
+ Key Usage
+
+
+ Private Key Usage Period
+
+
+ Subject Alternative Name
+
+
+ Issuer Alternative Name
+
+
+ Basic Constraints
+
+
+ CRL Number
+
+
+ Reason code
+
+
+ Hold Instruction Code
+
+
+ Invalidity Date
+
+
+ Delta CRL indicator
+
+
+ Issuing Distribution Point
+
+
+ Certificate Issuer
+
+
+ Name Constraints
+
+
+ CRL Distribution Points
+
+
+ Certificate Policies
+
+
+ Policy Mappings
+
+
+ Authority Key Identifier
+
+
+ Policy Constraints
+
+
+ Extended Key Usage
+
+
+ Freshest CRL
+
+
+ Inhibit Any Policy
+
+
+ Authority Info Access
+
+
+ Subject Info Access
+
+
+ Logo Type
+
+
+ BiometricInfo
+
+
+ QCStatements
+
+
+ Audit identity extension in attribute certificates.
+
+
+ NoRevAvail extension in attribute certificates.
+
+
+ TargetInformation extension in attribute certificates.
+
+
+ Constructor from Asn1Sequence.
+
+ the extensions are a list of constructed sequences, either with (Oid, OctetString) or (Oid, Boolean, OctetString)
+
+
+ constructor from a table of extensions.
+
+ it's is assumed the table contains Oid/string pairs.
+
+
+ Constructor from a table of extensions with ordering.
+
+ It's is assumed the table contains Oid/string pairs.
+
+
+ Constructor from two vectors
+
+ @param objectIDs an ArrayList of the object identifiers.
+ @param values an ArrayList of the extension values.
+
+
+ constructor from a table of extensions.
+
+ it's is assumed the table contains Oid/string pairs.
+
+
+ Constructor from a table of extensions with ordering.
+
+ It's is assumed the table contains Oid/string pairs.
+
+
+ Constructor from two vectors
+
+ @param objectIDs an ArrayList of the object identifiers.
+ @param values an ArrayList of the extension values.
+
+
+ return an Enumeration of the extension field's object ids.
+
+
+ return the extension represented by the object identifier
+ passed in.
+
+ @return the extension if it's present, null otherwise.
+
+
+
+ Extensions ::= SEQUENCE SIZE (1..MAX) OF Extension
+
+ Extension ::= SEQUENCE {
+ extnId EXTENSION.&id ({ExtensionSet}),
+ critical BOOLEAN DEFAULT FALSE,
+ extnValue OCTET STRING }
+
+
+
+ Generator for X.509 extensions
+
+
+ Reset the generator
+
+
+
+ Add an extension with the given oid and the passed in value to be included
+ in the OCTET STRING associated with the extension.
+
+ OID for the extension.
+ True if critical, false otherwise.
+ The ASN.1 object to be included in the extension.
+
+
+
+ Add an extension with the given oid and the passed in byte array to be wrapped
+ in the OCTET STRING associated with the extension.
+
+ OID for the extension.
+ True if critical, false otherwise.
+ The byte array to be wrapped.
+
+
+ Return true if there are no extension present in this generator.
+ True if empty, false otherwise
+
+
+ Generate an X509Extensions object based on the current state of the generator.
+ An X509Extensions object
+
+
+
+ RDNSequence ::= SEQUENCE OF RelativeDistinguishedName
+
+ RelativeDistinguishedName ::= SET SIZE (1..MAX) OF AttributeTypeAndValue
+
+ AttributeTypeAndValue ::= SEQUENCE {
+ type OBJECT IDENTIFIER,
+ value ANY }
+
+
+
+ country code - StringType(SIZE(2))
+
+
+ organization - StringType(SIZE(1..64))
+
+
+ organizational unit name - StringType(SIZE(1..64))
+
+
+ Title
+
+
+ common name - StringType(SIZE(1..64))
+
+
+ street - StringType(SIZE(1..64))
+
+
+ device serial number name - StringType(SIZE(1..64))
+
+
+ locality name - StringType(SIZE(1..64))
+
+
+ state, or province name - StringType(SIZE(1..64))
+
+
+ Naming attributes of type X520name
+
+
+ businessCategory - DirectoryString(SIZE(1..128)
+
+
+ postalCode - DirectoryString(SIZE(1..40)
+
+
+ dnQualifier - DirectoryString(SIZE(1..64)
+
+
+ RFC 3039 Pseudonym - DirectoryString(SIZE(1..64)
+
+
+ RFC 3039 DateOfBirth - GeneralizedTime - YYYYMMDD000000Z
+
+
+ RFC 3039 PlaceOfBirth - DirectoryString(SIZE(1..128)
+
+
+ RFC 3039 DateOfBirth - PrintableString (SIZE(1)) -- "M", "F", "m" or "f"
+
+
+ RFC 3039 CountryOfCitizenship - PrintableString (SIZE (2)) -- ISO 3166
+ codes only
+
+
+ RFC 3039 CountryOfCitizenship - PrintableString (SIZE (2)) -- ISO 3166
+ codes only
+
+
+ ISIS-MTT NameAtBirth - DirectoryString(SIZE(1..64)
+
+
+ RFC 3039 PostalAddress - SEQUENCE SIZE (1..6) OF
+ DirectoryString(SIZE(1..30))
+
+
+ RFC 2256 dmdName
+
+
+ id-at-telephoneNumber
+
+
+ id-at-name
+
+
+ Email address (RSA PKCS#9 extension) - IA5String.
+ Note: if you're trying to be ultra orthodox, don't use this! It shouldn't be in here.
+
+
+ more from PKCS#9
+
+
+ email address in Verisign certificates
+
+
+ LDAP User id.
+
+
+ determines whether or not strings should be processed and printed
+ from back to front.
+
+
+ default look up table translating OID values into their common symbols following
+ the convention in RFC 2253 with a few extras
+
+
+ look up table translating OID values into their common symbols following the convention in RFC 2253
+
+
+ look up table translating OID values into their common symbols following the convention in RFC 1779
+
+
+
+ look up table translating common symbols into their OIDS.
+
+
+ Return a X509Name based on the passed in tagged object.
+
+ @param obj tag object holding name.
+ @param explicitly true if explicitly tagged false otherwise.
+ @return the X509Name
+
+
+ Constructor from Asn1Sequence
+
+ the principal will be a list of constructed sets, each containing an (OID, string) pair.
+
+
+ Constructor from a table of attributes with ordering.
+
+ it's is assumed the table contains OID/string pairs, and the contents
+ of the table are copied into an internal table as part of the
+ construction process. The ordering ArrayList should contain the OIDs
+ in the order they are meant to be encoded or printed in ToString.
+
+
+ Constructor from a table of attributes with ordering.
+
+ it's is assumed the table contains OID/string pairs, and the contents
+ of the table are copied into an internal table as part of the
+ construction process. The ordering ArrayList should contain the OIDs
+ in the order they are meant to be encoded or printed in ToString.
+
+ The passed in converter will be used to convert the strings into their
+ ASN.1 counterparts.
+
+
+ Takes two vectors one of the oids and the other of the values.
+
+
+ Takes two vectors one of the oids and the other of the values.
+
+ The passed in converter will be used to convert the strings into their
+ ASN.1 counterparts.
+
+
+ Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or
+ some such, converting it into an ordered set of name attributes.
+
+
+ Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or
+ some such, converting it into an ordered set of name attributes with each
+ string value being converted to its associated ASN.1 type using the passed
+ in converter.
+
+
+ Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or
+ some such, converting it into an ordered set of name attributes. If reverse
+ is true, create the encoded version of the sequence starting from the
+ last element in the string.
+
+
+ Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or
+ some such, converting it into an ordered set of name attributes with each
+ string value being converted to its associated ASN.1 type using the passed
+ in converter. If reverse is true the ASN.1 sequence representing the DN will
+ be built by starting at the end of the string, rather than the start.
+
+
+ Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or
+ some such, converting it into an ordered set of name attributes. lookUp
+ should provide a table of lookups, indexed by lowercase only strings and
+ yielding a DerObjectIdentifier, other than that OID. and numeric oids
+ will be processed automatically.
+
+ If reverse is true, create the encoded version of the sequence
+ starting from the last element in the string.
+ @param reverse true if we should start scanning from the end (RFC 2553).
+ @param lookUp table of names and their oids.
+ @param dirName the X.500 string to be parsed.
+
+
+ Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or
+ some such, converting it into an ordered set of name attributes. lookUp
+ should provide a table of lookups, indexed by lowercase only strings and
+ yielding a DerObjectIdentifier, other than that OID. and numeric oids
+ will be processed automatically. The passed in converter is used to convert the
+ string values to the right of each equals sign to their ASN.1 counterparts.
+
+ @param reverse true if we should start scanning from the end, false otherwise.
+ @param lookUp table of names and oids.
+ @param dirName the string dirName
+ @param converter the converter to convert string values into their ASN.1 equivalents
+
+
+ return an IList of the oids in the name, in the order they were found.
+
+
+ return an IList of the values found in the name, in the order they
+ were found.
+
+
+ return an IList of the values found in the name, in the order they
+ were found, with the DN label corresponding to passed in oid.
+
+
+ The X509Name object to test equivalency against.
+ If true, the order of elements must be the same,
+ as well as the values associated with each element.
+
+
+ test for equivalence - note: case is ignored.
+
+
+ convert the structure to a string - if reverse is true the
+ oids and values are listed out starting with the last element
+ in the sequence (ala RFC 2253), otherwise the string will begin
+ with the first element of the structure. If no string definition
+ for the oid is found in oidSymbols the string value of the oid is
+ added. Two standard symbol tables are provided DefaultSymbols, and
+ RFC2253Symbols as part of this class.
+
+ @param reverse if true start at the end of the sequence and work back.
+ @param oidSymbols look up table strings for oids.
+
+
+ * It turns out that the number of standard ways the fields in a DN should be
+ * encoded into their ASN.1 counterparts is rapidly approaching the
+ * number of machines on the internet. By default the X509Name class
+ * will produce UTF8Strings in line with the current recommendations (RFC 3280).
+ *
+ * An example of an encoder look like below:
+ *
+ * public class X509DirEntryConverter
+ * : X509NameEntryConverter
+ * {
+ * public Asn1Object GetConvertedValue(
+ * DerObjectIdentifier oid,
+ * string value)
+ * {
+ * if (str.Length() != 0 && str.charAt(0) == '#')
+ * {
+ * return ConvertHexEncoded(str, 1);
+ * }
+ * if (oid.Equals(EmailAddress))
+ * {
+ * return new DerIA5String(str);
+ * }
+ * else if (CanBePrintable(str))
+ * {
+ * return new DerPrintableString(str);
+ * }
+ * else if (CanBeUTF8(str))
+ * {
+ * return new DerUtf8String(str);
+ * }
+ * else
+ * {
+ * return new DerBmpString(str);
+ * }
+ * }
+ * }
+ *
+ *
+
+
+ Convert an inline encoded hex string rendition of an ASN.1
+ object back into its corresponding ASN.1 object.
+
+ @param str the hex encoded object
+ @param off the index at which the encoding starts
+ @return the decoded object
+
+
+ return true if the passed in string can be represented without
+ loss as a PrintableString, false otherwise.
+
+
+ Convert the passed in string value into the appropriate ASN.1
+ encoded object.
+
+ @param oid the oid associated with the value in the DN.
+ @param value the value of the particular DN component.
+ @return the ASN.1 equivalent for the value.
+
+
+ class for breaking up an X500 Name into it's component tokens, ala
+ java.util.StringTokenizer. We need this class as some of the
+ lightweight Java environment don't support classes like
+ StringTokenizer.
+
+
+ The BiometricData object.
+
+ BiometricData ::= SEQUENCE {
+ typeOfBiometricData TypeOfBiometricData,
+ hashAlgorithm AlgorithmIdentifier,
+ biometricDataHash OCTET STRING,
+ sourceDataUri IA5String OPTIONAL }
+
+
+
+ The Iso4217CurrencyCode object.
+
+ Iso4217CurrencyCode ::= CHOICE {
+ alphabetic PrintableString (SIZE 3), --Recommended
+ numeric INTEGER (1..999) }
+ -- Alphabetic or numeric currency code as defined in ISO 4217
+ -- It is recommended that the Alphabetic form is used
+
+
+
+ The MonetaryValue object.
+
+ MonetaryValue ::= SEQUENCE {
+ currency Iso4217CurrencyCode,
+ amount INTEGER,
+ exponent INTEGER }
+ -- value = amount * 10^exponent
+
+
+
+ The QCStatement object.
+
+ QCStatement ::= SEQUENCE {
+ statementId OBJECT IDENTIFIER,
+ statementInfo ANY DEFINED BY statementId OPTIONAL}
+
+
+
+ The SemanticsInformation object.
+
+ SemanticsInformation ::= SEQUENCE {
+ semanticsIdentifier OBJECT IDENTIFIER OPTIONAL,
+ nameRegistrationAuthorities NameRegistrationAuthorities
+ OPTIONAL }
+ (WITH COMPONENTS {..., semanticsIdentifier PRESENT}|
+ WITH COMPONENTS {..., nameRegistrationAuthorities PRESENT})
+
+ NameRegistrationAuthorities ::= SEQUENCE SIZE (1..MAX) OF
+ GeneralName
+
+
+
+ The TypeOfBiometricData object.
+
+ TypeOfBiometricData ::= CHOICE {
+ predefinedBiometricType PredefinedBiometricType,
+ biometricDataOid OBJECT IDENTIFIER }
+
+ PredefinedBiometricType ::= INTEGER {
+ picture(0),handwritten-signature(1)}
+ (picture|handwritten-signature)
+
+
+
+ Structure for a name or pseudonym.
+
+
+ NameOrPseudonym ::= CHOICE {
+ surAndGivenName SEQUENCE {
+ surName DirectoryString,
+ givenName SEQUENCE OF DirectoryString
+ },
+ pseudonym DirectoryString
+ }
+
+
+ @see org.bouncycastle.asn1.x509.sigi.PersonalData
+
+
+
+ Constructor from DERString.
+
+ The sequence is of type NameOrPseudonym:
+
+
+ NameOrPseudonym ::= CHOICE {
+ surAndGivenName SEQUENCE {
+ surName DirectoryString,
+ givenName SEQUENCE OF DirectoryString
+ },
+ pseudonym DirectoryString
+ }
+
+ @param pseudonym pseudonym value to use.
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type NameOrPseudonym:
+
+
+ NameOrPseudonym ::= CHOICE {
+ surAndGivenName SEQUENCE {
+ surName DirectoryString,
+ givenName SEQUENCE OF DirectoryString
+ },
+ pseudonym DirectoryString
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from a given details.
+
+ @param pseudonym The pseudonym.
+
+
+ Constructor from a given details.
+
+ @param surname The surname.
+ @param givenName A sequence of directory strings making up the givenName
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ NameOrPseudonym ::= CHOICE {
+ surAndGivenName SEQUENCE {
+ surName DirectoryString,
+ givenName SEQUENCE OF DirectoryString
+ },
+ pseudonym DirectoryString
+ }
+
+
+ @return an Asn1Object
+
+
+ Contains personal data for the otherName field in the subjectAltNames
+ extension.
+
+
+ PersonalData ::= SEQUENCE {
+ nameOrPseudonym NameOrPseudonym,
+ nameDistinguisher [0] INTEGER OPTIONAL,
+ dateOfBirth [1] GeneralizedTime OPTIONAL,
+ placeOfBirth [2] DirectoryString OPTIONAL,
+ gender [3] PrintableString OPTIONAL,
+ postalAddress [4] DirectoryString OPTIONAL
+ }
+
+
+ @see org.bouncycastle.asn1.x509.sigi.NameOrPseudonym
+ @see org.bouncycastle.asn1.x509.sigi.SigIObjectIdentifiers
+
+
+ Constructor from Asn1Sequence.
+
+ The sequence is of type NameOrPseudonym:
+
+
+ PersonalData ::= SEQUENCE {
+ nameOrPseudonym NameOrPseudonym,
+ nameDistinguisher [0] INTEGER OPTIONAL,
+ dateOfBirth [1] GeneralizedTime OPTIONAL,
+ placeOfBirth [2] DirectoryString OPTIONAL,
+ gender [3] PrintableString OPTIONAL,
+ postalAddress [4] DirectoryString OPTIONAL
+ }
+
+
+ @param seq The ASN.1 sequence.
+
+
+ Constructor from a given details.
+
+ @param nameOrPseudonym Name or pseudonym.
+ @param nameDistinguisher Name distinguisher.
+ @param dateOfBirth Date of birth.
+ @param placeOfBirth Place of birth.
+ @param gender Gender.
+ @param postalAddress Postal Address.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Returns:
+
+
+ PersonalData ::= SEQUENCE {
+ nameOrPseudonym NameOrPseudonym,
+ nameDistinguisher [0] INTEGER OPTIONAL,
+ dateOfBirth [1] GeneralizedTime OPTIONAL,
+ placeOfBirth [2] DirectoryString OPTIONAL,
+ gender [3] PrintableString OPTIONAL,
+ postalAddress [4] DirectoryString OPTIONAL
+ }
+
+
+ @return an Asn1Object
+
+
+ Object Identifiers of SigI specifciation (German Signature Law
+ Interoperability specification).
+
+
+ Key purpose IDs for German SigI (Signature Interoperability
+ Specification)
+
+
+ Certificate policy IDs for German SigI (Signature Interoperability
+ Specification)
+
+
+ Other Name IDs for German SigI (Signature Interoperability Specification)
+
+
+ To be used for for the generation of directory service certificates.
+
+
+ ID for PersonalData
+
+
+ Certificate is conform to german signature law.
+
+
+ A general class that reads all X9.62 style EC curve tables.
+
+
+ return a X9ECParameters object representing the passed in named
+ curve. The routine returns null if the curve is not present.
+
+ @param name the name of the curve requested
+ @return an X9ECParameters object or null if the curve is not available.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return a X9ECParameters object representing the passed in named
+ curve.
+
+ @param oid the object id of the curve requested
+ @return an X9ECParameters object or null if the curve is not available.
+
+
+ return an enumeration of the names of the available curves.
+
+ @return an enumeration of the names of the available curves.
+
+
+ ASN.1 def for Diffie-Hellman key exchange KeySpecificInfo structure. See
+ RFC 2631, or X9.42, for further details.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ KeySpecificInfo ::= Sequence {
+ algorithm OBJECT IDENTIFIER,
+ counter OCTET STRING SIZE (4..4)
+ }
+
+
+
+ ANS.1 def for Diffie-Hellman key exchange OtherInfo structure. See
+ RFC 2631, or X9.42, for further details.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ OtherInfo ::= Sequence {
+ keyInfo KeySpecificInfo,
+ partyAInfo [0] OCTET STRING OPTIONAL,
+ suppPubInfo [2] OCTET STRING
+ }
+
+
+
+ table of the current named curves defined in X.962 EC-DSA.
+
+
+ return the X9ECParameters object for the named curve represented by
+ the passed in object identifier. Null if the curve isn't present.
+
+ @param oid an object identifier representing a named curve, if present.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Parameters ::= CHOICE {
+ ecParameters ECParameters,
+ namedCurve CURVES.&id({CurveNames}),
+ implicitlyCA Null
+ }
+
+
+
+ ASN.1 def for Elliptic-Curve Curve structure. See
+ X9.62, for further details.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ Curve ::= Sequence {
+ a FieldElement,
+ b FieldElement,
+ seed BIT STRING OPTIONAL
+ }
+
+
+
+ ASN.1 def for Elliptic-Curve ECParameters structure. See
+ X9.62, for further details.
+
+
+ Return the ASN.1 entry representing the Curve.
+
+ @return the X9Curve for the curve in these parameters.
+
+
+ Return the ASN.1 entry representing the FieldID.
+
+ @return the X9FieldID for the FieldID in these parameters.
+
+
+ Return the ASN.1 entry representing the base point G.
+
+ @return the X9ECPoint for the base point in these parameters.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ECParameters ::= Sequence {
+ version Integer { ecpVer1(1) } (ecpVer1),
+ fieldID FieldID {{FieldTypes}},
+ curve X9Curve,
+ base X9ECPoint,
+ order Integer,
+ cofactor Integer OPTIONAL
+ }
+
+
+
+ class for describing an ECPoint as a Der object.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ ECPoint ::= OCTET STRING
+
+
+ Octet string produced using ECPoint.GetEncoded().
+
+
+ Class for processing an ECFieldElement as a DER object.
+
+
+ Produce an object suitable for an Asn1OutputStream.
+
+ FieldElement ::= OCTET STRING
+
+
+
+ - if q is an odd prime then the field element is
+ processed as an Integer and converted to an octet string
+ according to x 9.62 4.3.1.
+ - if q is 2m then the bit string
+ contained in the field element is converted into an octet
+ string with the same ordering padded at the front if necessary.
+
+
+
+
+
+ ASN.1 def for Elliptic-Curve Field ID structure. See
+ X9.62, for further details.
+
+
+ Constructor for elliptic curves over prime fields
+ F2
.
+ @param primeP The prime p
defining the prime field.
+
+
+ Constructor for elliptic curves over binary fields
+ F2m
.
+ @param m The exponent m
of
+ F2m
.
+ @param k1 The integer k1
where xm +
+ xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ Constructor for elliptic curves over binary fields
+ F2m
.
+ @param m The exponent m
of
+ F2m
.
+ @param k1 The integer k1
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k2 The integer k2
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k3 The integer k3
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
..
+
+
+ Produce a Der encoding of the following structure.
+
+ FieldID ::= Sequence {
+ fieldType FIELD-ID.&id({IOSet}),
+ parameters FIELD-ID.&Type({IOSet}{@fieldType})
+ }
+
+
+
+ id-dsa-with-sha1 OBJECT IDENTIFIER ::= { iso(1) member-body(2)
+ us(840) x9-57 (10040) x9cm(4) 3 }
+
+
+ X9.63
+
+
+ X9.42
+
+
+ reader for Base64 armored objects - read the headers and then start returning
+ bytes when the data is reached. An IOException is thrown if the CRC check
+ fails.
+
+
+ decode the base 64 encoded input data.
+
+ @return the offset the data starts in out.
+
+
+ Create a stream for reading a PGP armoured message, parsing up to a header
+ and then reading the data that follows.
+
+ @param input
+
+
+ Create an armoured input stream which will assume the data starts
+ straight away, or parse for headers first depending on the value of
+ hasHeaders.
+
+ @param input
+ @param hasHeaders true if headers are to be looked for, false otherwise.
+
+
+ @return true if we are inside the clear text section of a PGP
+ signed message.
+
+
+ @return true if the stream is actually at end of file.
+
+
+ Return the armor header line (if there is one)
+ @return the armor header line, null if none present.
+
+
+ Return the armor headers (the lines after the armor header line),
+ @return an array of armor headers, null if there aren't any.
+
+
+ Basic output stream.
+
+
+ encode the input data producing a base 64 encoded byte array.
+
+
+ Set an additional header entry.
+
+ @param name the name of the header entry.
+ @param v the value of the header entry.
+
+
+ Reset the headers to only contain a Version string.
+
+
+ Start a clear text signed message.
+ @param hashAlgorithm
+
+
+ Note: Close() does not close the underlying stream. So it is possible to write
+ multiple objects using armoring to a single stream.
+
+
+ Reader for PGP objects.
+
+
+ Returns the next packet tag in the stream.
+
+
+
+ A stream that overlays our input stream, allowing the user to only read a segment of it.
+ NB: dataLength will be negative if the segment length is in the upper range above 2**31.
+
+
+
+ Base class for a PGP object.
+
+
+ Basic output stream.
+
+
+ Create a stream representing a general packet.
+ Output stream to write to.
+
+
+ Create a stream representing an old style partial object.
+ Output stream to write to.
+ The packet tag for the object.
+
+
+ Create a stream representing a general packet.
+ Output stream to write to.
+ Packet tag.
+ Size of chunks making up the packet.
+ If true, the header is written out in old format.
+
+
+ Create a new style partial input stream buffered into chunks.
+ Output stream to write to.
+ Packet tag.
+ Size of chunks making up the packet.
+
+
+ Create a new style partial input stream buffered into chunks.
+ Output stream to write to.
+ Packet tag.
+ Buffer to use for collecting chunks.
+
+
+ Flush the underlying stream.
+
+
+ Finish writing out the current packet without closing the underlying stream.
+
+
+ Generic compressed data object.
+
+
+ The algorithm tag value.
+
+
+ Basic tags for compression algorithms.
+
+
+ Basic type for a PGP packet.
+
+
+ Base class for a DSA public key.
+
+
+ The stream to read the packet from.
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ Base class for a DSA secret key.
+
+
+ @param in
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ @return x
+
+
+ Base class for an ECDH Public Key.
+
+
+ The stream to read the packet from.
+
+
+ Base class for an ECDSA Public Key.
+
+
+ The stream to read the packet from.
+
+
+ Base class for an EC Public Key.
+
+
+ The stream to read the packet from.
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ Base class for an EC Secret Key.
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ Base class for an ElGamal public key.
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ Base class for an ElGamal secret key.
+
+
+ @param in
+
+
+ @param x
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ Basic packet for an experimental packet.
+
+
+ Basic tags for hash algorithms.
+
+
+ Base interface for a PGP key.
+
+
+
+ The base format for this key - in the case of the symmetric keys it will generally
+ be raw indicating that the key is just a straight byte representation, for an asymmetric
+ key the format will be PGP, indicating the key is a string of MPIs encoded in PGP format.
+
+ "RAW" or "PGP".
+
+
+ Note: you can only read from this once...
+
+
+ Generic literal data packet.
+
+
+ The format tag value.
+
+
+ The modification time of the file in milli-seconds (since Jan 1, 1970 UTC)
+
+
+ A multiple precision integer
+
+
+ Basic type for a marker packet.
+
+
+ Basic packet for a modification detection code packet.
+
+
+ Generic signature object
+
+
+ The encryption algorithm tag.
+
+
+ The hash algorithm tag.
+
+
+ Basic PGP packet tag types.
+
+
+ Public Key Algorithm tag numbers.
+
+
+ Basic packet for a PGP public key.
+
+
+ Basic packet for a PGP public key.
+
+
+ Construct a version 4 public key packet.
+
+
+ Basic packet for a PGP public subkey
+
+
+ Construct a version 4 public subkey packet.
+
+
+ Base class for an RSA public key.
+
+
+ Construct an RSA public key from the passed in stream.
+
+
+ The modulus.
+ The public exponent.
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ Base class for an RSA secret (or priate) key.
+
+
+ The format, as a string, always "PGP".
+
+
+ Return the standard PGP encoding of the key.
+
+
+ The string to key specifier class.
+
+
+ The hash algorithm.
+
+
+ The IV for the key generation algorithm.
+
+
+ The iteration count
+
+
+ The protection mode - only if GnuDummyS2K
+
+
+ Basic packet for a PGP secret key.
+
+
+ Basic packet for a PGP secret key.
+
+
+ Generic signature packet.
+
+
+ Generate a version 4 signature packet.
+
+ @param signatureType
+ @param keyAlgorithm
+ @param hashAlgorithm
+ @param hashedData
+ @param unhashedData
+ @param fingerprint
+ @param signature
+
+
+ Generate a version 2/3 signature packet.
+
+ @param signatureType
+ @param keyAlgorithm
+ @param hashAlgorithm
+ @param fingerprint
+ @param signature
+
+
+ return the keyId
+ @return the keyId that created the signature.
+
+
+ return the signature trailer that must be included with the data
+ to reconstruct the signature
+
+ @return byte[]
+
+
+ * return the signature as a set of integers - note this is normalised to be the
+ * ASN.1 encoding of what appears in the signature packet.
+
+
+ Return the byte encoding of the signature section.
+ @return uninterpreted signature bytes.
+
+
+ Return the creation time in milliseconds since 1 Jan., 1970 UTC.
+
+
+ Basic type for a PGP Signature sub-packet.
+
+
+ Return the generic data making up the packet.
+
+
+ Basic PGP signature sub-packet tag types.
+
+
+ reader for signature sub-packets
+
+
+ Basic type for a symmetric key encrypted packet.
+
+
+ Basic tags for symmetric key algorithms
+
+
+ Basic type for a symmetric encrypted session key packet
+
+
+ @return int
+
+
+ @return S2k
+
+
+ @return byte[]
+
+
+ @return int
+
+
+ Basic type for a trust packet.
+
+
+ Basic type for a user attribute packet.
+
+
+ Basic type for a user attribute sub-packet.
+
+
+ return the generic data making up the packet.
+
+
+ Basic PGP user attribute sub-packet tag types.
+
+
+ reader for user attribute sub-packets
+
+
+ Basic type for a user ID packet.
+
+
+ Basic type for a image attribute packet.
+
+
+ Packet embedded signature
+
+
+ packet giving signature creation time.
+
+
+ packet giving signature expiration time.
+
+
+ Identifier for the modification detection feature
+
+
+ Returns if modification detection is supported.
+
+
+ Returns if a particular feature is supported.
+
+
+ Sets support for a particular feature.
+
+
+ packet giving signature creation time.
+
+
+ packet giving time after creation at which the key expires.
+
+
+ Return the number of seconds after creation time a key is valid for.
+
+ @return second count for key validity.
+
+
+ Packet holding the key flag values.
+
+
+
+ Return the flag values contained in the first 4 octets (note: at the moment
+ the standard only uses the first one).
+
+
+
+ Class provided a NotationData object according to
+ RFC2440, Chapter 5.2.3.15. Notation Data
+
+
+ packet giving signature creation time.
+
+
+ packet giving whether or not the signature is signed using the primary user ID for the key.
+
+
+ packet giving whether or not is revocable.
+
+
+ packet giving signature creation time.
+
+
+ packet giving signature expiration time.
+
+
+ return time in seconds before signature expires after creation time.
+
+
+ packet giving the User ID of the signer.
+
+
+ packet giving trust.
+
+
+
+ Represents revocation key OpenPGP signature sub packet.
+
+
+
+
+ Represents revocation reason OpenPGP signature sub packet.
+
+
+
+ Compressed data objects
+
+
+ The algorithm used for compression
+
+
+ Get the raw input stream contained in the object.
+
+
+ Return an uncompressed input stream which allows reading of the compressed data.
+
+
+ Class for producing compressed data packets.
+
+
+
+
+ Return an output stream which will save the data being written to
+ the compressed object.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+ Stream to be used for output.
+ A Stream for output of the compressed data.
+
+
+
+
+
+
+
+ Return an output stream which will compress the data as it is written to it.
+ The stream will be written out in chunks according to the size of the passed in buffer.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+ Note: if the buffer is not a power of 2 in length only the largest power of 2
+ bytes worth of the buffer will be used.
+
+
+ Note: using this may break compatibility with RFC 1991 compliant tools.
+ Only recent OpenPGP implementations are capable of accepting these streams.
+
+
+ Stream to be used for output.
+ The buffer to use.
+ A Stream for output of the compressed data.
+
+
+
+
+
+
+ Close the compressed object.summary>
+
+
+
+ Thrown if the IV at the start of a data stream indicates the wrong key is being used.
+
+
+
+ Return the raw input stream for the data stream.
+
+
+ Return true if the message is integrity protected.
+ True, if there is a modification detection code namespace associated
+ with this stream.
+
+
+ Note: This can only be called after the message has been read.
+ True, if the message verifies, false otherwise
+
+
+ Generator for encrypted objects.
+
+
+ Existing SecureRandom constructor.
+ The symmetric algorithm to use.
+ Source of randomness.
+
+
+ Creates a cipher stream which will have an integrity packet associated with it.
+
+
+ Base constructor.
+ The symmetric algorithm to use.
+ Source of randomness.
+ PGP 2.6.x compatibility required.
+
+
+
+ Add a PBE encryption method to the encrypted object using the default algorithm (S2K_SHA1).
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+ Add a PBE encryption method to the encrypted object.
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+ Add a PBE encryption method to the encrypted object.
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+
+
+ Add a PBE encryption method to the encrypted object.
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+ Add a public key encrypted session key to the encrypted object.
+
+
+
+
+ If buffer is non null stream assumed to be partial, otherwise the length will be used
+ to output a fixed length packet.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+
+
+
+
+ Return an output stream which will encrypt the data as it is written to it.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+
+
+
+
+ Return an output stream which will encrypt the data as it is written to it.
+ The stream will be written out in chunks according to the size of the passed in buffer.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+ Note: if the buffer is not a power of 2 in length only the largest power of 2
+ bytes worth of the buffer will be used.
+
+
+
+
+
+
+ Close off the encrypted object - this is equivalent to calling Close() on the stream
+ returned by the Open() method.
+
+
+ Note: This does not close the underlying output stream, only the stream on top of
+ it created by the Open() method.
+
+
+
+
+ A holder for a list of PGP encryption method packets.
+
+
+ Generic exception class for PGP encoding/decoding problems.
+
+
+ Key flag values for the KeyFlags subpacket.
+
+
+
+ General class to handle JCA key pairs and convert them into OpenPGP ones.
+
+ A word for the unwary, the KeyId for an OpenPGP public key is calculated from
+ a hash that includes the time of creation, if you pass a different date to the
+ constructor below with the same public private key pair the KeyIs will not be the
+ same as for previous generations of the key, so ideally you only want to do
+ this once.
+
+
+
+
+ Create a key pair from a PgpPrivateKey and a PgpPublicKey.
+ The public key.
+ The private key.
+
+
+ The keyId associated with this key pair.
+
+
+
+ Generator for a PGP master and subkey ring.
+ This class will generate both the secret and public key rings
+
+
+
+
+ Create a new key ring generator using old style checksumming. It is recommended to use
+ SHA1 checksumming where possible.
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+ The passPhrase to be used to protect secret keys.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+
+ Create a new key ring generator.
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+ The passPhrase to be used to protect secret keys.
+ Checksum the secret keys with SHA1 rather than the older 16 bit checksum.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+
+ Create a new key ring generator.
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+
+ If true, conversion of the passphrase to bytes uses Encoding.UTF8.GetBytes(), otherwise the conversion
+ is performed using Convert.ToByte(), which is the historical behaviour of the library (1.7 and earlier).
+
+ The passPhrase to be used to protect secret keys.
+ Checksum the secret keys with SHA1 rather than the older 16 bit checksum.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+
+ Create a new key ring generator.
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+ The passPhrase to be used to protect secret keys.
+ Checksum the secret keys with SHA1 rather than the older 16 bit checksum.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+
+ Create a new key ring generator.
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+ The hash algorithm.
+ The passPhrase to be used to protect secret keys.
+ Checksum the secret keys with SHA1 rather than the older 16 bit checksum.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+
+ Create a new key ring generator.
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+ The hash algorithm.
+
+ If true, conversion of the passphrase to bytes uses Encoding.UTF8.GetBytes(), otherwise the conversion
+ is performed using Convert.ToByte(), which is the historical behaviour of the library (1.7 and earlier).
+
+ The passPhrase to be used to protect secret keys.
+ Checksum the secret keys with SHA1 rather than the older 16 bit checksum.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+
+ Create a new key ring generator.
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+ The certification level for keys on this ring.
+ The master key pair.
+ The id to be associated with the ring.
+ The algorithm to be used to protect secret keys.
+ The hash algorithm.
+ The passPhrase to be used to protect secret keys.
+ Checksum the secret keys with SHA1 rather than the older 16 bit checksum.
+ Packets to be included in the certification hash.
+ Packets to be attached unhashed to the certification.
+ input secured random.
+
+
+ Add a subkey to the key ring to be generated with default certification.
+
+
+
+ Add a subkey to the key ring to be generated with default certification.
+
+ The key pair.
+ The hash algorithm.
+
+
+
+ Add a subkey with specific hashed and unhashed packets associated with it and
+ default certification.
+
+ Public/private key pair.
+ Hashed packet values to be included in certification.
+ Unhashed packets values to be included in certification.
+
+
+
+
+ Add a subkey with specific hashed and unhashed packets associated with it and
+ default certification.
+
+ Public/private key pair.
+ Hashed packet values to be included in certification.
+ Unhashed packets values to be included in certification.
+ The hash algorithm.
+ exception adding subkey:
+
+
+
+ Return the secret key ring.
+
+
+ Return the public key ring that corresponds to the secret key ring.
+
+
+
+ Thrown if the key checksum is invalid.
+
+
+
+ Class for processing literal data objects.
+
+
+ The special name indicating a "for your eyes only" packet.
+
+
+ The format of the data stream - Binary or Text
+
+
+ The file name that's associated with the data stream.
+
+
+ Return the file name as an unintrepreted byte array.
+
+
+ The modification time for the file.
+
+
+ The raw input stream for the data stream.
+
+
+ The input stream representing the data stream.
+
+
+ Class for producing literal data packets.
+
+
+ The special name indicating a "for your eyes only" packet.
+
+
+
+ Generates literal data objects in the old format.
+ This is important if you need compatibility with PGP 2.6.x.
+
+ If true, uses old format.
+
+
+
+
+ Open a literal data packet, returning a stream to store the data inside the packet.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+ The stream we want the packet in.
+ The format we are using.
+ The name of the 'file'.
+ The length of the data we will write.
+ The time of last modification we want stored.
+
+
+
+
+ Open a literal data packet, returning a stream to store the data inside the packet,
+ as an indefinite length stream. The stream is written out as a series of partial
+ packets with a chunk size determined by the size of the passed in buffer.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+ Note: if the buffer is not a power of 2 in length only the largest power of 2
+ bytes worth of the buffer will be used.
+
+ The stream we want the packet in.
+ The format we are using.
+ The name of the 'file'.
+ The time of last modification we want stored.
+ The buffer to use for collecting data to put into chunks.
+
+
+
+
+ Open a literal data packet for the passed in FileInfo object, returning
+ an output stream for saving the file contents.
+
+
+ The stream created can be closed off by either calling Close()
+ on the stream or Close() on the generator. Closing the returned
+ stream does not close off the Stream parameter outStr.
+
+
+ The stream we want the packet in.
+ The format we are using.
+ The FileInfo object containg the packet details.
+
+
+
+ Close the literal data packet - this is equivalent to calling Close()
+ on the stream returned by the Open() method.
+
+
+
+
+ A PGP marker packet - in general these should be ignored other than where
+ the idea is to preserve the original input stream.
+
+
+
+
+ General class for reading a PGP object stream.
+
+ Note: if this class finds a PgpPublicKey or a PgpSecretKey it
+ will create a PgpPublicKeyRing, or a PgpSecretKeyRing for each
+ key found. If all you are trying to do is read a key ring file use
+ either PgpPublicKeyRingBundle or PgpSecretKeyRingBundle.
+
+
+
+ Return the next object in the stream, or null if the end is reached.
+ On a parse error
+
+
+
+ Return all available objects in a list.
+
+ An IList containing all objects from this factory, in order.
+
+
+ A one pass signature object.
+
+
+ Initialise the signature object for verification.
+
+
+ Verify the calculated signature against the passed in PgpSignature.
+
+
+ Holder for a list of PgpOnePassSignature objects.
+
+
+ Padding functions.
+
+
+ A password based encryption object.
+
+
+ Return the raw input stream for the data stream.
+
+
+ Return the decrypted input stream, using the passed in passphrase.
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+ Return the decrypted input stream, using the passed in passphrase.
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+
+
+ Return the decrypted input stream, using the passed in passphrase.
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+ General class to contain a private key for use with other OpenPGP objects.
+
+
+
+ Create a PgpPrivateKey from a keyID, the associated public data packet, and a regular private key.
+
+ ID of the corresponding public key.
+ the public key data packet to be associated with this private key.
+ the private key data packet to be associated with this private key.
+
+
+ The keyId associated with the contained private key.
+
+
+ The public key packet associated with this private key, if available.
+
+
+ The contained private key.
+
+
+ General class to handle a PGP public key object.
+
+
+
+ Create a PgpPublicKey from the passed in lightweight one.
+
+
+ Note: the time passed in affects the value of the key's keyId, so you probably only want
+ to do this once for a lightweight key, or make sure you keep track of the time you used.
+
+ Asymmetric algorithm type representing the public key.
+ Actual public key to associate.
+ Date of creation.
+ If pubKey is not public.
+ On key creation problem.
+
+
+ Constructor for a sub-key.
+
+
+ Copy constructor.
+ The public key to copy.
+
+
+ The version of this key.
+
+
+ The creation time of this key.
+
+
+ The number of valid days from creation time - zero means no expiry.
+ WARNING: This method will return 1 for keys with version > 3 that expire in less than 1 day
+
+
+ Return the trust data associated with the public key, if present.
+ A byte array with trust data, null otherwise.
+
+
+ The number of valid seconds from creation time - zero means no expiry.
+
+
+ The keyId associated with the public key.
+
+
+ The fingerprint of the key
+
+
+
+ Check if this key has an algorithm type that makes it suitable to use for encryption.
+
+
+ Note: with version 4 keys KeyFlags subpackets should also be considered when present for
+ determining the preferred use of the key.
+
+
+ true if this key algorithm is suitable for encryption.
+
+
+
+ True, if this is a master key.
+
+
+ The algorithm code associated with the public key.
+
+
+ The strength of the key in bits.
+
+
+ The public key contained in the object.
+ A lightweight public key.
+ If the key algorithm is not recognised.
+
+
+ Allows enumeration of any user IDs associated with the key.
+ An IEnumerable of string objects.
+
+
+ Allows enumeration of any user attribute vectors associated with the key.
+ An IEnumerable of PgpUserAttributeSubpacketVector objects.
+
+
+ Allows enumeration of any signatures associated with the passed in id.
+ The ID to be matched.
+ An IEnumerable of PgpSignature objects.
+
+
+ Allows enumeration of signatures associated with the passed in user attributes.
+ The vector of user attributes to be matched.
+ An IEnumerable of PgpSignature objects.
+
+
+ Allows enumeration of signatures of the passed in type that are on this key.
+ The type of the signature to be returned.
+ An IEnumerable of PgpSignature objects.
+
+
+ Allows enumeration of all signatures/certifications associated with this key.
+ An IEnumerable with all signatures/certifications.
+
+
+ Return all signatures/certifications directly associated with this key (ie, not to a user id).
+
+ @return an iterator (possibly empty) with all signatures/certifications.
+
+
+ Check whether this (sub)key has a revocation signature on it.
+ True, if this (sub)key has been revoked.
+
+
+ Add a certification for an id to the given public key.
+ The key the certification is to be added to.
+ The ID the certification is associated with.
+ The new certification.
+ The re-certified key.
+
+
+ Add a certification for the given UserAttributeSubpackets to the given public key.
+ The key the certification is to be added to.
+ The attributes the certification is associated with.
+ The new certification.
+ The re-certified key.
+
+
+
+ Remove any certifications associated with a user attribute subpacket on a key.
+
+ The key the certifications are to be removed from.
+ The attributes to be removed.
+
+ The re-certified key, or null if the user attribute subpacket was not found on the key.
+
+
+
+ Remove any certifications associated with a given ID on a key.
+ The key the certifications are to be removed from.
+ The ID that is to be removed.
+ The re-certified key, or null if the ID was not found on the key.
+
+
+ Remove a certification associated with a given ID on a key.
+ The key the certifications are to be removed from.
+ The ID that the certfication is to be removed from.
+ The certfication to be removed.
+ The re-certified key, or null if the certification was not found.
+
+
+ Remove a certification associated with a given user attributes on a key.
+ The key the certifications are to be removed from.
+ The user attributes that the certfication is to be removed from.
+ The certification to be removed.
+ The re-certified key, or null if the certification was not found.
+
+
+ Add a revocation or some other key certification to a key.
+ The key the revocation is to be added to.
+ The key signature to be added.
+ The new changed public key object.
+
+
+ Remove a certification from the key.
+ The key the certifications are to be removed from.
+ The certfication to be removed.
+ The modified key, null if the certification was not found.
+
+
+ A public key encrypted data object.
+
+
+ The key ID for the key used to encrypt the data.
+
+
+
+ Return the algorithm code for the symmetric algorithm used to encrypt the data.
+
+
+
+ Return the decrypted data stream for the packet.
+
+
+
+ Class to hold a single master public key and its subkeys.
+
+ Often PGP keyring files consist of multiple master keys, if you are trying to process
+ or construct one of these you should use the PgpPublicKeyRingBundle class.
+
+
+
+
+ Return the first public key in the ring.
+
+
+ Return the public key referred to by the passed in key ID if it is present.
+
+
+ Allows enumeration of all the public keys.
+ An IEnumerable of PgpPublicKey objects.
+
+
+
+ Returns a new key ring with the public key passed in either added or
+ replacing an existing one.
+
+ The public key ring to be modified.
+ The public key to be inserted.
+ A new PgpPublicKeyRing
+
+
+ Returns a new key ring with the public key passed in removed from the key ring.
+ The public key ring to be modified.
+ The public key to be removed.
+ A new PgpPublicKeyRing, or null if pubKey is not found.
+
+
+
+ Often a PGP key ring file is made up of a succession of master/sub-key key rings.
+ If you want to read an entire public key file in one hit this is the class for you.
+
+
+
+ Build a PgpPublicKeyRingBundle from the passed in input stream.
+ Input stream containing data.
+ If a problem parsing the stream occurs.
+ If an object is encountered which isn't a PgpPublicKeyRing.
+
+
+ Return the number of key rings in this collection.
+
+
+ Allow enumeration of the public key rings making up this collection.
+
+
+ Allow enumeration of the key rings associated with the passed in userId.
+ The user ID to be matched.
+ An IEnumerable of key rings which matched (possibly none).
+
+
+ Allow enumeration of the key rings associated with the passed in userId.
+ The user ID to be matched.
+ If true, userId need only be a substring of an actual ID string to match.
+ An IEnumerable of key rings which matched (possibly none).
+
+
+ Allow enumeration of the key rings associated with the passed in userId.
+ The user ID to be matched.
+ If true, userId need only be a substring of an actual ID string to match.
+ If true, case is ignored in user ID comparisons.
+ An IEnumerable of key rings which matched (possibly none).
+
+
+ Return the PGP public key associated with the given key id.
+ The ID of the public key to return.
+
+
+ Return the public key ring which contains the key referred to by keyId
+ key ID to match against
+
+
+
+ Return true if a key matching the passed in key ID is present, false otherwise.
+
+ key ID to look for.
+
+
+
+ Return a new bundle containing the contents of the passed in bundle and
+ the passed in public key ring.
+
+ The PgpPublicKeyRingBundle the key ring is to be added to.
+ The key ring to be added.
+ A new PgpPublicKeyRingBundle merging the current one with the passed in key ring.
+ If the keyId for the passed in key ring is already present.
+
+
+
+ Return a new bundle containing the contents of the passed in bundle with
+ the passed in public key ring removed.
+
+ The PgpPublicKeyRingBundle the key ring is to be removed from.
+ The key ring to be removed.
+ A new PgpPublicKeyRingBundle not containing the passed in key ring.
+ If the keyId for the passed in key ring is not present.
+
+
+ General class to handle a PGP secret key object.
+
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ If utf8PassPhrase is true, conversion of the passphrase to bytes uses Encoding.UTF8.GetBytes(), otherwise the conversion
+ is performed using Convert.ToByte(), which is the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ If utf8PassPhrase is true, conversion of the passphrase to bytes uses Encoding.UTF8.GetBytes(), otherwise the conversion
+ is performed using Convert.ToByte(), which is the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+
+ Check if this key has an algorithm type that makes it suitable to use for signing.
+
+
+ Note: with version 4 keys KeyFlags subpackets should also be considered when present for
+ determining the preferred use of the key.
+
+
+ true if this key algorithm is suitable for use with signing.
+
+
+
+ True, if this is a master key.
+
+
+ Detect if the Secret Key's Private Key is empty or not
+
+
+ The algorithm the key is encrypted with.
+
+
+ The key ID of the public key associated with this key.
+
+
+ Return the S2K usage associated with this key.
+
+
+ Return the S2K used to process this key.
+
+
+ The public key associated with this key.
+
+
+ Allows enumeration of any user IDs associated with the key.
+ An IEnumerable of string objects.
+
+
+ Allows enumeration of any user attribute vectors associated with the key.
+ An IEnumerable of string objects.
+
+
+ Extract a PgpPrivateKey from this secret key's encrypted contents.
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+ Extract a PgpPrivateKey from this secret key's encrypted contents.
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+
+
+ Extract a PgpPrivateKey from this secret key's encrypted contents.
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+
+ Return a copy of the passed in secret key, encrypted using a new password
+ and the passed in algorithm.
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+ The PgpSecretKey to be copied.
+ The current password for the key.
+ The new password for the key.
+ The algorithm to be used for the encryption.
+ Source of randomness.
+
+
+
+ Return a copy of the passed in secret key, encrypted using a new password
+ and the passed in algorithm.
+
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+ The PgpSecretKey to be copied.
+ The current password for the key.
+ The new password for the key.
+ The algorithm to be used for the encryption.
+ Source of randomness.
+
+
+
+ Return a copy of the passed in secret key, encrypted using a new password
+ and the passed in algorithm.
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+ The PgpSecretKey to be copied.
+ The current password for the key.
+ The new password for the key.
+ The algorithm to be used for the encryption.
+ Source of randomness.
+
+
+ Replace the passed the public key on the passed in secret key.
+ Secret key to change.
+ New public key.
+ A new secret key.
+ If KeyId's do not match.
+
+
+
+ Parse a secret key from one of the GPG S expression keys associating it with the passed in public key.
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ Parse a secret key from one of the GPG S expression keys associating it with the passed in public key.
+
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+
+
+
+ Parse a secret key from one of the GPG S expression keys associating it with the passed in public key.
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+
+ Parse a secret key from one of the GPG S expression keys.
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ Parse a secret key from one of the GPG S expression keys.
+
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+
+
+
+ Parse a secret key from one of the GPG S expression keys.
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+
+ Parse a secret key from one of the GPG S expression keys.
+
+
+
+
+ Class to hold a single master secret key and its subkeys.
+
+ Often PGP keyring files consist of multiple master keys, if you are trying to process
+ or construct one of these you should use the PgpSecretKeyRingBundle class.
+
+
+
+
+ Return the public key for the master key.
+
+
+ Return the master private key.
+
+
+ Allows enumeration of the secret keys.
+ An IEnumerable of PgpSecretKey objects.
+
+
+
+ Return an iterator of the public keys in the secret key ring that
+ have no matching private key. At the moment only personal certificate data
+ appears in this fashion.
+
+ An IEnumerable of unattached, or extra, public keys.
+
+
+
+ Replace the public key set on the secret ring with the corresponding key off the public ring.
+
+ Secret ring to be changed.
+ Public ring containing the new public key set.
+
+
+
+ Return a copy of the passed in secret key ring, with the master key and sub keys encrypted
+ using a new password and the passed in algorithm.
+
+ The PgpSecretKeyRing to be copied.
+ The current password for key.
+ The new password for the key.
+ The algorithm to be used for the encryption.
+ Source of randomness.
+
+
+
+ Returns a new key ring with the secret key passed in either added or
+ replacing an existing one with the same key ID.
+
+ The secret key ring to be modified.
+ The secret key to be inserted.
+ A new PgpSecretKeyRing
+
+
+ Returns a new key ring with the secret key passed in removed from the key ring.
+ The secret key ring to be modified.
+ The secret key to be removed.
+ A new PgpSecretKeyRing, or null if secKey is not found.
+
+
+
+ Often a PGP key ring file is made up of a succession of master/sub-key key rings.
+ If you want to read an entire secret key file in one hit this is the class for you.
+
+
+
+ Build a PgpSecretKeyRingBundle from the passed in input stream.
+ Input stream containing data.
+ If a problem parsing the stream occurs.
+ If an object is encountered which isn't a PgpSecretKeyRing.
+
+
+ Return the number of rings in this collection.
+
+
+ Allow enumeration of the secret key rings making up this collection.
+
+
+ Allow enumeration of the key rings associated with the passed in userId.
+ The user ID to be matched.
+ An IEnumerable of key rings which matched (possibly none).
+
+
+ Allow enumeration of the key rings associated with the passed in userId.
+ The user ID to be matched.
+ If true, userId need only be a substring of an actual ID string to match.
+ An IEnumerable of key rings which matched (possibly none).
+
+
+ Allow enumeration of the key rings associated with the passed in userId.
+ The user ID to be matched.
+ If true, userId need only be a substring of an actual ID string to match.
+ If true, case is ignored in user ID comparisons.
+ An IEnumerable of key rings which matched (possibly none).
+
+
+ Return the PGP secret key associated with the given key id.
+ The ID of the secret key to return.
+
+
+ Return the secret key ring which contains the key referred to by keyId
+ The ID of the secret key
+
+
+
+ Return true if a key matching the passed in key ID is present, false otherwise.
+
+ key ID to look for.
+
+
+
+ Return a new bundle containing the contents of the passed in bundle and
+ the passed in secret key ring.
+
+ The PgpSecretKeyRingBundle the key ring is to be added to.
+ The key ring to be added.
+ A new PgpSecretKeyRingBundle merging the current one with the passed in key ring.
+ If the keyId for the passed in key ring is already present.
+
+
+
+ Return a new bundle containing the contents of the passed in bundle with
+ the passed in secret key ring removed.
+
+ The PgpSecretKeyRingBundle the key ring is to be removed from.
+ The key ring to be removed.
+ A new PgpSecretKeyRingBundle not containing the passed in key ring.
+ If the keyId for the passed in key ring is not present.
+
+
+ A PGP signature object.
+
+
+ The OpenPGP version number for this signature.
+
+
+ The key algorithm associated with this signature.
+
+
+ The hash algorithm associated with this signature.
+
+
+
+ Verify the signature as certifying the passed in public key as associated
+ with the passed in user attributes.
+
+ User attributes the key was stored under.
+ The key to be verified.
+ True, if the signature matches, false otherwise.
+
+
+
+ Verify the signature as certifying the passed in public key as associated
+ with the passed in ID.
+
+ ID the key was stored under.
+ The key to be verified.
+ True, if the signature matches, false otherwise.
+
+
+ Verify a certification for the passed in key against the passed in master key.
+ The key we are verifying against.
+ The key we are verifying.
+ True, if the certification is valid, false otherwise.
+
+
+ Verify a key certification, such as revocation, for the passed in key.
+ The key we are checking.
+ True, if the certification is valid, false otherwise.
+
+
+ The ID of the key that created the signature.
+
+
+ The creation time of this signature.
+
+
+
+ Return true if the signature has either hashed or unhashed subpackets.
+
+
+
+ Generator for PGP signatures.
+
+
+ Create a generator for the passed in keyAlgorithm and hashAlgorithm codes.
+
+
+ Initialise the generator for signing.
+
+
+ Initialise the generator for signing.
+
+
+ Return the one pass header associated with the current signature.
+
+
+ Return a signature object containing the current signature state.
+
+
+ Generate a certification for the passed in ID and key.
+ The ID we are certifying against the public key.
+ The key we are certifying against the ID.
+ The certification.
+
+
+ Generate a certification for the passed in userAttributes.
+ The ID we are certifying against the public key.
+ The key we are certifying against the ID.
+ The certification.
+
+
+ Generate a certification for the passed in key against the passed in master key.
+ The key we are certifying against.
+ The key we are certifying.
+ The certification.
+
+
+ Generate a certification, such as a revocation, for the passed in key.
+ The key we are certifying.
+ The certification.
+
+
+ A list of PGP signatures - normally in the signature block after literal data.
+
+
+ Generator for signature subpackets.
+
+
+
+ Add a TrustSignature packet to the signature. The values for depth and trust are largely
+ installation dependent but there are some guidelines in RFC 4880 - 5.2.3.13.
+
+ true if the packet is critical.
+ depth level.
+ trust amount.
+
+
+
+ Set the number of seconds a key is valid for after the time of its creation.
+ A value of zero means the key never expires.
+
+ True, if should be treated as critical, false otherwise.
+ The number of seconds the key is valid, or zero if no expiry.
+
+
+
+ Set the number of seconds a signature is valid for after the time of its creation.
+ A value of zero means the signature never expires.
+
+ True, if should be treated as critical, false otherwise.
+ The number of seconds the signature is valid, or zero if no expiry.
+
+
+
+ Set the creation time for the signature.
+
+ Note: this overrides the generation of a creation time when the signature
+ is generated.
+
+
+
+
+ Sets revocation reason sub packet
+
+
+
+
+ Sets revocation key sub packet
+
+
+
+
+ Sets issuer key sub packet
+
+
+
+ Container for a list of signature subpackets.
+
+
+ Return true if a particular subpacket type exists.
+
+ @param type type to look for.
+ @return true if present, false otherwise.
+
+
+ Return all signature subpackets of the passed in type.
+ @param type subpacket type code
+ @return an array of zero or more matching subpackets.
+
+
+
+ Return the number of seconds a signature is valid for after its creation date.
+ A value of zero means the signature never expires.
+
+ Seconds a signature is valid for.
+
+
+
+ Return the number of seconds a key is valid for after its creation date.
+ A value of zero means the key never expires.
+
+ Seconds a signature is valid for.
+
+
+ Return the number of packets this vector contains.
+
+
+ Container for a list of user attribute subpackets.
+
+
+ Basic utility class.
+
+
+
+ Conversion of the passphrase characters to bytes is performed using Convert.ToByte(), which is
+ the historical behaviour of the library (1.7 and earlier).
+
+
+
+
+ The passphrase is encoded to bytes using UTF8 (Encoding.UTF8.GetBytes).
+
+
+
+
+ Allows the caller to handle the encoding of the passphrase to bytes.
+
+
+
+ Write out the passed in file as a literal data packet.
+
+
+ Write out the passed in file as a literal data packet in partial packet format.
+
+
+
+ Return either an ArmoredInputStream or a BcpgInputStream based on whether
+ the initial characters of the stream are binary PGP encodings or not.
+
+
+
+ Generator for old style PGP V3 Signatures.
+
+
+ Create a generator for the passed in keyAlgorithm and hashAlgorithm codes.
+
+
+ Initialise the generator for signing.
+
+
+ Initialise the generator for signing.
+
+
+ Return the one pass header associated with the current signature.
+
+
+ Return a V3 signature object containing the current signature state.
+
+
+ Utility functions for looking a S-expression keys. This class will move when it finds a better home!
+
+ Format documented here:
+ http://git.gnupg.org/cgi-bin/gitweb.cgi?p=gnupg.git;a=blob;f=agent/keyformat.txt;h=42c4b1f06faf1bbe71ffadc2fee0fad6bec91a97;hb=refs/heads/master
+
+
+
+
+ The 'Signature' parameter is only available when generating unsigned attributes.
+
+
+
+ containing class for an CMS AuthEnveloped Data object
+
+
+ containing class for an CMS Authenticated Data object
+
+
+ return the object identifier for the content MAC algorithm.
+
+
+ return a store of the intended recipients for this message
+
+
+ return the ContentInfo
+
+
+ return a table of the digested attributes indexed by
+ the OID of the attribute.
+
+
+ return a table of the undigested attributes indexed by
+ the OID of the attribute.
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ General class for generating a CMS authenticated-data message.
+
+ A simple example of usage.
+
+
+ CMSAuthenticatedDataGenerator fact = new CMSAuthenticatedDataGenerator();
+
+ fact.addKeyTransRecipient(cert);
+
+ CMSAuthenticatedData data = fact.generate(content, algorithm, "BC");
+
+
+
+ base constructor
+
+
+ constructor allowing specific source of randomness
+ @param rand instance of SecureRandom to use
+
+
+ generate an enveloped object that contains an CMS Enveloped Data
+ object using the given provider and the passed in key generator.
+
+
+ generate an authenticated object that contains an CMS Authenticated Data object
+
+
+ Parsing class for an CMS Authenticated Data object from an input stream.
+
+ Note: that because we are in a streaming mode only one recipient can be tried and it is important
+ that the methods on the parser are called in the appropriate order.
+
+
+ Example of use - assuming the first recipient matches the private key we have.
+
+ CMSAuthenticatedDataParser ad = new CMSAuthenticatedDataParser(inputStream);
+
+ RecipientInformationStore recipients = ad.getRecipientInfos();
+
+ Collection c = recipients.getRecipients();
+ Iterator it = c.iterator();
+
+ if (it.hasNext())
+ {
+ RecipientInformation recipient = (RecipientInformation)it.next();
+
+ CMSTypedStream recData = recipient.getContentStream(privateKey, "BC");
+
+ processDataStream(recData.getContentStream());
+
+ if (!Arrays.equals(ad.getMac(), recipient.getMac())
+ {
+ System.err.println("Data corrupted!!!!");
+ }
+ }
+
+ Note: this class does not introduce buffering - if you are processing large files you should create
+ the parser with:
+
+ CMSAuthenticatedDataParser ep = new CMSAuthenticatedDataParser(new BufferedInputStream(inputStream, bufSize));
+
+ where bufSize is a suitably large buffer size.
+
+
+
+ return the object identifier for the mac algorithm.
+
+
+ return the ASN.1 encoded encryption algorithm parameters, or null if
+ there aren't any.
+
+
+ return a store of the intended recipients for this message
+
+
+ return a table of the unauthenticated attributes indexed by
+ the OID of the attribute.
+ @exception java.io.IOException
+
+
+ return a table of the unauthenticated attributes indexed by
+ the OID of the attribute.
+ @exception java.io.IOException
+
+
+ General class for generating a CMS authenticated-data message stream.
+
+ A simple example of usage.
+
+ CMSAuthenticatedDataStreamGenerator edGen = new CMSAuthenticatedDataStreamGenerator();
+
+ edGen.addKeyTransRecipient(cert);
+
+ ByteArrayOutputStream bOut = new ByteArrayOutputStream();
+
+ OutputStream out = edGen.open(
+ bOut, CMSAuthenticatedDataGenerator.AES128_CBC, "BC");*
+ out.write(data);
+
+ out.close();
+
+
+
+
+ base constructor
+
+
+ constructor allowing specific source of randomness
+ @param rand instance of SecureRandom to use
+
+
+ Set the underlying string size for encapsulated data
+
+ @param bufferSize length of octet strings to buffer the data.
+
+
+ Use a BER Set to store the recipient information
+
+
+ generate an enveloped object that contains an CMS Enveloped Data
+ object using the given provider and the passed in key generator.
+ @throws java.io.IOException
+
+
+ generate an enveloped object that contains an CMS Enveloped Data object
+
+
+ generate an enveloped object that contains an CMS Enveloped Data object
+
+
+ base constructor
+
+
+ constructor allowing specific source of randomness
+
+ @param rand instance of SecureRandom to use
+
+
+ containing class for an CMS Compressed Data object
+
+
+ Return the uncompressed content.
+
+ @return the uncompressed content
+ @throws CmsException if there is an exception uncompressing the data.
+
+
+ Return the uncompressed content, throwing an exception if the data size
+ is greater than the passed in limit. If the content is exceeded getCause()
+ on the CMSException will contain a StreamOverflowException
+
+ @param limit maximum number of bytes to read
+ @return the content read
+ @throws CMSException if there is an exception uncompressing the data.
+
+
+ return the ContentInfo
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ * General class for generating a compressed CMS message.
+ *
+ * A simple example of usage.
+ *
+ *
+ * CMSCompressedDataGenerator fact = new CMSCompressedDataGenerator();
+ * CMSCompressedData data = fact.Generate(content, algorithm);
+ *
+ *
+
+
+ Generate an object that contains an CMS Compressed Data
+
+
+ Class for reading a CMS Compressed Data stream.
+
+ CMSCompressedDataParser cp = new CMSCompressedDataParser(inputStream);
+
+ process(cp.GetContent().GetContentStream());
+
+ Note: this class does not introduce buffering - if you are processing large files you should create
+ the parser with:
+
+ CMSCompressedDataParser ep = new CMSCompressedDataParser(new BufferedInputStream(inputStream, bufSize));
+
+ where bufSize is a suitably large buffer size.
+
+
+ General class for generating a compressed CMS message stream.
+
+ A simple example of usage.
+
+
+ CMSCompressedDataStreamGenerator gen = new CMSCompressedDataStreamGenerator();
+
+ Stream cOut = gen.Open(outputStream, CMSCompressedDataStreamGenerator.ZLIB);
+
+ cOut.Write(data);
+
+ cOut.Close();
+
+
+
+ base constructor
+
+
+ Set the underlying string size for encapsulated data
+
+ @param bufferSize length of octet strings to buffer the data.
+
+
+ Close the underlying data stream.
+ @throws IOException if the close fails.
+
+
+ containing class for an CMS Enveloped Data object
+
+
+ return the object identifier for the content encryption algorithm.
+
+
+ return a store of the intended recipients for this message
+
+
+ return the ContentInfo
+
+
+ return a table of the unprotected attributes indexed by
+ the OID of the attribute.
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+
+ General class for generating a CMS enveloped-data message.
+
+ A simple example of usage.
+
+
+ CmsEnvelopedDataGenerator fact = new CmsEnvelopedDataGenerator();
+
+ fact.AddKeyTransRecipient(cert);
+
+ CmsEnvelopedData data = fact.Generate(content, algorithm);
+
+
+
+
+ Constructor allowing specific source of randomness
+ Instance of SecureRandom to use.
+
+
+
+ Generate an enveloped object that contains a CMS Enveloped Data
+ object using the passed in key generator.
+
+
+
+ Generate an enveloped object that contains an CMS Enveloped Data object.
+
+
+ Generate an enveloped object that contains an CMS Enveloped Data object.
+
+
+ Parsing class for an CMS Enveloped Data object from an input stream.
+
+ Note: that because we are in a streaming mode only one recipient can be tried and it is important
+ that the methods on the parser are called in the appropriate order.
+
+
+ Example of use - assuming the first recipient matches the private key we have.
+
+ CmsEnvelopedDataParser ep = new CmsEnvelopedDataParser(inputStream);
+
+ RecipientInformationStore recipients = ep.GetRecipientInfos();
+
+ Collection c = recipients.getRecipients();
+ Iterator it = c.iterator();
+
+ if (it.hasNext())
+ {
+ RecipientInformation recipient = (RecipientInformation)it.next();
+
+ CMSTypedStream recData = recipient.getContentStream(privateKey);
+
+ processDataStream(recData.getContentStream());
+ }
+
+ Note: this class does not introduce buffering - if you are processing large files you should create
+ the parser with:
+
+ CmsEnvelopedDataParser ep = new CmsEnvelopedDataParser(new BufferedInputStream(inputStream, bufSize));
+
+ where bufSize is a suitably large buffer size.
+
+
+
+ return the object identifier for the content encryption algorithm.
+
+
+ return the ASN.1 encoded encryption algorithm parameters, or null if
+ there aren't any.
+
+
+ return a store of the intended recipients for this message
+
+
+ return a table of the unprotected attributes indexed by
+ the OID of the attribute.
+ @throws IOException
+
+
+ General class for generating a CMS enveloped-data message stream.
+
+ A simple example of usage.
+
+ CmsEnvelopedDataStreamGenerator edGen = new CmsEnvelopedDataStreamGenerator();
+
+ edGen.AddKeyTransRecipient(cert);
+
+ MemoryStream bOut = new MemoryStream();
+
+ Stream out = edGen.Open(
+ bOut, CMSEnvelopedDataGenerator.AES128_CBC);*
+ out.Write(data);
+
+ out.Close();
+
+
+
+
+ Constructor allowing specific source of randomness
+ Instance of SecureRandom to use.
+
+
+ Set the underlying string size for encapsulated data.
+ Length of octet strings to buffer the data.
+
+
+ Use a BER Set to store the recipient information.
+
+
+
+ Generate an enveloped object that contains an CMS Enveloped Data
+ object using the passed in key generator.
+
+
+
+ generate an enveloped object that contains an CMS Enveloped Data object
+ @throws IOException
+
+
+ generate an enveloped object that contains an CMS Enveloped Data object
+ @throws IOException
+
+
+ General class for generating a CMS enveloped-data message.
+
+ A simple example of usage.
+
+
+ CMSEnvelopedDataGenerator fact = new CMSEnvelopedDataGenerator();
+
+ fact.addKeyTransRecipient(cert);
+
+ CMSEnvelopedData data = fact.generate(content, algorithm, "BC");
+
+
+
+ Constructor allowing specific source of randomness
+ Instance of SecureRandom to use.
+
+
+ add a recipient.
+
+ @param cert recipient's public key certificate
+ @exception ArgumentException if there is a problem with the certificate
+
+
+ add a recipient
+
+ @param key the public key used by the recipient
+ @param subKeyId the identifier for the recipient's public key
+ @exception ArgumentException if there is a problem with the key
+
+
+ add a KEK recipient.
+ @param key the secret key to use for wrapping
+ @param keyIdentifier the byte string that identifies the key
+
+
+ add a KEK recipient.
+ @param key the secret key to use for wrapping
+ @param keyIdentifier the byte string that identifies the key
+
+
+ Add a key agreement based recipient.
+
+ @param agreementAlgorithm key agreement algorithm to use.
+ @param senderPrivateKey private key to initialise sender side of agreement with.
+ @param senderPublicKey sender public key to include with message.
+ @param recipientCert recipient's public key certificate.
+ @param cekWrapAlgorithm OID for key wrapping algorithm to use.
+ @exception SecurityUtilityException if the algorithm requested cannot be found
+ @exception InvalidKeyException if the keys are inappropriate for the algorithm specified
+
+
+ Add multiple key agreement based recipients (sharing a single KeyAgreeRecipientInfo structure).
+
+ @param agreementAlgorithm key agreement algorithm to use.
+ @param senderPrivateKey private key to initialise sender side of agreement with.
+ @param senderPublicKey sender public key to include with message.
+ @param recipientCerts recipients' public key certificates.
+ @param cekWrapAlgorithm OID for key wrapping algorithm to use.
+ @exception SecurityUtilityException if the algorithm requested cannot be found
+ @exception InvalidKeyException if the keys are inappropriate for the algorithm specified
+
+
+
+ Generic routine to copy out the data we want processed.
+
+
+ This routine may be called multiple times.
+
+
+
+ a holding class for a byte array of data to be processed.
+
+
+ A clone of the byte array
+
+
+ a holding class for a file of data to be processed.
+
+
+ The file handle
+
+
+ general class for handling a pkcs7-signature message.
+
+ A simple example of usage - note, in the example below the validity of
+ the certificate isn't verified, just the fact that one of the certs
+ matches the given signer...
+
+
+ IX509Store certs = s.GetCertificates();
+ SignerInformationStore signers = s.GetSignerInfos();
+
+ foreach (SignerInformation signer in signers.GetSigners())
+ {
+ ArrayList certList = new ArrayList(certs.GetMatches(signer.SignerID));
+ X509Certificate cert = (X509Certificate) certList[0];
+
+ if (signer.Verify(cert.GetPublicKey()))
+ {
+ verified++;
+ }
+ }
+
+
+
+ Content with detached signature, digests precomputed
+
+ @param hashes a map of precomputed digests for content indexed by name of hash.
+ @param sigBlock the signature object.
+
+
+ base constructor - content with detached signature.
+
+ @param signedContent the content that was signed.
+ @param sigData the signature object.
+
+
+ base constructor - with encapsulated content
+
+
+ Return the version number for this object.
+
+
+ return the collection of signers that are associated with the
+ signatures for the message.
+
+
+ return a X509Store containing the attribute certificates, if any, contained
+ in this message.
+
+ @param type type of store to create
+ @return a store of attribute certificates
+ @exception NoSuchStoreException if the store type isn't available.
+ @exception CmsException if a general exception prevents creation of the X509Store
+
+
+ return a X509Store containing the public key certificates, if any, contained
+ in this message.
+
+ @param type type of store to create
+ @return a store of public key certificates
+ @exception NoSuchStoreException if the store type isn't available.
+ @exception CmsException if a general exception prevents creation of the X509Store
+
+
+ return a X509Store containing CRLs, if any, contained
+ in this message.
+
+ @param type type of store to create
+ @return a store of CRLs
+ @exception NoSuchStoreException if the store type isn't available.
+ @exception CmsException if a general exception prevents creation of the X509Store
+
+
+
+ Return the DerObjectIdentifier associated with the encapsulated
+ content info structure carried in the signed data.
+
+
+
+ return the ContentInfo
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ Replace the signerinformation store associated with this
+ CmsSignedData object with the new one passed in. You would
+ probably only want to do this if you wanted to change the unsigned
+ attributes associated with a signer, or perhaps delete one.
+
+ @param signedData the signed data object to be used as a base.
+ @param signerInformationStore the new signer information store to use.
+ @return a new signed data object.
+
+
+ Replace the certificate and CRL information associated with this
+ CmsSignedData object with the new one passed in.
+
+ @param signedData the signed data object to be used as a base.
+ @param x509Certs the new certificates to be used.
+ @param x509Crls the new CRLs to be used.
+ @return a new signed data object.
+ @exception CmsException if there is an error processing the stores
+
+
+ * general class for generating a pkcs7-signature message.
+ *
+ * A simple example of usage.
+ *
+ *
+ * IX509Store certs...
+ * IX509Store crls...
+ * CmsSignedDataGenerator gen = new CmsSignedDataGenerator();
+ *
+ * gen.AddSigner(privKey, cert, CmsSignedGenerator.DigestSha1);
+ * gen.AddCertificates(certs);
+ * gen.AddCrls(crls);
+ *
+ * CmsSignedData data = gen.Generate(content);
+ *
+ *
+
+
+ Constructor allowing specific source of randomness
+ Instance of SecureRandom to use.
+
+
+ * add a signer - no attributes other than the default ones will be
+ * provided here.
+ *
+ * @param key signing key to use
+ * @param cert certificate containing corresponding public key
+ * @param digestOID digest algorithm OID
+
+
+ add a signer, specifying the digest encryption algorithm to use - no attributes other than the default ones will be
+ provided here.
+
+ @param key signing key to use
+ @param cert certificate containing corresponding public key
+ @param encryptionOID digest encryption algorithm OID
+ @param digestOID digest algorithm OID
+
+
+ add a signer - no attributes other than the default ones will be
+ provided here.
+
+
+ add a signer, specifying the digest encryption algorithm to use - no attributes other than the default ones will be
+ provided here.
+
+
+ * add a signer with extra signed/unsigned attributes.
+ *
+ * @param key signing key to use
+ * @param cert certificate containing corresponding public key
+ * @param digestOID digest algorithm OID
+ * @param signedAttr table of attributes to be included in signature
+ * @param unsignedAttr table of attributes to be included as unsigned
+
+
+ add a signer, specifying the digest encryption algorithm, with extra signed/unsigned attributes.
+
+ @param key signing key to use
+ @param cert certificate containing corresponding public key
+ @param encryptionOID digest encryption algorithm OID
+ @param digestOID digest algorithm OID
+ @param signedAttr table of attributes to be included in signature
+ @param unsignedAttr table of attributes to be included as unsigned
+
+
+ * add a signer with extra signed/unsigned attributes.
+ *
+ * @param key signing key to use
+ * @param subjectKeyID subjectKeyID of corresponding public key
+ * @param digestOID digest algorithm OID
+ * @param signedAttr table of attributes to be included in signature
+ * @param unsignedAttr table of attributes to be included as unsigned
+
+
+ add a signer, specifying the digest encryption algorithm, with extra signed/unsigned attributes.
+
+ @param key signing key to use
+ @param subjectKeyID subjectKeyID of corresponding public key
+ @param encryptionOID digest encryption algorithm OID
+ @param digestOID digest algorithm OID
+ @param signedAttr table of attributes to be included in signature
+ @param unsignedAttr table of attributes to be included as unsigned
+
+
+ add a signer with extra signed/unsigned attributes based on generators.
+
+
+ add a signer, specifying the digest encryption algorithm, with extra signed/unsigned attributes based on generators.
+
+
+ add a signer with extra signed/unsigned attributes based on generators.
+
+
+ add a signer, including digest encryption algorithm, with extra signed/unsigned attributes based on generators.
+
+
+ generate a signed object that for a CMS Signed Data object
+
+
+ generate a signed object that for a CMS Signed Data
+ object - if encapsulate is true a copy
+ of the message will be included in the signature. The content type
+ is set according to the OID represented by the string signedContentType.
+
+
+ generate a signed object that for a CMS Signed Data
+ object - if encapsulate is true a copy
+ of the message will be included in the signature with the
+ default content type "data".
+
+
+ generate a set of one or more SignerInformation objects representing counter signatures on
+ the passed in SignerInformation object.
+
+ @param signer the signer to be countersigned
+ @param sigProvider the provider to be used for counter signing.
+ @return a store containing the signers.
+
+
+ Parsing class for an CMS Signed Data object from an input stream.
+
+ Note: that because we are in a streaming mode only one signer can be tried and it is important
+ that the methods on the parser are called in the appropriate order.
+
+
+ A simple example of usage for an encapsulated signature.
+
+
+ Two notes: first, in the example below the validity of
+ the certificate isn't verified, just the fact that one of the certs
+ matches the given signer, and, second, because we are in a streaming
+ mode the order of the operations is important.
+
+
+ CmsSignedDataParser sp = new CmsSignedDataParser(encapSigData);
+
+ sp.GetSignedContent().Drain();
+
+ IX509Store certs = sp.GetCertificates();
+ SignerInformationStore signers = sp.GetSignerInfos();
+
+ foreach (SignerInformation signer in signers.GetSigners())
+ {
+ ArrayList certList = new ArrayList(certs.GetMatches(signer.SignerID));
+ X509Certificate cert = (X509Certificate) certList[0];
+
+ Console.WriteLine("verify returns: " + signer.Verify(cert));
+ }
+
+ Note also: this class does not introduce buffering - if you are processing large files you should create
+ the parser with:
+
+ CmsSignedDataParser ep = new CmsSignedDataParser(new BufferedInputStream(encapSigData, bufSize));
+
+ where bufSize is a suitably large buffer size.
+
+
+ base constructor - with encapsulated content
+
+
+ base constructor
+
+ @param signedContent the content that was signed.
+ @param sigData the signature object.
+
+
+ Return the version number for the SignedData object
+
+ @return the version number
+
+
+ return the collection of signers that are associated with the
+ signatures for the message.
+ @throws CmsException
+
+
+ return a X509Store containing the attribute certificates, if any, contained
+ in this message.
+
+ @param type type of store to create
+ @return a store of attribute certificates
+ @exception org.bouncycastle.x509.NoSuchStoreException if the store type isn't available.
+ @exception CmsException if a general exception prevents creation of the X509Store
+
+
+ return a X509Store containing the public key certificates, if any, contained
+ in this message.
+
+ @param type type of store to create
+ @return a store of public key certificates
+ @exception NoSuchStoreException if the store type isn't available.
+ @exception CmsException if a general exception prevents creation of the X509Store
+
+
+ return a X509Store containing CRLs, if any, contained
+ in this message.
+
+ @param type type of store to create
+ @return a store of CRLs
+ @exception NoSuchStoreException if the store type isn't available.
+ @exception CmsException if a general exception prevents creation of the X509Store
+
+
+
+ Return the DerObjectIdentifier associated with the encapsulated
+ content info structure carried in the signed data.
+
+
+
+ Replace the signerinformation store associated with the passed
+ in message contained in the stream original with the new one passed in.
+ You would probably only want to do this if you wanted to change the unsigned
+ attributes associated with a signer, or perhaps delete one.
+
+ The output stream is returned unclosed.
+
+ @param original the signed data stream to be used as a base.
+ @param signerInformationStore the new signer information store to use.
+ @param out the stream to Write the new signed data object to.
+ @return out.
+
+
+ Replace the certificate and CRL information associated with this
+ CMSSignedData object with the new one passed in.
+
+ The output stream is returned unclosed.
+
+ @param original the signed data stream to be used as a base.
+ @param certsAndCrls the new certificates and CRLs to be used.
+ @param out the stream to Write the new signed data object to.
+ @return out.
+ @exception CmsException if there is an error processing the CertStore
+
+
+ General class for generating a pkcs7-signature message stream.
+
+ A simple example of usage.
+
+
+ IX509Store certs...
+ CmsSignedDataStreamGenerator gen = new CmsSignedDataStreamGenerator();
+
+ gen.AddSigner(privateKey, cert, CmsSignedDataStreamGenerator.DIGEST_SHA1);
+
+ gen.AddCertificates(certs);
+
+ Stream sigOut = gen.Open(bOut);
+
+ sigOut.Write(Encoding.UTF8.GetBytes("Hello World!"));
+
+ sigOut.Close();
+
+
+
+ Constructor allowing specific source of randomness
+ Instance of SecureRandom to use.
+
+
+ Set the underlying string size for encapsulated data
+
+ @param bufferSize length of octet strings to buffer the data.
+
+
+ add a signer - no attributes other than the default ones will be
+ provided here.
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ add a signer, specifying the digest encryption algorithm - no attributes other than the default ones will be
+ provided here.
+ @throws NoSuchProviderException
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ add a signer with extra signed/unsigned attributes.
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ add a signer with extra signed/unsigned attributes - specifying digest
+ encryption algorithm.
+ @throws NoSuchProviderException
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ add a signer - no attributes other than the default ones will be
+ provided here.
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ add a signer - no attributes other than the default ones will be
+ provided here.
+ @throws NoSuchProviderException
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ add a signer with extra signed/unsigned attributes.
+ @throws NoSuchAlgorithmException
+ @throws InvalidKeyException
+
+
+ generate a signed object that for a CMS Signed Data object
+
+
+ generate a signed object that for a CMS Signed Data
+ object - if encapsulate is true a copy
+ of the message will be included in the signature with the
+ default content type "data".
+
+
+ generate a signed object that for a CMS Signed Data
+ object using the given provider - if encapsulate is true a copy
+ of the message will be included in the signature with the
+ default content type "data". If dataOutputStream is non null the data
+ being signed will be written to the stream as it is processed.
+ @param out stream the CMS object is to be written to.
+ @param encapsulate true if data should be encapsulated.
+ @param dataOutputStream output stream to copy the data being signed to.
+
+
+ generate a signed object that for a CMS Signed Data
+ object - if encapsulate is true a copy
+ of the message will be included in the signature. The content type
+ is set according to the OID represented by the string signedContentType.
+
+
+ generate a signed object that for a CMS Signed Data
+ object using the given provider - if encapsulate is true a copy
+ of the message will be included in the signature. The content type
+ is set according to the OID represented by the string signedContentType.
+ @param out stream the CMS object is to be written to.
+ @param signedContentType OID for data to be signed.
+ @param encapsulate true if data should be encapsulated.
+ @param dataOutputStream output stream to copy the data being signed to.
+
+
+ Default type for the signed data.
+
+
+ Constructor allowing specific source of randomness
+ Instance of SecureRandom to use.
+
+
+ Add the attribute certificates contained in the passed in store to the
+ generator.
+
+ @param store a store of Version 2 attribute certificates
+ @throws CmsException if an error occurse processing the store.
+
+
+ Add a store of precalculated signers to the generator.
+
+ @param signerStore store of signers
+
+
+ Return a map of oids and byte arrays representing the digests calculated on the content during
+ the last generate.
+
+ @return a map of oids (as String objects) and byte[] representing digests.
+
+
+ Return the digest algorithm using one of the standard JCA string
+ representations rather than the algorithm identifier (if possible).
+
+
+ Return the digest encryption algorithm using one of the standard
+ JCA string representations rather than the algorithm identifier (if
+ possible).
+
+
+ Default authenticated attributes generator.
+
+
+ Initialise to use all defaults
+
+
+ Initialise with some extra attributes or overrides.
+
+ @param attributeTable initial attribute table to use.
+
+
+ Create a standard attribute table from the passed in parameters - this will
+ normally include contentType and messageDigest. If the constructor
+ using an AttributeTable was used, entries in it for contentType and
+ messageDigest will override the generated ones.
+
+ @param parameters source parameters for table generation.
+
+ @return a filled in IDictionary of attributes.
+
+
+ @param parameters source parameters
+ @return the populated attribute table
+
+
+ Default signed attributes generator.
+
+
+ Initialise to use all defaults
+
+
+ Initialise with some extra attributes or overrides.
+
+ @param attributeTable initial attribute table to use.
+
+
+ Create a standard attribute table from the passed in parameters - this will
+ normally include contentType, signingTime, and messageDigest. If the constructor
+ using an AttributeTable was used, entries in it for contentType, signingTime, and
+ messageDigest will override the generated ones.
+
+ @param parameters source parameters for table generation.
+
+ @return a filled in Hashtable of attributes.
+
+
+ @param parameters source parameters
+ @return the populated attribute table
+
+
+ the RecipientInfo class for a recipient who has been sent a message
+ encrypted using a secret key known to the other side.
+
+
+ decrypt the content and return an input stream.
+
+
+ the RecipientInfo class for a recipient who has been sent a message
+ encrypted using key agreement.
+
+
+ decrypt the content and return an input stream.
+
+
+ the KeyTransRecipientInformation class for a recipient who has been sent a secret
+ key encrypted using their public key that needs to be used to
+ extract the message.
+
+
+ decrypt the content and return it as a byte array.
+
+
+ a basic index for an originator.
+
+
+ Return the certificates stored in the underlying OriginatorInfo object.
+
+ @return a Store of X509CertificateHolder objects.
+
+
+ Return the CRLs stored in the underlying OriginatorInfo object.
+
+ @return a Store of X509CRLHolder objects.
+
+
+ Return the underlying ASN.1 object defining this SignerInformation object.
+
+ @return a OriginatorInfo.
+
+
+
+ PKCS5 scheme-2 - password converted to bytes assuming ASCII.
+
+
+
+ PKCS5 scheme-2 - password converted to bytes using UTF-8.
+
+
+ the RecipientInfo class for a recipient who has been sent a message
+ encrypted using a password.
+
+
+ return the object identifier for the key derivation algorithm, or null
+ if there is none present.
+
+ @return OID for key derivation algorithm, if present.
+
+
+ decrypt the content and return an input stream.
+
+
+
+ Generate a RecipientInfo object for the given key.
+
+
+ A
+
+
+ A
+
+
+ A
+
+
+
+
+ * return the object identifier for the key encryption algorithm.
+ *
+ * @return OID for key encryption algorithm.
+
+
+ * return the ASN.1 encoded key encryption algorithm parameters, or null if
+ * there aren't any.
+ *
+ * @return ASN.1 encoding of key encryption algorithm parameters.
+
+
+ Return the MAC calculated for the content stream. Note: this call is only meaningful once all
+ the content has been read.
+
+ @return byte array containing the mac.
+
+
+ Return the first RecipientInformation object that matches the
+ passed in selector. Null if there are no matches.
+
+ @param selector to identify a recipient
+ @return a single RecipientInformation object. Null if none matches.
+
+
+ Return the number of recipients in the collection.
+
+ @return number of recipients identified.
+
+
+ Return all recipients in the collection
+
+ @return a collection of recipients.
+
+
+ Return possible empty collection with recipients matching the passed in RecipientID
+
+ @param selector a recipient id to select against.
+ @return a collection of RecipientInformation objects.
+
+
+ a basic index for a signer.
+
+
+ If the passed in flag is true, the signer signature will be based on the data, not
+ a collection of signed attributes, and no signed attributes will be included.
+
+ @return the builder object
+
+
+ Provide a custom signed attribute generator.
+
+ @param signedGen a generator of signed attributes.
+ @return the builder object
+
+
+ Provide a generator of unsigned attributes.
+
+ @param unsignedGen a generator for signed attributes.
+ @return the builder object
+
+
+ Build a generator with the passed in certHolder issuer and serial number as the signerIdentifier.
+
+ @param contentSigner operator for generating the final signature in the SignerInfo with.
+ @param certHolder carrier for the X.509 certificate related to the contentSigner.
+ @return a SignerInfoGenerator
+ @throws OperatorCreationException if the generator cannot be built.
+
+
+ Build a generator with the passed in subjectKeyIdentifier as the signerIdentifier. If used you should
+ try to follow the calculation described in RFC 5280 section 4.2.1.2.
+
+ @param signerFactory operator factory for generating the final signature in the SignerInfo with.
+ @param subjectKeyIdentifier key identifier to identify the public key for verifying the signature.
+ @return a SignerInfoGenerator
+
+
+ an expanded SignerInfo block from a CMS Signed message
+
+
+ return the version number for this objects underlying SignerInfo structure.
+
+
+ return the object identifier for the signature.
+
+
+ return the signature parameters, or null if there aren't any.
+
+
+ return the content digest that was calculated during verification.
+
+
+ return the object identifier for the signature.
+
+
+ return the signature/encryption algorithm parameters, or null if
+ there aren't any.
+
+
+ return a table of the signed attributes - indexed by
+ the OID of the attribute.
+
+
+ return a table of the unsigned attributes indexed by
+ the OID of the attribute.
+
+
+ return the encoded signature
+
+
+ Return a SignerInformationStore containing the counter signatures attached to this
+ signer. If no counter signatures are present an empty store is returned.
+
+
+ return the DER encoding of the signed attributes.
+ @throws IOException if an encoding error occurs.
+
+
+ verify that the given public key successfully handles and confirms the
+ signature associated with this signer.
+
+
+ verify that the given certificate successfully handles and confirms
+ the signature associated with this signer and, if a signingTime
+ attribute is available, that the certificate was valid at the time the
+ signature was generated.
+
+
+ Return the base ASN.1 CMS structure that this object contains.
+
+ @return an object containing a CMS SignerInfo structure.
+
+
+ Return a signer information object with the passed in unsigned
+ attributes replacing the ones that are current associated with
+ the object passed in.
+
+ @param signerInformation the signerInfo to be used as the basis.
+ @param unsignedAttributes the unsigned attributes to add.
+ @return a copy of the original SignerInformationObject with the changed attributes.
+
+
+ Return a signer information object with passed in SignerInformationStore representing counter
+ signatures attached as an unsigned attribute.
+
+ @param signerInformation the signerInfo to be used as the basis.
+ @param counterSigners signer info objects carrying counter signature.
+ @return a copy of the original SignerInformationObject with the changed attributes.
+
+
+ Create a store containing a single SignerInformation object.
+
+ @param signerInfo the signer information to contain.
+
+
+ Create a store containing a collection of SignerInformation objects.
+
+ @param signerInfos a collection signer information objects to contain.
+
+
+ Return the first SignerInformation object that matches the
+ passed in selector. Null if there are no matches.
+
+ @param selector to identify a signer
+ @return a single SignerInformation object. Null if none matches.
+
+
+ The number of signers in the collection.
+
+
+ An ICollection of all signers in the collection
+
+
+ Return possible empty collection with signers matching the passed in SignerID
+
+ @param selector a signer id to select against.
+ @return a collection of SignerInformation objects.
+
+
+ Basic generator that just returns a preconstructed attribute table
+
+
+ a holding class for public/private parameter pairs.
+
+
+ basic constructor.
+
+ @param publicParam a public key parameters object.
+ @param privateParam the corresponding private key parameters.
+
+
+ return the public key parameters.
+
+ @return the public key parameters.
+
+
+ return the private key parameters.
+
+ @return the private key parameters.
+
+
+ The AEAD block ciphers already handle buffering internally, so this class
+ just takes care of implementing IBufferedCipher methods.
+
+
+ initialise the cipher.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the blocksize for the underlying cipher.
+
+ @return the blocksize for the underlying cipher.
+
+
+ return the size of the output buffer required for an update
+ an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to update
+ with len bytes of input.
+
+
+ return the size of the output buffer required for an update plus a
+ doFinal with an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to update and doFinal
+ with len bytes of input.
+
+
+ process a single byte, producing an output block if necessary.
+
+ @param in the input byte.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ process an array of bytes, producing output if necessary.
+
+ @param in the input byte array.
+ @param inOff the offset at which the input data starts.
+ @param len the number of bytes to be copied out of the input array.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ Process the last block in the buffer.
+
+ @param out the array the block currently being held is copied into.
+ @param outOff the offset at which the copying starts.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there is insufficient space in out for
+ the output, or the input is not block size aligned and should be.
+ @exception InvalidOperationException if the underlying cipher is not
+ initialised.
+ @exception InvalidCipherTextException if padding is expected and not found.
+ @exception DataLengthException if the input is not block size
+ aligned.
+
+
+ Reset the buffer and cipher. After resetting the object is in the same
+ state as it was after the last init (if there was one).
+
+
+ a buffer wrapper for an asymmetric block cipher, allowing input
+ to be accumulated in a piecemeal fashion until final processing.
+
+
+ base constructor.
+
+ @param cipher the cipher this buffering object wraps.
+
+
+ return the amount of data sitting in the buffer.
+
+ @return the amount of data sitting in the buffer.
+
+
+ initialise the buffer and the underlying cipher.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+
+
+ process the contents of the buffer using the underlying
+ cipher.
+
+ @return the result of the encryption/decryption process on the
+ buffer.
+ @exception InvalidCipherTextException if we are given a garbage block.
+
+
+ Reset the buffer
+
+
+ A wrapper class that allows block ciphers to be used to process data in
+ a piecemeal fashion. The BufferedBlockCipher outputs a block only when the
+ buffer is full and more data is being added, or on a doFinal.
+
+ Note: in the case where the underlying cipher is either a CFB cipher or an
+ OFB one the last block may not be a multiple of the block size.
+
+
+
+ constructor for subclasses
+
+
+ Create a buffered block cipher without padding.
+
+ @param cipher the underlying block cipher this buffering object wraps.
+ false otherwise.
+
+
+ initialise the cipher.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the blocksize for the underlying cipher.
+
+ @return the blocksize for the underlying cipher.
+
+
+ return the size of the output buffer required for an update
+ an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to update
+ with len bytes of input.
+
+
+ return the size of the output buffer required for an update plus a
+ doFinal with an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to update and doFinal
+ with len bytes of input.
+
+
+ process a single byte, producing an output block if necessary.
+
+ @param in the input byte.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ process an array of bytes, producing output if necessary.
+
+ @param in the input byte array.
+ @param inOff the offset at which the input data starts.
+ @param len the number of bytes to be copied out of the input array.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ Process the last block in the buffer.
+
+ @param out the array the block currently being held is copied into.
+ @param outOff the offset at which the copying starts.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there is insufficient space in out for
+ the output, or the input is not block size aligned and should be.
+ @exception InvalidOperationException if the underlying cipher is not
+ initialised.
+ @exception InvalidCipherTextException if padding is expected and not found.
+ @exception DataLengthException if the input is not block size
+ aligned.
+
+
+ Reset the buffer and cipher. After resetting the object is in the same
+ state as it was after the last init (if there was one).
+
+
+ The base class for symmetric, or secret, cipher key generators.
+
+
+ initialise the key generator.
+
+ @param param the parameters to be used for key generation
+
+
+ Generate a secret key.
+
+ @return a byte array containing the key value.
+
+
+ this exception is thrown if a buffer that is meant to have output
+ copied into it turns out to be too short, or if we've been given
+ insufficient input. In general this exception will Get thrown rather
+ than an ArrayOutOfBounds exception.
+
+
+ base constructor.
+
+
+ create a DataLengthException with the given message.
+
+ @param message the message to be carried with the exception.
+
+
+ Wrapper removes exposure to the IMemoable interface on an IDigest implementation.
+
+
+ Base constructor.
+
+ @param baseDigest underlying digest to use.
+ @exception IllegalArgumentException if baseDigest is null
+
+
+ implementation of GOST R 34.11-94
+
+
+ Standard constructor
+
+
+ Constructor to allow use of a particular sbox with GOST28147
+ @see GOST28147Engine#getSBox(String)
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables to the IV values.
+
+
+ base implementation of MD4 family style digest as outlined in
+ "Handbook of Applied Cryptography", pages 344 - 347.
+
+
+
+ Implementation of Keccak based on following KeccakNISTInterface.c from http://keccak.noekeon.org/
+
+
+ Following the naming conventions used in the C source code to enable easy review of the implementation.
+
+
+
+ Return the size of block that the compression function is applied to in bytes.
+
+ @return internal byte length of a block.
+
+
+ Base class for SHA-384 and SHA-512.
+
+
+ Constructor for variable length word
+
+
+ Copy constructor. We are using copy constructors in place
+ of the object.Clone() interface as this interface is not
+ supported by J2ME.
+
+
+ adjust the byte counts so that byteCount2 represents the
+ upper long (less 3 bits) word of the byte count.
+
+
+ implementation of MD2
+ as outlined in RFC1319 by B.Kaliski from RSA Laboratories April 1992
+
+
+ return the algorithm name
+
+ @return the algorithm name
+
+
+ Close the digest, producing the final digest value. The doFinal
+ call leaves the digest reset.
+
+ @param out the array the digest is to be copied into.
+ @param outOff the offset into the out array the digest is to start at.
+
+
+ reset the digest back to it's initial state.
+
+
+ update the message digest with a single byte.
+
+ @param in the input byte to be entered.
+
+
+ update the message digest with a block of bytes.
+
+ @param in the byte array containing the data.
+ @param inOff the offset into the byte array where the data starts.
+ @param len the length of the data.
+
+
+ implementation of MD4 as RFC 1320 by R. Rivest, MIT Laboratory for
+ Computer Science and RSA Data Security, Inc.
+
+ NOTE: This algorithm is only included for backwards compatibility
+ with legacy applications, it's not secure, don't use it for anything new!
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables to the IV values.
+
+
+ implementation of MD5 as outlined in "Handbook of Applied Cryptography", pages 346 - 347.
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables to the IV values.
+
+
+ implementation of RipeMD128
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables to the IV values.
+
+
+ implementation of RipeMD see,
+ http://www.esat.kuleuven.ac.be/~bosselae/ripemd160.html
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables to the IV values.
+
+
+
+ Implementation of RipeMD256.
+ Note: this algorithm offers the same level of security as RipeMD128.
+
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+
+ reset the chaining variables to the IV values.
+
+
+
+ Implementation of RipeMD 320.
+ Note: this algorithm offers the same level of security as RipeMD160.
+
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+
+ reset the chaining variables to the IV values.
+
+
+
+ Implementation of SHA-3 based on following KeccakNISTInterface.c from http://keccak.noekeon.org/
+
+
+ Following the naming conventions used in the C source code to enable easy review of the implementation.
+
+
+
+
+ Implementation of Chinese SM3 digest as described at
+ http://tools.ietf.org/html/draft-shen-sm3-hash-00
+ and at .... ( Chinese PDF )
+
+
+ The specification says "process a bit stream",
+ but this is written to process bytes in blocks of 4,
+ meaning this will process 32-bit word groups.
+ But so do also most other digest specifications,
+ including the SHA-256 which was a origin for
+ this specification.
+
+
+
+
+ Standard constructor
+
+
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+
+
+ reset the chaining variables
+
+
+
+ implementation of SHA-1 as outlined in "Handbook of Applied Cryptography", pages 346 - 349.
+
+ It is interesting to ponder why the, apart from the extra IV, the other difference here from MD5
+ is the "endianness" of the word processing!
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+ SHA-224 as described in RFC 3874
+
+ block word digest
+ SHA-1 512 32 160
+ SHA-224 512 32 224
+ SHA-256 512 32 256
+ SHA-384 1024 64 384
+ SHA-512 1024 64 512
+
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+ Draft FIPS 180-2 implementation of SHA-256. Note: As this is
+ based on a draft this implementation is subject to change.
+
+
+ block word digest
+ SHA-1 512 32 160
+ SHA-256 512 32 256
+ SHA-384 1024 64 384
+ SHA-512 1024 64 512
+
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+ Draft FIPS 180-2 implementation of SHA-384. Note: As this is
+ based on a draft this implementation is subject to change.
+
+
+ block word digest
+ SHA-1 512 32 160
+ SHA-256 512 32 256
+ SHA-384 1024 64 384
+ SHA-512 1024 64 512
+
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+ Draft FIPS 180-2 implementation of SHA-512. Note: As this is
+ based on a draft this implementation is subject to change.
+
+
+ block word digest
+ SHA-1 512 32 160
+ SHA-256 512 32 256
+ SHA-384 1024 64 384
+ SHA-512 1024 64 512
+
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+ FIPS 180-4 implementation of SHA-512/t
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+
+ Implementation of SHAKE based on following KeccakNISTInterface.c from http://keccak.noekeon.org/
+
+
+ Following the naming conventions used in the C source code to enable easy review of the implementation.
+
+
+
+ Wrapper class that reduces the output length of a particular digest to
+ only the first n bytes of the digest function.
+
+
+ Base constructor.
+
+ @param baseDigest underlying digest to use.
+ @param length length in bytes of the output of doFinal.
+ @exception ArgumentException if baseDigest is null, or length is greater than baseDigest.GetDigestSize().
+
+
+
+ Implementation of the Skein parameterised hash function in 256, 512 and 1024 bit block sizes,
+ based on the Threefish tweakable block cipher.
+
+
+ This is the 1.3 version of Skein defined in the Skein hash function submission to the NIST SHA-3
+ competition in October 2010.
+
+ Skein was designed by Niels Ferguson - Stefan Lucks - Bruce Schneier - Doug Whiting - Mihir
+ Bellare - Tadayoshi Kohno - Jon Callas - Jesse Walker.
+
+
+
+
+
+
+ 256 bit block size - Skein-256
+
+
+
+
+ 512 bit block size - Skein-512
+
+
+
+
+ 1024 bit block size - Skein-1024
+
+
+
+
+ Constructs a Skein digest with an internal state size and output size.
+
+ the internal state size in bits - one of or
+ .
+ the output/digest size to produce in bits, which must be an integral number of
+ bytes.
+
+
+
+ Optionally initialises the Skein digest with the provided parameters.
+
+ See for details on the parameterisation of the Skein hash function.
+ the parameters to apply to this engine, or null
to use no parameters.
+
+
+
+ Implementation of the Skein family of parameterised hash functions in 256, 512 and 1024 bit block
+ sizes, based on the Threefish tweakable block cipher.
+
+
+ This is the 1.3 version of Skein defined in the Skein hash function submission to the NIST SHA-3
+ competition in October 2010.
+
+ Skein was designed by Niels Ferguson - Stefan Lucks - Bruce Schneier - Doug Whiting - Mihir
+ Bellare - Tadayoshi Kohno - Jon Callas - Jesse Walker.
+
+ This implementation is the basis for and , implementing the
+ parameter based configuration system that allows Skein to be adapted to multiple applications.
+ Initialising the engine with allows standard and arbitrary parameters to
+ be applied during the Skein hash function.
+
+ Implemented:
+
+ - 256, 512 and 1024 bit internal states.
+ - Full 96 bit input length.
+ - Parameters defined in the Skein specification, and arbitrary other pre and post message
+ parameters.
+ - Arbitrary output size in 1 byte intervals.
+
+
+ Not implemented:
+
+ - Sub-byte length input (bit padding).
+ - Tree hashing.
+
+
+
+
+
+
+ 256 bit block size - Skein-256
+
+
+
+
+ 512 bit block size - Skein-512
+
+
+
+
+ 1024 bit block size - Skein-1024
+
+
+
+ The parameter type for the Skein key.
+
+
+ The parameter type for the Skein configuration block.
+
+
+ The parameter type for the message.
+
+
+ The parameter type for the output transformation.
+
+
+ Precalculated UBI(CFG) states for common state/output combinations without key or other
+ pre-message params.
+
+
+ Point at which position might overflow long, so switch to add with carry logic
+
+
+ Bit 127 = final
+
+
+ Bit 126 = first
+
+
+ UBI uses a 128 bit tweak
+
+
+ Whether 64 bit position exceeded
+
+
+ Advances the position in the tweak by the specified value.
+
+
+ The Unique Block Iteration chaining mode.
+
+
+ Buffer for the current block of message data
+
+
+ Offset into the current message block
+
+
+ Buffer for message words for feedback into encrypted block
+
+
+ Underlying Threefish tweakable block cipher
+
+
+ Size of the digest output, in bytes
+
+
+ The current chaining/state value
+
+
+ The initial state value
+
+
+ The (optional) key parameter
+
+
+ Parameters to apply prior to the message
+
+
+ Parameters to apply after the message, but prior to output
+
+
+ The current UBI operation
+
+
+ Buffer for single byte update method
+
+
+
+ Constructs a Skein digest with an internal state size and output size.
+
+ the internal state size in bits - one of or
+ .
+ the output/digest size to produce in bits, which must be an integral number of
+ bytes.
+
+
+
+ Creates a SkeinEngine as an exact copy of an existing instance.
+
+
+
+
+ Initialises the Skein engine with the provided parameters. See for
+ details on the parameterisation of the Skein hash function.
+
+ the parameters to apply to this engine, or null
to use no parameters.
+
+
+ Calculate the initial (pre message block) chaining state.
+
+
+
+ Reset the engine to the initial state (with the key and any pre-message parameters , ready to
+ accept message input.
+
+
+
+ implementation of Tiger based on:
+
+ http://www.cs.technion.ac.il/~biham/Reports/Tiger
+
+
+ Standard constructor
+
+
+ Copy constructor. This will copy the state of the provided
+ message digest.
+
+
+ reset the chaining variables
+
+
+ Implementation of WhirlpoolDigest, based on Java source published by Barreto
+ and Rijmen.
+
+
+
+ Copy constructor. This will copy the state of the provided message
+ digest.
+
+
+ Reset the chaining variables
+
+
+ initialise a Serpent cipher.
+
+ @param encrypting whether or not we are for encryption.
+ @param params the parameters required to set up the cipher.
+ @throws IllegalArgumentException if the params argument is
+ inappropriate.
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @return the number of bytes processed and produced.
+ @throws DataLengthException if there isn't enough data in in, or
+ space in out.
+ @throws IllegalStateException if the cipher isn't initialised.
+
+
+ InvSO - {13, 3,11, 0,10, 6, 5,12, 1,14, 4, 7,15, 9, 8, 2 } - 15 terms.
+
+
+ S1 - {15,12, 2, 7, 9, 0, 5,10, 1,11,14, 8, 6,13, 3, 4 } - 14 terms.
+
+
+ InvS1 - { 5, 8, 2,14,15, 6,12, 3,11, 4, 7, 9, 1,13,10, 0 } - 14 steps.
+
+
+ S2 - { 8, 6, 7, 9, 3,12,10,15,13, 1,14, 4, 0,11, 5, 2 } - 16 terms.
+
+
+ InvS2 - {12, 9,15, 4,11,14, 1, 2, 0, 3, 6,13, 5, 8,10, 7 } - 16 steps.
+
+
+ S3 - { 0,15,11, 8,12, 9, 6, 3,13, 1, 2, 4,10, 7, 5,14 } - 16 terms.
+
+
+ InvS3 - { 0, 9,10, 7,11,14, 6,13, 3, 5,12, 2, 4, 8,15, 1 } - 15 terms
+
+
+ S4 - { 1,15, 8, 3,12, 0,11, 6, 2, 5, 4,10, 9,14, 7,13 } - 15 terms.
+
+
+ InvS4 - { 5, 0, 8, 3,10, 9, 7,14, 2,12,11, 6, 4,15,13, 1 } - 15 terms.
+
+
+ S5 - {15, 5, 2,11, 4,10, 9,12, 0, 3,14, 8,13, 6, 7, 1 } - 16 terms.
+
+
+ InvS5 - { 8,15, 2, 9, 4, 1,13,14,11, 6, 5, 3, 7,12,10, 0 } - 16 terms.
+
+
+ S6 - { 7, 2,12, 5, 8, 4, 6,11,14, 9, 1,15,13, 3,10, 0 } - 15 terms.
+
+
+ InvS6 - {15,10, 1,13, 5, 3, 6, 0, 4, 9,14, 7, 2,12, 8,11 } - 15 terms.
+
+
+ S7 - { 1,13,15, 0,14, 8, 2,11, 7, 4,12,10, 9, 3, 5, 6 } - 16 terms.
+
+
+ InvS7 - { 3, 0, 6,13, 9,14,15, 8, 5,12,11, 7,10, 1, 4, 2 } - 17 terms.
+
+
+ Apply the linear transformation to the register set.
+
+
+ Apply the inverse of the linear transformation to the register set.
+
+
+ Tnepres is a 128-bit 32-round block cipher with variable key lengths,
+ including 128, 192 and 256 bit keys conjectured to be at least as
+ secure as three-key triple-DES.
+
+ Tnepres is based on Serpent which was designed by Ross Anderson, Eli Biham and Lars Knudsen as a
+ candidate algorithm for the NIST AES Quest. Unfortunately there was an endianness issue
+ with test vectors in the AES submission and the resulting confusion lead to the Tnepres cipher
+ as well, which is a byte swapped version of Serpent.
+
+
+ For full details see The Serpent home page
+
+
+
+ Expand a user-supplied key material into a session key.
+
+ @param key The user-key bytes (multiples of 4) to use.
+ @exception ArgumentException
+
+
+ Encrypt one block of plaintext.
+
+ @param input the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param output the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+
+
+ Decrypt one block of ciphertext.
+
+ @param input the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param output the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+
+
+ an implementation of the AES (Rijndael), from FIPS-197.
+
+ For further details see: http://csrc.nist.gov/encryption/aes/.
+
+ This implementation is based on optimizations from Dr. Brian Gladman's paper and C code at
+ http://fp.gladman.plus.com/cryptography_technology/rijndael/
+
+ There are three levels of tradeoff of speed vs memory
+ Because java has no preprocessor, they are written as three separate classes from which to choose
+
+ The fastest uses 8Kbytes of static tables to precompute round calculations, 4 256 word tables for encryption
+ and 4 for decryption.
+
+ The middle performance version uses only one 256 word table for each, for a total of 2Kbytes,
+ adding 12 rotate operations per round to compute the values contained in the other tables from
+ the contents of the first.
+
+ The slowest version uses no static tables at all and computes the values in each round.
+
+
+ This file contains the middle performance version with 2Kbytes of static tables for round precomputation.
+
+
+
+ Calculate the necessary round keys
+ The number of calculations depends on key size and block size
+ AES specified a fixed block size of 128 bits and key sizes 128/192/256 bits
+ This code is written assuming those are the only possible values
+
+
+ default constructor - 128 bit block size.
+
+
+ initialise an AES cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ an implementation of the AES (Rijndael)), from FIPS-197.
+
+ For further details see: http://csrc.nist.gov/encryption/aes/.
+
+ This implementation is based on optimizations from Dr. Brian Gladman's paper and C code at
+ http://fp.gladman.plus.com/cryptography_technology/rijndael/
+
+ There are three levels of tradeoff of speed vs memory
+ Because java has no preprocessor), they are written as three separate classes from which to choose
+
+ The fastest uses 8Kbytes of static tables to precompute round calculations), 4 256 word tables for encryption
+ and 4 for decryption.
+
+ The middle performance version uses only one 256 word table for each), for a total of 2Kbytes),
+ adding 12 rotate operations per round to compute the values contained in the other tables from
+ the contents of the first
+
+ The slowest version uses no static tables at all and computes the values in each round
+
+
+ This file contains the fast version with 8Kbytes of static tables for round precomputation
+
+
+
+ Calculate the necessary round keys
+ The number of calculations depends on key size and block size
+ AES specified a fixed block size of 128 bits and key sizes 128/192/256 bits
+ This code is written assuming those are the only possible values
+
+
+ default constructor - 128 bit block size.
+
+
+ initialise an AES cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ an implementation of the AES (Rijndael), from FIPS-197.
+
+ For further details see: http://csrc.nist.gov/encryption/aes/.
+
+ This implementation is based on optimizations from Dr. Brian Gladman's paper and C code at
+ http://fp.gladman.plus.com/cryptography_technology/rijndael/
+
+ There are three levels of tradeoff of speed vs memory
+ Because java has no preprocessor, they are written as three separate classes from which to choose
+
+ The fastest uses 8Kbytes of static tables to precompute round calculations, 4 256 word tables for encryption
+ and 4 for decryption.
+
+ The middle performance version uses only one 256 word table for each, for a total of 2Kbytes,
+ adding 12 rotate operations per round to compute the values contained in the other tables from
+ the contents of the first
+
+ The slowest version uses no static tables at all and computes the values
+ in each round.
+
+
+ This file contains the slowest performance version with no static tables
+ for round precomputation, but it has the smallest foot print.
+
+
+
+ Calculate the necessary round keys
+ The number of calculations depends on key size and block size
+ AES specified a fixed block size of 128 bits and key sizes 128/192/256 bits
+ This code is written assuming those are the only possible values
+
+
+ default constructor - 128 bit block size.
+
+
+ initialise an AES cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+
+ An implementation of the AES Key Wrapper from the NIST Key Wrap Specification.
+
+ For further details see: http://csrc.nist.gov/encryption/kms/key-wrap.pdf.
+
+
+
+ A class that provides Blowfish key encryption operations,
+ such as encoding data and generating keys.
+ All the algorithms herein are from Applied Cryptography
+ and implement a simplified cryptography interface.
+
+
+ initialise a Blowfish cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ apply the encryption cycle to each value pair in the table.
+
+
+ Encrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+ The input will be an exact multiple of our blocksize.
+
+
+ Decrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+ The input will be an exact multiple of our blocksize.
+
+
+ Camellia - based on RFC 3713.
+
+
+ Camellia - based on RFC 3713, smaller implementation, about half the size of CamelliaEngine.
+
+
+
+ An implementation of the Camellia key wrapper based on RFC 3657/RFC 3394.
+
+ For further details see: http://www.ietf.org/rfc/rfc3657.txt.
+
+
+
+ A class that provides CAST key encryption operations,
+ such as encoding data and generating keys.
+
+ All the algorithms herein are from the Internet RFC's
+
+ RFC2144 - Cast5 (64bit block, 40-128bit key)
+ RFC2612 - CAST6 (128bit block, 128-256bit key)
+
+ and implement a simplified cryptography interface.
+
+
+ initialise a CAST cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Encrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+
+ @param src The plaintext buffer
+ @param srcIndex An offset into src
+ @param dst The ciphertext buffer
+ @param dstIndex An offset into dst
+
+
+ Decrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+
+ @param src The plaintext buffer
+ @param srcIndex An offset into src
+ @param dst The ciphertext buffer
+ @param dstIndex An offset into dst
+
+
+ The first of the three processing functions for the
+ encryption and decryption.
+
+ @param D the input to be processed
+ @param Kmi the mask to be used from Km[n]
+ @param Kri the rotation value to be used
+
+
+
+ The second of the three processing functions for the
+ encryption and decryption.
+
+ @param D the input to be processed
+ @param Kmi the mask to be used from Km[n]
+ @param Kri the rotation value to be used
+
+
+
+ The third of the three processing functions for the
+ encryption and decryption.
+
+ @param D the input to be processed
+ @param Kmi the mask to be used from Km[n]
+ @param Kri the rotation value to be used
+
+
+
+ Does the 16 rounds to encrypt the block.
+
+ @param L0 the LH-32bits of the plaintext block
+ @param R0 the RH-32bits of the plaintext block
+
+
+ A class that provides CAST6 key encryption operations,
+ such as encoding data and generating keys.
+
+ All the algorithms herein are from the Internet RFC
+
+ RFC2612 - CAST6 (128bit block, 128-256bit key)
+
+ and implement a simplified cryptography interface.
+
+
+ Encrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+
+ @param src The plaintext buffer
+ @param srcIndex An offset into src
+ @param dst The ciphertext buffer
+ @param dstIndex An offset into dst
+
+
+ Decrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+
+ @param src The plaintext buffer
+ @param srcIndex An offset into src
+ @param dst The ciphertext buffer
+ @param dstIndex An offset into dst
+
+
+ Does the 12 quad rounds rounds to encrypt the block.
+
+ @param A the 00-31 bits of the plaintext block
+ @param B the 32-63 bits of the plaintext block
+ @param C the 64-95 bits of the plaintext block
+ @param D the 96-127 bits of the plaintext block
+ @param result the resulting ciphertext
+
+
+ Does the 12 quad rounds rounds to decrypt the block.
+
+ @param A the 00-31 bits of the ciphertext block
+ @param B the 32-63 bits of the ciphertext block
+ @param C the 64-95 bits of the ciphertext block
+ @param D the 96-127 bits of the ciphertext block
+ @param result the resulting plaintext
+
+
+
+ Implementation of Daniel J. Bernstein's ChaCha stream cipher.
+
+
+
+
+ Creates a 20 rounds ChaCha engine.
+
+
+
+
+ Creates a ChaCha engine with a specific number of rounds.
+
+ the number of rounds (must be an even number).
+
+
+
+ ChacCha function.
+
+ The number of ChaCha rounds to execute
+ The input words.
+ The ChaCha state to modify.
+
+
+ A class that provides a basic DESede (or Triple DES) engine.
+
+
+ initialise a DESede cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ * Wrap keys according to
+ *
+ * draft-ietf-smime-key-wrap-01.txt.
+ *
+ * Note:
+ *
+ * - this is based on a draft, and as such is subject to change - don't use this class for anything requiring long term storage.
+ * - if you are using this to wrap triple-des keys you need to set the
+ * parity bits on the key and, if it's a two-key triple-des key, pad it
+ * yourself.
+ *
+ *
+
+
+ Field engine
+
+
+ Field param
+
+
+ Field paramPlusIV
+
+
+ Field iv
+
+
+ Field forWrapping
+
+
+ Field IV2
+
+
+ Method init
+
+ @param forWrapping
+ @param param
+
+
+ Method GetAlgorithmName
+
+ @return
+
+
+ Method wrap
+
+ @param in
+ @param inOff
+ @param inLen
+ @return
+
+
+ Method unwrap
+
+ @param in
+ @param inOff
+ @param inLen
+ @return
+ @throws InvalidCipherTextException
+
+
+ Some key wrap algorithms make use of the Key Checksum defined
+ in CMS [CMS-Algorithms]. This is used to provide an integrity
+ check value for the key being wrapped. The algorithm is
+
+ - Compute the 20 octet SHA-1 hash on the key being wrapped.
+ - Use the first 8 octets of this hash as the checksum value.
+
+ @param key
+ @return
+ @throws Exception
+ @see http://www.w3.org/TR/xmlenc-core/#sec-CMSKeyChecksum
+
+
+ @param key
+ @param checksum
+ @return
+ @see http://www.w3.org/TR/xmlenc-core/#sec-CMSKeyChecksum
+
+
+ A class that provides a basic DES engine.
+
+
+ initialise a DES cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ what follows is mainly taken from "Applied Cryptography", by
+ Bruce Schneier, however it also bears great resemblance to Richard
+ Outerbridge's D3DES...
+
+
+ Generate an integer based working key based on our secret key
+ and what we processing we are planning to do.
+
+ Acknowledgements for this routine go to James Gillogly and Phil Karn.
+ (whoever, and wherever they are!).
+
+
+ the DES engine.
+
+
+ this does your basic ElGamal algorithm.
+
+
+ initialise the ElGamal engine.
+
+ @param forEncryption true if we are encrypting, false otherwise.
+ @param param the necessary ElGamal key parameters.
+
+
+ Return the maximum size for an input block to this engine.
+ For ElGamal this is always one byte less than the size of P on
+ encryption, and twice the length as the size of P on decryption.
+
+ @return maximum size for an input block.
+
+
+ Return the maximum size for an output block to this engine.
+ For ElGamal this is always one byte less than the size of P on
+ decryption, and twice the length as the size of P on encryption.
+
+ @return maximum size for an output block.
+
+
+ Process a single block using the basic ElGamal algorithm.
+
+ @param in the input array.
+ @param inOff the offset into the input buffer where the data starts.
+ @param length the length of the data to be processed.
+ @return the result of the ElGamal process.
+ @exception DataLengthException the input block is too large.
+
+
+ implementation of GOST 28147-89
+
+
+ standard constructor.
+
+
+ initialise an Gost28147 cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is inappropriate.
+
+
+ Return the S-Box associated with SBoxName
+ @param sBoxName name of the S-Box
+ @return byte array representing the S-Box
+
+
+ HC-128 is a software-efficient stream cipher created by Hongjun Wu. It
+ generates keystream from a 128-bit secret key and a 128-bit initialization
+ vector.
+
+ http://www.ecrypt.eu.org/stream/p3ciphers/hc/hc128_p3.pdf
+
+ It is a third phase candidate in the eStream contest, and is patent-free.
+ No attacks are known as of today (April 2007). See
+
+ http://www.ecrypt.eu.org/stream/hcp3.html
+
+
+
+ Initialise a HC-128 cipher.
+
+ @param forEncryption whether or not we are for encryption. Irrelevant, as
+ encryption and decryption are the same.
+ @param params the parameters required to set up the cipher.
+ @throws ArgumentException if the params argument is
+ inappropriate (ie. the key is not 128 bit long).
+
+
+ HC-256 is a software-efficient stream cipher created by Hongjun Wu. It
+ generates keystream from a 256-bit secret key and a 256-bit initialization
+ vector.
+
+ http://www.ecrypt.eu.org/stream/p3ciphers/hc/hc256_p3.pdf
+
+ Its brother, HC-128, is a third phase candidate in the eStream contest.
+ The algorithm is patent-free. No attacks are known as of today (April 2007).
+ See
+
+ http://www.ecrypt.eu.org/stream/hcp3.html
+
+
+
+ Initialise a HC-256 cipher.
+
+ @param forEncryption whether or not we are for encryption. Irrelevant, as
+ encryption and decryption are the same.
+ @param params the parameters required to set up the cipher.
+ @throws ArgumentException if the params argument is
+ inappropriate (ie. the key is not 256 bit long).
+
+
+ Implementation of Bob Jenkin's ISAAC (Indirection Shift Accumulate Add and Count).
+ see: http://www.burtleburtle.net/bob/rand/isaacafa.html
+
+
+ initialise an ISAAC cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param params the parameters required to set up the cipher.
+ @exception ArgumentException if the params argument is
+ inappropriate.
+
+
+ A class that provides a basic International Data Encryption Algorithm (IDEA) engine.
+
+ This implementation is based on the "HOWTO: INTERNATIONAL DATA ENCRYPTION ALGORITHM"
+ implementation summary by Fauzan Mirza (F.U.Mirza@sheffield.ac.uk). (baring 1 typo at the
+ end of the mulinv function!).
+
+
+ It can be found at ftp://ftp.funet.fi/pub/crypt/cryptography/symmetric/idea/
+
+
+ Note 1: This algorithm is patented in the USA, Japan, and Europe including
+ at least Austria, France, Germany, Italy, Netherlands, Spain, Sweden, Switzerland
+ and the United Kingdom. Non-commercial use is free, however any commercial
+ products are liable for royalties. Please see
+ www.mediacrypt.com for
+ further details. This announcement has been included at the request of
+ the patent holders.
+
+
+ Note 2: Due to the requests concerning the above, this algorithm is now only
+ included in the extended assembly. It is not included in the default distributions.
+
+
+
+ standard constructor.
+
+
+ initialise an IDEA cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return x = x * y where the multiplication is done modulo
+ 65537 (0x10001) (as defined in the IDEA specification) and
+ a zero input is taken to be 65536 (0x10000).
+
+ @param x the x value
+ @param y the y value
+ @return x = x * y
+
+
+ The following function is used to expand the user key to the encryption
+ subkey. The first 16 bytes are the user key, and the rest of the subkey
+ is calculated by rotating the previous 16 bytes by 25 bits to the left,
+ and so on until the subkey is completed.
+
+
+ This function computes multiplicative inverse using Euclid's Greatest
+ Common Divisor algorithm. Zero and one are self inverse.
+
+ i.e. x * MulInv(x) == 1 (modulo BASE)
+
+
+
+ Return the additive inverse of x.
+
+ i.e. x + AddInv(x) == 0
+
+
+
+ The function to invert the encryption subkey to the decryption subkey.
+ It also involves the multiplicative inverse and the additive inverse functions.
+
+
+ support class for constructing intergrated encryption ciphers
+ for doing basic message exchanges on top of key agreement ciphers
+
+
+ set up for use with stream mode, where the key derivation function
+ is used to provide a stream of bytes to xor with the message.
+
+ @param agree the key agreement used as the basis for the encryption
+ @param kdf the key derivation function used for byte generation
+ @param mac the message authentication code generator for the message
+
+
+ set up for use in conjunction with a block cipher to handle the
+ message.
+
+ @param agree the key agreement used as the basis for the encryption
+ @param kdf the key derivation function used for byte generation
+ @param mac the message authentication code generator for the message
+ @param cipher the cipher to used for encrypting the message
+
+
+ Initialise the encryptor.
+
+ @param forEncryption whether or not this is encryption/decryption.
+ @param privParam our private key parameters
+ @param pubParam the recipient's/sender's public key parameters
+ @param param encoding and derivation parameters.
+
+
+ NaccacheStern Engine. For details on this cipher, please see
+ http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf
+
+
+ Initializes this algorithm. Must be called before all other Functions.
+
+ @see org.bouncycastle.crypto.AsymmetricBlockCipher#init(bool,
+ org.bouncycastle.crypto.CipherParameters)
+
+
+ Returns the input block size of this algorithm.
+
+ @see org.bouncycastle.crypto.AsymmetricBlockCipher#GetInputBlockSize()
+
+
+ Returns the output block size of this algorithm.
+
+ @see org.bouncycastle.crypto.AsymmetricBlockCipher#GetOutputBlockSize()
+
+
+ Process a single Block using the Naccache-Stern algorithm.
+
+ @see org.bouncycastle.crypto.AsymmetricBlockCipher#ProcessBlock(byte[],
+ int, int)
+
+
+ Encrypts a BigInteger aka Plaintext with the public key.
+
+ @param plain
+ The BigInteger to encrypt
+ @return The byte[] representation of the encrypted BigInteger (i.e.
+ crypted.toByteArray())
+
+
+ Adds the contents of two encrypted blocks mod sigma
+
+ @param block1
+ the first encrypted block
+ @param block2
+ the second encrypted block
+ @return encrypt((block1 + block2) mod sigma)
+ @throws InvalidCipherTextException
+
+
+ Convenience Method for data exchange with the cipher.
+
+ Determines blocksize and splits data to blocksize.
+
+ @param data the data to be processed
+ @return the data after it went through the NaccacheSternEngine.
+ @throws InvalidCipherTextException
+
+
+ Computes the integer x that is expressed through the given primes and the
+ congruences with the chinese remainder theorem (CRT).
+
+ @param congruences
+ the congruences c_i
+ @param primes
+ the primes p_i
+ @return an integer x for that x % p_i == c_i
+
+
+ A Noekeon engine, using direct-key mode.
+
+
+ Create an instance of the Noekeon encryption algorithm
+ and set some defaults
+
+
+ initialise
+
+ @param forEncryption whether or not we are for encryption.
+ @param params the parameters required to set up the cipher.
+ @exception ArgumentException if the params argument is
+ inappropriate.
+
+
+ Re-key the cipher.
+
+ @param key the key to be used
+
+
+ The no-op engine that just copies bytes through, irrespective of whether encrypting and decrypting.
+ Provided for the sake of completeness.
+
+
+ an implementation of RC2 as described in RFC 2268
+ "A Description of the RC2(r) Encryption Algorithm" R. Rivest.
+
+
+ initialise a RC2 cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the result rotating the 16 bit number in x left by y
+
+
+ Wrap keys according to RFC 3217 - RC2 mechanism
+
+
+ Field engine
+
+
+ Field param
+
+
+ Field paramPlusIV
+
+
+ Field iv
+
+
+ Field forWrapping
+
+
+ Field IV2
+
+
+ Method init
+
+ @param forWrapping
+ @param param
+
+
+ Method GetAlgorithmName
+
+ @return
+
+
+ Method wrap
+
+ @param in
+ @param inOff
+ @param inLen
+ @return
+
+
+ Method unwrap
+
+ @param in
+ @param inOff
+ @param inLen
+ @return
+ @throws InvalidCipherTextException
+
+
+ Some key wrap algorithms make use of the Key Checksum defined
+ in CMS [CMS-Algorithms]. This is used to provide an integrity
+ check value for the key being wrapped. The algorithm is
+
+ - Compute the 20 octet SHA-1 hash on the key being wrapped.
+ - Use the first 8 octets of this hash as the checksum value.
+
+ @param key
+ @return
+ @throws Exception
+ @see http://www.w3.org/TR/xmlenc-core/#sec-CMSKeyChecksum
+
+
+ @param key
+ @param checksum
+ @return
+ @see http://www.w3.org/TR/xmlenc-core/#sec-CMSKeyChecksum
+
+
+ initialise a RC4 cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ The specification for RC5 came from the RC5 Encryption Algorithm
+ publication in RSA CryptoBytes, Spring of 1995.
+ http://www.rsasecurity.com/rsalabs/cryptobytes.
+
+ This implementation has a word size of 32 bits.
+
+
+ Create an instance of the RC5 encryption algorithm
+ and set some defaults
+
+
+ initialise a RC5-32 cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Re-key the cipher.
+
+ @param key the key to be used
+
+
+ Encrypt the given block starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+
+ @param in in byte buffer containing data to encrypt
+ @param inOff offset into src buffer
+ @param out out buffer where encrypted data is written
+ @param outOff offset into out buffer
+
+
+ Perform a left "spin" of the word. The rotation of the given
+ word x is rotated left by y bits.
+ Only the lg(32) low-order bits of y
+ are used to determine the rotation amount. Here it is
+ assumed that the wordsize used is a power of 2.
+
+ @param x word to rotate
+ @param y number of bits to rotate % 32
+
+
+ Perform a right "spin" of the word. The rotation of the given
+ word x is rotated left by y bits.
+ Only the lg(32) low-order bits of y
+ are used to determine the rotation amount. Here it is
+ assumed that the wordsize used is a power of 2.
+
+ @param x word to rotate
+ @param y number of bits to rotate % 32
+
+
+ The specification for RC5 came from the RC5 Encryption Algorithm
+ publication in RSA CryptoBytes, Spring of 1995.
+ http://www.rsasecurity.com/rsalabs/cryptobytes.
+
+ This implementation is set to work with a 64 bit word size.
+
+
+ Create an instance of the RC5 encryption algorithm
+ and set some defaults
+
+
+ initialise a RC5-64 cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Re-key the cipher.
+
+ @param key the key to be used
+
+
+ Encrypt the given block starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+
+ @param in in byte buffer containing data to encrypt
+ @param inOff offset into src buffer
+ @param out out buffer where encrypted data is written
+ @param outOff offset into out buffer
+
+
+ Perform a left "spin" of the word. The rotation of the given
+ word x is rotated left by y bits.
+ Only the lg(wordSize) low-order bits of y
+ are used to determine the rotation amount. Here it is
+ assumed that the wordsize used is a power of 2.
+
+ @param x word to rotate
+ @param y number of bits to rotate % wordSize
+
+
+ Perform a right "spin" of the word. The rotation of the given
+ word x is rotated left by y bits.
+ Only the lg(wordSize) low-order bits of y
+ are used to determine the rotation amount. Here it is
+ assumed that the wordsize used is a power of 2.
+
+ @param x word to rotate
+ @param y number of bits to rotate % wordSize
+
+
+ An RC6 engine.
+
+
+ Create an instance of the RC6 encryption algorithm
+ and set some defaults
+
+
+ initialise a RC5-32 cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Re-key the cipher.
+
+ @param inKey the key to be used
+
+
+ Perform a left "spin" of the word. The rotation of the given
+ word x is rotated left by y bits.
+ Only the lg(wordSize) low-order bits of y
+ are used to determine the rotation amount. Here it is
+ assumed that the wordsize used is a power of 2.
+
+ @param x word to rotate
+ @param y number of bits to rotate % wordSize
+
+
+ Perform a right "spin" of the word. The rotation of the given
+ word x is rotated left by y bits.
+ Only the lg(wordSize) low-order bits of y
+ are used to determine the rotation amount. Here it is
+ assumed that the wordsize used is a power of 2.
+
+ @param x word to rotate
+ @param y number of bits to rotate % wordSize
+
+
+ an implementation of the RFC 3211 Key Wrap
+ Specification.
+
+
+
+ An implementation of the AES Key Wrapper from the NIST Key Wrap
+ Specification as described in RFC 3394.
+
+ For further details see: http://www.ietf.org/rfc/rfc3394.txt
+ and http://csrc.nist.gov/encryption/kms/key-wrap.pdf.
+
+
+
+ this does your basic RSA algorithm with blinding
+
+
+ initialise the RSA engine.
+
+ @param forEncryption true if we are encrypting, false otherwise.
+ @param param the necessary RSA key parameters.
+
+
+ Return the maximum size for an input block to this engine.
+ For RSA this is always one byte less than the key size on
+ encryption, and the same length as the key size on decryption.
+
+ @return maximum size for an input block.
+
+
+ Return the maximum size for an output block to this engine.
+ For RSA this is always one byte less than the key size on
+ decryption, and the same length as the key size on encryption.
+
+ @return maximum size for an output block.
+
+
+ Process a single block using the basic RSA algorithm.
+
+ @param inBuf the input array.
+ @param inOff the offset into the input buffer where the data starts.
+ @param inLen the length of the data to be processed.
+ @return the result of the RSA process.
+ @exception DataLengthException the input block is too large.
+
+
+ This does your basic RSA Chaum's blinding and unblinding as outlined in
+ "Handbook of Applied Cryptography", page 475. You need to use this if you are
+ trying to get another party to generate signatures without them being aware
+ of the message they are signing.
+
+
+ Initialise the blinding engine.
+
+ @param forEncryption true if we are encrypting (blinding), false otherwise.
+ @param param the necessary RSA key parameters.
+
+
+ Return the maximum size for an input block to this engine.
+ For RSA this is always one byte less than the key size on
+ encryption, and the same length as the key size on decryption.
+
+ @return maximum size for an input block.
+
+
+ Return the maximum size for an output block to this engine.
+ For RSA this is always one byte less than the key size on
+ decryption, and the same length as the key size on encryption.
+
+ @return maximum size for an output block.
+
+
+ Process a single block using the RSA blinding algorithm.
+
+ @param in the input array.
+ @param inOff the offset into the input buffer where the data starts.
+ @param inLen the length of the data to be processed.
+ @return the result of the RSA process.
+ @throws DataLengthException the input block is too large.
+
+
+ this does your basic RSA algorithm.
+
+
+ initialise the RSA engine.
+
+ @param forEncryption true if we are encrypting, false otherwise.
+ @param param the necessary RSA key parameters.
+
+
+ Return the maximum size for an input block to this engine.
+ For RSA this is always one byte less than the key size on
+ encryption, and the same length as the key size on decryption.
+
+ @return maximum size for an input block.
+
+
+ Return the maximum size for an output block to this engine.
+ For RSA this is always one byte less than the key size on
+ decryption, and the same length as the key size on encryption.
+
+ @return maximum size for an output block.
+
+
+ an implementation of Rijndael, based on the documentation and reference implementation
+ by Paulo Barreto, Vincent Rijmen, for v2.0 August '99.
+
+ Note: this implementation is based on information prior to readonly NIST publication.
+
+
+
+ multiply two elements of GF(2^m)
+ needed for MixColumn and InvMixColumn
+
+
+ xor corresponding text input and round key input bytes
+
+
+ Row 0 remains unchanged
+ The other three rows are shifted a variable amount
+
+
+ Replace every byte of the input by the byte at that place
+ in the nonlinear S-box
+
+
+ Mix the bytes of every column in a linear way
+
+
+ Mix the bytes of every column in a linear way
+ This is the opposite operation of Mixcolumn
+
+
+ Calculate the necessary round keys
+ The number of calculations depends on keyBits and blockBits
+
+
+ default constructor - 128 bit block size.
+
+
+ basic constructor - set the cipher up for a given blocksize
+
+ @param blocksize the blocksize in bits, must be 128, 192, or 256.
+
+
+ initialise a Rijndael cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ this does your basic RSA algorithm.
+
+
+ initialise the RSA engine.
+
+ @param forEncryption true if we are encrypting, false otherwise.
+ @param param the necessary RSA key parameters.
+
+
+ Return the maximum size for an input block to this engine.
+ For RSA this is always one byte less than the key size on
+ encryption, and the same length as the key size on decryption.
+
+ @return maximum size for an input block.
+
+
+ Return the maximum size for an output block to this engine.
+ For RSA this is always one byte less than the key size on
+ decryption, and the same length as the key size on encryption.
+
+ @return maximum size for an output block.
+
+
+ Process a single block using the basic RSA algorithm.
+
+ @param inBuf the input array.
+ @param inOff the offset into the input buffer where the data starts.
+ @param inLen the length of the data to be processed.
+ @return the result of the RSA process.
+ @exception DataLengthException the input block is too large.
+
+
+ Implementation of the SEED algorithm as described in RFC 4009
+
+
+
+ An implementation of the SEED key wrapper based on RFC 4010/RFC 3394.
+
+ For further details see: http://www.ietf.org/rfc/rfc4010.txt.
+
+
+
+
+ Implementation of Daniel J. Bernstein's Salsa20 stream cipher, Snuffle 2005
+
+
+
+ Constants
+
+
+
+ Creates a 20 round Salsa20 engine.
+
+
+
+
+ Creates a Salsa20 engine with a specific number of rounds.
+
+ the number of rounds (must be an even number).
+
+
+ Rotate left
+
+ @param x value to rotate
+ @param y amount to rotate x
+
+ @return rotated x
+
+
+ * Serpent is a 128-bit 32-round block cipher with variable key lengths,
+ * including 128, 192 and 256 bit keys conjectured to be at least as
+ * secure as three-key triple-DES.
+ *
+ * Serpent was designed by Ross Anderson, Eli Biham and Lars Knudsen as a
+ * candidate algorithm for the NIST AES Quest.
+ *
+ *
+ * For full details see The Serpent home page
+ *
+
+
+ Expand a user-supplied key material into a session key.
+
+ @param key The user-key bytes (multiples of 4) to use.
+ @exception ArgumentException
+
+
+ Encrypt one block of plaintext.
+
+ @param input the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param output the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+
+
+ Decrypt one block of ciphertext.
+
+ @param input the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param output the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+
+
+ a class that provides a basic SKIPJACK engine.
+
+
+ initialise a SKIPJACK cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ The G permutation
+
+
+ the inverse of the G permutation.
+
+
+ An TEA engine.
+
+
+ Create an instance of the TEA encryption algorithm
+ and set some defaults
+
+
+ initialise
+
+ @param forEncryption whether or not we are for encryption.
+ @param params the parameters required to set up the cipher.
+ @exception ArgumentException if the params argument is
+ inappropriate.
+
+
+ Re-key the cipher.
+
+ @param key the key to be used
+
+
+
+ Implementation of the Threefish tweakable large block cipher in 256, 512 and 1024 bit block
+ sizes.
+
+
+ This is the 1.3 version of Threefish defined in the Skein hash function submission to the NIST
+ SHA-3 competition in October 2010.
+
+ Threefish was designed by Niels Ferguson - Stefan Lucks - Bruce Schneier - Doug Whiting - Mihir
+ Bellare - Tadayoshi Kohno - Jon Callas - Jesse Walker.
+
+ This implementation inlines all round functions, unrolls 8 rounds, and uses 1.2k of static tables
+ to speed up key schedule injection.
+ 2 x block size state is retained by each cipher instance.
+
+
+
+
+ 256 bit block size - Threefish-256
+
+
+
+
+ 512 bit block size - Threefish-512
+
+
+
+
+ 1024 bit block size - Threefish-1024
+
+
+
+ Size of the tweak in bytes (always 128 bit/16 bytes)
+
+
+ Rounds in Threefish-256
+
+
+ Rounds in Threefish-512
+
+
+ Rounds in Threefish-1024
+
+
+ Max rounds of any of the variants
+
+
+ Key schedule parity constant
+
+
+ Block size in bytes
+
+
+ Block size in 64 bit words
+
+
+ Buffer for byte oriented processBytes to call internal word API
+
+
+ Tweak bytes (2 byte t1,t2, calculated t3 and repeat of t1,t2 for modulo free lookup
+
+
+ Key schedule words
+
+
+ The internal cipher implementation (varies by blocksize)
+
+
+
+ Constructs a new Threefish cipher, with a specified block size.
+
+ the block size in bits, one of , ,
+ .
+
+
+
+ Initialise the engine.
+
+ Initialise for encryption if true, for decryption if false.
+ an instance of or (to
+ use a 0 tweak)
+
+
+
+ Initialise the engine, specifying the key and tweak directly.
+
+ the cipher mode.
+ the words of the key, or null
to use the current key.
+ the 2 word (128 bit) tweak, or null
to use the current tweak.
+
+
+
+ Process a block of data represented as 64 bit words.
+
+ the number of 8 byte words processed (which will be the same as the block size).
+ a block sized buffer of words to process.
+ a block sized buffer of words to receive the output of the operation.
+ if either the input or output is not block sized
+ if this engine is not initialised
+
+
+
+ Read a single 64 bit word from input in LSB first order.
+
+
+
+
+ Write a 64 bit word to output in LSB first order.
+
+
+
+ Rotate left + xor part of the mix operation.
+
+
+ Rotate xor + rotate right part of the unmix operation.
+
+
+ The extended + repeated tweak words
+
+
+ The extended + repeated key words
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ Mix rotation constants defined in Skein 1.3 specification
+
+
+ A class that provides Twofish encryption operations.
+
+ This Java implementation is based on the Java reference
+ implementation provided by Bruce Schneier and developed
+ by Raif S. Naffah.
+
+
+ Define the fixed p0/p1 permutations used in keyed S-box lookup.
+ By changing the following constant definitions, the S-boxes will
+ automatically Get changed in the Twofish engine.
+
+
+ gSubKeys[] and gSBox[] are eventually used in the
+ encryption and decryption methods.
+
+
+ initialise a Twofish cipher.
+
+ @param forEncryption whether or not we are for encryption.
+ @param parameters the parameters required to set up the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Encrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+ The input will be an exact multiple of our blocksize.
+
+ encryptBlock uses the pre-calculated gSBox[] and subKey[]
+ arrays.
+
+
+ Decrypt the given input starting at the given offset and place
+ the result in the provided buffer starting at the given offset.
+ The input will be an exact multiple of our blocksize.
+
+
+ Use (12, 8) Reed-Solomon code over GF(256) to produce
+ a key S-box 32-bit entity from 2 key material 32-bit
+ entities.
+
+ @param k0 first 32-bit entity
+ @param k1 second 32-bit entity
+ @return Remainder polynomial Generated using RS code
+
+
+ * Reed-Solomon code parameters: (12,8) reversible code:
+ *
+ *
+ * G(x) = x^4 + (a+1/a)x^3 + ax^2 + (a+1/a)x + 1
+ *
+ * where a = primitive root of field generator 0x14D
+ *
+
+
+ initialise a VMPC cipher.
+
+ @param forEncryption
+ whether or not we are for encryption.
+ @param params
+ the parameters required to set up the cipher.
+ @exception ArgumentException
+ if the params argument is inappropriate.
+
+
+
+ Implementation of Daniel J. Bernstein's XSalsa20 stream cipher - Salsa20 with an extended nonce.
+
+
+ XSalsa20 requires a 256 bit key, and a 192 bit nonce.
+
+
+
+
+ XSalsa20 key generation: process 256 bit input key and 128 bits of the input nonce
+ using a core Salsa20 function without input addition to produce 256 bit working key
+ and use that with the remaining 64 bits of nonce to initialize a standard Salsa20 engine state.
+
+
+
+ An XTEA engine.
+
+
+ Create an instance of the TEA encryption algorithm
+ and set some defaults
+
+
+ initialise
+
+ @param forEncryption whether or not we are for encryption.
+ @param params the parameters required to set up the cipher.
+ @exception ArgumentException if the params argument is
+ inappropriate.
+
+
+ Re-key the cipher.
+
+ @param key the key to be used
+
+
+ Base interface for a public/private key block cipher.
+
+
+ The name of the algorithm this cipher implements.
+
+
+ Initialise the cipher.
+ Initialise for encryption if true, for decryption if false.
+ The key or other data required by the cipher.
+
+
+ The maximum size, in bytes, an input block may be.
+
+
+ The maximum size, in bytes, an output block will be.
+
+
+ Process a block.
+ The input buffer.
+ The offset into inBuf that the input block begins.
+ The length of the input block.
+ Input decrypts improperly.
+ Input is too large for the cipher.
+
+
+ interface that a public/private key pair generator should conform to.
+
+
+ intialise the key pair generator.
+
+ @param the parameters the key pair is to be initialised with.
+
+
+ return an AsymmetricCipherKeyPair containing the Generated keys.
+
+ @return an AsymmetricCipherKeyPair containing the Generated keys.
+
+
+ The basic interface that basic Diffie-Hellman implementations
+ conforms to.
+
+
+ initialise the agreement engine.
+
+
+ return the field size for the agreement algorithm in bytes.
+
+
+ given a public key from a given party calculate the next
+ message in the agreement sequence.
+
+
+ Base interface for a symmetric key block cipher.
+
+
+ The name of the algorithm this cipher implements.
+
+
+ Initialise the cipher.
+ Initialise for encryption if true, for decryption if false.
+ The key or other data required by the cipher.
+
+
+ The block size for this cipher, in bytes.
+
+
+ Indicates whether this cipher can handle partial blocks.
+
+
+ Process a block.
+ The input buffer.
+ The offset into inBuf that the input block begins.
+ The output buffer.
+ The offset into outBuf to write the output block.
+ If input block is wrong size, or outBuf too small.
+ The number of bytes processed and produced.
+
+
+
+ Reset the cipher to the same state as it was after the last init (if there was one).
+
+
+
+
+ Operators that reduce their input to a single block return an object
+ of this type.
+
+
+
+
+ Return the final result of the operation.
+
+ A block of bytes, representing the result of an operation.
+
+
+
+ Store the final result of the operation by copying it into the destination array.
+
+ The number of bytes copied into destination.
+ The byte array to copy the result into.
+ The offset into destination to start copying the result at.
+
+
+ Block cipher engines are expected to conform to this interface.
+
+
+ The name of the algorithm this cipher implements.
+
+
+ Initialise the cipher.
+ If true the cipher is initialised for encryption,
+ if false for decryption.
+ The key and other data required by the cipher.
+
+
+
+ Reset the cipher. After resetting the cipher is in the same state
+ as it was after the last init (if there was one).
+
+
+
+ all parameter classes implement this.
+
+
+ interface for classes implementing the Digital Signature Algorithm
+
+
+ initialise the signer for signature generation or signature
+ verification.
+
+ @param forSigning true if we are generating a signature, false
+ otherwise.
+ @param param key parameters for signature generation.
+
+
+ sign the passed in message (usually the output of a hash function).
+
+ @param message the message to be signed.
+ @return two big integers representing the r and s values respectively.
+
+
+ verify the message message against the signature values r and s.
+
+ @param message the message that was supposed to have been signed.
+ @param r the r signature value.
+ @param s the s signature value.
+
+
+ base interface for general purpose byte derivation functions.
+
+
+ return the message digest used as the basis for the function
+
+
+ Parameters for key/byte stream derivation classes
+
+
+ interface that a message digest conforms to.
+
+
+ return the algorithm name
+
+ @return the algorithm name
+
+
+ return the size, in bytes, of the digest produced by this message digest.
+
+ @return the size, in bytes, of the digest produced by this message digest.
+
+
+ return the size, in bytes, of the internal buffer used by this digest.
+
+ @return the size, in bytes, of the internal buffer used by this digest.
+
+
+ update the message digest with a single byte.
+
+ @param inByte the input byte to be entered.
+
+
+ update the message digest with a block of bytes.
+
+ @param input the byte array containing the data.
+ @param inOff the offset into the byte array where the data starts.
+ @param len the length of the data.
+
+
+ Close the digest, producing the final digest value. The doFinal
+ call leaves the digest reset.
+
+ @param output the array the digest is to be copied into.
+ @param outOff the offset into the out array the digest is to start at.
+
+
+ reset the digest back to it's initial state.
+
+
+
+ Base interface describing an entropy source for a DRBG.
+
+
+
+
+ Return whether or not this entropy source is regarded as prediction resistant.
+
+ true if this instance is prediction resistant; otherwise, false.
+
+
+
+ Return a byte array of entropy.
+
+ The entropy bytes.
+
+
+
+ Return the number of bits of entropy this source can produce.
+
+ The size, in bits, of the return value of getEntropy.
+
+
+
+ Base interface describing a provider of entropy sources.
+
+
+
+
+ Return an entropy source providing a block of entropy.
+
+ The size of the block of entropy required.
+ An entropy source providing bitsRequired blocks of entropy.
+
+
+ The base interface for implementations of message authentication codes (MACs).
+
+
+ Initialise the MAC.
+
+ @param param the key and other data required by the MAC.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Return the name of the algorithm the MAC implements.
+
+ @return the name of the algorithm the MAC implements.
+
+
+ Return the block size for this MAC (in bytes).
+
+ @return the block size for this MAC in bytes.
+
+
+ add a single byte to the mac for processing.
+
+ @param in the byte to be processed.
+ @exception InvalidOperationException if the MAC is not initialised.
+
+
+ @param in the array containing the input.
+ @param inOff the index in the array the data begins at.
+ @param len the length of the input starting at inOff.
+ @exception InvalidOperationException if the MAC is not initialised.
+ @exception DataLengthException if there isn't enough data in in.
+
+
+ Compute the final stage of the MAC writing the output to the out
+ parameter.
+
+ doFinal leaves the MAC in the same state it was after the last init.
+
+ @param out the array the MAC is to be output to.
+ @param outOff the offset into the out buffer the output is to start at.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the MAC is not initialised.
+
+
+ Reset the MAC. At the end of resetting the MAC should be in the
+ in the same state it was after the last init (if there was one).
+
+
+
+ Base interface for operators that serve as stream-based signature calculators.
+
+
+
+ The algorithm details object for this calculator.
+
+
+
+ Create a stream calculator for this signature calculator. The stream
+ calculator is used for the actual operation of entering the data to be signed
+ and producing the signature block.
+
+ A calculator producing an IBlockResult with a signature in it.
+
+
+
+ Base interface for cryptographic operations such as Hashes, MACs, and Signatures which reduce a stream of data
+ to a single value.
+
+
+
+ Return a "sink" stream which only exists to update the implementing object.
+ A stream to write to in order to update the implementing object.
+
+
+
+ Return the result of processing the stream. This value is only available once the stream
+ has been closed.
+
+ The result of processing the stream.
+
+
+ Return the name of the algorithm the signer implements.
+
+ @return the name of the algorithm the signer implements.
+
+
+ Initialise the signer for signing or verification.
+
+ @param forSigning true if for signing, false otherwise
+ @param param necessary parameters.
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ Generate a signature for the message we've been loaded with using
+ the key we were initialised with.
+
+
+ return true if the internal state represents the signature described
+ in the passed in array.
+
+
+ reset the internal state
+
+
+ Signer with message recovery.
+
+
+ Returns true if the signer has recovered the full message as
+ part of signature verification.
+
+ @return true if full message recovered.
+
+
+ Returns a reference to what message was recovered (if any).
+
+ @return full/partial message, null if nothing.
+
+
+ Perform an update with the recovered message before adding any other data. This must
+ be the first update method called, and calling it will result in the signer assuming
+ that further calls to update will include message content past what is recoverable.
+
+ @param signature the signature that we are in the process of verifying.
+ @throws IllegalStateException
+
+
+ The interface stream ciphers conform to.
+
+
+ The name of the algorithm this cipher implements.
+
+
+ Initialise the cipher.
+ If true the cipher is initialised for encryption,
+ if false for decryption.
+ The key and other data required by the cipher.
+
+ If the parameters argument is inappropriate.
+
+
+
+ encrypt/decrypt a single byte returning the result.
+ the byte to be processed.
+ the result of processing the input byte.
+
+
+
+ Process a block of bytes from input putting the result into output.
+
+ The input byte array.
+
+ The offset into input where the data to be processed starts.
+
+ The number of bytes to be processed.
+ The output buffer the processed bytes go into.
+
+ The offset into output the processed data starts at.
+
+ If the output buffer is too small.
+
+
+
+ Reset the cipher to the same state as it was after the last init (if there was one).
+
+
+
+
+ Operators that reduce their input to the validation of a signature produce this type.
+
+
+
+
+ Return true if the passed in data matches what is expected by the verification result.
+
+ The bytes representing the signature.
+ true if the signature verifies, false otherwise.
+
+
+
+ Return true if the length bytes from off in the source array match the signature
+ expected by the verification result.
+
+ Byte array containing the signature.
+ The offset into the source array where the signature starts.
+ The number of bytes in source making up the signature.
+ true if the signature verifies, false otherwise.
+
+
+
+ Base interface for operators that serve as stream-based signature verifiers.
+
+
+
+ The algorithm details object for this verifier.
+
+
+
+ Create a stream calculator for this verifier. The stream
+ calculator is used for the actual operation of entering the data to be verified
+ and producing a result which can be used to verify the original signature.
+
+ A calculator producing an IVerifier which can verify the signature.
+
+
+
+ Base interface for a provider to support the dynamic creation of signature verifiers.
+
+
+
+
+ Return a signature verfier for signature algorithm described in the passed in algorithm details object.
+
+ The details of the signature algorithm verification is required for.
+ A new signature verifier.
+
+
+ The name of the algorithm this cipher implements.
+
+
+
+ With FIPS PUB 202 a new kind of message digest was announced which supported extendable output, or variable digest sizes.
+ This interface provides the extra method required to support variable output on a digest implementation.
+
+
+
+ Output the results of the final calculation for this digest to outLen number of bytes.
+
+ @param out output array to write the output bytes to.
+ @param outOff offset to start writing the bytes at.
+ @param outLen the number of output bytes requested.
+ @return the number of bytes written
+
+
+ this exception is thrown whenever we find something we don't expect in a
+ message.
+
+
+ base constructor.
+
+
+ create a InvalidCipherTextException with the given message.
+
+ @param message the message to be carried with the exception.
+
+
+ The base class for parameters to key generators.
+
+
+ initialise the generator with a source of randomness
+ and a strength (in bits).
+
+ @param random the random byte source.
+ @param strength the size, in bits, of the keys we want to produce.
+
+
+ return the random source associated with this
+ generator.
+
+ @return the generators random source.
+
+
+ return the bit strength for keys produced by this generator,
+
+ @return the strength of the keys this generator produces (in bits).
+
+
+
+ This exception is thrown whenever a cipher requires a change of key, iv
+ or similar after x amount of bytes enciphered
+
+
+
+ super class for all Password Based Encyrption (Pbe) parameter generator classes.
+
+
+ base constructor.
+
+
+ initialise the Pbe generator.
+
+ @param password the password converted into bytes (see below).
+ @param salt the salt to be mixed with the password.
+ @param iterationCount the number of iterations the "mixing" function
+ is to be applied for.
+
+
+ return the password byte array.
+
+ @return the password byte array.
+
+
+ return the salt byte array.
+
+ @return the salt byte array.
+
+
+ return the iteration count.
+
+ @return the iteration count.
+
+
+ Generate derived parameters for a key of length keySize.
+
+ @param keySize the length, in bits, of the key required.
+ @return a parameters object representing a key.
+
+
+ Generate derived parameters for a key of length keySize, and
+ an initialisation vector (IV) of length ivSize.
+
+ @param keySize the length, in bits, of the key required.
+ @param ivSize the length, in bits, of the iv required.
+ @return a parameters object representing a key and an IV.
+
+
+ Generate derived parameters for a key of length keySize, specifically
+ for use with a MAC.
+
+ @param keySize the length, in bits, of the key required.
+ @return a parameters object representing a key.
+
+
+ converts a password to a byte array according to the scheme in
+ Pkcs5 (ascii, no padding)
+
+ @param password a character array representing the password.
+ @return a byte array representing the password.
+
+
+ converts a password to a byte array according to the scheme in
+ PKCS5 (UTF-8, no padding)
+
+ @param password a character array representing the password.
+ @return a byte array representing the password.
+
+
+ converts a password to a byte array according to the scheme in
+ Pkcs12 (unicode, big endian, 2 zero pad bytes at the end).
+
+ @param password a character array representing the password.
+ @return a byte array representing the password.
+
+
+ An EntropySourceProvider where entropy generation is based on a SecureRandom output using SecureRandom.generateSeed().
+
+
+ Create a entropy source provider based on the passed in SecureRandom.
+
+ @param secureRandom the SecureRandom to base EntropySource construction on.
+ @param isPredictionResistant boolean indicating if the SecureRandom is based on prediction resistant entropy or not (true if it is).
+
+
+ Return an entropy source that will create bitsRequired bits of entropy on
+ each invocation of getEntropy().
+
+ @param bitsRequired size (in bits) of entropy to be created by the provided source.
+ @return an EntropySource that generates bitsRequired bits of entropy on each call to its getEntropy() method.
+
+
+ A SP800-90A CTR DRBG.
+
+
+ Construct a SP800-90A CTR DRBG.
+
+ Minimum entropy requirement is the security strength requested.
+
+ @param engine underlying block cipher to use to support DRBG
+ @param keySizeInBits size of the key to use with the block cipher.
+ @param securityStrength security strength required (in bits)
+ @param entropySource source of entropy to use for seeding/reseeding.
+ @param personalizationString personalization string to distinguish this DRBG (may be null).
+ @param nonce nonce to further distinguish this DRBG (may be null).
+
+
+ Return the block size (in bits) of the DRBG.
+
+ @return the number of bits produced on each internal round of the DRBG.
+
+
+ Populate a passed in array with random data.
+
+ @param output output array for generated bits.
+ @param additionalInput additional input to be added to the DRBG in this step.
+ @param predictionResistant true if a reseed should be forced, false otherwise.
+
+ @return number of bits generated, -1 if a reseed required.
+
+
+ Reseed the DRBG.
+
+ @param additionalInput additional input to be added to the DRBG in this step.
+
+
+ Pad out a key for TDEA, setting odd parity for each byte.
+
+ @param keyMaster
+ @param keyOff
+ @param tmp
+ @param tmpOff
+
+
+ Used by both Dual EC and Hash.
+
+
+ A SP800-90A Hash DRBG.
+
+
+ Construct a SP800-90A Hash DRBG.
+
+ Minimum entropy requirement is the security strength requested.
+
+ @param digest source digest to use for DRB stream.
+ @param securityStrength security strength required (in bits)
+ @param entropySource source of entropy to use for seeding/reseeding.
+ @param personalizationString personalization string to distinguish this DRBG (may be null).
+ @param nonce nonce to further distinguish this DRBG (may be null).
+
+
+ Return the block size (in bits) of the DRBG.
+
+ @return the number of bits produced on each internal round of the DRBG.
+
+
+ Populate a passed in array with random data.
+
+ @param output output array for generated bits.
+ @param additionalInput additional input to be added to the DRBG in this step.
+ @param predictionResistant true if a reseed should be forced, false otherwise.
+
+ @return number of bits generated, -1 if a reseed required.
+
+
+ Reseed the DRBG.
+
+ @param additionalInput additional input to be added to the DRBG in this step.
+
+
+ A SP800-90A HMAC DRBG.
+
+
+ Construct a SP800-90A Hash DRBG.
+
+ Minimum entropy requirement is the security strength requested.
+
+ @param hMac Hash MAC to base the DRBG on.
+ @param securityStrength security strength required (in bits)
+ @param entropySource source of entropy to use for seeding/reseeding.
+ @param personalizationString personalization string to distinguish this DRBG (may be null).
+ @param nonce nonce to further distinguish this DRBG (may be null).
+
+
+ Return the block size (in bits) of the DRBG.
+
+ @return the number of bits produced on each round of the DRBG.
+
+
+ Populate a passed in array with random data.
+
+ @param output output array for generated bits.
+ @param additionalInput additional input to be added to the DRBG in this step.
+ @param predictionResistant true if a reseed should be forced, false otherwise.
+
+ @return number of bits generated, -1 if a reseed required.
+
+
+ Reseed the DRBG.
+
+ @param additionalInput additional input to be added to the DRBG in this step.
+
+
+ Interface to SP800-90A deterministic random bit generators.
+
+
+ Return the block size of the DRBG.
+
+ @return the block size (in bits) produced by each round of the DRBG.
+
+
+ Populate a passed in array with random data.
+
+ @param output output array for generated bits.
+ @param additionalInput additional input to be added to the DRBG in this step.
+ @param predictionResistant true if a reseed should be forced, false otherwise.
+
+ @return number of bits generated, -1 if a reseed required.
+
+
+ Reseed the DRBG.
+
+ @param additionalInput additional input to be added to the DRBG in this step.
+
+
+ Generate numBytes worth of entropy from the passed in entropy source.
+
+ @param entropySource the entropy source to request the data from.
+ @param numBytes the number of bytes of entropy requested.
+ @return a byte array populated with the random data.
+
+
+ Builder class for making SecureRandom objects based on SP 800-90A Deterministic Random Bit Generators (DRBG).
+
+
+ Basic constructor, creates a builder using an EntropySourceProvider based on the default SecureRandom with
+ predictionResistant set to false.
+
+ Any SecureRandom created from a builder constructed like this will make use of input passed to SecureRandom.setSeed() if
+ the default SecureRandom does for its generateSeed() call.
+
+
+
+ Construct a builder with an EntropySourceProvider based on the passed in SecureRandom and the passed in value
+ for prediction resistance.
+
+ Any SecureRandom created from a builder constructed like this will make use of input passed to SecureRandom.setSeed() if
+ the passed in SecureRandom does for its generateSeed() call.
+
+ @param entropySource
+ @param predictionResistant
+
+
+ Create a builder which makes creates the SecureRandom objects from a specified entropy source provider.
+
+ Note: If this constructor is used any calls to setSeed() in the resulting SecureRandom will be ignored.
+
+ @param entropySourceProvider a provider of EntropySource objects.
+
+
+ Set the personalization string for DRBG SecureRandoms created by this builder
+ @param personalizationString the personalisation string for the underlying DRBG.
+ @return the current builder.
+
+
+ Set the security strength required for DRBGs used in building SecureRandom objects.
+
+ @param securityStrength the security strength (in bits)
+ @return the current builder.
+
+
+ Set the amount of entropy bits required for seeding and reseeding DRBGs used in building SecureRandom objects.
+
+ @param entropyBitsRequired the number of bits of entropy to be requested from the entropy source on each seed/reseed.
+ @return the current builder.
+
+
+ Build a SecureRandom based on a SP 800-90A Hash DRBG.
+
+ @param digest digest algorithm to use in the DRBG underneath the SecureRandom.
+ @param nonce nonce value to use in DRBG construction.
+ @param predictionResistant specify whether the underlying DRBG in the resulting SecureRandom should reseed on each request for bytes.
+ @return a SecureRandom supported by a Hash DRBG.
+
+
+ Build a SecureRandom based on a SP 800-90A CTR DRBG.
+
+ @param cipher the block cipher to base the DRBG on.
+ @param keySizeInBits key size in bits to be used with the block cipher.
+ @param nonce nonce value to use in DRBG construction.
+ @param predictionResistant specify whether the underlying DRBG in the resulting SecureRandom should reseed on each request for bytes.
+ @return a SecureRandom supported by a CTR DRBG.
+
+
+ Build a SecureRandom based on a SP 800-90A HMAC DRBG.
+
+ @param hMac HMAC algorithm to use in the DRBG underneath the SecureRandom.
+ @param nonce nonce value to use in DRBG construction.
+ @param predictionResistant specify whether the underlying DRBG in the resulting SecureRandom should reseed on each request for bytes.
+ @return a SecureRandom supported by a HMAC DRBG.
+
+
+
+ @param engine
+ @param entropySource
+
+
+ Populate a passed in array with random data.
+
+ @param output output array for generated bits.
+ @param predictionResistant true if a reseed should be forced, false otherwise.
+
+ @return number of bits generated, -1 if a reseed required.
+
+
+ Reseed the RNG.
+
+
+ Basic constructor, creates a builder using an EntropySourceProvider based on the default SecureRandom with
+ predictionResistant set to false.
+
+ Any SecureRandom created from a builder constructed like this will make use of input passed to SecureRandom.setSeed() if
+ the default SecureRandom does for its generateSeed() call.
+
+
+
+ Construct a builder with an EntropySourceProvider based on the passed in SecureRandom and the passed in value
+ for prediction resistance.
+
+ Any SecureRandom created from a builder constructed like this will make use of input passed to SecureRandom.setSeed() if
+ the passed in SecureRandom does for its generateSeed() call.
+
+ @param entropySource
+ @param predictionResistant
+
+
+ Create a builder which makes creates the SecureRandom objects from a specified entropy source provider.
+
+ Note: If this constructor is used any calls to setSeed() in the resulting SecureRandom will be ignored.
+
+ @param entropySourceProvider a provider of EntropySource objects.
+
+
+ Construct a X9.31 secure random generator using the passed in engine and key. If predictionResistant is true the
+ generator will be reseeded on each request.
+
+ @param engine a block cipher to use as the operator.
+ @param key the block cipher key to initialise engine with.
+ @param predictionResistant true if engine to be reseeded on each use, false otherwise.
+ @return a SecureRandom.
+
+
+
+ Uses Microsoft's RNGCryptoServiceProvider
+
+
+
+ Random generation based on the digest with counter. Calling AddSeedMaterial will
+ always increase the entropy of the hash.
+
+ Internal access to the digest is synchronized so a single one of these can be shared.
+
+
+
+ Generic interface for objects generating random bytes.
+
+
+ Add more seed material to the generator.
+ A byte array to be mixed into the generator's state.
+
+
+ Add more seed material to the generator.
+ A long value to be mixed into the generator's state.
+
+
+ Fill byte array with random values.
+ Array to be filled.
+
+
+ Fill byte array with random values.
+ Array to receive bytes.
+ Index to start filling at.
+ Length of segment to fill.
+
+
+
+ Takes bytes generated by an underling RandomGenerator and reverses the order in
+ each small window (of configurable size).
+
+ Access to internals is synchronized so a single one of these can be shared.
+
+
+
+
+ Add more seed material to the generator.
+ A byte array to be mixed into the generator's state.
+
+
+ Add more seed material to the generator.
+ A long value to be mixed into the generator's state.
+
+
+ Fill byte array with random values.
+ Array to be filled.
+
+
+ Fill byte array with random values.
+ Array to receive bytes.
+ Index to start filling at.
+ Length of segment to fill.
+
+
+ A thread based seed generator - one source of randomness.
+
+ Based on an idea from Marcus Lippert.
+
+
+
+ Generate seed bytes. Set fast to false for best quality.
+
+ If fast is set to true, the code should be round about 8 times faster when
+ generating a long sequence of random bytes. 20 bytes of random values using
+ the fast mode take less than half a second on a Nokia e70. If fast is set to false,
+ it takes round about 2500 ms.
+
+ @param numBytes the number of bytes to generate
+ @param fast true if fast mode should be used
+
+
+
+ Permutation generated by code:
+
+ // First 1850 fractional digit of Pi number.
+ byte[] key = new BigInteger("14159265358979323846...5068006422512520511").ToByteArray();
+ s = 0;
+ P = new byte[256];
+ for (int i = 0; i < 256; i++)
+ {
+ P[i] = (byte) i;
+ }
+ for (int m = 0; m < 768; m++)
+ {
+ s = P[(s + P[m & 0xff] + key[m % key.length]) & 0xff];
+ byte temp = P[m & 0xff];
+ P[m & 0xff] = P[s & 0xff];
+ P[s & 0xff] = temp;
+ }
+
+
+
+ Value generated in the same way as P.
+
+
+ a wrapper for block ciphers with a single byte block size, so that they
+ can be treated like stream ciphers.
+
+
+ basic constructor.
+
+ @param cipher the block cipher to be wrapped.
+ @exception ArgumentException if the cipher has a block size other than
+ one.
+
+
+ initialise the underlying cipher.
+
+ @param forEncryption true if we are setting up for encryption, false otherwise.
+ @param param the necessary parameters for the underlying cipher to be initialised.
+
+
+ return the name of the algorithm we are wrapping.
+
+ @return the name of the algorithm we are wrapping.
+
+
+ encrypt/decrypt a single byte returning the result.
+
+ @param in the byte to be processed.
+ @return the result of processing the input byte.
+
+
+ process a block of bytes from in putting the result into out.
+
+ @param in the input byte array.
+ @param inOff the offset into the in array where the data to be processed starts.
+ @param len the number of bytes to be processed.
+ @param out the output buffer the processed bytes go into.
+ @param outOff the offset into the output byte array the processed data stars at.
+ @exception DataLengthException if the output buffer is too small.
+
+
+ reset the underlying cipher. This leaves it in the same state
+ it was at after the last init (if there was one).
+
+
+ a Diffie-Hellman key exchange engine.
+
+ note: This uses MTI/A0 key agreement in order to make the key agreement
+ secure against passive attacks. If you're doing Diffie-Hellman and both
+ parties have long term public keys you should look at using this. For
+ further information have a look at RFC 2631.
+
+ It's possible to extend this to more than two parties as well, for the moment
+ that is left as an exercise for the reader.
+
+
+ calculate our initial message.
+
+
+ given a message from a given party and the corresponding public key
+ calculate the next message in the agreement sequence. In this case
+ this will represent the shared secret.
+
+
+ a Diffie-Hellman key agreement class.
+
+ note: This is only the basic algorithm, it doesn't take advantage of
+ long term public keys if they are available. See the DHAgreement class
+ for a "better" implementation.
+
+
+ given a short term public key from a given party calculate the next
+ message in the agreement sequence.
+
+
+ Standard Diffie-Hellman groups from various IETF specifications.
+
+
+ P1363 7.2.1 ECSVDP-DH
+
+ ECSVDP-DH is Elliptic Curve Secret Value Derivation Primitive,
+ Diffie-Hellman version. It is based on the work of [DH76], [Mil86],
+ and [Kob87]. This primitive derives a shared secret value from one
+ party's private key and another party's public key, where both have
+ the same set of EC domain parameters. If two parties correctly
+ execute this primitive, they will produce the same output. This
+ primitive can be invoked by a scheme to derive a shared secret key;
+ specifically, it may be used with the schemes ECKAS-DH1 and
+ DL/ECKAS-DH2. It assumes that the input keys are valid (see also
+ Section 7.2.2).
+
+
+ P1363 7.2.2 ECSVDP-DHC
+
+ ECSVDP-DHC is Elliptic Curve Secret Value Derivation Primitive,
+ Diffie-Hellman version with cofactor multiplication. It is based on
+ the work of [DH76], [Mil86], [Kob87], [LMQ98] and [Kal98a]. This
+ primitive derives a shared secret value from one party's private key
+ and another party's public key, where both have the same set of EC
+ domain parameters. If two parties correctly execute this primitive,
+ they will produce the same output. This primitive can be invoked by a
+ scheme to derive a shared secret key; specifically, it may be used
+ with the schemes ECKAS-DH1 and DL/ECKAS-DH2. It does not assume the
+ validity of the input public key (see also Section 7.2.1).
+
+ Note: As stated P1363 compatibility mode with ECDH can be preset, and
+ in this case the implementation doesn't have a ECDH compatibility mode
+ (if you want that just use ECDHBasicAgreement and note they both implement
+ BasicAgreement!).
+
+
+
+ A participant in a Password Authenticated Key Exchange by Juggling (J-PAKE) exchange.
+
+ The J-PAKE exchange is defined by Feng Hao and Peter Ryan in the paper
+
+ "Password Authenticated Key Exchange by Juggling, 2008."
+
+ The J-PAKE protocol is symmetric.
+ There is no notion of a client or server, but rather just two participants.
+ An instance of JPakeParticipant represents one participant, and
+ is the primary interface for executing the exchange.
+
+ To execute an exchange, construct a JPakeParticipant on each end,
+ and call the following 7 methods
+ (once and only once, in the given order, for each participant, sending messages between them as described):
+
+ CreateRound1PayloadToSend() - and send the payload to the other participant
+ ValidateRound1PayloadReceived(JPakeRound1Payload) - use the payload received from the other participant
+ CreateRound2PayloadToSend() - and send the payload to the other participant
+ ValidateRound2PayloadReceived(JPakeRound2Payload) - use the payload received from the other participant
+ CalculateKeyingMaterial()
+ CreateRound3PayloadToSend(BigInteger) - and send the payload to the other participant
+ ValidateRound3PayloadReceived(JPakeRound3Payload, BigInteger) - use the payload received from the other participant
+
+ Each side should derive a session key from the keying material returned by CalculateKeyingMaterial().
+ The caller is responsible for deriving the session key using a secure key derivation function (KDF).
+
+ Round 3 is an optional key confirmation process.
+ If you do not execute round 3, then there is no assurance that both participants are using the same key.
+ (i.e. if the participants used different passwords, then their session keys will differ.)
+
+ If the round 3 validation succeeds, then the keys are guaranteed to be the same on both sides.
+
+ The symmetric design can easily support the asymmetric cases when one party initiates the communication.
+ e.g. Sometimes the round1 payload and round2 payload may be sent in one pass.
+ Also, in some cases, the key confirmation payload can be sent together with the round2 payload.
+ These are the trivial techniques to optimize the communication.
+
+ The key confirmation process is implemented as specified in
+ NIST SP 800-56A Revision 1,
+ Section 8.2 Unilateral Key Confirmation for Key Agreement Schemes.
+
+ This class is stateful and NOT threadsafe.
+ Each instance should only be used for ONE complete J-PAKE exchange
+ (i.e. a new JPakeParticipant should be constructed for each new J-PAKE exchange).
+
+
+
+
+ Convenience constructor for a new JPakeParticipant that uses
+ the JPakePrimeOrderGroups#NIST_3072 prime order group,
+ a SHA-256 digest, and a default SecureRandom implementation.
+
+ After construction, the State state will be STATE_INITIALIZED.
+
+ Throws NullReferenceException if any argument is null. Throws
+ ArgumentException if password is empty.
+
+ Unique identifier of this participant.
+ The two participants in the exchange must NOT share the same id.
+ Shared secret.
+ A defensive copy of this array is made (and cleared once CalculateKeyingMaterial() is called).
+ Caller should clear the input password as soon as possible.
+
+
+
+ Convenience constructor for a new JPakeParticipant that uses
+ a SHA-256 digest, and a default SecureRandom implementation.
+
+ After construction, the State state will be STATE_INITIALIZED.
+
+ Throws NullReferenceException if any argument is null. Throws
+ ArgumentException if password is empty.
+
+ Unique identifier of this participant.
+ The two participants in the exchange must NOT share the same id.
+ Shared secret.
+ A defensive copy of this array is made (and cleared once CalculateKeyingMaterial() is called).
+ Caller should clear the input password as soon as possible.
+ Prime order group. See JPakePrimeOrderGroups for standard groups.
+
+
+
+ Constructor for a new JPakeParticipant.
+
+ After construction, the State state will be STATE_INITIALIZED.
+
+ Throws NullReferenceException if any argument is null. Throws
+ ArgumentException if password is empty.
+
+ Unique identifier of this participant.
+ The two participants in the exchange must NOT share the same id.
+ Shared secret.
+ A defensive copy of this array is made (and cleared once CalculateKeyingMaterial() is called).
+ Caller should clear the input password as soon as possible.
+ Prime order group. See JPakePrimeOrderGroups for standard groups.
+ Digest to use during zero knowledge proofs and key confirmation
+ (SHA-256 or stronger preferred).
+ Source of secure random data for x1 and x2, and for the zero knowledge proofs.
+
+
+
+ Gets the current state of this participant.
+ See the STATE_* constants for possible values.
+
+
+
+
+ Creates and returns the payload to send to the other participant during round 1.
+
+ After execution, the State state} will be STATE_ROUND_1_CREATED}.
+
+
+
+
+ Validates the payload received from the other participant during round 1.
+
+ Must be called prior to CreateRound2PayloadToSend().
+
+ After execution, the State state will be STATE_ROUND_1_VALIDATED.
+
+ Throws CryptoException if validation fails. Throws InvalidOperationException
+ if called multiple times.
+
+
+
+
+ Creates and returns the payload to send to the other participant during round 2.
+
+ ValidateRound1PayloadReceived(JPakeRound1Payload) must be called prior to this method.
+
+ After execution, the State state will be STATE_ROUND_2_CREATED.
+
+ Throws InvalidOperationException if called prior to ValidateRound1PayloadReceived(JPakeRound1Payload), or multiple times
+
+
+
+
+ Validates the payload received from the other participant during round 2.
+ Note that this DOES NOT detect a non-common password.
+ The only indication of a non-common password is through derivation
+ of different keys (which can be detected explicitly by executing round 3 and round 4)
+
+ Must be called prior to CalculateKeyingMaterial().
+
+ After execution, the State state will be STATE_ROUND_2_VALIDATED.
+
+ Throws CryptoException if validation fails. Throws
+ InvalidOperationException if called prior to ValidateRound1PayloadReceived(JPakeRound1Payload), or multiple times
+
+
+
+
+ Calculates and returns the key material.
+ A session key must be derived from this key material using a secure key derivation function (KDF).
+ The KDF used to derive the key is handled externally (i.e. not by JPakeParticipant).
+
+ The keying material will be identical for each participant if and only if
+ each participant's password is the same. i.e. If the participants do not
+ share the same password, then each participant will derive a different key.
+ Therefore, if you immediately start using a key derived from
+ the keying material, then you must handle detection of incorrect keys.
+ If you want to handle this detection explicitly, you can optionally perform
+ rounds 3 and 4. See JPakeParticipant for details on how to execute
+ rounds 3 and 4.
+
+ The keying material will be in the range [0, p-1].
+
+ ValidateRound2PayloadReceived(JPakeRound2Payload) must be called prior to this method.
+
+ As a side effect, the internal password array is cleared, since it is no longer needed.
+
+ After execution, the State state will be STATE_KEY_CALCULATED.
+
+ Throws InvalidOperationException if called prior to ValidateRound2PayloadReceived(JPakeRound2Payload),
+ or if called multiple times.
+
+
+
+
+ Creates and returns the payload to send to the other participant during round 3.
+
+ See JPakeParticipant for more details on round 3.
+
+ After execution, the State state} will be STATE_ROUND_3_CREATED.
+ Throws InvalidOperationException if called prior to CalculateKeyingMaterial, or multiple
+ times.
+
+ The keying material as returned from CalculateKeyingMaterial().
+
+
+
+ Validates the payload received from the other participant during round 3.
+
+ See JPakeParticipant for more details on round 3.
+
+ After execution, the State state will be STATE_ROUND_3_VALIDATED.
+
+ Throws CryptoException if validation fails. Throws InvalidOperationException if called prior to
+ CalculateKeyingMaterial or multiple times
+
+ The round 3 payload received from the other participant.
+ The keying material as returned from CalculateKeyingMaterial().
+
+
+
+ A pre-computed prime order group for use during a J-PAKE exchange.
+
+ Typically a Schnorr group is used. In general, J-PAKE can use any prime order group
+ that is suitable for public key cryptography, including elliptic curve cryptography.
+
+ See JPakePrimeOrderGroups for convenient standard groups.
+
+ NIST publishes
+ many groups that can be used for the desired level of security.
+
+
+
+
+ Constructs a new JPakePrimeOrderGroup.
+
+ In general, you should use one of the pre-approved groups from
+ JPakePrimeOrderGroups, rather than manually constructing one.
+
+ The following basic checks are performed:
+
+ p-1 must be evenly divisible by q
+ g must be in [2, p-1]
+ g^q mod p must equal 1
+ p must be prime (within reasonably certainty)
+ q must be prime (within reasonably certainty)
+
+ The prime checks are performed using BigInteger#isProbablePrime(int),
+ and are therefore subject to the same probability guarantees.
+
+ These checks prevent trivial mistakes.
+ However, due to the small uncertainties if p and q are not prime,
+ advanced attacks are not prevented.
+ Use it at your own risk.
+
+ Throws NullReferenceException if any argument is null. Throws
+ InvalidOperationException is any of the above validations fail.
+
+
+
+
+ Constructor used by the pre-approved groups in JPakePrimeOrderGroups.
+ These pre-approved groups can avoid the expensive checks.
+ User-specified groups should not use this constructor.
+
+
+
+
+ Standard pre-computed prime order groups for use by J-PAKE.
+ (J-PAKE can use pre-computed prime order groups, same as DSA and Diffie-Hellman.)
+
+ This class contains some convenient constants for use as input for
+ constructing {@link JPAKEParticipant}s.
+
+ The prime order groups below are taken from Sun's JDK JavaDoc (docs/guide/security/CryptoSpec.html#AppB),
+ and from the prime order groups
+ published by NIST.
+
+
+
+
+ From Sun's JDK JavaDoc (docs/guide/security/CryptoSpec.html#AppB)
+ 1024-bit p, 160-bit q and 1024-bit g for 80-bit security.
+
+
+
+
+ From NIST.
+ 2048-bit p, 224-bit q and 2048-bit g for 112-bit security.
+
+
+
+
+ From NIST.
+ 3072-bit p, 256-bit q and 3072-bit g for 128-bit security.
+
+
+
+
+ The payload sent/received during the first round of a J-PAKE exchange.
+
+ Each JPAKEParticipant creates and sends an instance of this payload to
+ the other. The payload to send should be created via
+ JPAKEParticipant.CreateRound1PayloadToSend().
+
+ Each participant must also validate the payload received from the other.
+ The received payload should be validated via
+ JPAKEParticipant.ValidateRound1PayloadReceived(JPakeRound1Payload).
+
+
+
+
+ The id of the JPAKEParticipant who created/sent this payload.
+
+
+
+
+ The value of g^x1
+
+
+
+
+ The value of g^x2
+
+
+
+
+ The zero knowledge proof for x1.
+
+ This is a two element array, containing {g^v, r} for x1.
+
+
+
+
+ The zero knowledge proof for x2.
+
+ This is a two element array, containing {g^v, r} for x2.
+
+
+
+
+ The payload sent/received during the second round of a J-PAKE exchange.
+
+ Each JPAKEParticipant creates and sends an instance
+ of this payload to the other JPAKEParticipant.
+ The payload to send should be created via
+ JPAKEParticipant#createRound2PayloadToSend()
+
+ Each JPAKEParticipant must also validate the payload
+ received from the other JPAKEParticipant.
+ The received payload should be validated via
+ JPAKEParticipant#validateRound2PayloadReceived(JPakeRound2Payload)
+
+
+
+
+ The id of the JPAKEParticipant who created/sent this payload.
+
+
+
+
+ The value of A, as computed during round 2.
+
+
+
+
+ The zero knowledge proof for x2 * s.
+
+ This is a two element array, containing {g^v, r} for x2 * s.
+
+
+
+
+ The payload sent/received during the optional third round of a J-PAKE exchange,
+ which is for explicit key confirmation.
+
+ Each JPAKEParticipant creates and sends an instance
+ of this payload to the other JPAKEParticipant.
+ The payload to send should be created via
+ JPAKEParticipant#createRound3PayloadToSend(BigInteger)
+
+ Eeach JPAKEParticipant must also validate the payload
+ received from the other JPAKEParticipant.
+ The received payload should be validated via
+ JPAKEParticipant#validateRound3PayloadReceived(JPakeRound3Payload, BigInteger)
+
+
+
+
+ The id of the {@link JPAKEParticipant} who created/sent this payload.
+
+
+
+
+ The value of MacTag, as computed by round 3.
+
+ See JPAKEUtil#calculateMacTag(string, string, BigInteger, BigInteger, BigInteger, BigInteger, BigInteger, org.bouncycastle.crypto.Digest)
+
+
+
+
+ Primitives needed for a J-PAKE exchange.
+
+ The recommended way to perform a J-PAKE exchange is by using
+ two JPAKEParticipants. Internally, those participants
+ call these primitive operations in JPakeUtilities.
+
+ The primitives, however, can be used without a JPAKEParticipant if needed.
+
+
+
+
+ Return a value that can be used as x1 or x3 during round 1.
+ The returned value is a random value in the range [0, q-1].
+
+
+
+
+ Return a value that can be used as x2 or x4 during round 1.
+ The returned value is a random value in the range [1, q-1].
+
+
+
+
+ Converts the given password to a BigInteger
+ for use in arithmetic calculations.
+
+
+
+
+ Calculate g^x mod p as done in round 1.
+
+
+
+
+ Calculate ga as done in round 2.
+
+
+
+
+ Calculate x2 * s as done in round 2.
+
+
+
+
+ Calculate A as done in round 2.
+
+
+
+
+ Calculate a zero knowledge proof of x using Schnorr's signature.
+ The returned array has two elements {g^v, r = v-x*h} for x.
+
+
+
+
+ Validates that g^x4 is not 1.
+ throws CryptoException if g^x4 is 1
+
+
+
+
+ Validates that ga is not 1.
+
+ As described by Feng Hao...
+ Alice could simply check ga != 1 to ensure it is a generator.
+ In fact, as we will explain in Section 3, (x1 + x3 + x4 ) is random over Zq even in the face of active attacks.
+ Hence, the probability for ga = 1 is extremely small - on the order of 2^160 for 160-bit q.
+
+ throws CryptoException if ga is 1
+
+
+
+
+ Validates the zero knowledge proof (generated by
+ calculateZeroKnowledgeProof(BigInteger, BigInteger, BigInteger, BigInteger, BigInteger, string, Digest, SecureRandom)
+ is correct.
+
+ throws CryptoException if the zero knowledge proof is not correct
+
+
+
+
+ Calculates the keying material, which can be done after round 2 has completed.
+ A session key must be derived from this key material using a secure key derivation function (KDF).
+ The KDF used to derive the key is handled externally (i.e. not by JPAKEParticipant).
+
+ KeyingMaterial = (B/g^{x2*x4*s})^x2
+
+
+
+
+ Validates that the given participant ids are not equal.
+ (For the J-PAKE exchange, each participant must use a unique id.)
+
+ Throws CryptoException if the participantId strings are equal.
+
+
+
+
+ Validates that the given participant ids are equal.
+ This is used to ensure that the payloads received from
+ each round all come from the same participant.
+
+
+
+
+ Validates that the given object is not null.
+ throws NullReferenceException if the object is null.
+
+ object in question
+ name of the object (to be used in exception message)
+
+
+
+ Calculates the MacTag (to be used for key confirmation), as defined by
+ NIST SP 800-56A Revision 1,
+ Section 8.2 Unilateral Key Confirmation for Key Agreement Schemes.
+
+ MacTag = HMAC(MacKey, MacLen, MacData)
+ MacKey = H(K || "JPAKE_KC")
+ MacData = "KC_1_U" || participantId || partnerParticipantId || gx1 || gx2 || gx3 || gx4
+
+ Note that both participants use "KC_1_U" because the sender of the round 3 message
+ is always the initiator for key confirmation.
+
+ HMAC = {@link HMac} used with the given {@link Digest}
+ H = The given {@link Digest}
+ MacLen = length of MacTag
+
+
+
+
+ Calculates the MacKey (i.e. the key to use when calculating the MagTag for key confirmation).
+
+ MacKey = H(K || "JPAKE_KC")
+
+
+
+
+ Validates the MacTag received from the partner participant.
+
+ throws CryptoException if the participantId strings are equal.
+
+
+
+ RFC 2631 Diffie-hellman KEK derivation function.
+
+
+ X9.63 based key derivation function for ECDH CMS.
+
+
+ Implements the client side SRP-6a protocol. Note that this class is stateful, and therefore NOT threadsafe.
+ This implementation of SRP is based on the optimized message sequence put forth by Thomas Wu in the paper
+ "SRP-6: Improvements and Refinements to the Secure Remote Password Protocol, 2002"
+
+
+ Initialises the client to begin new authentication attempt
+ @param N The safe prime associated with the client's verifier
+ @param g The group parameter associated with the client's verifier
+ @param digest The digest algorithm associated with the client's verifier
+ @param random For key generation
+
+
+ Generates client's credentials given the client's salt, identity and password
+ @param salt The salt used in the client's verifier.
+ @param identity The user's identity (eg. username)
+ @param password The user's password
+ @return Client's public value to send to server
+
+
+ Generates client's verification message given the server's credentials
+ @param serverB The server's credentials
+ @return Client's verification message for the server
+ @throws CryptoException If server's credentials are invalid
+
+
+ Computes the client evidence message M1 using the previously received values.
+ To be called after calculating the secret S.
+ @return M1: the client side generated evidence message
+ @throws CryptoException
+
+
+ Authenticates the server evidence message M2 received and saves it only if correct.
+ @param M2: the server side generated evidence message
+ @return A boolean indicating if the server message M2 was the expected one.
+ @throws CryptoException
+
+
+ Computes the final session key as a result of the SRP successful mutual authentication
+ To be called after verifying the server evidence message M2.
+ @return Key: the mutually authenticated symmetric session key
+ @throws CryptoException
+
+
+ Implements the server side SRP-6a protocol. Note that this class is stateful, and therefore NOT threadsafe.
+ This implementation of SRP is based on the optimized message sequence put forth by Thomas Wu in the paper
+ "SRP-6: Improvements and Refinements to the Secure Remote Password Protocol, 2002"
+
+
+ Initialises the server to accept a new client authentication attempt
+ @param N The safe prime associated with the client's verifier
+ @param g The group parameter associated with the client's verifier
+ @param v The client's verifier
+ @param digest The digest algorithm associated with the client's verifier
+ @param random For key generation
+
+
+ Generates the server's credentials that are to be sent to the client.
+ @return The server's public value to the client
+
+
+ Processes the client's credentials. If valid the shared secret is generated and returned.
+ @param clientA The client's credentials
+ @return A shared secret BigInteger
+ @throws CryptoException If client's credentials are invalid
+
+
+ Authenticates the received client evidence message M1 and saves it only if correct.
+ To be called after calculating the secret S.
+ @param M1: the client side generated evidence message
+ @return A boolean indicating if the client message M1 was the expected one.
+ @throws CryptoException
+
+
+ Computes the server evidence message M2 using the previously verified values.
+ To be called after successfully verifying the client evidence message M1.
+ @return M2: the server side generated evidence message
+ @throws CryptoException
+
+
+ Computes the final session key as a result of the SRP successful mutual authentication
+ To be called after calculating the server evidence message M2.
+ @return Key: the mutual authenticated symmetric session key
+ @throws CryptoException
+
+
+ Computes the client evidence message (M1) according to the standard routine:
+ M1 = H( A | B | S )
+ @param digest The Digest used as the hashing function H
+ @param N Modulus used to get the pad length
+ @param A The public client value
+ @param B The public server value
+ @param S The secret calculated by both sides
+ @return M1 The calculated client evidence message
+
+
+ Computes the server evidence message (M2) according to the standard routine:
+ M2 = H( A | M1 | S )
+ @param digest The Digest used as the hashing function H
+ @param N Modulus used to get the pad length
+ @param A The public client value
+ @param M1 The client evidence message
+ @param S The secret calculated by both sides
+ @return M2 The calculated server evidence message
+
+
+ Computes the final Key according to the standard routine: Key = H(S)
+ @param digest The Digest used as the hashing function H
+ @param N Modulus used to get the pad length
+ @param S The secret calculated by both sides
+ @return
+
+
+ Generates new SRP verifier for user
+
+
+ Initialises generator to create new verifiers
+ @param N The safe prime to use (see DHParametersGenerator)
+ @param g The group parameter to use (see DHParametersGenerator)
+ @param digest The digest to use. The same digest type will need to be used later for the actual authentication
+ attempt. Also note that the final session key size is dependent on the chosen digest.
+
+
+ Creates a new SRP verifier
+ @param salt The salt to use, generally should be large and random
+ @param identity The user's identifying information (eg. username)
+ @param password The user's password
+ @return A new verifier for use in future SRP authentication
+
+
+ return the X9ECParameters object for the named curve represented by
+ the passed in object identifier. Null if the curve isn't present.
+
+ @param oid an object identifier representing a named curve, if present.
+
+
+ return the object identifier signified by the passed in name. Null
+ if there is no object identifier associated with name.
+
+ @return the object identifier associated with name, if present.
+
+
+ return the named curve name represented by the given object identifier.
+
+
+ returns an enumeration containing the name strings for curves
+ contained in this structure.
+
+
+ ISO 9796-1 padding. Note in the light of recent results you should
+ only use this with RSA (rather than the "simpler" Rabin keys) and you
+ should never use it with anything other than a hash (ie. even if the
+ message is small don't sign the message, sign it's hash) or some "random"
+ value. See your favorite search engine for details.
+
+
+ return the input block size. The largest message we can process
+ is (key_size_in_bits + 3)/16, which in our world comes to
+ key_size_in_bytes / 2.
+
+
+ return the maximum possible size for the output.
+
+
+ set the number of bits in the next message to be treated as
+ pad bits.
+
+
+ retrieve the number of pad bits in the last decoded message.
+
+
+ @exception InvalidCipherTextException if the decrypted block is not a valid ISO 9796 bit string
+
+
+ Optimal Asymmetric Encryption Padding (OAEP) - see PKCS 1 V 2.
+
+
+ @exception InvalidCipherTextException if the decrypted block turns out to
+ be badly formatted.
+
+
+ int to octet string.
+
+
+ mask generator function, as described in PKCS1v2.
+
+
+ this does your basic Pkcs 1 v1.5 padding - whether or not you should be using this
+ depends on your application - see Pkcs1 Version 2 for details.
+
+
+ some providers fail to include the leading zero in PKCS1 encoded blocks. If you need to
+ work with one of these set the system property Org.BouncyCastle.Pkcs1.Strict to false.
+
+
+ The same effect can be achieved by setting the static property directly
+
+ The static property is checked during construction of the encoding object, it is set to
+ true by default.
+
+
+
+ Basic constructor.
+ @param cipher
+
+
+ Constructor for decryption with a fixed plaintext length.
+
+ @param cipher The cipher to use for cryptographic operation.
+ @param pLen Length of the expected plaintext.
+
+
+ Constructor for decryption with a fixed plaintext length and a fallback
+ value that is returned, if the padding is incorrect.
+
+ @param cipher
+ The cipher to use for cryptographic operation.
+ @param fallback
+ The fallback value, we don't to a arraycopy here.
+
+
+ Checks if the argument is a correctly PKCS#1.5 encoded Plaintext
+ for encryption.
+
+ @param encoded The Plaintext.
+ @param pLen Expected length of the plaintext.
+ @return Either 0, if the encoding is correct, or -1, if it is incorrect.
+
+
+ Decode PKCS#1.5 encoding, and return a random value if the padding is not correct.
+
+ @param in The encrypted block.
+ @param inOff Offset in the encrypted block.
+ @param inLen Length of the encrypted block.
+ @param pLen Length of the desired output.
+ @return The plaintext without padding, or a random value if the padding was incorrect.
+
+ @throws InvalidCipherTextException
+
+
+ @exception InvalidCipherTextException if the decrypted block is not in Pkcs1 format.
+
+
+ Basic KDF generator for derived keys and ivs as defined by IEEE P1363a/ISO 18033
+
+ This implementation is based on ISO 18033/P1363a.
+
+
+ Construct a KDF Parameters generator.
+
+ @param counterStart value of counter.
+ @param digest the digest to be used as the source of derived keys.
+
+
+ return the underlying digest.
+
+
+ fill len bytes of the output buffer with bytes generated from
+ the derivation function.
+
+ @throws ArgumentException if the size of the request will cause an overflow.
+ @throws DataLengthException if the out buffer is too small.
+
+
+ a basic Diffie-Hellman key pair generator.
+
+ This generates keys consistent for use with the basic algorithm for
+ Diffie-Hellman.
+
+
+ a Diffie-Hellman key pair generator.
+
+ This generates keys consistent for use in the MTI/A0 key agreement protocol
+ as described in "Handbook of Applied Cryptography", Pages 516-519.
+
+
+ which Generates the p and g values from the given parameters,
+ returning the DHParameters object.
+
+ Note: can take a while...
+
+
+ initialise the key generator - if strength is set to zero
+ the key Generated will be 192 bits in size, otherwise
+ strength can be 128 or 192 (or 112 or 168 if you don't count
+ parity bits), depending on whether you wish to do 2-key or 3-key
+ triple DES.
+
+ @param param the parameters to be used for key generation
+
+
+ initialise the key generator - if strength is set to zero
+ the key generated will be 64 bits in size, otherwise
+ strength can be 64 or 56 bits (if you don't count the parity bits).
+
+ @param param the parameters to be used for key generation
+
+
+ a DSA key pair generator.
+
+ This Generates DSA keys in line with the method described
+ in FIPS 186-3 B.1 FFC Key Pair Generation.
+
+
+ Generate suitable parameters for DSA, in line with FIPS 186-2, or FIPS 186-3.
+
+
+ Initialise the generator
+ This form can only be used for older DSA (pre-DSA2) parameters
+ the size of keys in bits (from 512 up to 1024, and a multiple of 64)
+ measure of robustness of primes (at least 80 for FIPS 186-2 compliance)
+ the source of randomness to use
+
+
+ Initialise the generator for DSA 2
+ You must use this Init method if you need to generate parameters for DSA 2 keys
+ An instance of DsaParameterGenerationParameters used to configure this generator
+
+
+ Generates a set of DsaParameters
+ Can take a while...
+
+
+ generate suitable parameters for DSA, in line with
+ FIPS 186-3 A.1 Generation of the FFC Primes p and q.
+
+
+ Given the domain parameters this routine generates an EC key
+ pair in accordance with X9.62 section 5.2.1 pages 26, 27.
+
+
+ a ElGamal key pair generator.
+
+ This Generates keys consistent for use with ElGamal as described in
+ page 164 of "Handbook of Applied Cryptography".
+
+
+ * which Generates the p and g values from the given parameters,
+ * returning the ElGamalParameters object.
+ *
+ * Note: can take a while...
+ *
+
+
+ a GOST3410 key pair generator.
+ This generates GOST3410 keys in line with the method described
+ in GOST R 34.10-94.
+
+
+ generate suitable parameters for GOST3410.
+
+
+ initialise the key generator.
+
+ @param size size of the key
+ @param typeProcedure type procedure A,B = 1; A',B' - else
+ @param random random byte source.
+
+
+ Procedure C
+ procedure generates the a value from the given p,q,
+ returning the a value.
+
+
+ which generates the p , q and a values from the given parameters,
+ returning the Gost3410Parameters object.
+
+
+ KFD2 generator for derived keys and ivs as defined by IEEE P1363a/ISO 18033
+
+ This implementation is based on IEEE P1363/ISO 18033.
+
+
+ Construct a KDF1 byte generator.
+
+ @param digest the digest to be used as the source of derived keys.
+
+
+ KDF2 generator for derived keys and ivs as defined by IEEE P1363a/ISO 18033
+
+ This implementation is based on IEEE P1363/ISO 18033.
+
+
+ Construct a KDF2 bytes generator. Generates key material
+ according to IEEE P1363 or ISO 18033 depending on the initialisation.
+
+ @param digest the digest to be used as the source of derived keys.
+
+
+ Generator for MGF1 as defined in Pkcs 1v2
+
+
+ @param digest the digest to be used as the source of Generated bytes
+
+
+ return the underlying digest.
+
+
+ int to octet string.
+
+
+ fill len bytes of the output buffer with bytes Generated from
+ the derivation function.
+
+ @throws DataLengthException if the out buffer is too small.
+
+
+ Key generation parameters for NaccacheStern cipher. For details on this cipher, please see
+
+ http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf
+
+
+ Generates a permuted ArrayList from the original one. The original List
+ is not modified
+
+ @param arr
+ the ArrayList to be permuted
+ @param rand
+ the source of Randomness for permutation
+ @return a new IList with the permuted elements.
+
+
+ Finds the first 'count' primes starting with 3
+
+ @param count
+ the number of primes to find
+ @return a vector containing the found primes as Integer
+
+
+ Generator for PBE derived keys and ivs as usd by OpenSSL.
+
+ The scheme is a simple extension of PKCS 5 V2.0 Scheme 1 using MD5 with an
+ iteration count of 1.
+
+
+
+ Construct a OpenSSL Parameters generator.
+
+
+ Initialise - note the iteration count for this algorithm is fixed at 1.
+
+ @param password password to use.
+ @param salt salt to use.
+
+
+ the derived key function, the ith hash of the password and the salt.
+
+
+ Generate a key parameter derived from the password, salt, and iteration
+ count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+ @exception ArgumentException if the key length larger than the base hash size.
+
+
+ Generate a key with initialisation vector parameter derived from
+ the password, salt, and iteration count we are currently initialised
+ with.
+
+ @param keySize the size of the key we want (in bits)
+ @param ivSize the size of the iv we want (in bits)
+ @return a ParametersWithIV object.
+ @exception ArgumentException if keySize + ivSize is larger than the base hash size.
+
+
+ Generate a key parameter for use with a MAC derived from the password,
+ salt, and iteration count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+ @exception ArgumentException if the key length larger than the base hash size.
+
+
+ Generator for Pbe derived keys and ivs as defined by Pkcs 12 V1.0.
+
+ The document this implementation is based on can be found at
+
+ RSA's Pkcs12 Page
+
+
+
+ Construct a Pkcs 12 Parameters generator.
+
+ @param digest the digest to be used as the source of derived keys.
+ @exception ArgumentException if an unknown digest is passed in.
+
+
+ add a + b + 1, returning the result in a. The a value is treated
+ as a BigInteger of length (b.Length * 8) bits. The result is
+ modulo 2^b.Length in case of overflow.
+
+
+ generation of a derived key ala Pkcs12 V1.0.
+
+
+ Generate a key parameter derived from the password, salt, and iteration
+ count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+
+
+ Generate a key with initialisation vector parameter derived from
+ the password, salt, and iteration count we are currently initialised
+ with.
+
+ @param keySize the size of the key we want (in bits)
+ @param ivSize the size of the iv we want (in bits)
+ @return a ParametersWithIV object.
+
+
+ Generate a key parameter for use with a MAC derived from the password,
+ salt, and iteration count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+
+
+ Generator for Pbe derived keys and ivs as defined by Pkcs 5 V2.0 Scheme 1.
+ Note this generator is limited to the size of the hash produced by the
+ digest used to drive it.
+
+ The document this implementation is based on can be found at
+
+ RSA's Pkcs5 Page
+
+
+
+ Construct a Pkcs 5 Scheme 1 Parameters generator.
+
+ @param digest the digest to be used as the source of derived keys.
+
+
+ the derived key function, the ith hash of the mPassword and the mSalt.
+
+
+ Generate a key parameter derived from the mPassword, mSalt, and iteration
+ count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+ @exception ArgumentException if the key length larger than the base hash size.
+
+
+ Generate a key with initialisation vector parameter derived from
+ the mPassword, mSalt, and iteration count we are currently initialised
+ with.
+
+ @param keySize the size of the key we want (in bits)
+ @param ivSize the size of the iv we want (in bits)
+ @return a ParametersWithIV object.
+ @exception ArgumentException if keySize + ivSize is larger than the base hash size.
+
+
+ Generate a key parameter for use with a MAC derived from the mPassword,
+ mSalt, and iteration count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+ @exception ArgumentException if the key length larger than the base hash size.
+
+
+ Generator for Pbe derived keys and ivs as defined by Pkcs 5 V2.0 Scheme 2.
+ This generator uses a SHA-1 HMac as the calculation function.
+
+ The document this implementation is based on can be found at
+
+ RSA's Pkcs5 Page
+
+
+ construct a Pkcs5 Scheme 2 Parameters generator.
+
+
+ Generate a key parameter derived from the password, salt, and iteration
+ count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+
+
+ Generate a key with initialisation vector parameter derived from
+ the password, salt, and iteration count we are currently initialised
+ with.
+
+ @param keySize the size of the key we want (in bits)
+ @param ivSize the size of the iv we want (in bits)
+ @return a ParametersWithIV object.
+
+
+ Generate a key parameter for use with a MAC derived from the password,
+ salt, and iteration count we are currently initialised with.
+
+ @param keySize the size of the key we want (in bits)
+ @return a KeyParameter object.
+
+
+
+ Generates keys for the Poly1305 MAC.
+
+
+ Poly1305 keys are 256 bit keys consisting of a 128 bit secret key used for the underlying block
+ cipher followed by a 128 bit {@code r} value used for the polynomial portion of the Mac.
+ The {@code r} value has a specific format with some bits required to be cleared, resulting in an
+ effective 106 bit key.
+ A separately generated 256 bit key can be modified to fit the Poly1305 key format by using the
+ {@link #clamp(byte[])} method to clear the required bits.
+
+
+
+
+
+ Initialises the key generator.
+
+
+ Poly1305 keys are always 256 bits, so the key length in the provided parameters is ignored.
+
+
+
+
+ Generates a 256 bit key in the format required for Poly1305 - e.g.
+ k[0] ... k[15], r[0] ... r[15]
with the required bits in r
cleared
+ as per .
+
+
+
+
+ Modifies an existing 32 byte key value to comply with the requirements of the Poly1305 key by
+ clearing required bits in the r
(second 16 bytes) portion of the key.
+ Specifically:
+
+ - r[3], r[7], r[11], r[15] have top four bits clear (i.e., are {0, 1, . . . , 15})
+ - r[4], r[8], r[12] have bottom two bits clear (i.e., are in {0, 4, 8, . . . , 252})
+
+
+ a 32 byte key value k[0] ... k[15], r[0] ... r[15]
+
+
+
+ Checks a 32 byte key for compliance with the Poly1305 key requirements, e.g.
+ k[0] ... k[15], r[0] ... r[15]
with the required bits in r
cleared
+ as per .
+
+ Key.
+ if the key is of the wrong length, or has invalid bits set
+ in the r
portion of the key.
+
+
+ Generate a random factor suitable for use with RSA blind signatures
+ as outlined in Chaum's blinding and unblinding as outlined in
+ "Handbook of Applied Cryptography", page 475.
+
+
+ Initialise the factor generator
+
+ @param param the necessary RSA key parameters.
+
+
+ Generate a suitable blind factor for the public key the generator was initialised with.
+
+ @return a random blind factor
+
+
+ an RSA key pair generator.
+
+
+ Choose a random prime value for use with RSA
+ the bit-length of the returned prime
+ the RSA public exponent
+ a prime p, with (p-1) relatively prime to e
+
+
+ CMAC - as specified at www.nuee.nagoya-u.ac.jp/labs/tiwata/omac/omac.html
+
+ CMAC is analogous to OMAC1 - see also en.wikipedia.org/wiki/CMAC
+
+ CMAC is a NIST recomendation - see
+ csrc.nist.gov/CryptoToolkit/modes/800-38_Series_Publications/SP800-38B.pdf
+
+ CMAC/OMAC1 is a blockcipher-based message authentication code designed and
+ analyzed by Tetsu Iwata and Kaoru Kurosawa.
+
+ CMAC/OMAC1 is a simple variant of the CBC MAC (Cipher Block Chaining Message
+ Authentication Code). OMAC stands for One-Key CBC MAC.
+
+ It supports 128- or 64-bits block ciphers, with any key size, and returns
+ a MAC with dimension less or equal to the block size of the underlying
+ cipher.
+
+
+
+ create a standard MAC based on a CBC block cipher (64 or 128 bit block).
+ This will produce an authentication code the length of the block size
+ of the cipher.
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+
+
+ create a standard MAC based on a block cipher with the size of the
+ MAC been given in bits.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8 and @lt;= 128.
+
+
+ Reset the mac generator.
+
+
+ standard CBC Block Cipher MAC - if no padding is specified the default of
+ pad of zeroes is used.
+
+
+ create a standard MAC based on a CBC block cipher. This will produce an
+ authentication code half the length of the block size of the cipher.
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+
+
+ create a standard MAC based on a CBC block cipher. This will produce an
+ authentication code half the length of the block size of the cipher.
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param padding the padding to be used to complete the last block.
+
+
+ create a standard MAC based on a block cipher with the size of the
+ MAC been given in bits. This class uses CBC mode as the basis for the
+ MAC generation.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8.
+
+
+ create a standard MAC based on a block cipher with the size of the
+ MAC been given in bits. This class uses CBC mode as the basis for the
+ MAC generation.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8.
+ @param padding the padding to be used to complete the last block.
+
+
+ Reset the mac generator.
+
+
+ implements a Cipher-FeedBack (CFB) mode on top of a simple cipher.
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used as the basis of the
+ feedback mode.
+ @param blockSize the block size in bits (note: a multiple of 8)
+
+
+ Initialise the cipher and, possibly, the initialisation vector (IV).
+ If an IV isn't passed as part of the parameter, the IV will be all zeros.
+ An IV which is too short is handled in FIPS compliant fashion.
+
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the algorithm name and mode.
+
+ @return the name of the underlying algorithm followed by "/CFB"
+ and the block size in bits.
+
+
+ return the block size we are operating at.
+
+ @return the block size we are operating at (in bytes).
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ reset the chaining vector back to the IV and reset the underlying
+ cipher.
+
+
+ create a standard MAC based on a CFB block cipher. This will produce an
+ authentication code half the length of the block size of the cipher, with
+ the CFB mode set to 8 bits.
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+
+
+ create a standard MAC based on a CFB block cipher. This will produce an
+ authentication code half the length of the block size of the cipher, with
+ the CFB mode set to 8 bits.
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param padding the padding to be used.
+
+
+ create a standard MAC based on a block cipher with the size of the
+ MAC been given in bits. This class uses CFB mode as the basis for the
+ MAC generation.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param cfbBitSize the size of an output block produced by the CFB mode.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8.
+
+
+ create a standard MAC based on a block cipher with the size of the
+ MAC been given in bits. This class uses CFB mode as the basis for the
+ MAC generation.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param cfbBitSize the size of an output block produced by the CFB mode.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8.
+ @param padding a padding to be used.
+
+
+ Reset the mac generator.
+
+
+
+ The GMAC specialisation of Galois/Counter mode (GCM) detailed in NIST Special Publication
+ 800-38D.
+
+
+ GMac is an invocation of the GCM mode where no data is encrypted (i.e. all input data to the Mac
+ is processed as additional authenticated data with the underlying GCM block cipher).
+
+
+
+
+ Creates a GMAC based on the operation of a block cipher in GCM mode.
+
+
+ This will produce an authentication code the length of the block size of the cipher.
+
+ the cipher to be used in GCM mode to generate the MAC.
+
+
+
+ Creates a GMAC based on the operation of a 128 bit block cipher in GCM mode.
+
+
+ This will produce an authentication code the length of the block size of the cipher.
+
+ the cipher to be used in GCM mode to generate the MAC.
+ the mac size to generate, in bits. Must be a multiple of 8, between 32 and 128 (inclusive).
+ Sizes less than 96 are not recommended, but are supported for specialized applications.
+
+
+
+ Initialises the GMAC - requires a
+ providing a and a nonce.
+
+
+
+ implementation of GOST 28147-89 MAC
+
+
+ HMAC implementation based on RFC2104
+
+ H(K XOR opad, H(K XOR ipad, text))
+
+
+ Reset the mac generator.
+
+
+ DES based CBC Block Cipher MAC according to ISO9797, algorithm 3 (ANSI X9.19 Retail MAC)
+
+ This could as well be derived from CBCBlockCipherMac, but then the property mac in the base
+ class must be changed to protected
+
+
+ create a Retail-MAC based on a CBC block cipher. This will produce an
+ authentication code of the length of the block size of the cipher.
+
+ @param cipher the cipher to be used as the basis of the MAC generation. This must
+ be DESEngine.
+
+
+ create a Retail-MAC based on a CBC block cipher. This will produce an
+ authentication code of the length of the block size of the cipher.
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param padding the padding to be used to complete the last block.
+
+
+ create a Retail-MAC based on a block cipher with the size of the
+ MAC been given in bits. This class uses single DES CBC mode as the basis for the
+ MAC generation.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8.
+
+
+ create a standard MAC based on a block cipher with the size of the
+ MAC been given in bits. This class uses single DES CBC mode as the basis for the
+ MAC generation. The final block is decrypted and then encrypted using the
+ middle and right part of the key.
+
+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81),
+ or 16 bits if being used as a data authenticator (FIPS Publication 113),
+ and in general should be less than the size of the block cipher as it reduces
+ the chance of an exhaustive attack (see Handbook of Applied Cryptography).
+
+ @param cipher the cipher to be used as the basis of the MAC generation.
+ @param macSizeInBits the size of the MAC in bits, must be a multiple of 8.
+ @param padding the padding to be used to complete the last block.
+
+
+ Reset the mac generator.
+
+
+
+ Poly1305 message authentication code, designed by D. J. Bernstein.
+
+
+ Poly1305 computes a 128-bit (16 bytes) authenticator, using a 128 bit nonce and a 256 bit key
+ consisting of a 128 bit key applied to an underlying cipher, and a 128 bit key (with 106
+ effective key bits) used in the authenticator.
+
+ The polynomial calculation in this implementation is adapted from the public domain poly1305-donna-unrolled C implementation
+ by Andrew M (@floodyberry).
+
+
+
+
+ Polynomial key
+
+
+ Polynomial key
+
+
+ Polynomial key
+
+
+ Polynomial key
+
+
+ Polynomial key
+
+
+ Precomputed 5 * r[1..4]
+
+
+ Precomputed 5 * r[1..4]
+
+
+ Precomputed 5 * r[1..4]
+
+
+ Precomputed 5 * r[1..4]
+
+
+ Encrypted nonce
+
+
+ Encrypted nonce
+
+
+ Encrypted nonce
+
+
+ Encrypted nonce
+
+
+ Current block of buffered input
+
+
+ Current offset in input buffer
+
+
+ Polynomial accumulator
+
+
+ Polynomial accumulator
+
+
+ Polynomial accumulator
+
+
+ Polynomial accumulator
+
+
+ Polynomial accumulator
+
+
+ Constructs a Poly1305 MAC, where the key passed to init() will be used directly.
+
+
+ Constructs a Poly1305 MAC, using a 128 bit block cipher.
+
+
+
+ Initialises the Poly1305 MAC.
+
+ a {@link ParametersWithIV} containing a 128 bit nonce and a {@link KeyParameter} with
+ a 256 bit key complying to the {@link Poly1305KeyGenerator Poly1305 key format}.
+
+
+
+ Implementation of SipHash as specified in "SipHash: a fast short-input PRF", by Jean-Philippe
+ Aumasson and Daniel J. Bernstein (https://131002.net/siphash/siphash.pdf).
+
+
+ "SipHash is a family of PRFs SipHash-c-d where the integer parameters c and d are the number of
+ compression rounds and the number of finalization rounds. A compression round is identical to a
+ finalization round and this round function is called SipRound. Given a 128-bit key k and a
+ (possibly empty) byte string m, SipHash-c-d returns a 64-bit value..."
+
+
+
+ SipHash-2-4
+
+
+ SipHash-c-d
+ the number of compression rounds
+ the number of finalization rounds
+
+
+
+ Implementation of the Skein parameterised MAC function in 256, 512 and 1024 bit block sizes,
+ based on the Threefish tweakable block cipher.
+
+
+ This is the 1.3 version of Skein defined in the Skein hash function submission to the NIST SHA-3
+ competition in October 2010.
+
+ Skein was designed by Niels Ferguson - Stefan Lucks - Bruce Schneier - Doug Whiting - Mihir
+ Bellare - Tadayoshi Kohno - Jon Callas - Jesse Walker.
+
+
+
+
+
+
+ 256 bit block size - Skein-256
+
+
+
+
+ 512 bit block size - Skein-512
+
+
+
+
+ 1024 bit block size - Skein-1024
+
+
+
+
+ Constructs a Skein MAC with an internal state size and output size.
+
+ the internal state size in bits - one of or
+ .
+ the output/MAC size to produce in bits, which must be an integral number of
+ bytes.
+
+
+
+ Optionally initialises the Skein digest with the provided parameters.
+
+ See for details on the parameterisation of the Skein hash function.
+ the parameters to apply to this engine, or null
to use no parameters.
+
+
+ implements Cipher-Block-Chaining (CBC) mode on top of a simple cipher.
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used as the basis of chaining.
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ Initialise the cipher and, possibly, the initialisation vector (IV).
+ If an IV isn't passed as part of the parameter, the IV will be all zeros.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the algorithm name and mode.
+
+ @return the name of the underlying algorithm followed by "/CBC".
+
+
+ return the block size of the underlying cipher.
+
+ @return the block size of the underlying cipher.
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ reset the chaining vector back to the IV and reset the underlying
+ cipher.
+
+
+ Do the appropriate chaining step for CBC mode encryption.
+
+ @param in the array containing the data to be encrypted.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the encrypted data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ Do the appropriate chaining step for CBC mode decryption.
+
+ @param in the array containing the data to be decrypted.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the decrypted data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ Implements the Counter with Cipher Block Chaining mode (CCM) detailed in
+ NIST Special Publication 800-38C.
+
+ Note: this mode is a packet mode - it needs all the data up front.
+
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used.
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ Returns a byte array containing the mac calculated as part of the
+ last encrypt or decrypt operation.
+
+ @return the last mac calculated.
+
+
+ Process a packet of data for either CCM decryption or encryption.
+
+ @param in data for processing.
+ @param inOff offset at which data starts in the input array.
+ @param inLen length of the data in the input array.
+ @return a byte array containing the processed input..
+ @throws IllegalStateException if the cipher is not appropriately set up.
+ @throws InvalidCipherTextException if the input data is truncated or the mac check fails.
+
+
+ Process a packet of data for either CCM decryption or encryption.
+
+ @param in data for processing.
+ @param inOff offset at which data starts in the input array.
+ @param inLen length of the data in the input array.
+ @param output output array.
+ @param outOff offset into output array to start putting processed bytes.
+ @return the number of bytes added to output.
+ @throws IllegalStateException if the cipher is not appropriately set up.
+ @throws InvalidCipherTextException if the input data is truncated or the mac check fails.
+ @throws DataLengthException if output buffer too short.
+
+
+ implements a Cipher-FeedBack (CFB) mode on top of a simple cipher.
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used as the basis of the
+ feedback mode.
+ @param blockSize the block size in bits (note: a multiple of 8)
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ Initialise the cipher and, possibly, the initialisation vector (IV).
+ If an IV isn't passed as part of the parameter, the IV will be all zeros.
+ An IV which is too short is handled in FIPS compliant fashion.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the algorithm name and mode.
+
+ @return the name of the underlying algorithm followed by "/CFB"
+ and the block size in bits.
+
+
+ return the block size we are operating at.
+
+ @return the block size we are operating at (in bytes).
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ Do the appropriate processing for CFB mode encryption.
+
+ @param in the array containing the data to be encrypted.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the encrypted data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ Do the appropriate processing for CFB mode decryption.
+
+ @param in the array containing the data to be decrypted.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the encrypted data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ reset the chaining vector back to the IV and reset the underlying
+ cipher.
+
+
+ A Cipher Text Stealing (CTS) mode cipher. CTS allows block ciphers to
+ be used to produce cipher text which is the same outLength as the plain text.
+
+
+ Create a buffered block cipher that uses Cipher Text Stealing
+
+ @param cipher the underlying block cipher this buffering object wraps.
+
+
+ return the size of the output buffer required for an update of 'length' bytes.
+
+ @param length the outLength of the input.
+ @return the space required to accommodate a call to update
+ with length bytes of input.
+
+
+ return the size of the output buffer required for an update plus a
+ doFinal with an input of length bytes.
+
+ @param length the outLength of the input.
+ @return the space required to accommodate a call to update and doFinal
+ with length bytes of input.
+
+
+ process a single byte, producing an output block if necessary.
+
+ @param in the input byte.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ process an array of bytes, producing output if necessary.
+
+ @param in the input byte array.
+ @param inOff the offset at which the input data starts.
+ @param length the number of bytes to be copied out of the input array.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ Process the last block in the buffer.
+
+ @param out the array the block currently being held is copied into.
+ @param outOff the offset at which the copying starts.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there is insufficient space in out for
+ the output.
+ @exception InvalidOperationException if the underlying cipher is not
+ initialised.
+ @exception InvalidCipherTextException if cipher text decrypts wrongly (in
+ case the exception will never Get thrown).
+
+
+ A Two-Pass Authenticated-Encryption Scheme Optimized for Simplicity and
+ Efficiency - by M. Bellare, P. Rogaway, D. Wagner.
+
+ http://www.cs.ucdavis.edu/~rogaway/papers/eax.pdf
+
+ EAX is an AEAD scheme based on CTR and OMAC1/CMAC, that uses a single block
+ cipher to encrypt and authenticate data. It's on-line (the length of a
+ message isn't needed to begin processing it), has good performances, it's
+ simple and provably secure (provided the underlying block cipher is secure).
+
+ Of course, this implementations is NOT thread-safe.
+
+
+ Constructor that accepts an instance of a block cipher engine.
+
+ @param cipher the engine to use
+
+
+
+ Implements the Galois/Counter mode (GCM) detailed in
+ NIST Special Publication 800-38D.
+
+
+
+
+ MAC sizes from 32 bits to 128 bits (must be a multiple of 8) are supported. The default is 128 bits.
+ Sizes less than 96 are not recommended, but are supported for specialized applications.
+
+
+
+ implements the GOST 28147 OFB counter mode (GCTR).
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used as the basis of the
+ counter mode (must have a 64 bit block size).
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ Initialise the cipher and, possibly, the initialisation vector (IV).
+ If an IV isn't passed as part of the parameter, the IV will be all zeros.
+ An IV which is too short is handled in FIPS compliant fashion.
+
+ @param encrypting if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param parameters the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is inappropriate.
+
+
+ return the algorithm name and mode.
+
+ @return the name of the underlying algorithm followed by "/GCTR"
+ and the block size in bits
+
+
+ return the block size we are operating at (in bytes).
+
+ @return the block size we are operating at (in bytes).
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ reset the feedback vector back to the IV and reset the underlying
+ cipher.
+
+
+
+ A block cipher mode that includes authenticated encryption with a streaming mode
+ and optional associated data.
+
+
+
+ The name of the algorithm this cipher implements.
+
+
+ The block cipher underlying this algorithm.
+
+
+ Initialise the cipher.
+ Parameter can either be an AeadParameters or a ParametersWithIV object.
+ Initialise for encryption if true, for decryption if false.
+ The key or other data required by the cipher.
+
+
+ The block size for this cipher, in bytes.
+
+
+ Add a single byte to the associated data check.
+ If the implementation supports it, this will be an online operation and will not retain the associated data.
+ The byte to be processed.
+
+
+ Add a sequence of bytes to the associated data check.
+ If the implementation supports it, this will be an online operation and will not retain the associated data.
+ The input byte array.
+ The offset into the input array where the data to be processed starts.
+ The number of bytes to be processed.
+
+
+ Encrypt/decrypt a single byte.
+
+ @param input the byte to be processed.
+ @param outBytes the output buffer the processed byte goes into.
+ @param outOff the offset into the output byte array the processed data starts at.
+ @return the number of bytes written to out.
+ @exception DataLengthException if the output buffer is too small.
+
+
+ Process a block of bytes from in putting the result into out.
+
+ @param inBytes the input byte array.
+ @param inOff the offset into the in array where the data to be processed starts.
+ @param len the number of bytes to be processed.
+ @param outBytes the output buffer the processed bytes go into.
+ @param outOff the offset into the output byte array the processed data starts at.
+ @return the number of bytes written to out.
+ @exception DataLengthException if the output buffer is too small.
+
+
+ Finish the operation either appending or verifying the MAC at the end of the data.
+
+ @param outBytes space for any resulting output data.
+ @param outOff offset into out to start copying the data at.
+ @return number of bytes written into out.
+ @throws InvalidOperationException if the cipher is in an inappropriate state.
+ @throws InvalidCipherTextException if the MAC fails to match.
+
+
+ Return the value of the MAC associated with the last stream processed.
+
+ @return MAC for plaintext data.
+
+
+ Return the size of the output buffer required for a ProcessBytes
+ an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to ProcessBytes
+ with len bytes of input.
+
+
+ Return the size of the output buffer required for a ProcessBytes plus a
+ DoFinal with an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to ProcessBytes and DoFinal
+ with len bytes of input.
+
+
+
+ Reset the cipher to the same state as it was after the last init (if there was one).
+
+
+
+ An implementation of RFC 7253 on The OCB
+ Authenticated-Encryption Algorithm, licensed per:
+
+ License for
+ Open-Source Software Implementations of OCB (Jan 9, 2013) - 'License 1'
+ Under this license, you are authorized to make, use, and distribute open-source software
+ implementations of OCB. This license terminates for you if you sue someone over their open-source
+ software implementation of OCB claiming that you have a patent covering their implementation.
+
+ This is a non-binding summary of a legal document (the link above). The parameters of the license
+ are specified in the license document and that document is controlling.
+
+
+ implements a Output-FeedBack (OFB) mode on top of a simple cipher.
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used as the basis of the
+ feedback mode.
+ @param blockSize the block size in bits (note: a multiple of 8)
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ Initialise the cipher and, possibly, the initialisation vector (IV).
+ If an IV isn't passed as part of the parameter, the IV will be all zeros.
+ An IV which is too short is handled in FIPS compliant fashion.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the algorithm name and mode.
+
+ @return the name of the underlying algorithm followed by "/OFB"
+ and the block size in bits
+
+
+ return the block size we are operating at (in bytes).
+
+ @return the block size we are operating at (in bytes).
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ reset the feedback vector back to the IV and reset the underlying
+ cipher.
+
+
+ * Implements OpenPGP's rather strange version of Cipher-FeedBack (CFB) mode
+ * on top of a simple cipher. This class assumes the IV has been prepended
+ * to the data stream already, and just accomodates the reset after
+ * (blockSize + 2) bytes have been read.
+ *
+ * For further info see RFC 2440.
+ *
+
+
+ Basic constructor.
+
+ @param cipher the block cipher to be used as the basis of the
+ feedback mode.
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ return the algorithm name and mode.
+
+ @return the name of the underlying algorithm followed by "/PGPCFB"
+ and the block size in bits.
+
+
+ return the block size we are operating at.
+
+ @return the block size we are operating at (in bytes).
+
+
+ Process one block of input from the array in and write it to
+ the out array.
+
+ @param in the array containing the input data.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the output data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ reset the chaining vector back to the IV and reset the underlying
+ cipher.
+
+
+ Initialise the cipher and, possibly, the initialisation vector (IV).
+ If an IV isn't passed as part of the parameter, the IV will be all zeros.
+ An IV which is too short is handled in FIPS compliant fashion.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param parameters the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ Encrypt one byte of data according to CFB mode.
+ @param data the byte to encrypt
+ @param blockOff offset in the current block
+ @returns the encrypted byte
+
+
+ Do the appropriate processing for CFB IV mode encryption.
+
+ @param in the array containing the data to be encrypted.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the encrypted data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ Do the appropriate processing for CFB IV mode decryption.
+
+ @param in the array containing the data to be decrypted.
+ @param inOff offset into the in array the data starts at.
+ @param out the array the encrypted data will be copied into.
+ @param outOff the offset into the out array the output will start at.
+ @exception DataLengthException if there isn't enough data in in, or
+ space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+ @return the number of bytes processed and produced.
+
+
+ Implements the Segmented Integer Counter (SIC) mode on top of a simple
+ block cipher.
+
+
+ Basic constructor.
+
+ @param c the block cipher to be used.
+
+
+ return the underlying block cipher that we are wrapping.
+
+ @return the underlying block cipher that we are wrapping.
+
+
+ Return the digest algorithm using one of the standard JCA string
+ representations rather than the algorithm identifier (if possible).
+
+
+
+ Calculator factory class for signature generation in ASN.1 based profiles that use an AlgorithmIdentifier to preserve
+ signature algorithm details.
+
+
+
+
+ Base constructor.
+
+ The name of the signature algorithm to use.
+ The private key to be used in the signing operation.
+
+
+
+ Constructor which also specifies a source of randomness to be used if one is required.
+
+ The name of the signature algorithm to use.
+ The private key to be used in the signing operation.
+ The source of randomness to be used in signature calculation.
+
+
+
+ Allows enumeration of the signature names supported by the verifier provider.
+
+
+
+
+ Verifier class for signature verification in ASN.1 based profiles that use an AlgorithmIdentifier to preserve
+ signature algorithm details.
+
+
+
+
+ Base constructor.
+
+ The name of the signature algorithm to use.
+ The public key to be used in the verification operation.
+
+
+
+ Provider class which supports dynamic creation of signature verifiers.
+
+
+
+
+ Base constructor - specify the public key to be used in verification.
+
+ The public key to be used in creating verifiers provided by this object.
+
+
+
+ Allows enumeration of the signature names supported by the verifier provider.
+
+
+
+ Block cipher padders are expected to conform to this interface
+
+
+ Initialise the padder.
+
+ @param param parameters, if any required.
+
+
+ Return the name of the algorithm the cipher implements.
+
+ @return the name of the algorithm the cipher implements.
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+
+ return the number of pad bytes present in the block.
+ @exception InvalidCipherTextException if the padding is badly formed
+ or invalid.
+
+
+ A padder that adds ISO10126-2 padding to a block.
+
+
+ Initialise the padder.
+
+ @param random a SecureRandom if available.
+
+
+ Return the name of the algorithm the cipher implements.
+
+ @return the name of the algorithm the cipher implements.
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+
+ return the number of pad bytes present in the block.
+
+
+ A padder that adds the padding according to the scheme referenced in
+ ISO 7814-4 - scheme 2 from ISO 9797-1. The first byte is 0x80, rest is 0x00
+
+
+ Initialise the padder.
+
+ @param random - a SecureRandom if available.
+
+
+ Return the name of the algorithm the padder implements.
+
+ @return the name of the algorithm the padder implements.
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+
+ return the number of pad bytes present in the block.
+
+
+ A wrapper class that allows block ciphers to be used to process data in
+ a piecemeal fashion with padding. The PaddedBufferedBlockCipher
+ outputs a block only when the buffer is full and more data is being added,
+ or on a doFinal (unless the current block in the buffer is a pad block).
+ The default padding mechanism used is the one outlined in Pkcs5/Pkcs7.
+
+
+ Create a buffered block cipher with the desired padding.
+
+ @param cipher the underlying block cipher this buffering object wraps.
+ @param padding the padding type.
+
+
+ Create a buffered block cipher Pkcs7 padding
+
+ @param cipher the underlying block cipher this buffering object wraps.
+
+
+ initialise the cipher.
+
+ @param forEncryption if true the cipher is initialised for
+ encryption, if false for decryption.
+ @param param the key and other data required by the cipher.
+ @exception ArgumentException if the parameters argument is
+ inappropriate.
+
+
+ return the minimum size of the output buffer required for an update
+ plus a doFinal with an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to update and doFinal
+ with len bytes of input.
+
+
+ return the size of the output buffer required for an update
+ an input of len bytes.
+
+ @param len the length of the input.
+ @return the space required to accommodate a call to update
+ with len bytes of input.
+
+
+ process a single byte, producing an output block if necessary.
+
+ @param in the input byte.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ process an array of bytes, producing output if necessary.
+
+ @param in the input byte array.
+ @param inOff the offset at which the input data starts.
+ @param len the number of bytes to be copied out of the input array.
+ @param out the space for any output that might be produced.
+ @param outOff the offset from which the output will be copied.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there isn't enough space in out.
+ @exception InvalidOperationException if the cipher isn't initialised.
+
+
+ Process the last block in the buffer. If the buffer is currently
+ full and padding needs to be added a call to doFinal will produce
+ 2 * GetBlockSize() bytes.
+
+ @param out the array the block currently being held is copied into.
+ @param outOff the offset at which the copying starts.
+ @return the number of output bytes copied to out.
+ @exception DataLengthException if there is insufficient space in out for
+ the output or we are decrypting and the input is not block size aligned.
+ @exception InvalidOperationException if the underlying cipher is not
+ initialised.
+ @exception InvalidCipherTextException if padding is expected and not found.
+
+
+ A padder that adds Pkcs7/Pkcs5 padding to a block.
+
+
+ Initialise the padder.
+
+ @param random - a SecureRandom if available.
+
+
+ Return the name of the algorithm the cipher implements.
+
+ @return the name of the algorithm the cipher implements.
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+
+ return the number of pad bytes present in the block.
+
+
+ A padder that adds Trailing-Bit-Compliment padding to a block.
+
+ This padding pads the block out compliment of the last bit
+ of the plain text.
+
+
+
+
+ Return the name of the algorithm the cipher implements.
+ the name of the algorithm the cipher implements.
+
+
+
+ Initialise the padder.
+ - a SecureRandom if available.
+
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+ Note: this assumes that the last block of plain text is always
+ passed to it inside in. i.e. if inOff is zero, indicating the
+ entire block is to be overwritten with padding the value of in
+ should be the same as the last block of plain text.
+
+
+
+
+ return the number of pad bytes present in the block.
+
+
+ A padder that adds X9.23 padding to a block - if a SecureRandom is
+ passed in random padding is assumed, otherwise padding with zeros is used.
+
+
+ Initialise the padder.
+
+ @param random a SecureRandom if one is available.
+
+
+ Return the name of the algorithm the cipher implements.
+
+ @return the name of the algorithm the cipher implements.
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+
+ return the number of pad bytes present in the block.
+
+
+ A padder that adds Null byte padding to a block.
+
+
+ Return the name of the algorithm the cipher implements.
+
+
+ the name of the algorithm the cipher implements.
+
+
+
+ Initialise the padder.
+
+
+ - a SecureRandom if available.
+
+
+
+ add the pad bytes to the passed in block, returning the
+ number of bytes added.
+
+
+
+ return the number of pad bytes present in the block.
+
+
+ Base constructor.
+
+ @param key key to be used by underlying cipher
+ @param macSize macSize in bits
+ @param nonce nonce to be used
+
+
+ Base constructor.
+
+ @param key key to be used by underlying cipher
+ @param macSize macSize in bits
+ @param nonce nonce to be used
+ @param associatedText associated text, if any
+
+
+ Base constructor.
+
+ @param key key to be used by underlying cipher
+ @param macSize macSize in bits
+ @param nonce nonce to be used
+ @param associatedText associated text, if any
+
+
+ The minimum bitlength of the private value.
+
+
+ The bitlength of the private value.
+
+
+ Construct without a usage index, this will do a random construction of G.
+
+ @param L desired length of prime P in bits (the effective key size).
+ @param N desired length of prime Q in bits.
+ @param certainty certainty level for prime number generation.
+ @param random the source of randomness to use.
+
+
+ Construct for a specific usage index - this has the effect of using verifiable canonical generation of G.
+
+ @param L desired length of prime P in bits (the effective key size).
+ @param N desired length of prime Q in bits.
+ @param certainty certainty level for prime number generation.
+ @param random the source of randomness to use.
+ @param usageIndex a valid usage index.
+
+
+ return true if the passed in key is a DES-EDE weak key.
+
+ @param key bytes making up the key
+ @param offset offset into the byte array the key starts at
+ @param length number of bytes making up the key
+
+
+ return true if the passed in key is a DES-EDE weak key.
+
+ @param key bytes making up the key
+ @param offset offset into the byte array the key starts at
+
+
+ return true if the passed in key is a real 2/3 part DES-EDE key.
+
+ @param key bytes making up the key
+ @param offset offset into the byte array the key starts at
+
+
+ return true if the passed in key is a real 2 part DES-EDE key.
+
+ @param key bytes making up the key
+ @param offset offset into the byte array the key starts at
+
+
+ return true if the passed in key is a real 3 part DES-EDE key.
+
+ @param key bytes making up the key
+ @param offset offset into the byte array the key starts at
+
+
+ DES has 16 weak keys. This method will check
+ if the given DES key material is weak or semi-weak.
+ Key material that is too short is regarded as weak.
+
+ See "Applied
+ Cryptography" by Bruce Schneier for more information.
+
+ @return true if the given DES key material is weak or semi-weak,
+ false otherwise.
+
+
+ DES Keys use the LSB as the odd parity bit. This can
+ be used to check for corrupt keys.
+
+ @param bytes the byte array to set the parity on.
+
+
+ return the generator - g
+
+
+ return private value limit - l
+
+
+ parameters for Key derivation functions for ISO-18033
+
+
+ parameters for using an integrated cipher in stream mode.
+
+
+ @param derivation the derivation parameter for the KDF function.
+ @param encoding the encoding parameter for the KDF function.
+ @param macKeySize the size of the MAC key (in bits).
+
+
+ @param derivation the derivation parameter for the KDF function.
+ @param encoding the encoding parameter for the KDF function.
+ @param macKeySize the size of the MAC key (in bits).
+ @param cipherKeySize the size of the associated Cipher key (in bits).
+
+
+ parameters for Key derivation functions for IEEE P1363a
+
+
+ Parameters for mask derivation functions.
+
+
+ Parameters for NaccacheStern public private key generation. For details on
+ this cipher, please see
+
+ http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf
+
+
+ Parameters for generating a NaccacheStern KeyPair.
+
+ @param random
+ The source of randomness
+ @param strength
+ The desired strength of the Key in Bits
+ @param certainty
+ the probability that the generated primes are not really prime
+ as integer: 2^(-certainty) is then the probability
+ @param countSmallPrimes
+ How many small key factors are desired
+
+
+ * Parameters for a NaccacheStern KeyPair.
+ *
+ * @param random
+ * The source of randomness
+ * @param strength
+ * The desired strength of the Key in Bits
+ * @param certainty
+ * the probability that the generated primes are not really prime
+ * as integer: 2^(-certainty) is then the probability
+ * @param cntSmallPrimes
+ * How many small key factors are desired
+ * @param debug
+ * Ignored
+
+
+ @return Returns the certainty.
+
+
+ @return Returns the countSmallPrimes.
+
+
+ Public key parameters for NaccacheStern cipher. For details on this cipher,
+ please see
+
+ http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf
+
+
+ @param privateKey
+
+
+ @return Returns the g.
+
+
+ @return Returns the lowerSigmaBound.
+
+
+ @return Returns the n.
+
+
+ Private key parameters for NaccacheStern cipher. For details on this cipher,
+ please see
+
+ http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf
+
+
+ Constructs a NaccacheSternPrivateKey
+
+ @param g
+ the public enryption parameter g
+ @param n
+ the public modulus n = p*q
+ @param lowerSigmaBound
+ the public lower sigma bound up to which data can be encrypted
+ @param smallPrimes
+ the small primes, of which sigma is constructed in the right
+ order
+ @param phi_n
+ the private modulus phi(n) = (p-1)(q-1)
+
+
+ Cipher parameters with a fixed salt value associated with them.
+
+
+
+ Parameters for the Skein hash function - a series of byte[] strings identified by integer tags.
+
+
+ Parameterised Skein can be used for:
+
+ - MAC generation, by providing a key.
+ - Randomised hashing, by providing a nonce.
+ - A hash function for digital signatures, associating a
+ public key with the message digest.
+ - A key derivation function, by providing a
+ key identifier.
+ - Personalised hashing, by providing a
+ recommended format or
+ arbitrary personalisation string.
+
+
+
+
+
+
+
+
+ The parameter type for a secret key, supporting MAC or KDF functions: 0
+
+
+
+
+ The parameter type for the Skein configuration block: 4
+
+
+
+
+ The parameter type for a personalisation string: 8
+
+
+
+
+ The parameter type for a public key: 12
+
+
+
+
+ The parameter type for a key identifier string: 16
+
+
+
+
+ The parameter type for a nonce: 20
+
+
+
+
+ The parameter type for the message: 48
+
+
+
+
+ The parameter type for the output transformation: 63
+
+
+
+
+ Obtains a map of type (int) to value (byte[]) for the parameters tracked in this object.
+
+
+
+
+ Obtains the value of the key parameter, or null
if not
+ set.
+
+ The key.
+
+
+
+ Obtains the value of the personalisation parameter, or
+ null
if not set.
+
+
+
+
+ Obtains the value of the public key parameter, or
+ null
if not set.
+
+
+
+
+ Obtains the value of the key identifier parameter, or
+ null
if not set.
+
+
+
+
+ Obtains the value of the nonce parameter, or null
if
+ not set.
+
+
+
+
+ A builder for .
+
+
+
+
+ Sets a parameters to apply to the Skein hash function.
+
+
+ Parameter types must be in the range 0,5..62, and cannot use the value 48
+ (reserved for message body).
+
+ Parameters with type < 48 are processed before
+ the message content, parameters with type > 48
+ are processed after the message and prior to output.
+
+ the type of the parameter, in the range 5..62.
+ the byte sequence of the parameter.
+
+
+
+ Sets the parameter.
+
+
+
+
+ Sets the parameter.
+
+
+
+
+ Implements the recommended personalisation format for Skein defined in Section 4.11 of
+ the Skein 1.3 specification.
+
+
+ The format is YYYYMMDD email@address distinguisher
, encoded to a byte
+ sequence using UTF-8 encoding.
+
+ the date the personalised application of the Skein was defined.
+ the email address of the creation of the personalised application.
+ an arbitrary personalisation string distinguishing the application.
+
+
+
+ Sets the parameter.
+
+
+
+
+ Sets the parameter.
+
+
+
+
+ Sets the parameter.
+
+
+
+
+ Constructs a new instance with the parameters provided to this
+ builder.
+
+
+
+
+ Parameters for tweakable block ciphers.
+
+
+
+
+ Gets the key.
+
+ the key to use, or null
to use the current key.
+
+
+
+ Gets the tweak value.
+
+ The tweak to use, or null
to use the current tweak.
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ Generate a signature for the message we've been loaded with using
+ the key we were initialised with.
+
+
+ true if the internal state represents the signature described in the passed in array.
+
+
+ Reset the internal state
+
+
+ The Digital Signature Algorithm - as described in "Handbook of Applied
+ Cryptography", pages 452 - 453.
+
+
+ Default configuration, random K values.
+
+
+ Configuration with an alternate, possibly deterministic calculator of K.
+
+ @param kCalculator a K value calculator.
+
+
+ Generate a signature for the given message using the key we were
+ initialised with. For conventional DSA the message should be a SHA-1
+ hash of the message of interest.
+
+ @param message the message that will be verified later.
+
+
+ return true if the value r and s represent a DSA signature for
+ the passed in message for standard DSA the message should be a
+ SHA-1 hash of the real message to be verified.
+
+
+ EC-DSA as described in X9.62
+
+
+ Default configuration, random K values.
+
+
+ Configuration with an alternate, possibly deterministic calculator of K.
+
+ @param kCalculator a K value calculator.
+
+
+ Generate a signature for the given message using the key we were
+ initialised with. For conventional DSA the message should be a SHA-1
+ hash of the message of interest.
+
+ @param message the message that will be verified later.
+
+
+ return true if the value r and s represent a DSA signature for
+ the passed in message (for standard DSA the message should be
+ a SHA-1 hash of the real message to be verified).
+
+
+ GOST R 34.10-2001 Signature Algorithm
+
+
+ generate a signature for the given message using the key we were
+ initialised with. For conventional GOST3410 the message should be a GOST3411
+ hash of the message of interest.
+
+ @param message the message that will be verified later.
+
+
+ return true if the value r and s represent a GOST3410 signature for
+ the passed in message (for standard GOST3410 the message should be
+ a GOST3411 hash of the real message to be verified).
+
+
+ EC-NR as described in IEEE 1363-2000
+
+
+ generate a signature for the given message using the key we were
+ initialised with. Generally, the order of the curve should be at
+ least as long as the hash of the message of interest, and with
+ ECNR it *must* be at least as long.
+
+ @param digest the digest to be signed.
+ @exception DataLengthException if the digest is longer than the key allows
+
+
+ return true if the value r and s represent a signature for the
+ message passed in. Generally, the order of the curve should be at
+ least as long as the hash of the message of interest, and with
+ ECNR, it *must* be at least as long. But just in case the signer
+ applied mod(n) to the longer digest, this implementation will
+ apply mod(n) during verification.
+
+ @param digest the digest to be verified.
+ @param r the r value of the signature.
+ @param s the s value of the signature.
+ @exception DataLengthException if the digest is longer than the key allows
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ Generate a signature for the message we've been loaded with using
+ the key we were initialised with.
+
+
+ true if the internal state represents the signature described in the passed in array.
+
+
+ Reset the internal state
+
+
+ Gost R 34.10-94 Signature Algorithm
+
+
+ generate a signature for the given message using the key we were
+ initialised with. For conventional Gost3410 the message should be a Gost3411
+ hash of the message of interest.
+
+ @param message the message that will be verified later.
+
+
+ return true if the value r and s represent a Gost3410 signature for
+ the passed in message for standard Gost3410 the message should be a
+ Gost3411 hash of the real message to be verified.
+
+
+ initialise the signer for signing or verification.
+
+ @param forSigning
+ true if for signing, false otherwise
+ @param parameters
+ necessary parameters.
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ Generate a signature for the message we've been loaded with using the key
+ we were initialised with.
+
+
+ return true if the internal state represents the signature described in
+ the passed in array.
+
+
+ A deterministic K calculator based on the algorithm in section 3.2 of RFC 6979.
+
+
+ Base constructor.
+
+ @param digest digest to build the HMAC on.
+
+
+ Interface define calculators of K values for DSA/ECDSA.
+
+
+ Return true if this calculator is deterministic, false otherwise.
+
+ @return true if deterministic, otherwise false.
+
+
+ Non-deterministic initialiser.
+
+ @param n the order of the DSA group.
+ @param random a source of randomness.
+
+
+ Deterministic initialiser.
+
+ @param n the order of the DSA group.
+ @param d the DSA private value.
+ @param message the message being signed.
+
+
+ Return the next valid value of K.
+
+ @return a K value.
+
+
+ ISO9796-2 - mechanism using a hash function with recovery (scheme 2 and 3).
+
+ Note: the usual length for the salt is the length of the hash
+ function used in bytes.
+
+
+
+
+ Return a reference to the recoveredMessage message.
+
+ The full/partial recoveredMessage message.
+
+
+
+
+ Generate a signer with either implicit or explicit trailers for ISO9796-2, scheme 2 or 3.
+
+ base cipher to use for signature creation/verification
+ digest to use.
+ length of salt in bytes.
+ whether or not the trailer is implicit or gives the hash.
+
+
+ Constructor for a signer with an explicit digest trailer.
+
+
+ cipher to use.
+
+ digest to sign with.
+
+ length of salt in bytes.
+
+
+
+ Initialise the signer.
+ true if for signing, false if for verification.
+ parameters for signature generation/verification. If the
+ parameters are for generation they should be a ParametersWithRandom,
+ a ParametersWithSalt, or just an RsaKeyParameters object. If RsaKeyParameters
+ are passed in a SecureRandom will be created.
+
+ if wrong parameter type or a fixed
+ salt is passed in which is the wrong length.
+
+
+
+ compare two byte arrays - constant time.
+
+
+ clear possible sensitive data
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ reset the internal state
+
+
+ Generate a signature for the loaded message using the key we were
+ initialised with.
+
+
+
+ return true if the signature represents a ISO9796-2 signature
+ for the passed in message.
+
+
+
+
+ Return true if the full message was recoveredMessage.
+
+ true on full message recovery, false otherwise, or if not sure.
+
+
+
+ int to octet string.
+ int to octet string.
+
+
+ long to octet string.
+
+
+ mask generator function, as described in Pkcs1v2.
+
+
+ ISO9796-2 - mechanism using a hash function with recovery (scheme 1)
+
+
+
+ Return a reference to the recoveredMessage message.
+
+ The full/partial recoveredMessage message.
+
+
+
+
+ Generate a signer with either implicit or explicit trailers for ISO9796-2.
+
+ base cipher to use for signature creation/verification
+ digest to use.
+ whether or not the trailer is implicit or gives the hash.
+
+
+ Constructor for a signer with an explicit digest trailer.
+
+
+ cipher to use.
+
+ digest to sign with.
+
+
+
+ compare two byte arrays - constant time.
+
+
+ clear possible sensitive data
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ reset the internal state
+
+
+ Generate a signature for the loaded message using the key we were
+ initialised with.
+
+
+
+ return true if the signature represents a ISO9796-2 signature
+ for the passed in message.
+
+
+
+
+ Return true if the full message was recoveredMessage.
+
+ true on full message recovery, false otherwise.
+
+
+
+ RSA-PSS as described in Pkcs# 1 v 2.1.
+
+ Note: the usual value for the salt length is the number of
+ bytes in the hash function.
+
+
+
+ Basic constructor
+ the asymmetric cipher to use.
+ the digest to use.
+ the length of the salt to use (in bytes).
+
+
+ Basic constructor
+ the asymmetric cipher to use.
+ the digest to use.
+ the fixed salt to be used.
+
+
+ clear possible sensitive data
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ reset the internal state
+
+
+ Generate a signature for the message we've been loaded with using
+ the key we were initialised with.
+
+
+
+ return true if the internal state represents the signature described
+ in the passed in array.
+
+
+
+ int to octet string.
+
+
+ mask generator function, as described in Pkcs1v2.
+
+
+
+ Load oid table.
+
+
+
+ Initialise the signer for signing or verification.
+
+ @param forSigning true if for signing, false otherwise
+ @param param necessary parameters.
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ Generate a signature for the message we've been loaded with using
+ the key we were initialised with.
+
+
+ return true if the internal state represents the signature described
+ in the passed in array.
+
+
+ X9.31-1998 - signing using a hash.
+
+ The message digest hash, H, is encapsulated to form a byte string as follows
+
+
+ EB = 06 || PS || 0xBA || H || TRAILER
+
+ where PS is a string of bytes all of value 0xBB of length such that |EB|=|n|, and TRAILER is the ISO/IEC 10118 part number†for the digest. The byte string, EB, is converted to an integer value, the message representative, f.
+
+
+ Generate a signer with either implicit or explicit trailers for X9.31.
+
+ @param cipher base cipher to use for signature creation/verification
+ @param digest digest to use.
+ @param implicit whether or not the trailer is implicit or gives the hash.
+
+
+ Constructor for a signer with an explicit digest trailer.
+
+ @param cipher cipher to use.
+ @param digest digest to sign with.
+
+
+ clear possible sensitive data
+
+
+ update the internal digest with the byte b
+
+
+ update the internal digest with the byte array in
+
+
+ reset the internal state
+
+
+ generate a signature for the loaded message using the key we were
+ initialised with.
+
+
+ return true if the signature represents a ISO9796-2 signature
+ for the passed in message.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ RFC 5246 7.2
+
+
+
+ This message notifies the recipient that the sender will not send any more messages on this
+ connection. Note that as of TLS 1.1, failure to properly close a connection no longer
+ requires that a session not be resumed. This is a change from TLS 1.0 ("The session becomes
+ unresumable if any connection is terminated without proper close_notify messages with level
+ equal to warning.") to conform with widespread implementation practice.
+
+
+ An inappropriate message was received. This alert is always fatal and should never be
+ observed in communication between proper implementations.
+
+
+ This alert is returned if a record is received with an incorrect MAC. This alert also MUST be
+ returned if an alert is sent because a TLSCiphertext decrypted in an invalid way: either it
+ wasn't an even multiple of the block length, or its padding values, when checked, weren't
+ correct. This message is always fatal and should never be observed in communication between
+ proper implementations (except when messages were corrupted in the network).
+
+
+ This alert was used in some earlier versions of TLS, and may have permitted certain attacks
+ against the CBC mode [CBCATT]. It MUST NOT be sent by compliant implementations.
+
+
+ A TLSCiphertext record was received that had a length more than 2^14+2048 bytes, or a record
+ decrypted to a TLSCompressed record with more than 2^14+1024 bytes. This message is always
+ fatal and should never be observed in communication between proper implementations (except
+ when messages were corrupted in the network).
+
+
+ The decompression function received improper input (e.g., data that would expand to excessive
+ length). This message is always fatal and should never be observed in communication between
+ proper implementations.
+
+
+ Reception of a handshake_failure alert message indicates that the sender was unable to
+ negotiate an acceptable set of security parameters given the options available. This is a
+ fatal error.
+
+
+ This alert was used in SSLv3 but not any version of TLS. It MUST NOT be sent by compliant
+ implementations.
+
+
+ A certificate was corrupt, contained signatures that did not verify correctly, etc.
+
+
+ A certificate was of an unsupported type.
+
+
+ A certificate was revoked by its signer.
+
+
+ A certificate has expired or is not currently valid.
+
+
+ Some other (unspecified) issue arose in processing the certificate, rendering it
+ unacceptable.
+
+
+ A field in the handshake was out of range or inconsistent with other fields. This message is
+ always fatal.
+
+
+ A valid certificate chain or partial chain was received, but the certificate was not accepted
+ because the CA certificate could not be located or couldn't be matched with a known, trusted
+ CA. This message is always fatal.
+
+
+ A valid certificate was received, but when access control was applied, the sender decided not
+ to proceed with negotiation. This message is always fatal.
+
+
+ A message could not be decoded because some field was out of the specified range or the
+ length of the message was incorrect. This message is always fatal and should never be
+ observed in communication between proper implementations (except when messages were corrupted
+ in the network).
+
+
+ A handshake cryptographic operation failed, including being unable to correctly verify a
+ signature or validate a Finished message. This message is always fatal.
+
+
+ This alert was used in some earlier versions of TLS. It MUST NOT be sent by compliant
+ implementations.
+
+
+ The protocol version the client has attempted to negotiate is recognized but not supported.
+ (For example, old protocol versions might be avoided for security reasons.) This message is
+ always fatal.
+
+
+ Returned instead of handshake_failure when a negotiation has failed specifically because the
+ server requires ciphers more secure than those supported by the client. This message is
+ always fatal.
+
+
+ An internal error unrelated to the peer or the correctness of the protocol (such as a memory
+ allocation failure) makes it impossible to continue. This message is always fatal.
+
+
+ This handshake is being canceled for some reason unrelated to a protocol failure. If the user
+ cancels an operation after the handshake is complete, just closing the connection by sending
+ a close_notify is more appropriate. This alert should be followed by a close_notify. This
+ message is generally a warning.
+
+
+ Sent by the client in response to a hello request or by the server in response to a client
+ hello after initial handshaking. Either of these would normally lead to renegotiation; when
+ that is not appropriate, the recipient should respond with this alert. At that point, the
+ original requester can decide whether to proceed with the connection. One case where this
+ would be appropriate is where a server has spawned a process to satisfy a request; the
+ process might receive security parameters (key length, authentication, etc.) at startup, and
+ it might be difficult to communicate changes to these parameters after that point. This
+ message is always a warning.
+
+
+ Sent by clients that receive an extended server hello containing an extension that they did
+ not put in the corresponding client hello. This message is always fatal.
+
+
+ This alert is sent by servers who are unable to retrieve a certificate chain from the URL
+ supplied by the client (see Section 3.3). This message MAY be fatal - for example if client
+ authentication is required by the server for the handshake to continue and the server is
+ unable to retrieve the certificate chain, it may send a fatal alert.
+
+
+ This alert is sent by servers that receive a server_name extension request, but do not
+ recognize the server name. This message MAY be fatal.
+
+
+ This alert is sent by clients that receive an invalid certificate status response (see
+ Section 3.6). This message is always fatal.
+
+
+ This alert is sent by servers when a certificate hash does not match a client provided
+ certificate_hash. This message is always fatal.
+
+
+ If the server does not recognize the PSK identity, it MAY respond with an
+ "unknown_psk_identity" alert message.
+
+
+ If TLS_FALLBACK_SCSV appears in ClientHello.cipher_suites and the highest protocol version
+ supported by the server is higher than the version indicated in ClientHello.client_version,
+ the server MUST respond with an inappropriate_fallback alert.
+
+
+
+ RFC 5246 7.2
+
+
+
+ RFC 2246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+
+ A queue for bytes.
+
+ This file could be more optimized.
+
+
+
+
+ The smallest number which can be written as 2^x which is bigger than i.
+
+
+ The initial size for our buffer.
+
+
+ The buffer where we store our data.
+
+
+ How many bytes at the beginning of the buffer are skipped.
+
+
+ How many bytes in the buffer are valid data.
+
+
+ Read data from the buffer.
+ The buffer where the read data will be copied to.
+ How many bytes to skip at the beginning of buf.
+ How many bytes to read at all.
+ How many bytes from our data to skip.
+
+
+ Add some data to our buffer.
+ A byte-array to read data from.
+ How many bytes to skip at the beginning of the array.
+ How many bytes to read from the array.
+
+
+ Remove some bytes from our data from the beginning.
+ How many bytes to remove.
+
+
+ The number of bytes which are available in this buffer.
+
+
+ Parsing and encoding of a Certificate struct from RFC 4346.
+
+
+ opaque ASN.1Cert<2^24-1>;
+
+ struct {
+ ASN.1Cert certificate_list<0..2^24-1>;
+ } Certificate;
+
+
+ @see Org.BouncyCastle.Asn1.X509.X509CertificateStructure
+
+
+ The certificates.
+
+
+ @return an array of {@link org.bouncycastle.asn1.x509.Certificate} representing a certificate
+ chain.
+
+
+ @return true
if this certificate chain contains no certificates, or
+ false
otherwise.
+
+
+ Encode this {@link Certificate} to a {@link Stream}.
+
+ @param output the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link Certificate} from a {@link Stream}.
+
+ @param input the {@link Stream} to parse from.
+ @return a {@link Certificate} object.
+ @throws IOException
+
+
+ Parsing and encoding of a CertificateRequest struct from RFC 4346.
+
+
+ struct {
+ ClientCertificateType certificate_types<1..2^8-1>;
+ DistinguishedName certificate_authorities<3..2^16-1>
+ } CertificateRequest;
+
+
+ @see ClientCertificateType
+ @see X509Name
+
+
+ @param certificateTypes see {@link ClientCertificateType} for valid constants.
+ @param certificateAuthorities an {@link IList} of {@link X509Name}.
+
+
+ @return an array of certificate types
+ @see {@link ClientCertificateType}
+
+
+ @return an {@link IList} of {@link SignatureAndHashAlgorithm} (or null before TLS 1.2).
+
+
+ @return an {@link IList} of {@link X509Name}
+
+
+ Encode this {@link CertificateRequest} to a {@link Stream}.
+
+ @param output the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link CertificateRequest} from a {@link Stream}.
+
+ @param context
+ the {@link TlsContext} of the current connection.
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link CertificateRequest} object.
+ @throws IOException
+
+
+ Encode this {@link CertificateStatus} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link CertificateStatus} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link CertificateStatus} object.
+ @throws IOException
+
+
+ Encode this {@link CertificateStatusRequest} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link CertificateStatusRequest} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link CertificateStatusRequest} object.
+ @throws IOException
+
+
+ @param type
+ see {@link CertChainType} for valid constants.
+ @param urlAndHashList
+ a {@link IList} of {@link UrlAndHash}.
+
+
+ @return {@link CertChainType}
+
+
+ @return an {@link IList} of {@link UrlAndHash}
+
+
+ Encode this {@link CertificateUrl} to a {@link Stream}.
+
+ @param output the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link CertificateUrl} from a {@link Stream}.
+
+ @param context
+ the {@link TlsContext} of the current connection.
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link CertificateUrl} object.
+ @throws IOException
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ RFC 2246 A.5
+
+
+
+ RFC 2246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+ A combined hash, which implements md5(m) || sha1(m).
+
+
+ @see org.bouncycastle.crypto.Digest#update(byte[], int, int)
+
+
+ @see org.bouncycastle.crypto.Digest#doFinal(byte[], int)
+
+
+ @see org.bouncycastle.crypto.Digest#reset()
+
+
+
+ RFC 2246 6.1
+
+
+
+ RFC 2246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+ RFC 2246 6.2.1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Accept only the group parameters specified in RFC 5054 Appendix A.
+
+
+ Specify a custom set of acceptable group parameters.
+
+ @param groups a {@link Vector} of acceptable {@link SRP6GroupParameters}
+
+
+ Buffers input until the hash algorithm is determined.
+
+
+ @return a {@link SignatureAndHashAlgorithm} (or null before TLS 1.2).
+
+
+ Encode this {@link DigitallySigned} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link DigitallySigned} from a {@link Stream}.
+
+ @param context
+ the {@link TlsContext} of the current connection.
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link DigitallySigned} object.
+ @throws IOException
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Check that there are no "extra" messages left in the current inbound flight
+
+
+ RFC 4347 4.1.2.5 Anti-replay
+
+ Support fast rejection of duplicate records by maintaining a sliding receive window
+
+
+ Check whether a received record with the given sequence number should be rejected as a duplicate.
+
+ @param seq the 48-bit DTLSPlainText.sequence_number field of a received record.
+ @return true if the record should be discarded without further processing.
+
+
+ Report that a received record with the given sequence number passed authentication checks.
+
+ @param seq the 48-bit DTLSPlainText.sequence_number field of an authenticated record.
+
+
+ When a new epoch begins, sequence numbers begin again at 0
+
+
+ RFC 4492 5.4. (Errata ID: 2389)
+
+
+
+ RFC 4492 5.4
+
+
+
+ Indicates the elliptic curve domain parameters are conveyed verbosely, and the
+ underlying finite field is a prime field.
+
+
+ Indicates the elliptic curve domain parameters are conveyed verbosely, and the
+ underlying finite field is a characteristic-2 field.
+
+
+ Indicates that a named curve is used. This option SHOULD be used when applicable.
+
+
+
+ RFC 4492 5.1.2
+
+
+
+ RFC 2246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+ RFC 5705
+
+
+ RFC 5246 7.4.1.4.1
+
+
+ Encode this {@link HeartbeatExtension} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link HeartbeatExtension} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link HeartbeatExtension} object.
+ @throws IOException
+
+
+ Encode this {@link HeartbeatMessage} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link HeartbeatMessage} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link HeartbeatMessage} object.
+ @throws IOException
+
+
+ RFC 2246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+ RFC 2246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+
+ RFC 4492 5.1.1
+ The named curves defined here are those specified in SEC 2 [13]. Note that many of
+ these curves are also recommended in ANSI X9.62 [7] and FIPS 186-2 [11]. Values 0xFE00
+ through 0xFEFF are reserved for private use. Values 0xFF01 and 0xFF02 indicate that the
+ client supports arbitrary prime and characteristic-2 curves, respectively (the curve
+ parameters must be encoded explicitly in ECParameters).
+
+
+
+ Encode this {@link NewSessionTicket} to a {@link Stream}.
+
+ @param output the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link NewSessionTicket} from a {@link Stream}.
+
+ @param input the {@link Stream} to parse from.
+ @return a {@link NewSessionTicket} object.
+ @throws IOException
+
+
+ RFC 3546 3.6
+
+
+ @param responderIDList
+ an {@link IList} of {@link ResponderID}, specifying the list of trusted OCSP
+ responders. An empty list has the special meaning that the responders are
+ implicitly known to the server - e.g., by prior arrangement.
+ @param requestExtensions
+ OCSP request extensions. A null value means that there are no extensions.
+
+
+ @return an {@link IList} of {@link ResponderID}
+
+
+ @return OCSP request extensions
+
+
+ Encode this {@link OcspStatusRequest} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link OcspStatusRequest} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return an {@link OcspStatusRequest} object.
+ @throws IOException
+
+
+ RFC 5246
+
+ Note that the values here are implementation-specific and arbitrary. It is recommended not to
+ depend on the particular values (e.g. serialization).
+
+
+
+
+
+
+ An implementation of the TLS 1.0/1.1/1.2 record layer, allowing downgrade to SSLv3.
+
+
+ RFC 5246 E.1. "Earlier versions of the TLS specification were not fully clear on what the
+ record layer version number (TLSPlaintext.version) should contain when sending ClientHello
+ (i.e., before it is known which version of the protocol will be employed). Thus, TLS servers
+ compliant with this specification MUST accept any value {03,XX} as the record layer version
+ number for ClientHello."
+
+
+ @return {@link ConnectionEnd}
+
+
+ @return {@link CipherSuite}
+
+
+ @return {@link CompressionMethod}
+
+
+ @return {@link PRFAlgorithm}
+
+
+ Encode this {@link ServerDHParams} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link ServerDHParams} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link ServerDHParams} object.
+ @throws IOException
+
+
+ Encode this {@link ServerName} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link ServerName} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link ServerName} object.
+ @throws IOException
+
+
+ @param serverNameList an {@link IList} of {@link ServerName}.
+
+
+ @return an {@link IList} of {@link ServerName}.
+
+
+ Encode this {@link ServerNameList} to a {@link Stream}.
+
+ @param output
+ the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link ServerNameList} from a {@link Stream}.
+
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link ServerNameList} object.
+ @throws IOException
+
+
+ Encode this {@link ServerSRPParams} to an {@link OutputStream}.
+
+ @param output
+ the {@link OutputStream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link ServerSRPParams} from an {@link InputStream}.
+
+ @param input
+ the {@link InputStream} to parse from.
+ @return a {@link ServerSRPParams} object.
+ @throws IOException
+
+
+ RFC 5246 7.4.1.4.1 (in RFC 2246, there were no specific values assigned)
+
+
+ RFC 5246 7.4.1.4.1
+
+
+ @param hash {@link HashAlgorithm}
+ @param signature {@link SignatureAlgorithm}
+
+
+ @return {@link HashAlgorithm}
+
+
+ @return {@link SignatureAlgorithm}
+
+
+ Encode this {@link SignatureAndHashAlgorithm} to a {@link Stream}.
+
+ @param output the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link SignatureAndHashAlgorithm} from a {@link Stream}.
+
+ @param input the {@link Stream} to parse from.
+ @return a {@link SignatureAndHashAlgorithm} object.
+ @throws IOException
+
+
+ An implementation of {@link TlsSRPIdentityManager} that simulates the existence of "unknown" identities
+ to obscure the fact that there is no verifier for them.
+
+
+ Create a {@link SimulatedTlsSRPIdentityManager} that implements the algorithm from RFC 5054 2.5.1.3
+
+ @param group the {@link SRP6GroupParameters} defining the group that SRP is operating in
+ @param seedKey the secret "seed key" referred to in RFC 5054 2.5.1.3
+ @return an instance of {@link SimulatedTlsSRPIdentityManager}
+
+
+ HMAC implementation based on original internet draft for HMAC (RFC 2104)
+
+ The difference is that padding is concatentated versus XORed with the key
+
+ H(K + opad, H(K + ipad, text))
+
+
+ Base constructor for one of the standard digest algorithms that the byteLength of
+ the algorithm is know for. Behaviour is undefined for digests other than MD5 or SHA1.
+
+ @param digest the digest.
+
+
+ Reset the mac generator.
+
+
+ RFC 4680
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Called by the protocol handler to report the server certificate.
+
+
+ This method is responsible for certificate verification and validation
+
+ The server received
+
+
+
+
+ Return client credentials in response to server's certificate request
+
+
+ A containing server certificate request details
+
+
+ A to be used for client authentication
+ (or null for no client authentication)
+
+
+
+
+
+ A generic TLS 1.0-1.2 / SSLv3 block cipher. This can be used for AES or 3DES for example.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Called at the start of a new TLS session, before any other methods.
+
+
+ A
+
+
+
+ Return the session this client wants to resume, if any.
+ Note that the peer's certificate chain for the session (if any) may need to be periodically revalidated.
+
+ A representing the resumable session to be used for this connection,
+ or null to use a new session.
+
+
+
+
+ Return the to use for the TLSPlaintext.version field prior to
+ receiving the server version. NOTE: This method is not called for DTLS.
+
+
+ See RFC 5246 E.1.: "TLS clients that wish to negotiate with older servers MAY send any value
+ {03,XX} as the record layer version number. Typical values would be {03,00}, the lowest
+ version number supported by the client, and the value of ClientHello.client_version. No
+ single value will guarantee interoperability with all old servers, but this is a complex
+ topic beyond the scope of this document."
+
+ The to use.
+
+
+
+ Get the list of cipher suites that this client supports.
+
+
+ An array of values, each specifying a supported cipher suite.
+
+
+
+
+ Get the list of compression methods that this client supports.
+
+
+ An array of values, each specifying a supported compression method.
+
+
+
+
+ Get the (optional) table of client extensions to be included in (extended) client hello.
+
+
+ A (Int32 -> byte[]). May be null.
+
+
+
+
+
+
+
+
+ Notifies the client of the session_id sent in the ServerHello.
+
+ An array of
+
+
+
+ Report the cipher suite that was selected by the server.
+
+
+ The protocol handler validates this value against the offered cipher suites
+
+
+
+ A
+
+
+
+
+ Report the compression method that was selected by the server.
+
+
+ The protocol handler validates this value against the offered compression methods
+
+
+
+ A
+
+
+
+
+ Report the extensions from an extended server hello.
+
+
+ Will only be called if we returned a non-null result from .
+
+
+ A (Int32 -> byte[])
+
+
+
+ A list of
+
+
+
+
+ Return an implementation of to negotiate the key exchange
+ part of the protocol.
+
+
+ A
+
+
+
+
+
+ Return an implementation of to handle authentication
+ part of the protocol.
+
+
+
+
+ A list of
+
+
+
+ RFC 5077 3.3. NewSessionTicket Handshake Message
+
+ This method will be called (only) when a NewSessionTicket handshake message is received. The
+ ticket is opaque to the client and clients MUST NOT examine the ticket under the assumption
+ that it complies with e.g. RFC 5077 4. Recommended Ticket Construction.
+
+ The ticket
+
+
+
+ Constructor for blocking mode.
+ @param stream The bi-directional stream of data to/from the server
+ @param secureRandom Random number generator for various cryptographic functions
+
+
+ Constructor for blocking mode.
+ @param input The stream of data from the server
+ @param output The stream of data to the server
+ @param secureRandom Random number generator for various cryptographic functions
+
+
+ Constructor for non-blocking mode.
+
+ When data is received, use {@link #offerInput(java.nio.ByteBuffer)} to
+ provide the received ciphertext, then use
+ {@link #readInput(byte[], int, int)} to read the corresponding cleartext.
+
+ Similarly, when data needs to be sent, use
+ {@link #offerOutput(byte[], int, int)} to provide the cleartext, then use
+ {@link #readOutput(byte[], int, int)} to get the corresponding
+ ciphertext.
+
+ @param secureRandom
+ Random number generator for various cryptographic functions
+
+
+ Initiates a TLS handshake in the role of client.
+
+ In blocking mode, this will not return until the handshake is complete.
+ In non-blocking mode, use {@link TlsPeer#NotifyHandshakeComplete()} to
+ receive a callback when the handshake is complete.
+
+ @param tlsClient The {@link TlsClient} to use for the handshake.
+ @throws IOException If in blocking mode and handshake was not successful.
+
+
+ Used to get the resumable session, if any, used by this connection. Only available after the
+ handshake has successfully completed.
+
+ @return A {@link TlsSession} representing the resumable session used by this connection, or
+ null if no resumable session available.
+ @see TlsPeer#NotifyHandshakeComplete()
+
+
+ Export keying material according to RFC 5705: "Keying Material Exporters for TLS".
+
+ @param asciiLabel indicates which application will use the exported keys.
+ @param context_value allows the application using the exporter to mix its own data with the TLS PRF for
+ the exporter output.
+ @param length the number of bytes to generate
+ @return a pseudorandom bit string of 'length' bytes generated from the master_secret.
+
+
+ (D)TLS DH key exchange.
+
+
+ (D)TLS ECDH key exchange (see RFC 4492).
+
+
+ (D)TLS ECDHE key exchange (see RFC 4492).
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ A generic interface for key exchange implementations in (D)TLS.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ A generic TLS MAC implementation, acting as an HMAC based on some underlying Digest.
+
+
+
+ Generate a new instance of an TlsMac.
+
+ @param context the TLS client context
+ @param digest The digest to use.
+ @param key A byte-array where the key for this MAC is located.
+ @param keyOff The number of bytes to skip, before the key starts in the buffer.
+ @param keyLen The length of the key.
+
+
+ @return the MAC write secret
+
+
+ @return The output length of this MAC.
+
+
+ Calculate the MAC for some given data.
+
+ @param type The message type of the message.
+ @param message A byte-buffer containing the message.
+ @param offset The number of bytes to skip, before the message starts.
+ @param length The length of the message.
+ @return A new byte-buffer containing the MAC value.
+
+
+
+ A NULL CipherSuite, with optional MAC.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ draft-mathewson-no-gmtunixtime-00 2. "If existing users of a TLS implementation may rely on
+ gmt_unix_time containing the current time, we recommend that implementors MAY provide the
+ ability to set gmt_unix_time as an option only, off by default."
+
+
+ true
if the current time should be used in the gmt_unix_time field of
+ Random, or false
if gmt_unix_time should contain a cryptographically
+ random value.
+
+
+
+
+ Report whether the server supports secure renegotiation
+
+
+ The protocol handler automatically processes the relevant extensions
+
+
+ A , true if the server supports secure renegotiation
+
+
+
+
+
+ Return an implementation of to handle record compression.
+
+ A
+
+
+
+
+ Return an implementation of to use for encryption/decryption.
+
+ A
+
+
+
+ This method will be called when an alert is raised by the protocol.
+
+
+ A human-readable message explaining what caused this alert. May be null.
+ The Exception that caused this alert to be raised. May be null.
+
+
+ This method will be called when an alert is received from the remote peer.
+
+
+
+
+ Notifies the peer that the handshake has been successfully completed.
+
+
+
+ This method is called, when a change cipher spec message is received.
+
+ @throws IOException If the message has an invalid content or the handshake is not in the correct
+ state.
+
+
+ Read data from the network. The method will return immediately, if there is still some data
+ left in the buffer, or block until some application data has been read from the network.
+
+ @param buf The buffer where the data will be copied to.
+ @param offset The position where the data will be placed in the buffer.
+ @param len The maximum number of bytes to read.
+ @return The number of bytes read.
+ @throws IOException If something goes wrong during reading data.
+
+
+ Send some application data to the remote system.
+
+ The method will handle fragmentation internally.
+
+ @param buf The buffer with the data.
+ @param offset The position in the buffer where the data is placed.
+ @param len The length of the data.
+ @throws IOException If something goes wrong during sending.
+
+
+ The secure bidirectional stream for this connection
+ Only allowed in blocking mode.
+
+
+ Offer input from an arbitrary source. Only allowed in non-blocking mode.
+
+ After this method returns, the input buffer is "owned" by this object. Other code
+ must not attempt to do anything with it.
+
+ This method will decrypt and process all records that are fully available.
+ If only part of a record is available, the buffer will be retained until the
+ remainder of the record is offered.
+
+ If any records containing application data were processed, the decrypted data
+ can be obtained using {@link #readInput(byte[], int, int)}. If any records
+ containing protocol data were processed, a response may have been generated.
+ You should always check to see if there is any available output after calling
+ this method by calling {@link #getAvailableOutputBytes()}.
+ @param input The input buffer to offer
+ @throws IOException If an error occurs while decrypting or processing a record
+
+
+ Gets the amount of received application data. A call to {@link #readInput(byte[], int, int)}
+ is guaranteed to be able to return at least this much data.
+
+ Only allowed in non-blocking mode.
+ @return The number of bytes of available application data
+
+
+ Retrieves received application data. Use {@link #getAvailableInputBytes()} to check
+ how much application data is currently available. This method functions similarly to
+ {@link InputStream#read(byte[], int, int)}, except that it never blocks. If no data
+ is available, nothing will be copied and zero will be returned.
+
+ Only allowed in non-blocking mode.
+ @param buffer The buffer to hold the application data
+ @param offset The start offset in the buffer at which the data is written
+ @param length The maximum number of bytes to read
+ @return The total number of bytes copied to the buffer. May be less than the
+ length specified if the length was greater than the amount of available data.
+
+
+ Offer output from an arbitrary source. Only allowed in non-blocking mode.
+
+ After this method returns, the specified section of the buffer will have been
+ processed. Use {@link #readOutput(byte[], int, int)} to get the bytes to
+ transmit to the other peer.
+
+ This method must not be called until after the handshake is complete! Attempting
+ to call it before the handshake is complete will result in an exception.
+ @param buffer The buffer containing application data to encrypt
+ @param offset The offset at which to begin reading data
+ @param length The number of bytes of data to read
+ @throws IOException If an error occurs encrypting the data, or the handshake is not complete
+
+
+ Gets the amount of encrypted data available to be sent. A call to
+ {@link #readOutput(byte[], int, int)} is guaranteed to be able to return at
+ least this much data.
+
+ Only allowed in non-blocking mode.
+ @return The number of bytes of available encrypted data
+
+
+ Retrieves encrypted data to be sent. Use {@link #getAvailableOutputBytes()} to check
+ how much encrypted data is currently available. This method functions similarly to
+ {@link InputStream#read(byte[], int, int)}, except that it never blocks. If no data
+ is available, nothing will be copied and zero will be returned.
+
+ Only allowed in non-blocking mode.
+ @param buffer The buffer to hold the encrypted data
+ @param offset The start offset in the buffer at which the data is written
+ @param length The maximum number of bytes to read
+ @return The total number of bytes copied to the buffer. May be less than the
+ length specified if the length was greater than the amount of available data.
+
+
+ Terminate this connection with an alert. Can be used for normal closure too.
+
+ @param alertLevel
+ See {@link AlertLevel} for values.
+ @param alertDescription
+ See {@link AlertDescription} for values.
+ @throws IOException
+ If alert was fatal.
+
+
+ Closes this connection.
+
+ @throws IOException If something goes wrong during closing.
+
+
+ Make sure the InputStream 'buf' now empty. Fail otherwise.
+
+ @param buf The InputStream to check.
+ @throws IOException If 'buf' is not empty.
+
+
+ 'sender' only relevant to SSLv3
+
+
+ Both streams can be the same object
+
+
+ (D)TLS PSK key exchange (RFC 4279).
+
+
+ (D)TLS and SSLv3 RSA key exchange.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ A (Int32 -> byte[]). Will never be null.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Get the (optional) table of server extensions to be included in (extended) server hello.
+
+
+ A (Int32 -> byte[]). May be null.
+
+
+
+
+
+ A (). May be null.
+
+
+
+
+
+
+
+
+ This method will be called (only) if the server included an extension of type
+ "status_request" with empty "extension_data" in the extended server hello. See RFC 3546
+ 3.6. Certificate Status Request. If a non-null is returned, it
+ is sent to the client as a handshake message of type "certificate_status".
+
+ A to be sent to the client (or null for none).
+
+
+
+
+
+
+
+
+
+ ()
+
+
+
+
+ Called by the protocol handler to report the client certificate, only if GetCertificateRequest
+ returned non-null.
+
+ Note: this method is responsible for certificate verification and validation.
+ the effective client certificate (may be an empty chain).
+
+
+
+ RFC 5077 3.3. NewSessionTicket Handshake Message.
+
+ This method will be called (only) if a NewSessionTicket extension was sent by the server. See
+ RFC 5077 4. Recommended Ticket Construction for recommended format and protection.
+
+ The ticket)
+
+
+
+ Constructor for blocking mode.
+ @param stream The bi-directional stream of data to/from the client
+ @param output The stream of data to the client
+ @param secureRandom Random number generator for various cryptographic functions
+
+
+ Constructor for blocking mode.
+ @param input The stream of data from the client
+ @param output The stream of data to the client
+ @param secureRandom Random number generator for various cryptographic functions
+
+
+ Constructor for non-blocking mode.
+
+ When data is received, use {@link #offerInput(java.nio.ByteBuffer)} to
+ provide the received ciphertext, then use
+ {@link #readInput(byte[], int, int)} to read the corresponding cleartext.
+
+ Similarly, when data needs to be sent, use
+ {@link #offerOutput(byte[], int, int)} to provide the cleartext, then use
+ {@link #readOutput(byte[], int, int)} to get the corresponding
+ ciphertext.
+
+ @param secureRandom
+ Random number generator for various cryptographic functions
+
+
+ Receives a TLS handshake in the role of server.
+
+ In blocking mode, this will not return until the handshake is complete.
+ In non-blocking mode, use {@link TlsPeer#notifyHandshakeComplete()} to
+ receive a callback when the handshake is complete.
+
+ @param tlsServer
+ @throws IOException If in blocking mode and handshake was not successful.
+
+
+
+
+
+ Check whether the given SRP group parameters are acceptable for use.
+
+ @param group the {@link SRP6GroupParameters} to check
+ @return true if (and only if) the specified group parameters are acceptable
+
+
+ Lookup the {@link TlsSRPLoginParameters} corresponding to the specified identity.
+
+ NOTE: To avoid "identity probing", unknown identities SHOULD be handled as recommended in RFC
+ 5054 2.5.1.3. {@link SimulatedTlsSRPIdentityManager} is provided for this purpose.
+
+ @param identity
+ the SRP identity sent by the connecting client
+ @return the {@link TlsSRPLoginParameters} for the specified identity, or else 'simulated'
+ parameters if the identity is not recognized. A null value is also allowed, but not
+ recommended.
+
+
+ (D)TLS SRP key exchange (RFC 5054).
+
+
+ RFC 5764 DTLS Extension to Establish Keys for SRTP.
+
+
+
+
+
+
+
+
+
+
+
+ Some helper functions for MicroTLS.
+
+
+ Add a 'signature_algorithms' extension to existing extensions.
+
+ @param extensions A {@link Hashtable} to add the extension to.
+ @param supportedSignatureAlgorithms {@link Vector} containing at least 1 {@link SignatureAndHashAlgorithm}.
+ @throws IOException
+
+
+ Get a 'signature_algorithms' extension from extensions.
+
+ @param extensions A {@link Hashtable} to get the extension from, if it is present.
+ @return A {@link Vector} containing at least 1 {@link SignatureAndHashAlgorithm}, or null.
+ @throws IOException
+
+
+ Create a 'signature_algorithms' extension value.
+
+ @param supportedSignatureAlgorithms A {@link Vector} containing at least 1 {@link SignatureAndHashAlgorithm}.
+ @return A byte array suitable for use as an extension value.
+ @throws IOException
+
+
+ Read 'signature_algorithms' extension data.
+
+ @param extensionData The extension data.
+ @return A {@link Vector} containing at least 1 {@link SignatureAndHashAlgorithm}.
+ @throws IOException
+
+
+ RFC 6066 5.
+
+
+ Encode this {@link UrlAndHash} to a {@link Stream}.
+
+ @param output the {@link Stream} to encode to.
+ @throws IOException
+
+
+ Parse a {@link UrlAndHash} from a {@link Stream}.
+
+ @param context
+ the {@link TlsContext} of the current connection.
+ @param input
+ the {@link Stream} to parse from.
+ @return a {@link UrlAndHash} object.
+ @throws IOException
+
+
+ RFC 5764 4.1.1
+
+
+ @param protectionProfiles see {@link SrtpProtectionProfile} for valid constants.
+ @param mki valid lengths from 0 to 255.
+
+
+ @return see {@link SrtpProtectionProfile} for valid constants.
+
+
+ @return valid lengths from 0 to 255.
+
+
+ RFC 4681
+
+
+ return a = a + b - b preserved.
+
+
+ unsigned comparison on two arrays - note the arrays may
+ start with leading zeros.
+
+
+ return z = x / y - done in place (z value preserved, x contains the
+ remainder)
+
+
+ return whether or not a BigInteger is probably prime with a
+ probability of 1 - (1/2)**certainty.
+ From Knuth Vol 2, pg 395.
+
+
+ Calculate the numbers u1, u2, and u3 such that:
+
+ u1 * a + u2 * b = u3
+
+ where u3 is the greatest common divider of a and b.
+ a and b using the extended Euclid algorithm (refer p. 323
+ of The Art of Computer Programming vol 2, 2nd ed).
+ This also seems to have the side effect of calculating
+ some form of multiplicative inverse.
+
+ @param a First number to calculate gcd for
+ @param b Second number to calculate gcd for
+ @param u1Out the return object for the u1 value
+ @return The greatest common divisor of a and b
+
+
+ return w with w = x * x - w is assumed to have enough space.
+
+
+ return x with x = y * z - x is assumed to have enough space.
+
+
+ Calculate mQuote = -m^(-1) mod b with b = 2^32 (32 = word size)
+
+
+ Montgomery multiplication: a = x * y * R^(-1) mod m
+
+ Based algorithm 14.36 of Handbook of Applied Cryptography.
+
+ m, x, y should have length n
+ a should have length (n + 1)
+ b = 2^32, R = b^n
+
+ The result is put in x
+
+ NOTE: the indices of x, y, m, a different in HAC and in Java
+
+
+ return x = x % y - done in place (y value preserved)
+
+
+ do a left shift - this returns a new array.
+
+
+ do a right shift - this does it in place.
+
+
+ do a right shift by one - this does it in place.
+
+
+ returns x = x - y - we assume x is >= y
+
+
+ Utility methods for generating primes and testing for primality.
+
+
+ Used to return the output from the
+ {@linkplain Primes#enhancedMRProbablePrimeTest(BigInteger, SecureRandom, int) Enhanced
+ Miller-Rabin Probabilistic Primality Test}
+
+
+ Used to return the output from the {@linkplain Primes#generateSTRandomPrime(Digest, int, byte[]) Shawe-Taylor Random_Prime Routine}
+
+
+ FIPS 186-4 C.6 Shawe-Taylor Random_Prime Routine
+
+ Construct a provable prime number using a hash function.
+
+ @param hash
+ the {@link Digest} instance to use (as "Hash()"). Cannot be null.
+ @param length
+ the length (in bits) of the prime to be generated. Must be at least 2.
+ @param inputSeed
+ the seed to be used for the generation of the requested prime. Cannot be null or
+ empty.
+ @return an {@link STOutput} instance containing the requested prime.
+
+
+ FIPS 186-4 C.3.2 Enhanced Miller-Rabin Probabilistic Primality Test
+
+ Run several iterations of the Miller-Rabin algorithm with randomly-chosen bases. This is an
+ alternative to {@link #isMRProbablePrime(BigInteger, SecureRandom, int)} that provides more
+ information about a composite candidate, which may be useful when generating or validating
+ RSA moduli.
+
+ @param candidate
+ the {@link BigInteger} instance to test for primality.
+ @param random
+ the source of randomness to use to choose bases.
+ @param iterations
+ the number of randomly-chosen bases to perform the test for.
+ @return an {@link MROutput} instance that can be further queried for details.
+
+
+ A fast check for small divisors, up to some implementation-specific limit.
+
+ @param candidate
+ the {@link BigInteger} instance to test for division by small factors.
+
+ @return true
if the candidate is found to have any small factors,
+ false
otherwise.
+
+
+ FIPS 186-4 C.3.1 Miller-Rabin Probabilistic Primality Test
+
+ Run several iterations of the Miller-Rabin algorithm with randomly-chosen bases.
+
+ @param candidate
+ the {@link BigInteger} instance to test for primality.
+ @param random
+ the source of randomness to use to choose bases.
+ @param iterations
+ the number of randomly-chosen bases to perform the test for.
+ @return false
if any witness to compositeness is found amongst the chosen bases
+ (so candidate
is definitely NOT prime), or else true
+ (indicating primality with some probability dependent on the number of iterations
+ that were performed).
+
+
+ FIPS 186-4 C.3.1 Miller-Rabin Probabilistic Primality Test (to a fixed base).
+
+ Run a single iteration of the Miller-Rabin algorithm against the specified base.
+
+ @param candidate
+ the {@link BigInteger} instance to test for primality.
+ @param baseValue
+ the base value to use for this iteration.
+ @return false
if the specified base is a witness to compositeness (so
+ candidate
is definitely NOT prime), or else true
.
+
+
+ Simple shift-and-add multiplication. Serves as reference implementation
+ to verify (possibly faster) implementations, and for very small scalars.
+
+ @param p
+ The point to multiply.
+ @param k
+ The multiplier.
+ @return The result of the point multiplication kP
.
+
+
+ Base class for an elliptic curve.
+
+
+ Adds PreCompInfo
for a point on this curve, under a given name. Used by
+ ECMultiplier
s to save the precomputation for this ECPoint
for use
+ by subsequent multiplication.
+
+ @param point
+ The ECPoint
to store precomputations for.
+ @param name
+ A String
used to index precomputations of different types.
+ @param preCompInfo
+ The values precomputed by the ECMultiplier
.
+
+
+ Normalization ensures that any projective coordinate is 1, and therefore that the x, y
+ coordinates reflect those of the equivalent point in an affine coordinate system. Where more
+ than one point is to be normalized, this method will generally be more efficient than
+ normalizing each point separately.
+
+ @param points
+ An array of points that will be updated in place with their normalized versions,
+ where necessary
+
+
+ Normalization ensures that any projective coordinate is 1, and therefore that the x, y
+ coordinates reflect those of the equivalent point in an affine coordinate system. Where more
+ than one point is to be normalized, this method will generally be more efficient than
+ normalizing each point separately. An (optional) z-scaling factor can be applied; effectively
+ each z coordinate is scaled by this value prior to normalization (but only one
+ actual multiplication is needed).
+
+ @param points
+ An array of points that will be updated in place with their normalized versions,
+ where necessary
+ @param off
+ The start of the range of points to normalize
+ @param len
+ The length of the range of points to normalize
+ @param iso
+ The (optional) z-scaling factor - can be null
+
+
+ Sets the default ECMultiplier
, unless already set.
+
+
+ Decode a point on this curve from its ASN.1 encoding. The different
+ encodings are taken account of, including point compression for
+ Fp
(X9.62 s 4.2.1 pg 17).
+ @return The decoded point.
+
+
+ Elliptic curve over Fp
+
+
+ The auxiliary values s0
and
+ s1
used for partial modular reduction for
+ Koblitz curves.
+
+
+ Solves a quadratic equation z2 + z = beta
(X9.62
+ D.1.6) The other solution is z + 1
.
+
+ @param beta
+ The value to solve the qradratic equation for.
+ @return the solution for z2 + z = beta
or
+ null
if no solution exists.
+
+
+ @return the auxiliary values s0
and
+ s1
used for partial modular reduction for
+ Koblitz curves.
+
+
+ Returns true if this is a Koblitz curve (ABC curve).
+ @return true if this is a Koblitz curve (ABC curve), false otherwise
+
+
+ Elliptic curves over F2m. The Weierstrass equation is given by
+ y2 + xy = x3 + ax2 + b
.
+
+
+ The exponent m
of F2m
.
+
+
+ TPB: The integer k
where xm +
+ xk + 1
represents the reduction polynomial
+ f(z)
.
+ PPB: The integer k1
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ TPB: Always set to 0
+ PPB: The integer k2
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ TPB: Always set to 0
+ PPB: The integer k3
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ The point at infinity on this curve.
+
+
+ Constructor for Trinomial Polynomial Basis (TPB).
+ @param m The exponent m
of
+ F2m
.
+ @param k The integer k
where xm +
+ xk + 1
represents the reduction
+ polynomial f(z)
.
+ @param a The coefficient a
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+ @param b The coefficient b
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+
+
+ Constructor for Trinomial Polynomial Basis (TPB).
+ @param m The exponent m
of
+ F2m
.
+ @param k The integer k
where xm +
+ xk + 1
represents the reduction
+ polynomial f(z)
.
+ @param a The coefficient a
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+ @param b The coefficient b
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+ @param order The order of the main subgroup of the elliptic curve.
+ @param cofactor The cofactor of the elliptic curve, i.e.
+ #Ea(F2m) = h * n
.
+
+
+ Constructor for Pentanomial Polynomial Basis (PPB).
+ @param m The exponent m
of
+ F2m
.
+ @param k1 The integer k1
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k2 The integer k2
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k3 The integer k3
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param a The coefficient a
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+ @param b The coefficient b
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+
+
+ Constructor for Pentanomial Polynomial Basis (PPB).
+ @param m The exponent m
of
+ F2m
.
+ @param k1 The integer k1
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k2 The integer k2
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k3 The integer k3
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param a The coefficient a
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+ @param b The coefficient b
in the Weierstrass equation
+ for non-supersingular elliptic curves over
+ F2m
.
+ @param order The order of the main subgroup of the elliptic curve.
+ @param cofactor The cofactor of the elliptic curve, i.e.
+ #Ea(F2m) = h * n
.
+
+
+ Return true if curve uses a Trinomial basis.
+
+ @return true if curve Trinomial, false otherwise.
+
+
+ return the field name for this field.
+
+ @return the string "Fp".
+
+
+ return a sqrt root - the routine verifies that the calculation
+ returns the right value - if none exists it returns null.
+
+
+ Class representing the Elements of the finite field
+ F2m
in polynomial basis (PB)
+ representation. Both trinomial (Tpb) and pentanomial (Ppb) polynomial
+ basis representations are supported. Gaussian normal basis (GNB)
+ representation is not supported.
+
+
+ Indicates gaussian normal basis representation (GNB). Number chosen
+ according to X9.62. GNB is not implemented at present.
+
+
+ Indicates trinomial basis representation (Tpb). Number chosen
+ according to X9.62.
+
+
+ Indicates pentanomial basis representation (Ppb). Number chosen
+ according to X9.62.
+
+
+ Tpb or Ppb.
+
+
+ The exponent m
of F2m
.
+
+
+ The LongArray
holding the bits.
+
+
+ Constructor for Ppb.
+ @param m The exponent m
of
+ F2m
.
+ @param k1 The integer k1
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k2 The integer k2
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param k3 The integer k3
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+ @param x The BigInteger representing the value of the field element.
+
+
+ Constructor for Tpb.
+ @param m The exponent m
of
+ F2m
.
+ @param k The integer k
where xm +
+ xk + 1
represents the reduction
+ polynomial f(z)
.
+ @param x The BigInteger representing the value of the field element.
+
+
+ Checks, if the ECFieldElements a
and b
+ are elements of the same field F2m
+ (having the same representation).
+ @param a field element.
+ @param b field element to be compared.
+ @throws ArgumentException if a
and b
+ are not elements of the same field
+ F2m
(having the same
+ representation).
+
+
+ @return the representation of the field
+ F2m
, either of
+ {@link F2mFieldElement.Tpb} (trinomial
+ basis representation) or
+ {@link F2mFieldElement.Ppb} (pentanomial
+ basis representation).
+
+
+ @return the degree m
of the reduction polynomial
+ f(z)
.
+
+
+ @return Tpb: The integer k
where xm +
+ xk + 1
represents the reduction polynomial
+ f(z)
.
+ Ppb: The integer k1
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ @return Tpb: Always returns 0
+ Ppb: The integer k2
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ @return Tpb: Always set to 0
+ Ppb: The integer k3
where xm +
+ xk3 + xk2 + xk1 + 1
+ represents the reduction polynomial f(z)
.
+
+
+ base class for points on elliptic curves.
+
+
+ Normalizes this point, and then returns the affine x-coordinate.
+
+ Note: normalization can be expensive, this method is deprecated in favour
+ of caller-controlled normalization.
+
+
+ Normalizes this point, and then returns the affine y-coordinate.
+
+ Note: normalization can be expensive, this method is deprecated in favour
+ of caller-controlled normalization.
+
+
+ Returns the affine x-coordinate after checking that this point is normalized.
+
+ @return The affine x-coordinate of this point
+ @throws IllegalStateException if the point is not normalized
+
+
+ Returns the affine y-coordinate after checking that this point is normalized
+
+ @return The affine y-coordinate of this point
+ @throws IllegalStateException if the point is not normalized
+
+
+ Returns the x-coordinate.
+
+ Caution: depending on the curve's coordinate system, this may not be the same value as in an
+ affine coordinate system; use Normalize() to get a point where the coordinates have their
+ affine values, or use AffineXCoord if you expect the point to already have been normalized.
+
+ @return the x-coordinate of this point
+
+
+ Returns the y-coordinate.
+
+ Caution: depending on the curve's coordinate system, this may not be the same value as in an
+ affine coordinate system; use Normalize() to get a point where the coordinates have their
+ affine values, or use AffineYCoord if you expect the point to already have been normalized.
+
+ @return the y-coordinate of this point
+
+
+ Normalization ensures that any projective coordinate is 1, and therefore that the x, y
+ coordinates reflect those of the equivalent point in an affine coordinate system.
+
+ @return a new ECPoint instance representing the same point, but with normalized coordinates
+
+
+ return the field element encoded with point compression. (S 4.3.6)
+
+
+ Multiplies this ECPoint
by the given number.
+ @param k The multiplicator.
+ @return k * this
.
+
+
+ Elliptic curve points over Fp
+
+
+ Create a point which encodes without point compression.
+
+ @param curve the curve to use
+ @param x affine x co-ordinate
+ @param y affine y co-ordinate
+
+
+ Create a point that encodes with or without point compression.
+
+ @param curve the curve to use
+ @param x affine x co-ordinate
+ @param y affine y co-ordinate
+ @param withCompression if true encode with point compression
+
+
+ Elliptic curve points over F2m
+
+
+ @param curve base curve
+ @param x x point
+ @param y y point
+
+
+ @param curve base curve
+ @param x x point
+ @param y y point
+ @param withCompression true if encode with point compression.
+
+
+ Constructor for point at infinity
+
+
+ Class representing a simple version of a big decimal. A
+ SimpleBigDecimal
is basically a
+ {@link java.math.BigInteger BigInteger} with a few digits on the right of
+ the decimal point. The number of (binary) digits on the right of the decimal
+ point is called the scale
of the SimpleBigDecimal
.
+ Unlike in {@link java.math.BigDecimal BigDecimal}, the scale is not adjusted
+ automatically, but must be set manually. All SimpleBigDecimal
s
+ taking part in the same arithmetic operation must have equal scale. The
+ result of a multiplication of two SimpleBigDecimal
s returns a
+ SimpleBigDecimal
with double scale.
+
+
+ Returns a SimpleBigDecimal
representing the same numerical
+ value as value
.
+ @param value The value of the SimpleBigDecimal
to be
+ created.
+ @param scale The scale of the SimpleBigDecimal
to be
+ created.
+ @return The such created SimpleBigDecimal
.
+
+
+ Constructor for SimpleBigDecimal
. The value of the
+ constructed SimpleBigDecimal
Equals bigInt /
+ 2scale
.
+ @param bigInt The bigInt
value parameter.
+ @param scale The scale of the constructed SimpleBigDecimal
.
+
+
+ Class holding methods for point multiplication based on the window
+ τ-adic nonadjacent form (WTNAF). The algorithms are based on the
+ paper "Improved Algorithms for Arithmetic on Anomalous Binary Curves"
+ by Jerome A. Solinas. The paper first appeared in the Proceedings of
+ Crypto 1997.
+
+
+ The window width of WTNAF. The standard value of 4 is slightly less
+ than optimal for running time, but keeps space requirements for
+ precomputation low. For typical curves, a value of 5 or 6 results in
+ a better running time. When changing this value, the
+ αu
's must be computed differently, see
+ e.g. "Guide to Elliptic Curve Cryptography", Darrel Hankerson,
+ Alfred Menezes, Scott Vanstone, Springer-Verlag New York Inc., 2004,
+ p. 121-122
+
+
+ 24
+
+
+ The αu
's for a=0
as an array
+ of ZTauElement
s.
+
+
+ The αu
's for a=0
as an array
+ of TNAFs.
+
+
+ The αu
's for a=1
as an array
+ of ZTauElement
s.
+
+
+ The αu
's for a=1
as an array
+ of TNAFs.
+
+
+ Computes the norm of an element λ
of
+ Z[τ]
.
+ @param mu The parameter μ
of the elliptic curve.
+ @param lambda The element λ
of
+ Z[τ]
.
+ @return The norm of λ
.
+
+
+ Computes the norm of an element λ
of
+ R[τ]
, where λ = u + vτ
+ and u
and u
are real numbers (elements of
+ R
).
+ @param mu The parameter μ
of the elliptic curve.
+ @param u The real part of the element λ
of
+ R[τ]
.
+ @param v The τ
-adic part of the element
+ λ
of R[τ]
.
+ @return The norm of λ
.
+
+
+ Rounds an element λ
of R[τ]
+ to an element of Z[τ]
, such that their difference
+ has minimal norm. λ
is given as
+ λ = λ0 + λ1τ
.
+ @param lambda0 The component λ0
.
+ @param lambda1 The component λ1
.
+ @param mu The parameter μ
of the elliptic curve. Must
+ equal 1 or -1.
+ @return The rounded element of Z[τ]
.
+ @throws ArgumentException if lambda0
and
+ lambda1
do not have same scale.
+
+
+ Approximate division by n
. For an integer
+ k
, the value λ = s k / n
is
+ computed to c
bits of accuracy.
+ @param k The parameter k
.
+ @param s The curve parameter s0
or
+ s1
.
+ @param vm The Lucas Sequence element Vm
.
+ @param a The parameter a
of the elliptic curve.
+ @param m The bit length of the finite field
+ Fm
.
+ @param c The number of bits of accuracy, i.e. the scale of the returned
+ SimpleBigDecimal
.
+ @return The value λ = s k / n
computed to
+ c
bits of accuracy.
+
+
+ Computes the τ
-adic NAF (non-adjacent form) of an
+ element λ
of Z[τ]
.
+ @param mu The parameter μ
of the elliptic curve.
+ @param lambda The element λ
of
+ Z[τ]
.
+ @return The τ
-adic NAF of λ
.
+
+
+ Applies the operation τ()
to an
+ AbstractF2mPoint
.
+ @param p The AbstractF2mPoint to which τ()
is applied.
+ @return τ(p)
+
+
+ Returns the parameter μ
of the elliptic curve.
+ @param curve The elliptic curve from which to obtain μ
.
+ The curve must be a Koblitz curve, i.e. a
Equals
+ 0
or 1
and b
Equals
+ 1
.
+ @return μ
of the elliptic curve.
+ @throws ArgumentException if the given ECCurve is not a Koblitz
+ curve.
+
+
+ Calculates the Lucas Sequence elements Uk-1
and
+ Uk
or Vk-1
and
+ Vk
.
+ @param mu The parameter μ
of the elliptic curve.
+ @param k The index of the second element of the Lucas Sequence to be
+ returned.
+ @param doV If set to true, computes Vk-1
and
+ Vk
, otherwise Uk-1
and
+ Uk
.
+ @return An array with 2 elements, containing Uk-1
+ and Uk
or Vk-1
+ and Vk
.
+
+
+ Computes the auxiliary value tw
. If the width is
+ 4, then for mu = 1
, tw = 6
and for
+ mu = -1
, tw = 10
+ @param mu The parameter μ
of the elliptic curve.
+ @param w The window width of the WTNAF.
+ @return the auxiliary value tw
+
+
+ Computes the auxiliary values s0
and
+ s1
used for partial modular reduction.
+ @param curve The elliptic curve for which to compute
+ s0
and s1
.
+ @throws ArgumentException if curve
is not a
+ Koblitz curve (Anomalous Binary Curve, ABC).
+
+
+ Partial modular reduction modulo
+ (τm - 1)/(τ - 1)
.
+ @param k The integer to be reduced.
+ @param m The bitlength of the underlying finite field.
+ @param a The parameter a
of the elliptic curve.
+ @param s The auxiliary values s0
and
+ s1
.
+ @param mu The parameter μ of the elliptic curve.
+ @param c The precision (number of bits of accuracy) of the partial
+ modular reduction.
+ @return ρ := k partmod (τm - 1)/(τ - 1)
+
+
+ Multiplies a {@link org.bouncycastle.math.ec.AbstractF2mPoint AbstractF2mPoint}
+ by a BigInteger
using the reduced τ
-adic
+ NAF (RTNAF) method.
+ @param p The AbstractF2mPoint to Multiply.
+ @param k The BigInteger
by which to Multiply p
.
+ @return k * p
+
+
+ Multiplies a {@link org.bouncycastle.math.ec.AbstractF2mPoint AbstractF2mPoint}
+ by an element λ
of Z[τ]
+ using the τ
-adic NAF (TNAF) method.
+ @param p The AbstractF2mPoint to Multiply.
+ @param lambda The element λ
of
+ Z[τ]
.
+ @return λ * p
+
+
+ Multiplies a {@link org.bouncycastle.math.ec.AbstractF2mPoint AbstractF2mPoint}
+ by an element λ
of Z[τ]
+ using the τ
-adic NAF (TNAF) method, given the TNAF
+ of λ
.
+ @param p The AbstractF2mPoint to Multiply.
+ @param u The the TNAF of λ
..
+ @return λ * p
+
+
+ Computes the [τ]
-adic window NAF of an element
+ λ
of Z[τ]
.
+ @param mu The parameter μ of the elliptic curve.
+ @param lambda The element λ
of
+ Z[τ]
of which to compute the
+ [τ]
-adic NAF.
+ @param width The window width of the resulting WNAF.
+ @param pow2w 2width.
+ @param tw The auxiliary value tw
.
+ @param alpha The αu
's for the window width.
+ @return The [τ]
-adic window NAF of
+ λ
.
+
+
+ Does the precomputation for WTNAF multiplication.
+ @param p The ECPoint
for which to do the precomputation.
+ @param a The parameter a
of the elliptic curve.
+ @return The precomputation array for p
.
+
+
+ Class representing an element of Z[τ]
. Let
+ λ
be an element of Z[τ]
. Then
+ λ
is given as λ = u + vτ
. The
+ components u
and v
may be used directly, there
+ are no accessor methods.
+ Immutable class.
+
+
+ The "real" part of λ
.
+
+
+ The "τ
-adic" part of λ
.
+
+
+ Constructor for an element λ
of
+ Z[τ]
.
+ @param u The "real" part of λ
.
+ @param v The "τ
-adic" part of
+ λ
.
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve the curve to use
+ @param x affine x co-ordinate
+ @param y affine y co-ordinate
+
+ @deprecated Use ECCurve.CreatePoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve the curve to use
+ @param x affine x co-ordinate
+ @param y affine y co-ordinate
+ @param withCompression if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(boolean)}
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.CreatePoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.CreatePoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.CreatePoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ return a sqrt root - the routine verifies that the calculation returns the right value - if
+ none exists it returns null.
+
+
+ Create a point which encodes with point compression.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ Create a point that encodes with or without point compresion.
+
+ @param curve
+ the curve to use
+ @param x
+ affine x co-ordinate
+ @param y
+ affine y co-ordinate
+ @param withCompression
+ if true encode with point compression
+
+ @deprecated per-point compression property will be removed, refer
+ {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ @deprecated Use ECCurve.createPoint to construct points
+
+
+ @deprecated per-point compression property will be removed, refer {@link #getEncoded(bool)}
+
+
+ Joye's double-add algorithm.
+
+
+ Interface for classes encapsulating a point multiplication algorithm
+ for ECPoint
s.
+
+
+ Multiplies the ECPoint p
by k
, i.e.
+ p
is added k
times to itself.
+ @param p The ECPoint
to be multiplied.
+ @param k The factor by which p
is multiplied.
+ @return p
multiplied by k
.
+
+
+ Class holding precomputation data for fixed-point multiplications.
+
+
+ Array holding the precomputed ECPoint
s used for a fixed
+ point multiplication.
+
+
+ The width used for the precomputation. If a larger width precomputation
+ is already available this may be larger than was requested, so calling
+ code should refer to the actual width.
+
+
+ Class implementing the NAF (Non-Adjacent Form) multiplication algorithm (right-to-left) using
+ mixed coordinates.
+
+
+ By default, addition will be done in Jacobian coordinates, and doubling will be done in
+ Modified Jacobian coordinates (independent of the original coordinate system of each point).
+
+
+ Montgomery ladder.
+
+
+ Class implementing the NAF (Non-Adjacent Form) multiplication algorithm (left-to-right).
+
+
+ Class implementing the NAF (Non-Adjacent Form) multiplication algorithm (right-to-left).
+
+
+ Interface for classes storing precomputation data for multiplication
+ algorithms. Used as a Memento (see GOF patterns) for
+ WNafMultiplier
.
+
+
+ Class implementing the WNAF (Window Non-Adjacent Form) multiplication
+ algorithm.
+
+
+ Multiplies this
by an integer k
using the
+ Window NAF method.
+ @param k The integer by which this
is multiplied.
+ @return A new ECPoint
which equals this
+ multiplied by k
.
+
+
+ Determine window width to use for a scalar multiplication of the given size.
+
+ @param bits the bit-length of the scalar to multiply by
+ @return the window size to use
+
+
+ Class holding precomputation data for the WNAF (Window Non-Adjacent Form)
+ algorithm.
+
+
+ Array holding the precomputed ECPoint
s used for a Window
+ NAF multiplication.
+
+
+ Array holding the negations of the precomputed ECPoint
s used
+ for a Window NAF multiplication.
+
+
+ Holds an ECPoint
representing Twice(this). Used for the
+ Window NAF multiplication to create or extend the precomputed values.
+
+
+ Computes the Window NAF (non-adjacent Form) of an integer.
+ @param width The width w
of the Window NAF. The width is
+ defined as the minimal number w
, such that for any
+ w
consecutive digits in the resulting representation, at
+ most one is non-zero.
+ @param k The integer of which the Window NAF is computed.
+ @return The Window NAF of the given width, such that the following holds:
+ k = ∑i=0l-1 ki2i
+
, where the ki
denote the elements of the
+ returned byte[]
.
+
+
+ Determine window width to use for a scalar multiplication of the given size.
+
+ @param bits the bit-length of the scalar to multiply by
+ @return the window size to use
+
+
+ Determine window width to use for a scalar multiplication of the given size.
+
+ @param bits the bit-length of the scalar to multiply by
+ @param windowSizeCutoffs a monotonically increasing list of bit sizes at which to increment the window width
+ @return the window size to use
+
+
+ Class implementing the WTNAF (Window
+ τ
-adic Non-Adjacent Form) algorithm.
+
+
+ Multiplies a {@link org.bouncycastle.math.ec.AbstractF2mPoint AbstractF2mPoint}
+ by k
using the reduced τ
-adic NAF (RTNAF)
+ method.
+ @param p The AbstractF2mPoint to multiply.
+ @param k The integer by which to multiply k
.
+ @return p
multiplied by k
.
+
+
+ Multiplies a {@link org.bouncycastle.math.ec.AbstractF2mPoint AbstractF2mPoint}
+ by an element λ
of Z[τ]
using
+ the τ
-adic NAF (TNAF) method.
+ @param p The AbstractF2mPoint to multiply.
+ @param lambda The element λ
of
+ Z[τ]
of which to compute the
+ [τ]
-adic NAF.
+ @return p
multiplied by λ
.
+
+
+ Multiplies a {@link org.bouncycastle.math.ec.AbstractF2mPoint AbstractF2mPoint}
+ by an element λ
of Z[τ]
+ using the window τ
-adic NAF (TNAF) method, given the
+ WTNAF of λ
.
+ @param p The AbstractF2mPoint to multiply.
+ @param u The the WTNAF of λ
..
+ @return λ * p
+
+
+ Class holding precomputation data for the WTNAF (Window
+ τ
-adic Non-Adjacent Form) algorithm.
+
+
+ Array holding the precomputed AbstractF2mPoint
s used for the
+ WTNAF multiplication in
+ {@link org.bouncycastle.math.ec.multiplier.WTauNafMultiplier.multiply()
+ WTauNafMultiplier.multiply()}
.
+
+
+ 'Zeroless' Signed Digit Left-to-Right.
+
+
+ 'Zeroless' Signed Digit Right-to-Left.
+
+
+
+
+ BasicOcspResponse ::= SEQUENCE {
+ tbsResponseData ResponseData,
+ signatureAlgorithm AlgorithmIdentifier,
+ signature BIT STRING,
+ certs [0] EXPLICIT SEQUENCE OF Certificate OPTIONAL
+ }
+
+
+
+
+ The DER encoding of the tbsResponseData field.
+ In the event of an encoding error.
+
+
+ The certificates, if any, associated with the response.
+ In the event of an encoding error.
+
+
+
+ Verify the signature against the tbsResponseData object we contain.
+
+
+
+ The ASN.1 encoded representation of this object.
+
+
+ Generator for basic OCSP response objects.
+
+
+ basic constructor
+
+
+ construct with the responderID to be the SHA-1 keyHash of the passed in public key.
+
+
+ Add a response for a particular Certificate ID.
+
+ @param certID certificate ID details
+ @param certStatus status of the certificate - null if okay
+
+
+ Add a response for a particular Certificate ID.
+
+ @param certID certificate ID details
+ @param certStatus status of the certificate - null if okay
+ @param singleExtensions optional extensions
+
+
+ Add a response for a particular Certificate ID.
+
+ @param certID certificate ID details
+ @param nextUpdate date when next update should be requested
+ @param certStatus status of the certificate - null if okay
+ @param singleExtensions optional extensions
+
+
+ Add a response for a particular Certificate ID.
+
+ @param certID certificate ID details
+ @param thisUpdate date this response was valid on
+ @param nextUpdate date when next update should be requested
+ @param certStatus status of the certificate - null if okay
+ @param singleExtensions optional extensions
+
+
+ Set the extensions for the response.
+
+ @param responseExtensions the extension object to carry.
+
+
+
+ Generate the signed response using the passed in signature calculator.
+
+ Implementation of signing calculator factory.
+ The certificate chain associated with the response signer.
+ "produced at" date.
+
+
+
+ Return an IEnumerable of the signature names supported by the generator.
+
+ @return an IEnumerable containing recognised names.
+
+
+ create from an issuer certificate and the serial number of the
+ certificate it signed.
+ @exception OcspException if any problems occur creating the id fields.
+
+
+ return the serial number for the certificate associated
+ with this request.
+
+
+ Create a new CertificateID for a new serial number derived from a previous one
+ calculated for the same CA certificate.
+
+ @param original the previously calculated CertificateID for the CA.
+ @param newSerialNumber the serial number for the new certificate of interest.
+
+ @return a new CertificateID for newSerialNumber
+
+
+
+ OcspRequest ::= SEQUENCE {
+ tbsRequest TBSRequest,
+ optionalSignature [0] EXPLICIT Signature OPTIONAL }
+
+ TBSRequest ::= SEQUENCE {
+ version [0] EXPLICIT Version DEFAULT v1,
+ requestorName [1] EXPLICIT GeneralName OPTIONAL,
+ requestList SEQUENCE OF Request,
+ requestExtensions [2] EXPLICIT Extensions OPTIONAL }
+
+ Signature ::= SEQUENCE {
+ signatureAlgorithm AlgorithmIdentifier,
+ signature BIT STRING,
+ certs [0] EXPLICIT SEQUENCE OF Certificate OPTIONAL}
+
+ Version ::= INTEGER { v1(0) }
+
+ Request ::= SEQUENCE {
+ reqCert CertID,
+ singleRequestExtensions [0] EXPLICIT Extensions OPTIONAL }
+
+ CertID ::= SEQUENCE {
+ hashAlgorithm AlgorithmIdentifier,
+ issuerNameHash OCTET STRING, -- Hash of Issuer's DN
+ issuerKeyHash OCTET STRING, -- Hash of Issuers public key
+ serialNumber CertificateSerialNumber }
+
+
+
+ Return the DER encoding of the tbsRequest field.
+ @return DER encoding of tbsRequest
+ @throws OcspException in the event of an encoding error.
+
+
+ return the object identifier representing the signature algorithm
+
+
+ If the request is signed return a possibly empty CertStore containing the certificates in the
+ request. If the request is not signed the method returns null.
+
+ @return null if not signed, a CertStore otherwise
+ @throws OcspException
+
+
+ Return whether or not this request is signed.
+
+ @return true if signed false otherwise.
+
+
+ Verify the signature against the TBSRequest object we contain.
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ Add a request for the given CertificateID.
+
+ @param certId certificate ID of interest
+
+
+ Add a request with extensions
+
+ @param certId certificate ID of interest
+ @param singleRequestExtensions the extensions to attach to the request
+
+
+ Set the requestor name to the passed in X509Principal
+
+ @param requestorName a X509Principal representing the requestor name.
+
+
+ Generate an unsigned request
+
+ @return the OcspReq
+ @throws OcspException
+
+
+ Return an IEnumerable of the signature names supported by the generator.
+
+ @return an IEnumerable containing recognised names.
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ base generator for an OCSP response - at the moment this only supports the
+ generation of responses containing BasicOCSP responses.
+
+
+ note 4 is not used.
+
+
+ Carrier for a ResponderID.
+
+
+ wrapper for the RevokedInfo object
+
+
+ return the revocation reason. Note: this field is optional, test for it
+ with hasRevocationReason() first.
+ @exception InvalidOperationException if a reason is asked for and none is avaliable
+
+
+ Return the status object for the response - null indicates good.
+
+ @return the status object for the response, null if it is good.
+
+
+ return the NextUpdate value - note: this is an optional field so may
+ be returned as null.
+
+ @return nextUpdate, or null if not present.
+
+
+ wrapper for the UnknownInfo object
+
+
+
+ Utility class for creating IBasicAgreement objects from their names/Oids
+
+
+
+
+ Cipher Utility class contains methods that can not be specifically grouped into other classes.
+
+
+
+
+ Returns a ObjectIdentifier for a give encoding.
+
+ A string representation of the encoding.
+ A DerObjectIdentifier, null if the Oid is not available.
+
+
+
+ Utility class for creating IDigest objects from their names/Oids
+
+
+
+
+ Returns a ObjectIdentifier for a given digest mechanism.
+
+ A string representation of the digest meanism.
+ A DerObjectIdentifier, null if the Oid is not available.
+
+
+
+ A class containing methods to interface the BouncyCastle world to the .NET Crypto world.
+
+
+
+
+ Create an System.Security.Cryptography.X509Certificate from an X509Certificate Structure.
+
+
+ A System.Security.Cryptography.X509Certificate.
+
+
+
+ Utility class for creating HMac object from their names/Oids
+
+
+
+
+
+
+
+
+
+ Returns a ObjectIdentifier for a give encoding.
+
+ A string representation of the encoding.
+ A DerObjectIdentifier, null if the Oid is not available.
+
+
+
+ Create and auto-seed an instance based on the given algorithm.
+
+ Equivalent to GetInstance(algorithm, true)
+ e.g. "SHA256PRNG"
+
+
+
+ Create an instance based on the given algorithm, with optional auto-seeding
+
+ e.g. "SHA256PRNG"
+ If true, the instance will be auto-seeded.
+
+
+
+ To replicate existing predictable output, replace with GetInstance("SHA1PRNG", false), followed by SetSeed(seed)
+
+
+
+ Use the specified instance of IRandomGenerator as random source.
+
+ This constructor performs no seeding of either the IRandomGenerator or the
+ constructed SecureRandom. It is the responsibility of the client to provide
+ proper seed material as necessary/appropriate for the given IRandomGenerator
+ implementation.
+
+ The source to generate all random bytes from.
+
+
+ base constructor.
+
+
+ create a SecurityUtilityException with the given message.
+
+ @param message the message to be carried with the exception.
+
+
+
+ Signer Utility class contains methods that can not be specifically grouped into other classes.
+
+
+
+
+ Returns an ObjectIdentifier for a given encoding.
+
+ A string representation of the encoding.
+ A DerObjectIdentifier, null if the OID is not available.
+
+
+
+ Utility class for creating IWrapper objects from their names/Oids
+
+
+
+ PEM generator for the original set of PEM objects used in Open SSL.
+
+
+ Class for reading OpenSSL PEM encoded streams containing
+ X509 certificates, PKCS8 encoded keys and PKCS7 objects.
+
+ In the case of PKCS7 objects the reader will return a CMS ContentInfo object. Keys and
+ Certificates will be returned using the appropriate java.security type.
+
+
+ Create a new PemReader
+
+ @param reader the Reader
+
+
+ Create a new PemReader with a password finder
+
+ @param reader the Reader
+ @param pFinder the password finder
+
+
+ Reads in a X509Certificate.
+
+ @return the X509Certificate
+ @throws IOException if an I/O error occured
+
+
+ Reads in a X509CRL.
+
+ @return the X509Certificate
+ @throws IOException if an I/O error occured
+
+
+ Reads in a PKCS10 certification request.
+
+ @return the certificate request.
+ @throws IOException if an I/O error occured
+
+
+ Reads in a X509 Attribute Certificate.
+
+ @return the X509 Attribute Certificate
+ @throws IOException if an I/O error occured
+
+
+ Reads in a PKCS7 object. This returns a ContentInfo object suitable for use with the CMS
+ API.
+
+ @return the X509Certificate
+ @throws IOException if an I/O error occured
+
+
+ Read a Key Pair
+
+
+ General purpose writer for OpenSSL PEM objects.
+
+
+ The TextWriter object to write the output to.
+
+
+ Constructor for an unencrypted private key PEM object.
+
+ @param key private key to be encoded.
+
+
+ Constructor for an encrypted private key PEM object.
+
+ @param key private key to be encoded
+ @param algorithm encryption algorithm to use
+ @param provider provider to use
+ @throws NoSuchAlgorithmException if algorithm/mode cannot be found
+
+
+
+ A class for verifying and creating Pkcs10 Certification requests.
+
+
+ CertificationRequest ::= Sequence {
+ certificationRequestInfo CertificationRequestInfo,
+ signatureAlgorithm AlgorithmIdentifier{{ SignatureAlgorithms }},
+ signature BIT STRING
+ }
+
+ CertificationRequestInfo ::= Sequence {
+ version Integer { v1(0) } (v1,...),
+ subject Name,
+ subjectPKInfo SubjectPublicKeyInfo{{ PKInfoAlgorithms }},
+ attributes [0] Attributes{{ CRIAttributes }}
+ }
+
+ Attributes { ATTRIBUTE:IOSet } ::= Set OF Attr{{ IOSet }}
+
+ Attr { ATTRIBUTE:IOSet } ::= Sequence {
+ type ATTRIBUTE.&id({IOSet}),
+ values Set SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{\@type})
+ }
+
+ see
+
+
+
+ Instantiate a Pkcs10CertificationRequest object with the necessary credentials.
+
+ Name of Sig Alg.
+ X509Name of subject eg OU="My unit." O="My Organisatioin" C="au"
+ Public Key to be included in cert reqest.
+ ASN1Set of Attributes.
+ Matching Private key for nominated (above) public key to be used to sign the request.
+
+
+
+ Instantiate a Pkcs10CertificationRequest object with the necessary credentials.
+
+ The factory for signature calculators to sign the PKCS#10 request with.
+ X509Name of subject eg OU="My unit." O="My Organisatioin" C="au"
+ Public Key to be included in cert reqest.
+ ASN1Set of Attributes.
+ Matching Private key for nominated (above) public key to be used to sign the request.
+
+
+
+ Get the public key.
+
+ The public key.
+
+
+
+ Verify Pkcs10 Cert Request is valid.
+
+ true = valid.
+
+
+
+ A class for creating and verifying Pkcs10 Certification requests (this is an extension on ).
+ The requests are made using delay signing. This is useful for situations where
+ the private key is in another environment and not directly accessible (e.g. HSM)
+ So the first step creates the request, then the signing is done outside this
+ object and the signature is then used to complete the request.
+
+
+ CertificationRequest ::= Sequence {
+ certificationRequestInfo CertificationRequestInfo,
+ signatureAlgorithm AlgorithmIdentifier{{ SignatureAlgorithms }},
+ signature BIT STRING
+ }
+
+ CertificationRequestInfo ::= Sequence {
+ version Integer { v1(0) } (v1,...),
+ subject Name,
+ subjectPKInfo SubjectPublicKeyInfo{{ PKInfoAlgorithms }},
+ attributes [0] Attributes{{ CRIAttributes }}
+ }
+
+ Attributes { ATTRIBUTE:IOSet } ::= Set OF Attr{{ IOSet }}
+
+ Attr { ATTRIBUTE:IOSet } ::= Sequence {
+ type ATTRIBUTE.&id({IOSet}),
+ values Set SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{\@type})
+ }
+
+ see
+
+
+
+ Instantiate a Pkcs10CertificationRequest object with the necessary credentials.
+
+ Name of Sig Alg.
+ X509Name of subject eg OU="My unit." O="My Organisatioin" C="au"
+ Public Key to be included in cert reqest.
+ ASN1Set of Attributes.
+
+ After the object is constructed use the and finally the
+ SignRequest methods to finalize the request.
+
+
+
+ simply return the cert entry for the private key
+
+
+ Utility class for reencoding PKCS#12 files to definite length.
+
+
+ Just re-encode the outer layer of the PKCS#12 file to definite length encoding.
+
+ @param berPKCS12File - original PKCS#12 file
+ @return a byte array representing the DER encoding of the PFX structure
+ @throws IOException
+
+
+ Re-encode the PKCS#12 structure to definite length encoding at the inner layer
+ as well, recomputing the MAC accordingly.
+
+ @param berPKCS12File - original PKCS12 file.
+ @param provider - provider to use for MAC calculation.
+ @return a byte array representing the DER encoding of the PFX structure.
+ @throws IOException on parsing, encoding errors.
+
+
+
+ Returns the revocationDate.
+
+
+
+
+ Returns the certStatus.
+
+
+
+ Returns an immutable Set
of X.509 attribute certificate
+ extensions that this PkixAttrCertChecker
supports or
+ null
if no extensions are supported.
+
+ Each element of the set is a String
representing the
+ Object Identifier (OID) of the X.509 extension that is supported.
+
+
+ All X.509 attribute certificate extensions that a
+ PkixAttrCertChecker
might possibly be able to process
+ should be included in the set.
+
+
+ @return an immutable Set
of X.509 extension OIDs (in
+ String
format) supported by this
+ PkixAttrCertChecker
, or null
if no
+ extensions are supported
+
+
+ Performs checks on the specified attribute certificate. Every handled
+ extension is rmeoved from the unresolvedCritExts
+ collection.
+
+ @param attrCert The attribute certificate to be checked.
+ @param certPath The certificate path which belongs to the attribute
+ certificate issuer public key certificate.
+ @param holderCertPath The certificate path which belongs to the holder
+ certificate.
+ @param unresolvedCritExts a Collection
of OID strings
+ representing the current set of unresolved critical extensions
+ @throws CertPathValidatorException if the specified attribute certificate
+ does not pass the check.
+
+
+ Returns a clone of this object.
+
+ @return a copy of this PkixAttrCertChecker
+
+
+ Build and validate a CertPath using the given parameter.
+
+ @param params PKIXBuilderParameters object containing all information to
+ build the CertPath
+
+
+ CertPathValidatorSpi implementation for X.509 Attribute Certificates la RFC 3281.
+
+ @see org.bouncycastle.x509.ExtendedPkixParameters
+
+
+ Validates an attribute certificate with the given certificate path.
+
+
+ params
must be an instance of
+ ExtendedPkixParameters
.
+
+ The target constraints in the params
must be an
+ X509AttrCertStoreSelector
with at least the attribute
+ certificate criterion set. Obey that also target informations may be
+ necessary to correctly validate this attribute certificate.
+
+ The attribute certificate issuer must be added to the trusted attribute
+ issuers with {@link ExtendedPkixParameters#setTrustedACIssuers(Set)}.
+
+ @param certPath The certificate path which belongs to the attribute
+ certificate issuer public key certificate.
+ @param params The PKIX parameters.
+ @return A PKIXCertPathValidatorResult
of the result of
+ validating the certPath
.
+ @throws InvalidAlgorithmParameterException if params
is
+ inappropriate for this validator.
+ @throws CertPathValidatorException if the verification fails.
+
+
+
+ Summary description for PkixBuilderParameters.
+
+
+
+ Returns an instance of PkixBuilderParameters
.
+
+ This method can be used to get a copy from other
+ PKIXBuilderParameters
, PKIXParameters
,
+ and ExtendedPKIXParameters
instances.
+
+
+ @param pkixParams The PKIX parameters to create a copy of.
+ @return An PkixBuilderParameters
instance.
+
+
+
+ Excluded certificates are not used for building a certification path.
+
+ the excluded certificates.
+
+
+
+ Sets the excluded certificates which are not used for building a
+ certification path. If the ISet
is null
an
+ empty set is assumed.
+
+
+ The given set is cloned to protect it against subsequent modifications.
+
+ The excluded certificates to set.
+
+
+ Can alse handle ExtendedPKIXBuilderParameters
and
+ PKIXBuilderParameters
.
+
+ @param params Parameters to set.
+ @see org.bouncycastle.x509.ExtendedPKIXParameters#setParams(java.security.cert.PKIXParameters)
+
+
+ Makes a copy of this PKIXParameters
object. Changes to the
+ copy will not affect the original and vice versa.
+
+ @return a copy of this PKIXParameters
object
+
+
+ An immutable sequence of certificates (a certification path).
+
+ This is an abstract class that defines the methods common to all CertPaths.
+ Subclasses can handle different kinds of certificates (X.509, PGP, etc.).
+
+ All CertPath objects have a type, a list of Certificates, and one or more
+ supported encodings. Because the CertPath class is immutable, a CertPath
+ cannot change in any externally visible way after being constructed. This
+ stipulation applies to all public fields and methods of this class and any
+ added or overridden by subclasses.
+
+ The type is a string that identifies the type of Certificates in the
+ certification path. For each certificate cert in a certification path
+ certPath, cert.getType().equals(certPath.getType()) must be true.
+
+ The list of Certificates is an ordered List of zero or more Certificates.
+ This List and all of the Certificates contained in it must be immutable.
+
+ Each CertPath object must support one or more encodings so that the object
+ can be translated into a byte array for storage or transmission to other
+ parties. Preferably, these encodings should be well-documented standards
+ (such as PKCS#7). One of the encodings supported by a CertPath is considered
+ the default encoding. This encoding is used if no encoding is explicitly
+ requested (for the {@link #getEncoded()} method, for instance).
+
+ All CertPath objects are also Serializable. CertPath objects are resolved
+ into an alternate {@link CertPathRep} object during serialization. This
+ allows a CertPath object to be serialized into an equivalent representation
+ regardless of its underlying implementation.
+
+ CertPath objects can be created with a CertificateFactory or they can be
+ returned by other classes, such as a CertPathBuilder.
+
+ By convention, X.509 CertPaths (consisting of X509Certificates), are ordered
+ starting with the target certificate and ending with a certificate issued by
+ the trust anchor. That is, the issuer of one certificate is the subject of
+ the following one. The certificate representing the
+ {@link TrustAnchor TrustAnchor} should not be included in the certification
+ path. Unvalidated X.509 CertPaths may not follow these conventions. PKIX
+ CertPathValidators will detect any departure from these conventions that
+ cause the certification path to be invalid and throw a
+ CertPathValidatorException.
+
+ Concurrent Access
+
+ All CertPath objects must be thread-safe. That is, multiple threads may
+ concurrently invoke the methods defined in this class on a single CertPath
+ object (or more than one) with no ill effects. This is also true for the List
+ returned by CertPath.getCertificates.
+
+ Requiring CertPath objects to be immutable and thread-safe allows them to be
+ passed around to various pieces of code without worrying about coordinating
+ access. Providing this thread-safety is generally not difficult, since the
+ CertPath and List objects in question are immutable.
+
+ @see CertificateFactory
+ @see CertPathBuilder
+
+ CertPath implementation for X.509 certificates.
+
+
+
+ @param certs
+
+
+ Creates a CertPath of the specified type.
+ This constructor is protected because most users should use
+ a CertificateFactory to create CertPaths.
+ @param type the standard name of the type of Certificatesin this path
+
+
+
+ Creates a CertPath of the specified type.
+ This constructor is protected because most users should use
+ a CertificateFactory to create CertPaths.
+
+ @param type the standard name of the type of Certificatesin this path
+
+
+
+ Returns an iteration of the encodings supported by this
+ certification path, with the default encoding
+ first. Attempts to modify the returned Iterator via its
+ remove method result in an UnsupportedOperationException.
+
+ @return an Iterator over the names of the supported encodings (as Strings)
+
+
+
+ Compares this certification path for equality with the specified object.
+ Two CertPaths are equal if and only if their types are equal and their
+ certificate Lists (and by implication the Certificates in those Lists)
+ are equal. A CertPath is never equal to an object that is not a CertPath.
+
+ This algorithm is implemented by this method. If it is overridden, the
+ behavior specified here must be maintained.
+
+ @param other
+ the object to test for equality with this certification path
+
+ @return true if the specified object is equal to this certification path,
+ false otherwise
+
+ @see Object#hashCode() Object.hashCode()
+
+
+ Returns the encoded form of this certification path, using
+ the default encoding.
+
+ @return the encoded bytes
+ @exception CertificateEncodingException if an encoding error occurs
+
+
+
+ Returns the encoded form of this certification path, using
+ the specified encoding.
+
+ @param encoding the name of the encoding to use
+ @return the encoded bytes
+ @exception CertificateEncodingException if an encoding error
+ occurs or the encoding requested is not supported
+
+
+
+
+ Returns the list of certificates in this certification
+ path.
+
+
+
+ Return a DERObject containing the encoded certificate.
+
+ @param cert the X509Certificate object to be encoded
+
+ @return the DERObject
+
+
+
+ Implements the PKIX CertPathBuilding algorithm for BouncyCastle.
+
+ @see CertPathBuilderSpi
+
+
+ Build and validate a CertPath using the given parameter.
+
+ @param params PKIXBuilderParameters object containing all information to
+ build the CertPath
+
+
+
+ Summary description for PkixCertPathBuilderException.
+
+
+
+
+ Summary description for PkixCertPathBuilderResult.
+
+
+
+ * Initializes the internal state of this PKIXCertPathChecker
.
+ *
+ * The forward
flag specifies the order that certificates
+ * will be passed to the {@link #check check} method (forward or reverse). A
+ * PKIXCertPathChecker
must support reverse checking
+ * and may support forward checking.
+ *
+ *
+ * @param forward
+ * the order that certificates are presented to the
+ * check
method. If true
,
+ * certificates are presented from target to most-trusted CA
+ * (forward); if false
, from most-trusted CA to
+ * target (reverse).
+ * @exception CertPathValidatorException
+ * if this PKIXCertPathChecker
is unable to
+ * check certificates in the specified order; it should never
+ * be thrown if the forward flag is false since reverse
+ * checking must be supported
+
+
+ Indicates if forward checking is supported. Forward checking refers to
+ the ability of the PKIXCertPathChecker
to perform its
+ checks when certificates are presented to the check
method
+ in the forward direction (from target to most-trusted CA).
+
+ @return true
if forward checking is supported,
+ false
otherwise
+
+
+ * Returns an immutable Set
of X.509 certificate extensions
+ * that this PKIXCertPathChecker
supports (i.e. recognizes,
+ * is able to process), or null
if no extensions are
+ * supported.
+ *
+ * Each element of the set is a String
representing the
+ * Object Identifier (OID) of the X.509 extension that is supported. The OID
+ * is represented by a set of nonnegative integers separated by periods.
+ *
+ * All X.509 certificate extensions that a PKIXCertPathChecker
+ * might possibly be able to process should be included in the set.
+ *
+ *
+ * @return an immutable Set
of X.509 extension OIDs (in
+ * String
format) supported by this
+ * PKIXCertPathChecker
, or null
if no
+ * extensions are supported
+
+
+ Performs the check(s) on the specified certificate using its internal
+ state and removes any critical extensions that it processes from the
+ specified collection of OID strings that represent the unresolved
+ critical extensions. The certificates are presented in the order
+ specified by the init
method.
+
+ @param cert
+ the Certificate
to be checked
+ @param unresolvedCritExts
+ a Collection
of OID strings representing the
+ current set of unresolved critical extensions
+ @exception CertPathValidatorException
+ if the specified certificate does not pass the check
+
+
+ Returns a clone of this object. Calls the Object.clone()
+ method. All subclasses which maintain state must support and override
+ this method, if necessary.
+
+ @return a copy of this PKIXCertPathChecker
+
+
+ The Service Provider Interface (SPI)
+ for the {@link CertPathValidator CertPathValidator} class. All
+ CertPathValidator
implementations must include a class (the
+ SPI class) that extends this class (CertPathValidatorSpi
)
+ and implements all of its methods. In general, instances of this class
+ should only be accessed through the CertPathValidator
class.
+ For details, see the Java Cryptography Architecture.
+
+ Concurrent Access
+
+ Instances of this class need not be protected against concurrent
+ access from multiple threads. Threads that need to access a single
+ CertPathValidatorSpi
instance concurrently should synchronize
+ amongst themselves and provide the necessary locking before calling the
+ wrapping CertPathValidator
object.
+
+ However, implementations of CertPathValidatorSpi
may still
+ encounter concurrency issues, since multiple threads each
+ manipulating a different CertPathValidatorSpi
instance need not
+ synchronize.
+
+ CertPathValidatorSpi implementation for X.509 Certificate validation a la RFC
+ 3280.
+
+
+
+ An exception indicating one of a variety of problems encountered when
+ validating a certification path.
+
+ A CertPathValidatorException
provides support for wrapping
+ exceptions. The {@link #getCause getCause} method returns the throwable,
+ if any, that caused this exception to be thrown.
+
+ A CertPathValidatorException
may also include the
+ certification path that was being validated when the exception was thrown
+ and the index of the certificate in the certification path that caused the
+ exception to be thrown. Use the {@link #getCertPath getCertPath} and
+ {@link #getIndex getIndex} methods to retrieve this information.
+
+ Concurrent Access
+
+ Unless otherwise specified, the methods defined in this class are not
+ thread-safe. Multiple threads that need to access a single
+ object concurrently should synchronize amongst themselves and
+ provide the necessary locking. Multiple threads each manipulating
+ separate objects need not synchronize.
+
+ @see CertPathValidator
+
+
+
+
+ Creates a PkixCertPathValidatorException
with the given detail
+ message. A detail message is a String
that describes this
+ particular exception.
+
+ the detail message
+
+
+
+ Creates a PkixCertPathValidatorException
with the specified
+ detail message and cause.
+
+ the detail message
+ the cause (which is saved for later retrieval by the
+ {@link #getCause getCause()} method). (A null
+ value is permitted, and indicates that the cause is
+ nonexistent or unknown.)
+
+
+
+ Creates a PkixCertPathValidatorException
with the specified
+ detail message, cause, certification path, and index.
+
+ the detail message (or null
if none)
+ the cause (or null
if none)
+ the certification path that was in the process of being
+ validated when the error was encountered
+ the index of the certificate in the certification path that *
+
+
+
+ Returns the detail message for this CertPathValidatorException
.
+
+ the detail message, or null
if neither the message nor cause were specified
+
+
+ Returns the certification path that was being validated when the
+ exception was thrown.
+
+ @return the CertPath
that was being validated when the
+ exception was thrown (or null
if not specified)
+
+
+ Returns the index of the certificate in the certification path that
+ caused the exception to be thrown. Note that the list of certificates in
+ a CertPath
is zero based. If no index has been set, -1 is
+ returned.
+
+ @return the index that has been set, or -1 if none has been set
+
+
+
+ Summary description for PkixCertPathValidatorResult.
+
+
+
+
+ Summary description for PkixCertPathValidatorUtilities.
+
+
+
+
+ key usage bits
+
+
+
+
+ Search the given Set of TrustAnchor's for one that is the
+ issuer of the given X509 certificate.
+
+ the X509 certificate
+ a Set of TrustAnchor's
+ the TrustAnchor
object if found or
+ null
if not.
+
+ @exception
+
+
+
+ Returns the issuer of an attribute certificate or certificate.
+
+ The attribute certificate or certificate.
+ The issuer as X500Principal
.
+
+
+ Return the next working key inheriting DSA parameters if necessary.
+
+ This methods inherits DSA parameters from the indexed certificate or
+ previous certificates in the certificate chain to the returned
+ PublicKey
. The list is searched upwards, meaning the end
+ certificate is at position 0 and previous certificates are following.
+
+
+ If the indexed certificate does not contain a DSA key this method simply
+ returns the public key. If the DSA key already contains DSA parameters
+ the key is also only returned.
+
+
+ @param certs The certification path.
+ @param index The index of the certificate which contains the public key
+ which should be extended with DSA parameters.
+ @return The public key of the certificate in list position
+ index
extended with DSA parameters if applicable.
+ @throws Exception if DSA parameters cannot be inherited.
+
+
+
+ Return a Collection of all certificates or attribute certificates found
+ in the X509Store's that are matching the certSelect criteriums.
+
+ a {@link Selector} object that will be used to select
+ the certificates
+ a List containing only X509Store objects. These
+ are used to search for certificates.
+ a Collection of all found or
+ objects.
+ May be empty but never null
.
+
+
+
+ Add the CRL issuers from the cRLIssuer field of the distribution point or
+ from the certificate if not given to the issuer criterion of the
+ selector
.
+
+ The issuerPrincipals
are a collection with a single
+ X500Principal
for X509Certificate
s. For
+ {@link X509AttributeCertificate}s the issuer may contain more than one
+ X500Principal
.
+
+
+ @param dp The distribution point.
+ @param issuerPrincipals The issuers of the certificate or attribute
+ certificate which contains the distribution point.
+ @param selector The CRL selector.
+ @param pkixParams The PKIX parameters containing the cert stores.
+ @throws Exception if an exception occurs while processing.
+ @throws ClassCastException if issuerPrincipals
does not
+ contain only X500Principal
s.
+
+
+ Fetches complete CRLs according to RFC 3280.
+
+ @param dp The distribution point for which the complete CRL
+ @param cert The X509Certificate
or
+ {@link org.bouncycastle.x509.X509AttributeCertificate} for
+ which the CRL should be searched.
+ @param currentDate The date for which the delta CRLs must be valid.
+ @param paramsPKIX The extended PKIX parameters.
+ @return A Set
of X509CRL
s with complete
+ CRLs.
+ @throws Exception if an exception occurs while picking the CRLs
+ or no CRLs are found.
+
+
+ Fetches delta CRLs according to RFC 3280 section 5.2.4.
+
+ @param currentDate The date for which the delta CRLs must be valid.
+ @param paramsPKIX The extended PKIX parameters.
+ @param completeCRL The complete CRL the delta CRL is for.
+ @return A Set
of X509CRL
s with delta CRLs.
+ @throws Exception if an exception occurs while picking the delta
+ CRLs.
+
+
+ Find the issuer certificates of a given certificate.
+
+ @param cert
+ The certificate for which an issuer should be found.
+ @param pkixParams
+ @return A Collection
object containing the issuer
+ X509Certificate
s. Never null
.
+
+ @exception Exception
+ if an error occurs.
+
+
+
+ Extract the value of the given extension, if it exists.
+
+ The extension object.
+ The object identifier to obtain.
+ Asn1Object
+ if the extension cannot be read.
+
+
+
+ crl checking
+ Return a Collection of all CRLs found in the X509Store's that are
+ matching the crlSelect criteriums.
+
+ a {@link X509CRLStoreSelector} object that will be used
+ to select the CRLs
+ a List containing only {@link org.bouncycastle.x509.X509Store
+ X509Store} objects. These are used to search for CRLs
+ a Collection of all found {@link X509CRL X509CRL} objects. May be
+ empty but never null
.
+
+
+
+ Returns the intersection of the permitted IP ranges in
+ permitted
with ip
.
+
+ @param permitted A Set
of permitted IP addresses with
+ their subnet mask as byte arrays.
+ @param ips The IP address with its subnet mask.
+ @return The Set
of permitted IP ranges intersected with
+ ip
.
+
+
+ Returns the union of the excluded IP ranges in excluded
+ with ip
.
+
+ @param excluded A Set
of excluded IP addresses with their
+ subnet mask as byte arrays.
+ @param ip The IP address with its subnet mask.
+ @return The Set
of excluded IP ranges unified with
+ ip
as byte arrays.
+
+
+ Calculates the union if two IP ranges.
+
+ @param ipWithSubmask1 The first IP address with its subnet mask.
+ @param ipWithSubmask2 The second IP address with its subnet mask.
+ @return A Set
with the union of both addresses.
+
+
+ Calculates the interesction if two IP ranges.
+
+ @param ipWithSubmask1 The first IP address with its subnet mask.
+ @param ipWithSubmask2 The second IP address with its subnet mask.
+ @return A Set
with the single IP address with its subnet
+ mask as a byte array or an empty Set
.
+
+
+ Concatenates the IP address with its subnet mask.
+
+ @param ip The IP address.
+ @param subnetMask Its subnet mask.
+ @return The concatenated IP address with its subnet mask.
+
+
+ Splits the IP addresses and their subnet mask.
+
+ @param ipWithSubmask1 The first IP address with the subnet mask.
+ @param ipWithSubmask2 The second IP address with the subnet mask.
+ @return An array with two elements. Each element contains the IP address
+ and the subnet mask in this order.
+
+
+ Based on the two IP addresses and their subnet masks the IP range is
+ computed for each IP address - subnet mask pair and returned as the
+ minimum IP address and the maximum address of the range.
+
+ @param ip1 The first IP address.
+ @param subnetmask1 The subnet mask of the first IP address.
+ @param ip2 The second IP address.
+ @param subnetmask2 The subnet mask of the second IP address.
+ @return A array with two elements. The first/second element contains the
+ min and max IP address of the first/second IP address and its
+ subnet mask.
+
+
+ Checks if the IP ip
is included in the permitted ISet
+ permitted
.
+
+ @param permitted A Set
of permitted IP addresses with
+ their subnet mask as byte arrays.
+ @param ip The IP address.
+ @throws PkixNameConstraintValidatorException
+ if the IP is not permitted.
+
+
+ Checks if the IP ip
is included in the excluded ISet
+ excluded
.
+
+ @param excluded A Set
of excluded IP addresses with their
+ subnet mask as byte arrays.
+ @param ip The IP address.
+ @throws PkixNameConstraintValidatorException
+ if the IP is excluded.
+
+
+ Checks if the IP address ip
is constrained by
+ constraint
.
+
+ @param ip The IP address.
+ @param constraint The constraint. This is an IP address concatenated with
+ its subnetmask.
+ @return true
if constrained, false
+ otherwise.
+
+
+ The common part of email1
and email2
is
+ added to the union union
. If email1
and
+ email2
have nothing in common they are added both.
+
+ @param email1 Email address constraint 1.
+ @param email2 Email address constraint 2.
+ @param union The union.
+
+
+ The most restricting part from email1
and
+ email2
is added to the intersection intersect
.
+
+ @param email1 Email address constraint 1.
+ @param email2 Email address constraint 2.
+ @param intersect The intersection.
+
+
+ Checks if the given GeneralName is in the permitted ISet.
+
+ @param name The GeneralName
+ @throws PkixNameConstraintValidatorException
+ If the name
+
+
+ Check if the given GeneralName is contained in the excluded ISet.
+
+ @param name The GeneralName.
+ @throws PkixNameConstraintValidatorException
+ If the name
is
+ excluded.
+
+
+ Updates the permitted ISet of these name constraints with the intersection
+ with the given subtree.
+
+ @param permitted The permitted subtrees
+
+
+ Adds a subtree to the excluded ISet of these name constraints.
+
+ @param subtree A subtree with an excluded GeneralName.
+
+
+ Returns the maximum IP address.
+
+ @param ip1 The first IP address.
+ @param ip2 The second IP address.
+ @return The maximum IP address.
+
+
+ Returns the minimum IP address.
+
+ @param ip1 The first IP address.
+ @param ip2 The second IP address.
+ @return The minimum IP address.
+
+
+ Compares IP address ip1
with ip2
. If ip1
+ is equal to ip2 0 is returned. If ip1 is bigger 1 is returned, -1
+ otherwise.
+
+ @param ip1 The first IP address.
+ @param ip2 The second IP address.
+ @return 0 if ip1 is equal to ip2, 1 if ip1 is bigger, -1 otherwise.
+
+
+ Returns the logical OR of the IP addresses ip1
and
+ ip2
.
+
+ @param ip1 The first IP address.
+ @param ip2 The second IP address.
+ @return The OR of ip1
and ip2
.
+
+
+ Stringifies an IPv4 or v6 address with subnet mask.
+
+ @param ip The IP with subnet mask.
+ @return The stringified IP address.
+
+
+
+ Summary description for PkixParameters.
+
+
+
+ This is the default PKIX validity model. Actually there are two variants
+ of this: The PKIX model and the modified PKIX model. The PKIX model
+ verifies that all involved certificates must have been valid at the
+ current time. The modified PKIX model verifies that all involved
+ certificates were valid at the signing time. Both are indirectly choosen
+ with the {@link PKIXParameters#setDate(java.util.Date)} method, so this
+ methods sets the Date when all certificates must have been
+ valid.
+
+
+ This model uses the following validity model. Each certificate must have
+ been valid at the moment where is was used. That means the end
+ certificate must have been valid at the time the signature was done. The
+ CA certificate which signed the end certificate must have been valid,
+ when the end certificate was signed. The CA (or Root CA) certificate must
+ have been valid, when the CA certificate was signed and so on. So the
+ {@link PKIXParameters#setDate(java.util.Date)} method sets the time, when
+ the end certificate must have been valid. It is used e.g.
+ in the German signature law.
+
+
+ Creates an instance of PKIXParameters with the specified Set of
+ most-trusted CAs. Each element of the set is a TrustAnchor.
+
+ Note that the Set is copied to protect against subsequent modifications.
+
+ @param trustAnchors
+ a Set of TrustAnchors
+
+ @exception InvalidAlgorithmParameterException
+ if the specified Set is empty
+ (trustAnchors.isEmpty() == true)
+ @exception NullPointerException
+ if the specified Set is null
+ @exception ClassCastException
+ if any of the elements in the Set are not of type
+ java.security.cert.TrustAnchor
+
+
+ Returns the required constraints on the target certificate. The
+ constraints are returned as an instance of CertSelector. If
+ null
, no constraints are defined.
+
+ Note that the CertSelector returned is cloned to protect against
+ subsequent modifications.
+
+ @return a CertSelector specifying the constraints on the target
+ certificate (or null
)
+
+ @see #setTargetCertConstraints(CertSelector)
+
+
+ Sets the required constraints on the target certificate. The constraints
+ are specified as an instance of CertSelector. If null, no constraints are
+ defined.
+
+ Note that the CertSelector specified is cloned to protect against
+ subsequent modifications.
+
+ @param selector
+ a CertSelector specifying the constraints on the target
+ certificate (or null
)
+
+ @see #getTargetCertConstraints()
+
+
+ Returns an immutable Set of initial policy identifiers (OID strings),
+ indicating that any one of these policies would be acceptable to the
+ certificate user for the purposes of certification path processing. The
+ default return value is an empty Set
, which is
+ interpreted as meaning that any policy would be acceptable.
+
+ @return an immutable Set
of initial policy OIDs in String
+ format, or an empty Set
(implying any policy is
+ acceptable). Never returns null
.
+
+ @see #setInitialPolicies(java.util.Set)
+
+
+ Sets the Set
of initial policy identifiers (OID strings),
+ indicating that any one of these policies would be acceptable to the
+ certificate user for the purposes of certification path processing. By
+ default, any policy is acceptable (i.e. all policies), so a user that
+ wants to allow any policy as acceptable does not need to call this
+ method, or can call it with an empty Set
(or
+ null
).
+
+ Note that the Set is copied to protect against subsequent modifications.
+
+
+ @param initialPolicies
+ a Set of initial policy OIDs in String format (or
+ null
)
+
+ @exception ClassCastException
+ if any of the elements in the set are not of type String
+
+ @see #getInitialPolicies()
+
+
+ Sets a List
of additional certification path checkers. If
+ the specified List contains an object that is not a PKIXCertPathChecker,
+ it is ignored.
+
+ Each PKIXCertPathChecker
specified implements additional
+ checks on a certificate. Typically, these are checks to process and
+ verify private extensions contained in certificates. Each
+ PKIXCertPathChecker
should be instantiated with any
+ initialization parameters needed to execute the check.
+
+ This method allows sophisticated applications to extend a PKIX
+ CertPathValidator
or CertPathBuilder
. Each
+ of the specified PKIXCertPathCheckers will be called, in turn, by a PKIX
+ CertPathValidator
or CertPathBuilder
for
+ each certificate processed or validated.
+
+ Regardless of whether these additional PKIXCertPathCheckers are set, a
+ PKIX CertPathValidator
or CertPathBuilder
+ must perform all of the required PKIX checks on each certificate. The one
+ exception to this rule is if the RevocationEnabled flag is set to false
+ (see the {@link #setRevocationEnabled(boolean) setRevocationEnabled}
+ method).
+
+ Note that the List supplied here is copied and each PKIXCertPathChecker
+ in the list is cloned to protect against subsequent modifications.
+
+ @param checkers
+ a List of PKIXCertPathCheckers. May be null, in which case no
+ additional checkers will be used.
+ @exception ClassCastException
+ if any of the elements in the list are not of type
+ java.security.cert.PKIXCertPathChecker
+ @see #getCertPathCheckers()
+
+
+ Returns the List of certification path checkers. Each PKIXCertPathChecker
+ in the returned IList is cloned to protect against subsequent modifications.
+
+ @return an immutable List of PKIXCertPathCheckers (may be empty, but not
+ null
)
+
+ @see #setCertPathCheckers(java.util.List)
+
+
+ Adds a PKIXCertPathChecker
to the list of certification
+ path checkers. See the {@link #setCertPathCheckers setCertPathCheckers}
+ method for more details.
+
+ Note that the PKIXCertPathChecker
is cloned to protect
+ against subsequent modifications.
+
+ @param checker a PKIXCertPathChecker
to add to the list of
+ checks. If null
, the checker is ignored (not added to list).
+
+
+ Method to support Clone()
under J2ME.
+ super.Clone()
does not exist and fields are not copied.
+
+ @param params Parameters to set. If this are
+ ExtendedPkixParameters
they are copied to.
+
+
+ Whether delta CRLs should be used for checking the revocation status.
+ Defaults to false
.
+
+
+ The validity model.
+ @see #CHAIN_VALIDITY_MODEL
+ @see #PKIX_VALIDITY_MODEL
+
+
+ Sets the Bouncy Castle Stores for finding CRLs, certificates, attribute
+ certificates or cross certificates.
+
+ The IList
is cloned.
+
+
+ @param stores A list of stores to use.
+ @see #getStores
+ @throws ClassCastException if an element of stores
is not
+ a {@link Store}.
+
+
+ Adds a Bouncy Castle {@link Store} to find CRLs, certificates, attribute
+ certificates or cross certificates.
+
+ This method should be used to add local stores, like collection based
+ X.509 stores, if available. Local stores should be considered first,
+ before trying to use additional (remote) locations, because they do not
+ need possible additional network traffic.
+
+ If store
is null
it is ignored.
+
+
+ @param store The store to add.
+ @see #getStores
+
+
+ Adds an additional Bouncy Castle {@link Store} to find CRLs, certificates,
+ attribute certificates or cross certificates.
+
+ You should not use this method. This method is used for adding additional
+ X.509 stores, which are used to add (remote) locations, e.g. LDAP, found
+ during X.509 object processing, e.g. in certificates or CRLs. This method
+ is used in PKIX certification path processing.
+
+ If store
is null
it is ignored.
+
+
+ @param store The store to add.
+ @see #getStores()
+
+
+ Returns an IList
of additional Bouncy Castle
+ Store
s used for finding CRLs, certificates, attribute
+ certificates or cross certificates.
+
+ @return an immutable IList
of additional Bouncy Castle
+ Store
s. Never null
.
+
+ @see #addAddionalStore(Store)
+
+
+ Returns an IList
of Bouncy Castle
+ Store
s used for finding CRLs, certificates, attribute
+ certificates or cross certificates.
+
+ @return an immutable IList
of Bouncy Castle
+ Store
s. Never null
.
+
+ @see #setStores(IList)
+
+
+ Returns if additional {@link X509Store}s for locations like LDAP found
+ in certificates or CRLs should be used.
+
+ @return Returns true
if additional stores are used.
+
+
+ Sets if additional {@link X509Store}s for locations like LDAP found in
+ certificates or CRLs should be used.
+
+ @param enabled true
if additional stores are used.
+
+
+ Returns the required constraints on the target certificate or attribute
+ certificate. The constraints are returned as an instance of
+ IX509Selector
. If null
, no constraints are
+ defined.
+
+
+ The target certificate in a PKIX path may be a certificate or an
+ attribute certificate.
+
+ Note that the IX509Selector
returned is cloned to protect
+ against subsequent modifications.
+
+ @return a IX509Selector
specifying the constraints on the
+ target certificate or attribute certificate (or null
)
+ @see #setTargetConstraints
+ @see X509CertStoreSelector
+ @see X509AttributeCertStoreSelector
+
+
+ Sets the required constraints on the target certificate or attribute
+ certificate. The constraints are specified as an instance of
+ IX509Selector
. If null
, no constraints are
+ defined.
+
+ The target certificate in a PKIX path may be a certificate or an
+ attribute certificate.
+
+ Note that the IX509Selector
specified is cloned to protect
+ against subsequent modifications.
+
+
+ @param selector a IX509Selector
specifying the constraints on
+ the target certificate or attribute certificate (or
+ null
)
+ @see #getTargetConstraints
+ @see X509CertStoreSelector
+ @see X509AttributeCertStoreSelector
+
+
+ Returns the trusted attribute certificate issuers. If attribute
+ certificates is verified the trusted AC issuers must be set.
+
+ The returned ISet
consists of TrustAnchor
s.
+
+ The returned ISet
is immutable. Never null
+
+
+ @return Returns an immutable set of the trusted AC issuers.
+
+
+ Sets the trusted attribute certificate issuers. If attribute certificates
+ is verified the trusted AC issuers must be set.
+
+ The trustedACIssuers
must be a ISet
of
+ TrustAnchor
+
+ The given set is cloned.
+
+
+ @param trustedACIssuers The trusted AC issuers to set. Is never
+ null
.
+ @throws ClassCastException if an element of stores
is not
+ a TrustAnchor
.
+
+
+ Returns the necessary attributes which must be contained in an attribute
+ certificate.
+
+ The returned ISet
is immutable and contains
+ String
s with the OIDs.
+
+
+ @return Returns the necessary AC attributes.
+
+
+ Sets the necessary which must be contained in an attribute certificate.
+
+ The ISet
must contain String
s with the
+ OIDs.
+
+ The set is cloned.
+
+
+ @param necessaryACAttributes The necessary AC attributes to set.
+ @throws ClassCastException if an element of
+ necessaryACAttributes
is not a
+ String
.
+
+
+ Returns the attribute certificates which are not allowed.
+
+ The returned ISet
is immutable and contains
+ String
s with the OIDs.
+
+
+ @return Returns the prohibited AC attributes. Is never null
.
+
+
+ Sets the attribute certificates which are not allowed.
+
+ The ISet
must contain String
s with the
+ OIDs.
+
+ The set is cloned.
+
+
+ @param prohibitedACAttributes The prohibited AC attributes to set.
+ @throws ClassCastException if an element of
+ prohibitedACAttributes
is not a
+ String
.
+
+
+ Returns the attribute certificate checker. The returned set contains
+ {@link PKIXAttrCertChecker}s and is immutable.
+
+ @return Returns the attribute certificate checker. Is never
+ null
.
+
+
+ Sets the attribute certificate checkers.
+
+ All elements in the ISet
must a {@link PKIXAttrCertChecker}.
+
+
+ The given set is cloned.
+
+
+ @param attrCertCheckers The attribute certificate checkers to set. Is
+ never null
.
+ @throws ClassCastException if an element of attrCertCheckers
+ is not a PKIXAttrCertChecker
.
+
+
+
+ Summary description for PkixPolicyNode.
+
+
+
+ Constructors
+
+
+
+ This class helps to handle CRL revocation reasons mask. Each CRL handles a
+ certain set of revocation reasons.
+
+
+
+
+ Constructs are reason mask with the reasons.
+
+ The reasons.
+
+
+
+ A reason mask with no reason.
+
+
+
+
+ A mask with all revocation reasons.
+
+
+
+ Adds all reasons from the reasons mask to this mask.
+
+ @param mask The reasons mask to add.
+
+
+
+ Returns true
if this reasons mask contains all possible
+ reasons.
+
+ true if this reasons mask contains all possible reasons.
+
+
+
+
+ Intersects this mask with the given reasons mask.
+
+ mask The mask to intersect with.
+ The intersection of this and teh given mask.
+
+
+
+ Returns true if the passed reasons mask has new reasons.
+
+ The reasons mask which should be tested for new reasons.
+ true if the passed reasons mask has new reasons.
+
+
+
+ Returns the reasons in this mask.
+
+
+
+ If the complete CRL includes an issuing distribution point (IDP) CRL
+ extension check the following:
+
+ (i) If the distribution point name is present in the IDP CRL extension
+ and the distribution field is present in the DP, then verify that one of
+ the names in the IDP matches one of the names in the DP. If the
+ distribution point name is present in the IDP CRL extension and the
+ distribution field is omitted from the DP, then verify that one of the
+ names in the IDP matches one of the names in the cRLIssuer field of the
+ DP.
+
+
+ (ii) If the onlyContainsUserCerts boolean is asserted in the IDP CRL
+ extension, verify that the certificate does not include the basic
+ constraints extension with the cA boolean asserted.
+
+
+ (iii) If the onlyContainsCACerts boolean is asserted in the IDP CRL
+ extension, verify that the certificate includes the basic constraints
+ extension with the cA boolean asserted.
+
+
+ (iv) Verify that the onlyContainsAttributeCerts boolean is not asserted.
+
+
+ @param dp The distribution point.
+ @param cert The certificate.
+ @param crl The CRL.
+ @throws AnnotatedException if one of the conditions is not met or an error occurs.
+
+
+ If the DP includes cRLIssuer, then verify that the issuer field in the
+ complete CRL matches cRLIssuer in the DP and that the complete CRL
+ contains an
+ g distribution point extension with the indirectCRL
+ boolean asserted. Otherwise, verify that the CRL issuer matches the
+ certificate issuer.
+
+ @param dp The distribution point.
+ @param cert The certificate ot attribute certificate.
+ @param crl The CRL for cert
.
+ @throws AnnotatedException if one of the above conditions does not apply or an error
+ occurs.
+
+
+ Obtain and validate the certification path for the complete CRL issuer.
+ If a key usage extension is present in the CRL issuer's certificate,
+ verify that the cRLSign bit is set.
+
+ @param crl CRL which contains revocation information for the certificate
+ cert
.
+ @param cert The attribute certificate or certificate to check if it is
+ revoked.
+ @param defaultCRLSignCert The issuer certificate of the certificate cert
.
+ @param defaultCRLSignKey The public key of the issuer certificate
+ defaultCRLSignCert
.
+ @param paramsPKIX paramsPKIX PKIX parameters.
+ @param certPathCerts The certificates on the certification path.
+ @return A Set
with all keys of possible CRL issuer
+ certificates.
+ @throws AnnotatedException if the CRL is not valid or the status cannot be checked or
+ some error occurs.
+
+
+ Checks a distribution point for revocation information for the
+ certificate cert
.
+
+ @param dp The distribution point to consider.
+ @param paramsPKIX PKIX parameters.
+ @param cert Certificate to check if it is revoked.
+ @param validDate The date when the certificate revocation status should be
+ checked.
+ @param defaultCRLSignCert The issuer certificate of the certificate cert
.
+ @param defaultCRLSignKey The public key of the issuer certificate
+ defaultCRLSignCert
.
+ @param certStatus The current certificate revocation status.
+ @param reasonMask The reasons mask which is already checked.
+ @param certPathCerts The certificates of the certification path.
+ @throws AnnotatedException if the certificate is revoked or the status cannot be checked
+ or some error occurs.
+
+
+ Checks a certificate if it is revoked.
+
+ @param paramsPKIX PKIX parameters.
+ @param cert Certificate to check if it is revoked.
+ @param validDate The date when the certificate revocation status should be
+ checked.
+ @param sign The issuer certificate of the certificate cert
.
+ @param workingPublicKey The public key of the issuer certificate sign
.
+ @param certPathCerts The certificates of the certification path.
+ @throws AnnotatedException if the certificate is revoked or the status cannot be checked
+ or some error occurs.
+
+
+ If use-deltas is set, verify the issuer and scope of the delta CRL.
+
+ @param deltaCRL The delta CRL.
+ @param completeCRL The complete CRL.
+ @param pkixParams The PKIX paramaters.
+ @throws AnnotatedException if an exception occurs.
+
+
+ Checks if an attribute certificate is revoked.
+
+ @param attrCert Attribute certificate to check if it is revoked.
+ @param paramsPKIX PKIX parameters.
+ @param issuerCert The issuer certificate of the attribute certificate
+ attrCert
.
+ @param validDate The date when the certificate revocation status should
+ be checked.
+ @param certPathCerts The certificates of the certification path to be
+ checked.
+
+ @throws CertPathValidatorException if the certificate is revoked or the
+ status cannot be checked or some error occurs.
+
+
+ Searches for a holder public key certificate and verifies its
+ certification path.
+
+ @param attrCert the attribute certificate.
+ @param pkixParams The PKIX parameters.
+ @return The certificate path of the holder certificate.
+ @throws Exception if
+
+ - no public key certificate can be found although holder
+ information is given by an entity name or a base certificate
+ ID
+ - support classes cannot be created
+ - no certification path for the public key certificate can
+ be built
+
+
+
+
+ Checks a distribution point for revocation information for the
+ certificate attrCert
.
+
+ @param dp The distribution point to consider.
+ @param attrCert The attribute certificate which should be checked.
+ @param paramsPKIX PKIX parameters.
+ @param validDate The date when the certificate revocation status should
+ be checked.
+ @param issuerCert Certificate to check if it is revoked.
+ @param reasonMask The reasons mask which is already checked.
+ @param certPathCerts The certificates of the certification path to be
+ checked.
+ @throws Exception if the certificate is revoked or the status
+ cannot be checked or some error occurs.
+
+
+
+ A trust anchor or most-trusted Certification Authority (CA).
+
+ This class represents a "most-trusted CA", which is used as a trust anchor
+ for validating X.509 certification paths. A most-trusted CA includes the
+ public key of the CA, the CA's name, and any constraints upon the set of
+ paths which may be validated using this key. These parameters can be
+ specified in the form of a trusted X509Certificate or as individual
+ parameters.
+
+
+
+
+ Creates an instance of TrustAnchor with the specified X509Certificate and
+ optional name constraints, which are intended to be used as additional
+ constraints when validating an X.509 certification path.
+ The name constraints are specified as a byte array. This byte array
+ should contain the DER encoded form of the name constraints, as they
+ would appear in the NameConstraints structure defined in RFC 2459 and
+ X.509. The ASN.1 definition of this structure appears below.
+
+
+ NameConstraints ::= SEQUENCE {
+ permittedSubtrees [0] GeneralSubtrees OPTIONAL,
+ excludedSubtrees [1] GeneralSubtrees OPTIONAL }
+
+ GeneralSubtrees ::= SEQUENCE SIZE (1..MAX) OF GeneralSubtree
+
+ GeneralSubtree ::= SEQUENCE {
+ base GeneralName,
+ minimum [0] BaseDistance DEFAULT 0,
+ maximum [1] BaseDistance OPTIONAL }
+
+ BaseDistance ::= INTEGER (0..MAX)
+
+ GeneralName ::= CHOICE {
+ otherName [0] OtherName,
+ rfc822Name [1] IA5String,
+ dNSName [2] IA5String,
+ x400Address [3] ORAddress,
+ directoryName [4] Name,
+ ediPartyName [5] EDIPartyName,
+ uniformResourceIdentifier [6] IA5String,
+ iPAddress [7] OCTET STRING,
+ registeredID [8] OBJECT IDENTIFIER}
+
+
+ Note that the name constraints byte array supplied is cloned to protect
+ against subsequent modifications.
+
+ a trusted X509Certificate
+ a byte array containing the ASN.1 DER encoding of a
+ NameConstraints extension to be used for checking name
+ constraints. Only the value of the extension is included, not
+ the OID or criticality flag. Specify null to omit the
+ parameter.
+ if the specified X509Certificate is null
+
+
+
+ Creates an instance of TrustAnchor where the
+ most-trusted CA is specified as an X500Principal and public key.
+
+
+
+ Name constraints are an optional parameter, and are intended to be used
+ as additional constraints when validating an X.509 certification path.
+
+ The name constraints are specified as a byte array. This byte array
+ contains the DER encoded form of the name constraints, as they
+ would appear in the NameConstraints structure defined in RFC 2459
+ and X.509. The ASN.1 notation for this structure is supplied in the
+ documentation for the other constructors.
+
+ Note that the name constraints byte array supplied here is cloned to
+ protect against subsequent modifications.
+
+
+ the name of the most-trusted CA as X509Name
+ the public key of the most-trusted CA
+
+ a byte array containing the ASN.1 DER encoding of a NameConstraints extension to
+ be used for checking name constraints. Only the value of the extension is included,
+ not the OID or criticality flag. Specify null to omit the parameter.
+
+
+ if caPrincipal or pubKey is null
+
+
+
+
+ Creates an instance of TrustAnchor
where the most-trusted
+ CA is specified as a distinguished name and public key. Name constraints
+ are an optional parameter, and are intended to be used as additional
+ constraints when validating an X.509 certification path.
+
+ The name constraints are specified as a byte array. This byte array
+ contains the DER encoded form of the name constraints, as they would
+ appear in the NameConstraints structure defined in RFC 2459 and X.509.
+
+ the X.500 distinguished name of the most-trusted CA in RFC
+ 2253 string format
+ the public key of the most-trusted CA
+ a byte array containing the ASN.1 DER encoding of a
+ NameConstraints extension to be used for checking name
+ constraints. Only the value of the extension is included, not
+ the OID or criticality flag. Specify null to omit the
+ parameter.
+ throws NullPointerException, IllegalArgumentException
+
+
+
+ Returns the most-trusted CA certificate.
+
+
+
+
+ Returns the name of the most-trusted CA as an X509Name.
+
+
+
+
+ Returns the name of the most-trusted CA in RFC 2253 string format.
+
+
+
+
+ Returns the public key of the most-trusted CA.
+
+
+
+
+ Decode the name constraints and clone them if not null.
+
+
+
+
+ Returns a formatted string describing the TrustAnchor
.
+
+ a formatted string describing the TrustAnchor
+
+
+ Recognised hash algorithms for the time stamp protocol.
+
+
+ Fetches the signature time-stamp attributes from a SignerInformation object.
+ Checks that the MessageImprint for each time-stamp matches the signature field.
+ (see RFC 3161 Appendix A).
+
+ @param signerInfo a SignerInformation to search for time-stamps
+ @return a collection of TimeStampToken objects
+ @throws TSPValidationException
+
+
+ Validate the passed in certificate as being of the correct type to be used
+ for time stamping. To be valid it must have an ExtendedKeyUsage extension
+ which has a key purpose identifier of id-kp-timeStamping.
+
+ @param cert the certificate of interest.
+ @throws TspValidationException if the certicate fails on one of the check points.
+
+
+
+ Return the digest algorithm using one of the standard JCA string
+ representations rather than the algorithm identifier (if possible).
+
+
+
+ Exception thrown if a TSP request or response fails to validate.
+
+ If a failure code is associated with the exception it can be retrieved using
+ the getFailureCode() method.
+
+
+ Return the failure code associated with this exception - if one is set.
+
+ @return the failure code if set, -1 otherwise.
+
+
+ Base class for an RFC 3161 Time Stamp Request.
+
+
+ Create a TimeStampRequest from the past in byte array.
+
+ @param req byte array containing the request.
+ @throws IOException if the request is malformed.
+
+
+ Create a TimeStampRequest from the past in input stream.
+
+ @param in input stream containing the request.
+ @throws IOException if the request is malformed.
+
+
+ Validate the timestamp request, checking the digest to see if it is of an
+ accepted type and whether it is of the correct length for the algorithm specified.
+
+ @param algorithms a set of string OIDS giving accepted algorithms.
+ @param policies if non-null a set of policies we are willing to sign under.
+ @param extensions if non-null a set of extensions we are willing to accept.
+ @throws TspException if the request is invalid, or processing fails.
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ Generator for RFC 3161 Time Stamp Request objects.
+
+
+ add a given extension field for the standard extensions tag (tag 3)
+ @throws IOException
+
+
+ add a given extension field for the standard extensions tag
+ The value parameter becomes the contents of the octet string associated
+ with the extension.
+
+
+ add a given extension field for the standard extensions tag (tag 3)
+ @throws IOException
+
+
+ add a given extension field for the standard extensions tag
+ The value parameter becomes the contents of the octet string associated
+ with the extension.
+
+
+ Base class for an RFC 3161 Time Stamp Response object.
+
+
+ Create a TimeStampResponse from a byte array containing an ASN.1 encoding.
+
+ @param resp the byte array containing the encoded response.
+ @throws TspException if the response is malformed.
+ @throws IOException if the byte array doesn't represent an ASN.1 encoding.
+
+
+ Create a TimeStampResponse from an input stream containing an ASN.1 encoding.
+
+ @param input the input stream containing the encoded response.
+ @throws TspException if the response is malformed.
+ @throws IOException if the stream doesn't represent an ASN.1 encoding.
+
+
+ Check this response against to see if it a well formed response for
+ the passed in request. Validation will include checking the time stamp
+ token if the response status is GRANTED or GRANTED_WITH_MODS.
+
+ @param request the request to be checked against
+ @throws TspException if the request can not match this response.
+
+
+ return the ASN.1 encoded representation of this object.
+
+
+ Generator for RFC 3161 Time Stamp Responses.
+
+
+ Return an appropriate TimeStampResponse.
+
+ If genTime is null a timeNotAvailable error response will be returned.
+
+ @param request the request this response is for.
+ @param serialNumber serial number for the response token.
+ @param genTime generation time for the response token.
+ @param provider provider to use for signature calculation.
+ @return
+ @throws NoSuchAlgorithmException
+ @throws NoSuchProviderException
+ @throws TSPException
+
+
+
+ Generate a TimeStampResponse with chosen status and FailInfoField.
+
+ @param status the PKIStatus to set.
+ @param failInfoField the FailInfoField to set.
+ @param statusString an optional string describing the failure.
+ @return a TimeStampResponse with a failInfoField and optional statusString
+ @throws TSPException in case the response could not be created
+
+
+ Validate the time stamp token.
+
+ To be valid the token must be signed by the passed in certificate and
+ the certificate must be the one referred to by the SigningCertificate
+ attribute included in the hashed attributes of the token. The
+ certificate must also have the ExtendedKeyUsageExtension with only
+ KeyPurposeID.IdKPTimeStamping and have been valid at the time the
+ timestamp was created.
+
+
+ A successful call to validate means all the above are true.
+
+
+
+ Return the underlying CmsSignedData object.
+
+ @return the underlying CMS structure.
+
+
+ Return a ASN.1 encoded byte stream representing the encoded object.
+
+ @throws IOException if encoding fails.
+
+
+ basic creation - only the default attributes will be included here.
+
+
+ create with a signer with extra signed/unsigned attributes.
+
+
+ @return the nonce value, null if there isn't one.
+
+
+ General array utilities.
+
+
+
+ Are two arrays equal.
+
+ Left side.
+ Right side.
+ True if equal.
+
+
+
+ A constant time equals comparison - does not terminate early if
+ test will fail.
+
+ first array
+ second array
+ true if arrays equal, false otherwise.
+
+
+ Make a copy of a range of bytes from the passed in data array. The range can
+ extend beyond the end of the input array, in which case the return array will
+ be padded with zeroes.
+
+ @param data the array from which the data is to be copied.
+ @param from the start index at which the copying should take place.
+ @param to the final index of the range (exclusive).
+
+ @return a new byte array containing the range given.
+
+
+ BigInteger utilities.
+
+
+ Return the passed in value as an unsigned byte array.
+
+ @param value value to be converted.
+ @return a byte array without a leading zero byte if present in the signed encoding.
+
+
+ Return the passed in value as an unsigned byte array of specified length, zero-extended as necessary.
+
+ @param length desired length of result array.
+ @param n value to be converted.
+ @return a byte array of specified length, with leading zeroes as necessary given the size of n.
+
+
+ Return a random BigInteger not less than 'min' and not greater than 'max'
+
+ @param min the least value that may be generated
+ @param max the greatest value that may be generated
+ @param random the source of randomness
+ @return a random BigInteger value in the range [min,max]
+
+
+
+ Produce a copy of this object with its configuration and in its current state.
+
+
+ The returned object may be used simply to store the state, or may be used as a similar object
+ starting from the copied state.
+
+
+
+
+ Restore a copied object state into this object.
+
+
+ Implementations of this method should try to avoid or minimise memory allocation to perform the reset.
+
+ an object originally {@link #copy() copied} from an object of the same type as this instance.
+ if the provided object is not of the correct type.
+ if the other parameter is in some other way invalid.
+
+
+ Exception to be thrown on a failure to reset an object implementing Memoable.
+
+ The exception extends InvalidCastException to enable users to have a single handling case,
+ only introducing specific handling of this one if required.
+
+
+
+ Basic Constructor.
+
+ @param msg message to be associated with this exception.
+
+
+ General string utilities.
+
+
+
+ Return the number of milliseconds since the Unix epoch (1 Jan., 1970 UTC) for a given DateTime value.
+
+ A UTC DateTime value not before epoch.
+ Number of whole milliseconds after epoch.
+ 'dateTime' is before epoch.
+
+
+
+ Create a DateTime value from the number of milliseconds since the Unix epoch (1 Jan., 1970 UTC).
+
+ Number of milliseconds since the epoch.
+ A UTC DateTime value
+
+
+
+ Return the current number of milliseconds since the Unix epoch (1 Jan., 1970 UTC).
+
+
+
+ encode the input data producing a base 64 encoded byte array.
+
+ @return a byte array containing the base 64 encoded data.
+
+
+ encode the input data producing a base 64 encoded byte array.
+
+ @return a byte array containing the base 64 encoded data.
+
+
+ Encode the byte data to base 64 writing it to the given output stream.
+
+ @return the number of bytes produced.
+
+
+ Encode the byte data to base 64 writing it to the given output stream.
+
+ @return the number of bytes produced.
+
+
+ decode the base 64 encoded input data. It is assumed the input data is valid.
+
+ @return a byte array representing the decoded data.
+
+
+ decode the base 64 encoded string data - whitespace will be ignored.
+
+ @return a byte array representing the decoded data.
+
+
+ decode the base 64 encoded string data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+ encode the input data producing a base 64 output stream.
+
+ @return the number of bytes produced.
+
+
+ decode the base 64 encoded byte data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+ decode the base 64 encoded string data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+
+ A buffering class to allow translation from one format to another to
+ be done in discrete chunks.
+
+
+
+
+ Create a buffered Decoder.
+
+ The translater to use.
+ The size of the buffer.
+
+
+
+ Process one byte of data.
+
+ Data in.
+ Byte array for the output.
+ The offset in the output byte array to start writing from.
+ The amount of output bytes.
+
+
+
+ Process data from a byte array.
+
+ The input data.
+ Start position within input data array.
+ Amount of data to process from input data array.
+ Array to store output.
+ Position in output array to start writing from.
+ The amount of output bytes.
+
+
+
+ A class that allows encoding of data using a specific encoder to be processed in chunks.
+
+
+
+
+ Create.
+
+ The translator to use.
+ Size of the chunks.
+
+
+
+ Process one byte of data.
+
+ The byte.
+ An array to store output in.
+ Offset within output array to start writing from.
+
+
+
+
+ Process data from a byte array.
+
+ Input data Byte array containing data to be processed.
+ Start position within input data array.
+ Amount of input data to be processed.
+ Output data array.
+ Offset within output data array to start writing to.
+ The amount of data written.
+
+
+
+ Class to decode and encode Hex.
+
+
+
+ encode the input data producing a Hex encoded byte array.
+
+ @return a byte array containing the Hex encoded data.
+
+
+ encode the input data producing a Hex encoded byte array.
+
+ @return a byte array containing the Hex encoded data.
+
+
+ Hex encode the byte data writing it to the given output stream.
+
+ @return the number of bytes produced.
+
+
+ Hex encode the byte data writing it to the given output stream.
+
+ @return the number of bytes produced.
+
+
+ decode the Hex encoded input data. It is assumed the input data is valid.
+
+ @return a byte array representing the decoded data.
+
+
+ decode the Hex encoded string data - whitespace will be ignored.
+
+ @return a byte array representing the decoded data.
+
+
+ decode the Hex encoded string data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+ encode the input data producing a Hex output stream.
+
+ @return the number of bytes produced.
+
+
+ decode the Hex encoded byte data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+ decode the Hex encoded string data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+
+ A hex translator.
+
+
+
+
+ Return encoded block size.
+
+ 2
+
+
+
+ Encode some data.
+
+ Input data array.
+ Start position within input data array.
+ The amount of data to process.
+ The output data array.
+ The offset within the output data array to start writing from.
+ Amount of data encoded.
+
+
+
+ Returns the decoded block size.
+
+ 1
+
+
+
+ Decode data from a byte array.
+
+ The input data array.
+ Start position within input data array.
+ The amounty of data to process.
+ The output data array.
+ The position within the output data array to start writing from.
+ The amount of data written.
+
+
+ Encode and decode byte arrays (typically from binary to 7-bit ASCII
+ encodings).
+
+
+
+ Translator interface.
+
+
+
+ Convert binary data to and from UrlBase64 encoding. This is identical to
+ Base64 encoding, except that the padding character is "." and the other
+ non-alphanumeric characters are "-" and "_" instead of "+" and "/".
+
+ The purpose of UrlBase64 encoding is to provide a compact encoding of binary
+ data that is safe for use as an URL parameter. Base64 encoding does not
+ produce encoded values that are safe for use in URLs, since "/" can be
+ interpreted as a path delimiter; "+" is the encoded form of a space; and
+ "=" is used to separate a name from the corresponding value in an URL
+ parameter.
+
+
+
+ Encode the input data producing a URL safe base 64 encoded byte array.
+
+ @return a byte array containing the URL safe base 64 encoded data.
+
+
+ Encode the byte data writing it to the given output stream.
+
+ @return the number of bytes produced.
+
+
+ Decode the URL safe base 64 encoded input data - white space will be ignored.
+
+ @return a byte array representing the decoded data.
+
+
+ decode the URL safe base 64 encoded byte data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+ decode the URL safe base 64 encoded string data - whitespace will be ignored.
+
+ @return a byte array representing the decoded data.
+
+
+ Decode the URL safe base 64 encoded string data writing it to the given output stream,
+ whitespace characters will be ignored.
+
+ @return the number of bytes produced.
+
+
+ Convert binary data to and from UrlBase64 encoding. This is identical to
+ Base64 encoding, except that the padding character is "." and the other
+ non-alphanumeric characters are "-" and "_" instead of "+" and "/".
+
+ The purpose of UrlBase64 encoding is to provide a compact encoding of binary
+ data that is safe for use as an URL parameter. Base64 encoding does not
+ produce encoded values that are safe for use in URLs, since "/" can be
+ interpreted as a path delimiter; "+" is the encoded form of a space; and
+ "=" is used to separate a name from the corresponding value in an URL
+ parameter.
+
+
+
+
+ Pipe all bytes from inStr to outStr, throwing StreamFlowException if greater
+ than limit bytes in inStr.
+
+
+ A
+
+
+ A
+
+
+ A
+
+ The number of bytes actually transferred, if not greater than limit
+
+
+
+
+ A
+
+
+
+
+
+ A
+
+
+ A
+
+
+
+
+
+ A
+
+
+
+
+ A generic PEM writer, based on RFC 1421
+
+
+ Base constructor.
+
+ @param out output stream to use.
+
+
+ Return the number of bytes or characters required to contain the
+ passed in object if it is PEM encoded.
+
+ @param obj pem object to be output
+ @return an estimate of the number of bytes
+
+
+ Validate the given IPv4 or IPv6 address.
+
+ @param address the IP address as a string.
+
+ @return true if a valid address, false otherwise
+
+
+ Validate the given IPv4 or IPv6 address and netmask.
+
+ @param address the IP address as a string.
+
+ @return true if a valid address with netmask, false otherwise
+
+
+ Validate the given IPv4 address.
+
+ @param address the IP address as a string.
+
+ @return true if a valid IPv4 address, false otherwise
+
+
+ Validate the given IPv6 address.
+
+ @param address the IP address as a string.
+
+ @return true if a valid IPv4 address, false otherwise
+
+
+
+ Summary description for DeflaterOutputStream.
+
+
+
+
+ Summary description for DeflaterOutputStream.
+
+
+
+
+ The Holder object.
+
+ Holder ::= SEQUENCE {
+ baseCertificateID [0] IssuerSerial OPTIONAL,
+ -- the issuer and serial number of
+ -- the holder's Public Key Certificate
+ entityName [1] GeneralNames OPTIONAL,
+ -- the name of the claimant or role
+ objectDigestInfo [2] ObjectDigestInfo OPTIONAL
+ -- used to directly authenticate the holder,
+ -- for example, an executable
+ }
+
+
+
+
+ Constructs a holder for v2 attribute certificates with a hash value for
+ some type of object.
+
+ digestedObjectType
can be one of the following:
+
+ - 0 - publicKey - A hash of the public key of the holder must be
+ passed.
+ - 1 - publicKeyCert - A hash of the public key certificate of the
+ holder must be passed.
+ - 2 - otherObjectDigest - A hash of some other object type must be
+ passed.
otherObjectTypeID
must not be empty.
+
+
+ This cannot be used if a v1 attribute certificate is used.
+
+ @param digestedObjectType The digest object type.
+ @param digestAlgorithm The algorithm identifier for the hash.
+ @param otherObjectTypeID The object type ID if
+ digestedObjectType
is
+ otherObjectDigest
.
+ @param objectDigest The hash value.
+
+
+ Returns the digest object type if an object digest info is used.
+
+
+ - 0 - publicKey - A hash of the public key of the holder must be
+ passed.
+ - 1 - publicKeyCert - A hash of the public key certificate of the
+ holder must be passed.
+ - 2 - otherObjectDigest - A hash of some other object type must be
+ passed.
otherObjectTypeID
must not be empty.
+
+
+
+ @return The digest object type or -1 if no object digest info is set.
+
+
+ Returns the other object type ID if an object digest info is used.
+
+ @return The other object type ID or null
if no object
+ digest info is set.
+
+
+ Returns the hash if an object digest info is used.
+
+ @return The hash or null
if no object digest info is set.
+
+
+ Returns the digest algorithm ID if an object digest info is used.
+
+ @return The digest algorithm ID or null
if no object
+ digest info is set.
+
+
+ Return any principal objects inside the attribute certificate holder entity names field.
+
+ @return an array of IPrincipal objects (usually X509Name), null if no entity names field is set.
+
+
+ Return the principals associated with the issuer attached to this holder
+
+ @return an array of principals, null if no BaseCertificateID is set.
+
+
+ Return the serial number associated with the issuer attached to this holder.
+
+ @return the certificate serial number, null if no BaseCertificateID is set.
+
+
+ Carrying class for an attribute certificate issuer.
+
+
+ Set the issuer directly with the ASN.1 structure.
+
+ @param issuer The issuer
+
+
+ Return any principal objects inside the attribute certificate issuer object.
+ An array of IPrincipal objects (usually X509Principal).
+
+
+ Interface for an X.509 Attribute Certificate.
+
+
+ The version number for the certificate.
+
+
+ The serial number for the certificate.
+
+
+ The UTC DateTime before which the certificate is not valid.
+
+
+ The UTC DateTime after which the certificate is not valid.
+
+
+ The holder of the certificate.
+
+
+ The issuer details for the certificate.
+
+
+ Return the attributes contained in the attribute block in the certificate.
+ An array of attributes.
+
+
+ Return the attributes with the same type as the passed in oid.
+ The object identifier we wish to match.
+ An array of matched attributes, null if there is no match.
+
+
+ Return an ASN.1 encoded byte array representing the attribute certificate.
+ An ASN.1 encoded byte array.
+ If the certificate cannot be encoded.
+
+
+
+ Get all critical extension values, by oid
+
+ IDictionary with string (OID) keys and Asn1OctetString values
+
+
+
+ Get all non-critical extension values, by oid
+
+ IDictionary with string (OID) keys and Asn1OctetString values
+
+
+
+ A utility class that will extract X509Principal objects from X.509 certificates.
+
+ Use this in preference to trying to recreate a principal from a string, not all
+ DNs are what they should be, so it's best to leave them encoded where they
+ can be.
+
+
+
+ Return the issuer of the given cert as an X509Principal.
+
+
+ Return the subject of the given cert as an X509Principal.
+
+
+ Return the issuer of the given CRL as an X509Principal.
+
+
+
+ A factory to produce Public Key Info Objects.
+
+
+
+
+ Create a Subject Public Key Info object for a given public key.
+
+ One of ElGammalPublicKeyParameters, DSAPublicKeyParameter, DHPublicKeyParameters, RsaKeyParameters or ECPublicKeyParameters
+ A subject public key info object.
+ Throw exception if object provided is not one of the above.
+
+
+
+ Create loading data from byte array.
+
+
+
+
+
+ Create loading data from byte array.
+
+
+
+
+ Generates a certificate object and initializes it with the data
+ read from the input stream inStream.
+
+
+ Returns a (possibly empty) collection view of the certificates
+ read from the given input stream inStream.
+
+
+ Class for carrying the values in an X.509 Attribute.
+
+
+ @param at an object representing an attribute.
+
+
+ Create an X.509 Attribute with the type given by the passed in oid and
+ the value represented by an ASN.1 Set containing value.
+
+ @param oid type of the attribute
+ @param value value object to go into the atribute's value set.
+
+
+ Create an X.59 Attribute with the type given by the passed in oid and the
+ value represented by an ASN.1 Set containing the objects in value.
+
+ @param oid type of the attribute
+ @param value vector of values to go in the attribute's value set.
+
+
+
+ Create loading data from byte array.
+
+
+
+
+
+ Create loading data from byte array.
+
+
+
+
+
+ An Object representing an X509 Certificate.
+ Has static methods for loading Certificates encoded in many forms that return X509Certificate Objects.
+
+
+
+
+ Return true if the current time is within the start and end times nominated on the certificate.
+
+ true id certificate is valid for the current time.
+
+
+
+ Return true if the nominated time is within the start and end times nominated on the certificate.
+
+ The time to test validity against.
+ True if certificate is valid for nominated time.
+
+
+
+ Checks if the current date is within certificate's validity period.
+
+
+
+
+ Checks if the given date is within certificate's validity period.
+
+ if the certificate is expired by given date
+ if the certificate is not yet valid on given date
+
+
+
+ Return the certificate's version.
+
+ An integer whose value Equals the version of the cerficate.
+
+
+
+ Return a BigInteger containing the serial number.
+
+ The Serial number.
+
+
+
+ Get the Issuer Distinguished Name. (Who signed the certificate.)
+
+ And X509Object containing name and value pairs.
+
+
+
+ Get the subject of this certificate.
+
+ An X509Name object containing name and value pairs.
+
+
+
+ The time that this certificate is valid from.
+
+ A DateTime object representing that time in the local time zone.
+
+
+
+ The time that this certificate is valid up to.
+
+ A DateTime object representing that time in the local time zone.
+
+
+
+ Return the Der encoded TbsCertificate data.
+ This is the certificate component less the signature.
+ To Get the whole certificate call the GetEncoded() member.
+
+ A byte array containing the Der encoded Certificate component.
+
+
+
+ The signature.
+
+ A byte array containg the signature of the certificate.
+
+
+
+ A meaningful version of the Signature Algorithm. (EG SHA1WITHRSA)
+
+ A sting representing the signature algorithm.
+
+
+
+ Get the Signature Algorithms Object ID.
+
+ A string containg a '.' separated object id.
+
+
+
+ Get the signature algorithms parameters. (EG DSA Parameters)
+
+ A byte array containing the Der encoded version of the parameters or null if there are none.
+
+
+
+ Get the issuers UID.
+
+ A DerBitString.
+
+
+
+ Get the subjects UID.
+
+ A DerBitString.
+
+
+
+ Get a key usage guidlines.
+
+
+
+
+ Get the public key of the subject of the certificate.
+
+ The public key parameters.
+
+
+
+ Return a Der encoded version of this certificate.
+
+ A byte array.
+
+
+
+ Verify the certificate's signature using the nominated public key.
+
+ An appropriate public key parameter object, RsaPublicKeyParameters, DsaPublicKeyParameters or ECDsaPublicKeyParameters
+ True if the signature is valid.
+ If key submitted is not of the above nominated types.
+
+
+
+ Verify the certificate's signature using a verifier created using the passed in verifier provider.
+
+ An appropriate provider for verifying the certificate's signature.
+ True if the signature is valid.
+ If verifier provider is not appropriate or the certificate algorithm is invalid.
+
+
+
+ This class contains a cross certificate pair. Cross certificates pairs may
+ contain two cross signed certificates from two CAs. A certificate from the
+ other CA to this CA is contained in the forward certificate, the certificate
+ from this CA to the other CA is contained in the reverse certificate.
+
+
+
+ Constructor
+ Certificate from the other CA to this CA.
+ Certificate from this CA to the other CA.
+
+
+ Constructor from a ASN.1 CertificatePair structure.
+ The CertificatePair ASN.1 object.
+
+
+ Returns the certificate from the other CA to this CA.
+
+
+ Returns the certificate from this CA to the other CA.
+
+
+ class for dealing with X509 certificates.
+
+ At the moment this will deal with "-----BEGIN CERTIFICATE-----" to "-----END CERTIFICATE-----"
+ base 64 encoded certs, as well as the BER binaries of certificates and some classes of PKCS#7
+ objects.
+
+
+
+ Create loading data from byte array.
+
+
+
+
+
+ Create loading data from byte array.
+
+
+
+
+ Generates a certificate object and initializes it with the data
+ read from the input stream inStream.
+
+
+ Returns a (possibly empty) collection view of the certificates
+ read from the given input stream inStream.
+
+
+ The following extensions are listed in RFC 2459 as relevant to CRLs
+
+ Authority Key Identifier
+ Issuer Alternative Name
+ CRL Number
+ Delta CRL Indicator (critical)
+ Issuing Distribution Point (critical)
+
+
+
+ Verify the CRL's signature using a verifier created using the passed in verifier provider.
+
+ An appropriate provider for verifying the CRL's signature.
+ True if the signature is valid.
+ If verifier provider is not appropriate or the CRL algorithm is invalid.
+
+
+ Returns a string representation of this CRL.
+
+ @return a string representation of this CRL.
+
+
+ Checks whether the given certificate is on this CRL.
+
+ @param cert the certificate to check for.
+ @return true if the given certificate is on this CRL,
+ false otherwise.
+
+
+ The following extensions are listed in RFC 2459 as relevant to CRL Entries
+
+ ReasonCode Hode Instruction Code Invalidity Date Certificate Issuer
+ (critical)
+
+
+ Constructor for CRLEntries of indirect CRLs. If isIndirect
+ is false
{@link #getCertificateIssuer()} will always
+ return null
, previousCertificateIssuer
is
+ ignored. If this isIndirect
is specified and this CrlEntry
+ has no certificate issuer CRL entry extension
+ previousCertificateIssuer
is returned by
+ {@link #getCertificateIssuer()}.
+
+ @param c
+ TbsCertificateList.CrlEntry object.
+ @param isIndirect
+ true
if the corresponding CRL is a indirect
+ CRL.
+ @param previousCertificateIssuer
+ Certificate issuer of the previous CrlEntry.
+
+
+
+ Create loading data from byte array.
+
+
+
+
+
+ Create loading data from byte array.
+
+
+
+
+ Generates a certificate revocation list (CRL) object and initializes
+ it with the data read from the input stream inStream.
+
+
+ Returns a (possibly empty) collection view of the CRLs read from
+ the given input stream inStream.
+
+ The inStream may contain a sequence of DER-encoded CRLs, or
+ a PKCS#7 CRL set. This is a PKCS#7 SignedData object, with the
+ only significant field being crls. In particular the signature
+ and the contents are ignored.
+
+
+
+ Get non critical extensions.
+
+ A set of non critical extension oids.
+
+
+
+ Get any critical extensions.
+
+ A sorted list of critical entension.
+
+
+
+ Get the value of a given extension.
+
+ The object ID of the extension.
+ An Asn1OctetString object if that extension is found or null if not.
+
+
+ A holding class for constructing an X509 Key Usage extension.
+
+
+ id-ce-keyUsage OBJECT IDENTIFIER ::= { id-ce 15 }
+
+ KeyUsage ::= BIT STRING {
+ digitalSignature (0),
+ nonRepudiation (1),
+ keyEncipherment (2),
+ dataEncipherment (3),
+ keyAgreement (4),
+ keyCertSign (5),
+ cRLSign (6),
+ encipherOnly (7),
+ decipherOnly (8) }
+
+
+
+ Basic constructor.
+
+ @param usage - the bitwise OR of the Key Usage flags giving the
+ allowed uses for the key.
+ e.g. (X509KeyUsage.keyEncipherment | X509KeyUsage.dataEncipherment)
+
+
+ Return the digest algorithm using one of the standard JCA string
+ representations rather than the algorithm identifier (if possible).
+
+
+
+ Class to Generate X509V1 Certificates.
+
+
+
+
+ Default Constructor.
+
+
+
+
+ Reset the generator.
+
+
+
+
+ Set the certificate's serial number.
+
+ Make serial numbers long, if you have no serial number policy make sure the number is at least 16 bytes of secure random data.
+ You will be surprised how ugly a serial number collision can get.
+ The serial number.
+
+
+
+ Set the issuer distinguished name.
+ The issuer is the entity whose private key is used to sign the certificate.
+
+ The issuers DN.
+
+
+
+ Set the date that this certificate is to be valid from.
+
+
+
+
+
+ Set the date after which this certificate will no longer be valid.
+
+
+
+
+
+ Set the subject distinguished name.
+ The subject describes the entity associated with the public key.
+
+
+
+
+
+ Set the public key that this certificate identifies.
+
+
+
+
+
+ Set the signature algorithm that will be used to sign this certificate.
+ This can be either a name or an OID, names are treated as case insensitive.
+
+ string representation of the algorithm name
+
+
+
+ Generate a new X509Certificate.
+
+ The private key of the issuer used to sign this certificate.
+ An X509Certificate.
+
+
+
+ Generate a new X509Certificate specifying a SecureRandom instance that you would like to use.
+
+ The private key of the issuer used to sign this certificate.
+ The Secure Random you want to use.
+ An X509Certificate.
+
+
+
+ Generate a new X509Certificate using the passed in SignatureCalculator.
+
+ A signature calculator factory with the necessary algorithm details.
+ An X509Certificate.
+
+
+
+ Allows enumeration of the signature names supported by the generator.
+
+
+
+ An implementation of a version 2 X.509 Attribute Certificate.
+
+
+
+ Verify the certificate's signature using a verifier created using the passed in verifier provider.
+
+ An appropriate provider for verifying the certificate's signature.
+ True if the signature is valid.
+ If verifier provider is not appropriate or the certificate algorithm is invalid.
+
+
+ Class to produce an X.509 Version 2 AttributeCertificate.
+
+
+ Reset the generator
+
+
+ Set the Holder of this Attribute Certificate.
+
+
+ Set the issuer.
+
+
+ Set the serial number for the certificate.
+
+
+
+ Set the signature algorithm. This can be either a name or an OID, names
+ are treated as case insensitive.
+
+ The algorithm name.
+
+
+ Add an attribute.
+
+
+ Add a given extension field for the standard extensions tag.
+
+
+
+ Add a given extension field for the standard extensions tag.
+ The value parameter becomes the contents of the octet string associated
+ with the extension.
+
+
+
+
+ Generate an X509 certificate, based on the current issuer and subject.
+
+
+
+
+ Generate an X509 certificate, based on the current issuer and subject,
+ using the supplied source of randomness, if required.
+
+
+
+
+ Generate a new X.509 Attribute Certificate using the passed in SignatureCalculator.
+
+ A signature calculator factory with the necessary algorithm details.
+ An IX509AttributeCertificate.
+
+
+
+ Allows enumeration of the signature names supported by the generator.
+
+
+
+ class to produce an X.509 Version 2 CRL.
+
+
+ reset the generator
+
+
+ Set the issuer distinguished name - the issuer is the entity whose private key is used to sign the
+ certificate.
+
+
+ Reason being as indicated by CrlReason, i.e. CrlReason.KeyCompromise
+ or 0 if CrlReason is not to be used
+
+
+
+ Add a CRL entry with an Invalidity Date extension as well as a CrlReason extension.
+ Reason being as indicated by CrlReason, i.e. CrlReason.KeyCompromise
+ or 0 if CrlReason is not to be used
+
+
+
+ Add a CRL entry with extensions.
+
+
+
+ Add the CRLEntry objects contained in a previous CRL.
+
+ @param other the X509Crl to source the other entries from.
+
+
+
+ Set the signature algorithm that will be used to sign this CRL.
+
+
+
+
+ add a given extension field for the standard extensions tag (tag 0)
+
+
+ add a given extension field for the standard extensions tag (tag 0)
+
+
+ add a given extension field for the standard extensions tag (tag 0)
+
+
+ add a given extension field for the standard extensions tag (tag 0)
+
+
+
+ Generate an X.509 CRL, based on the current issuer and subject.
+
+ The private key of the issuer that is signing this certificate.
+ An X509Crl.
+
+
+
+ Generate an X.509 CRL, based on the current issuer and subject using the specified secure random.
+
+ The private key of the issuer that is signing this certificate.
+ Your Secure Random instance.
+ An X509Crl.
+
+
+
+ Generate a new X509Crl using the passed in SignatureCalculator.
+
+ A signature calculator factory with the necessary algorithm details.
+ An X509Crl.
+
+
+
+ Allows enumeration of the signature names supported by the generator.
+
+
+
+
+ A class to Generate Version 3 X509Certificates.
+
+
+
+
+ Reset the Generator.
+
+
+
+
+ Set the certificate's serial number.
+
+ Make serial numbers long, if you have no serial number policy make sure the number is at least 16 bytes of secure random data.
+ You will be surprised how ugly a serial number collision can Get.
+ The serial number.
+
+
+
+ Set the distinguished name of the issuer.
+ The issuer is the entity which is signing the certificate.
+
+ The issuer's DN.
+
+
+
+ Set the date that this certificate is to be valid from.
+
+
+
+
+
+ Set the date after which this certificate will no longer be valid.
+
+
+
+
+
+ Set the DN of the entity that this certificate is about.
+
+
+
+
+
+ Set the public key that this certificate identifies.
+
+
+
+
+
+ Set the signature algorithm that will be used to sign this certificate.
+
+
+
+
+
+ Set the subject unique ID - note: it is very rare that it is correct to do this.
+
+
+
+
+
+ Set the issuer unique ID - note: it is very rare that it is correct to do this.
+
+
+
+
+
+ Add a given extension field for the standard extensions tag (tag 3).
+
+ string containing a dotted decimal Object Identifier.
+ Is it critical.
+ The value.
+
+
+
+ Add an extension to this certificate.
+
+ Its Object Identifier.
+ Is it critical.
+ The value.
+
+
+
+ Add an extension using a string with a dotted decimal OID.
+
+ string containing a dotted decimal Object Identifier.
+ Is it critical.
+ byte[] containing the value of this extension.
+
+
+
+ Add an extension to this certificate.
+
+ Its Object Identifier.
+ Is it critical.
+ byte[] containing the value of this extension.
+
+
+
+ Add a given extension field for the standard extensions tag (tag 3),
+ copying the extension value from another certificate.
+
+
+
+ add a given extension field for the standard extensions tag (tag 3)
+ copying the extension value from another certificate.
+ @throws CertificateParsingException if the extension cannot be extracted.
+
+
+
+ Generate an X509Certificate.
+
+ The private key of the issuer that is signing this certificate.
+ An X509Certificate.
+
+
+
+ Generate an X509Certificate using your own SecureRandom.
+
+ The private key of the issuer that is signing this certificate.
+ You Secure Random instance.
+ An X509Certificate.
+
+
+
+ Generate a new X509Certificate using the passed in SignatureCalculator.
+
+ A signature calculator factory with the necessary algorithm details.
+ An X509Certificate.
+
+
+
+ Allows enumeration of the signature names supported by the generator.
+
+
+
+ A high level authority key identifier.
+
+
+ Constructor which will take the byte[] returned from getExtensionValue()
+
+ @param encodedValue a DER octet encoded string with the extension structure in it.
+ @throws IOException on parsing errors.
+
+
+ Create an AuthorityKeyIdentifier using the passed in certificate's public
+ key, issuer and serial number.
+
+ @param certificate the certificate providing the information.
+ @throws CertificateParsingException if there is a problem processing the certificate
+
+
+ Create an AuthorityKeyIdentifier using just the hash of the
+ public key.
+
+ @param pubKey the key to generate the hash from.
+ @throws InvalidKeyException if there is a problem using the key.
+
+
+ A high level subject key identifier.
+
+
+ Constructor which will take the byte[] returned from getExtensionValue()
+
+ @param encodedValue a DER octet encoded string with the extension structure in it.
+ @throws IOException on parsing errors.
+
+
+ This class is an Selector
like implementation to select
+ attribute certificates from a given set of criteria.
+
+ @see org.bouncycastle.x509.X509AttributeCertificate
+ @see org.bouncycastle.x509.X509Store
+
+
+
+ Decides if the given attribute certificate should be selected.
+
+ The attribute certificate to be checked.
+ true
if the object matches this selector.
+
+
+ The attribute certificate which must be matched.
+ If null is given, any will do.
+
+
+ The criteria for validity
+ If null is given any will do.
+
+
+ The holder.
+ If null is given any will do.
+
+
+ The issuer.
+ If null is given any will do.
+
+
+ The serial number.
+ If null is given any will do.
+
+
+ Adds a target name criterion for the attribute certificate to the target
+ information extension criteria. The X509AttributeCertificate
+ must contain at least one of the specified target names.
+
+ Each attribute certificate may contain a target information extension
+ limiting the servers where this attribute certificate can be used. If
+ this extension is not present, the attribute certificate is not targeted
+ and may be accepted by any server.
+
+
+ @param name The name as a GeneralName (not null
)
+
+
+ Adds a target name criterion for the attribute certificate to the target
+ information extension criteria. The X509AttributeCertificate
+ must contain at least one of the specified target names.
+
+ Each attribute certificate may contain a target information extension
+ limiting the servers where this attribute certificate can be used. If
+ this extension is not present, the attribute certificate is not targeted
+ and may be accepted by any server.
+
+
+ @param name a byte array containing the name in ASN.1 DER encoded form of a GeneralName
+ @throws IOException if a parsing error occurs.
+
+
+ Adds a collection with target names criteria. If null
is
+ given any will do.
+
+ The collection consists of either GeneralName objects or byte[] arrays representing
+ DER encoded GeneralName structures.
+
+
+ @param names A collection of target names.
+ @throws IOException if a parsing error occurs.
+ @see #AddTargetName(byte[])
+ @see #AddTargetName(GeneralName)
+
+
+ Gets the target names. The collection consists of List
s
+ made up of an Integer
in the first entry and a DER encoded
+ byte array or a String
in the second entry.
+ The returned collection is immutable.
+
+ @return The collection of target names
+ @see #setTargetNames(Collection)
+
+
+ Adds a target group criterion for the attribute certificate to the target
+ information extension criteria. The X509AttributeCertificate
+ must contain at least one of the specified target groups.
+
+ Each attribute certificate may contain a target information extension
+ limiting the servers where this attribute certificate can be used. If
+ this extension is not present, the attribute certificate is not targeted
+ and may be accepted by any server.
+
+
+ @param group The group as GeneralName form (not null
)
+
+
+ Adds a target group criterion for the attribute certificate to the target
+ information extension criteria. The X509AttributeCertificate
+ must contain at least one of the specified target groups.
+
+ Each attribute certificate may contain a target information extension
+ limiting the servers where this attribute certificate can be used. If
+ this extension is not present, the attribute certificate is not targeted
+ and may be accepted by any server.
+
+
+ @param name a byte array containing the group in ASN.1 DER encoded form of a GeneralName
+ @throws IOException if a parsing error occurs.
+
+
+ Adds a collection with target groups criteria. If null
is
+ given any will do.
+
+ The collection consists of GeneralName
objects or byte[]
+ representing DER encoded GeneralNames.
+
+
+ @param names A collection of target groups.
+ @throws IOException if a parsing error occurs.
+ @see #AddTargetGroup(byte[])
+ @see #AddTargetGroup(GeneralName)
+
+
+ Gets the target groups. The collection consists of List
s
+ made up of an Integer
in the first entry and a DER encoded
+ byte array or a String
in the second entry.
+ The returned collection is immutable.
+
+ @return The collection of target groups.
+ @see #setTargetGroups(Collection)
+
+
+
+ This class is an IX509Selector
implementation to select
+ certificate pairs, which are e.g. used for cross certificates. The set of
+ criteria is given from two X509CertStoreSelector
objects,
+ each of which, if present, must match the respective component of a pair.
+
+
+
+ The certificate pair which is used for testing on equality.
+
+
+ The certificate selector for the forward part.
+
+
+ The certificate selector for the reverse part.
+
+
+
+ Decides if the given certificate pair should be selected. If
+ obj is not a X509CertificatePair
, this method
+ returns false
.
+
+ The X509CertificatePair
to be tested.
+ true
if the object matches this selector.
+
+
+
+ An ISet
of DerObjectIdentifier
objects.
+
+
+
+ A simple collection backed store.
+
+
+ Basic constructor.
+
+ @param collection - initial contents for the store, this is copied.
+
+
+ Return the matches in the collection for the passed in selector.
+
+ @param selector the selector to match against.
+ @return a possibly empty collection of matching objects.
+
+
+ This class contains a collection for collection based X509Store
s.
+
+
+
+ Constructor.
+
+ The collection is copied.
+
+
+ The collection containing X.509 object types.
+ If collection is null.
+
+
+ Returns a copy of the ICollection
.
+
+
+ Returns a formatted string describing the parameters.
+
+
+
+ An ICollection
of X509Name
objects
+
+
+
+ The attribute certificate being checked. This is not a criterion.
+ Rather, it is optional information that may help a {@link X509Store} find
+ CRLs that would be relevant when checking revocation for the specified
+ attribute certificate. If null
is specified, then no such
+ optional information is provided.
+
+ @param attrCert the IX509AttributeCertificate
being checked (or
+ null
)
+ @see #getAttrCertificateChecking()
+
+
+ If true
only complete CRLs are returned. Defaults to
+ false
.
+
+ @return true
if only complete CRLs are returned.
+
+
+ Returns if this selector must match CRLs with the delta CRL indicator
+ extension set. Defaults to false
.
+
+ @return Returns true
if only CRLs with the delta CRL
+ indicator extension are selected.
+
+
+ The issuing distribution point.
+
+ The issuing distribution point extension is a CRL extension which
+ identifies the scope and the distribution point of a CRL. The scope
+ contains among others information about revocation reasons contained in
+ the CRL. Delta CRLs and complete CRLs must have matching issuing
+ distribution points.
+
+ The byte array is cloned to protect against subsequent modifications.
+
+ You must also enable or disable this criteria with
+ {@link #setIssuingDistributionPointEnabled(bool)}.
+
+ @param issuingDistributionPoint The issuing distribution point to set.
+ This is the DER encoded OCTET STRING extension value.
+ @see #getIssuingDistributionPoint()
+
+
+ Whether the issuing distribution point criteria should be applied.
+ Defaults to false
.
+
+ You may also set the issuing distribution point criteria if not a missing
+ issuing distribution point should be assumed.
+
+ @return Returns if the issuing distribution point check is enabled.
+
+
+ The maximum base CRL number. Defaults to null
.
+
+ @return Returns the maximum base CRL number.
+ @see #setMaxBaseCRLNumber(BigInteger)
+
+
+
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/ExchangeDkimSigner.dll
new file mode 100644
index 00000000..723eac81
Binary files /dev/null and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/ExchangeDkimSigner.dll.config b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/ExchangeDkimSigner.dll.config
new file mode 100644
index 00000000..87478233
--- /dev/null
+++ b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/ExchangeDkimSigner.dll.config
@@ -0,0 +1,6 @@
+
+
+
+
+
+
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/ExchangeDkimSigner.pdb
new file mode 100644
index 00000000..d1c5012c
Binary files /dev/null and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/MimeKit.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/MimeKit.dll
new file mode 100644
index 00000000..8a58db8f
Binary files /dev/null and b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/MimeKit.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/MimeKit.xml b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/MimeKit.xml
new file mode 100644
index 00000000..8fc68d18
--- /dev/null
+++ b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU9/MimeKit.xml
@@ -0,0 +1,38398 @@
+
+
+
+ MimeKit
+
+
+
+
+ A MIME part with a Content-Type of application/pgp-encrypted.
+
+
+ An application/pgp-encrypted part will typically be the first child of
+ a part and contains only a Version
+ header.
+
+
+
+
+ Initializes a new instance of the
+ class based on the .
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new MIME part with a Content-Type of application/pgp-encrypted
+ and content matching "Version: 1\n".
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ A MIME part with a Content-Type of application/pgp-signature.
+
+
+ An application/pgp-signature part contains detatched pgp signature data
+ and is typically contained within a part.
+ To verify the signature, use the
+ method on the parent multipart/signed part.
+
+
+
+
+ Initializes a new instance of the
+ class based on the .
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the
+ class with a Content-Type of application/pgp-signature.
+
+
+ Creates a new MIME part with a Content-Type of application/pgp-signature
+ and the as its content.
+
+ The content stream.
+
+ is null.
+
+
+ does not support reading.
+ -or-
+ does not support seeking.
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ An S/MIME part with a Content-Type of application/pkcs7-mime.
+
+
+ An application/pkcs7-mime is an S/MIME part and may contain encrypted,
+ signed or compressed data (or any combination of the above).
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new MIME part with a Content-Type of application/pkcs7-mime
+ and the as its content.
+ Unless you are writing your own pkcs7 implementation, you'll probably
+ want to use the ,
+ , and/or
+ method to create new instances
+ of this class.
+
+ The S/MIME type.
+ The content stream.
+
+ is null.
+
+
+ is not a valid value.
+
+
+ does not support reading.
+ -or-
+ does not support seeking.
+
+
+
+
+ Gets the value of the "smime-type" parameter.
+
+
+ Gets the value of the "smime-type" parameter.
+
+ The value of the "smime-type" parameter.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Decompresses the content.
+
+
+ Decompresses the content using the specified .
+
+ The decompressed .
+ The S/MIME context to use for decompressing.
+
+ is null.
+
+
+ The "smime-type" parameter on the Content-Type header is not "compressed-data".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Decompresses the content.
+
+
+ Decompresses the content using the default .
+
+ The decompressed .
+
+ The "smime-type" parameter on the Content-Type header is not "compressed-data".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Decrypts the content.
+
+
+ Decrypts the content using the specified .
+
+ The decrypted .
+ The S/MIME context to use for decrypting.
+
+ is null.
+
+
+ The "smime-type" parameter on the Content-Type header is not "enveloped-data".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Decrypts the content.
+
+
+ Decrypts the content using the default .
+
+ The decrypted .
+
+ The "smime-type" parameter on the Content-Type header is not "certs-only".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Imports the certificates contained in the content.
+
+
+ Imports the certificates contained in the content.
+
+ The S/MIME context to import certificates into.
+
+ is null.
+
+
+ The "smime-type" parameter on the Content-Type header is not "certs-only".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Verifies the signed-data and returns the unencapsulated .
+
+
+ Verifies the signed-data and returns the unencapsulated .
+
+ The list of digital signatures.
+ The S/MIME context to use for verifying the signature.
+ The unencapsulated entity.
+
+ is null.
+
+
+ The "smime-type" parameter on the Content-Type header is not "signed-data".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Verifies the signed-data and returns the unencapsulated .
+
+
+ Verifies the signed-data and returns the unencapsulated .
+
+ The list of digital signatures.
+ The unencapsulated entity.
+
+ The "smime-type" parameter on the Content-Type header is not "signed-data".
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Compresses the specified entity.
+
+
+ Compresses the specified entity using the specified .
+ Most mail clients, even among those that support S/MIME,
+ do not support compression.
+
+ The compressed entity.
+ The S/MIME context to use for compressing.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Compresses the specified entity.
+
+
+ Compresses the specified entity using the default .
+ Most mail clients, even among those that support S/MIME,
+ do not support compression.
+
+ The compressed entity.
+ The entity.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Encrypts the specified entity.
+
+
+ Encrypts the entity to the specified recipients using the supplied .
+
+ The encrypted entity.
+ The S/MIME context to use for encrypting.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Encrypts the specified entity.
+
+
+ Encrypts the entity to the specified recipients using the default .
+
+ The encrypted entity.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Encrypts the specified entity.
+
+
+ Encrypts the entity to the specified recipients using the supplied .
+
+ The encrypted entity.
+ The S/MIME context to use for encrypting.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ Valid certificates could not be found for one or more of the .
+
+
+ A certificate could not be found for one or more of the .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Encrypts the specified entity.
+
+
+ Encrypts the entity to the specified recipients using the default .
+
+ The encrypted entity.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+
+
+ Valid certificates could not be found for one or more of the .
+
+
+ A certificate could not be found for one or more of the .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs the specified entity.
+
+
+ Signs the entity using the supplied signer and .
+ For better interoperability with other mail clients, you should use
+
+ instead as the multipart/signed format is supported among a much larger
+ subset of mail client software.
+
+ The signed entity.
+ The S/MIME context to use for signing.
+ The signer.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs the specified entity.
+
+
+ Signs the entity using the supplied signer.
+ For better interoperability with other mail clients, you should use
+
+ instead as the multipart/signed format is supported among a much larger
+ subset of mail client software.
+
+ The signed entity.
+ The signer.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs the specified entity.
+
+
+ Signs the entity using the supplied signer, digest algorithm and .
+ For better interoperability with other mail clients, you should use
+
+ instead as the multipart/signed format is supported among a much larger
+ subset of mail client software.
+
+ The signed entity.
+ The S/MIME context to use for signing.
+ The signer.
+ The digest algorithm to use for signing.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A signing certificate could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm.
+ For better interoperability with other mail clients, you should use
+
+ instead as the multipart/signed format is supported among a much larger
+ subset of mail client software.
+
+ The signed entity.
+ The signer.
+ The digest algorithm to use for signing.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+
+
+ A signing certificate could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs and encrypts the specified entity.
+
+
+ Cryptographically signs entity using the supplied signer and then
+ encrypts the result to the specified recipients.
+
+ The signed and encrypted entity.
+ The S/MIME context to use for signing and encrypting.
+ The signer.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs and encrypts the specified entity.
+
+
+ Cryptographically signs entity using the supplied signer and then
+ encrypts the result to the specified recipients.
+
+ The signed and encrypted entity.
+ The signer.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs and encrypts the specified entity.
+
+
+ Cryptographically signs entity using the supplied signer and then
+ encrypts the result to the specified recipients.
+
+ The signed and encrypted entity.
+ The S/MIME context to use for signing and encrypting.
+ The signer.
+ The digest algorithm to use for signing.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A signing certificate could not be found for .
+ -or-
+ A certificate could not be found for one or more of the .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs and encrypts the specified entity.
+
+
+ Cryptographically signs entity using the supplied signer and then
+ encrypts the result to the specified recipients.
+
+ The signed and encrypted entity.
+ The signer.
+ The digest algorithm to use for signing.
+ The recipients.
+ The entity.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A signing certificate could not be found for .
+ -or-
+ A certificate could not be found for one or more of the .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ An S/MIME part with a Content-Type of application/pkcs7-signature.
+
+
+ An application/pkcs7-signature part contains detatched pkcs7 signature data
+ and is typically contained within a part.
+ To verify the signature, use the
+ method on the parent multipart/signed part.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the
+ class with a Content-Type of application/pkcs7-signature.
+
+
+ Creates a new MIME part with a Content-Type of application/pkcs7-signature
+ and the as its content.
+
+ The content stream.
+
+ is null.
+
+
+ does not support reading.
+ -or-
+ does not support seeking.
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ An exception that is thrown when a certificate could not be found for a specified mailbox.
+
+
+ An exception that is thrown when a certificate could not be found for a specified mailbox.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The serialization info.
+ The stream context.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The mailbox that could not be resolved to a valid certificate.
+ A message explaining the error.
+
+
+
+ When overridden in a derived class, sets the
+ with information about the exception.
+
+
+ Sets the
+ with information about the exception.
+
+ The serialization info.
+ The streaming context.
+
+ is null.
+
+
+
+
+ Gets the mailbox address that could not be resolved to a certificate.
+
+
+ Gets the mailbox address that could not be resolved to a certificate.
+
+ The mailbox address.
+
+
+
+ An S/MIME recipient.
+
+
+ If the X.509 certificates are known for each of the recipients, you
+ may wish to use a as opposed to having
+ the do its own certificate
+ lookups for each .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the property will be set to
+ the Triple-DES encryption algorithm, which should be safe to assume for all modern
+ S/MIME v3.x client implementations.
+
+ The recipient's certificate.
+ The recipient identifier type.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the property will be set to
+ the Triple-DES encryption algorithm, which should be safe to assume for all modern
+ S/MIME v3.x client implementations.
+ The will be initialized to
+ .
+
+ The recipient's certificate.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the property will be set to
+ the Triple-DES encryption algorithm, which should be safe to assume for all modern
+ S/MIME v3.x client implementations.
+
+ The recipient's certificate.
+ The recipient identifier type.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the property will be set to
+ the Triple-DES encryption algorithm, which should be safe to assume for all modern
+ S/MIME v3.x client implementations.
+ The will be initialized to
+ .
+
+ The recipient's certificate.
+
+ is null.
+
+
+
+
+ Gets the recipient's certificate.
+
+
+ The certificate is used for the purpose of encrypting data.
+
+ The certificate.
+
+
+
+ Gets the recipient identifier type.
+
+
+ Specifies how the certificate should be looked up on the recipient's end.
+
+ The recipient identifier type.
+
+
+
+ Gets or sets the known S/MIME encryption capabilities of the
+ recipient's mail client, in their preferred order.
+
+
+ Provides the with an array of
+ encryption algorithms that are known to be supported by the
+ recpipient's client software and should be in the recipient's
+ order of preference.
+
+ The encryption algorithms.
+
+
+
+ A collection of objects.
+
+
+ If the X.509 certificates are known for each of the recipients, you
+ may wish to use a as opposed to
+ using the methods that take a list of
+ objects.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the number of recipients in the collection.
+
+
+ Indicates the number of recipients in the collection.
+
+ The number of recipients in the collection.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Adds the specified recipient.
+
+
+ Adds the specified recipient.
+
+ The recipient.
+
+ is null.
+
+
+
+
+ Clears the recipient collection.
+
+
+ Removes all of the recipients from the collection.
+
+
+
+
+ Checks if the collection contains the specified recipient.
+
+
+ Determines whether or not the collection contains the specified recipient.
+
+ true if the specified recipient exists;
+ otherwise false.
+ The recipient.
+
+ is null.
+
+
+
+
+ Copies all of the recipients in the to the specified array.
+
+
+ Copies all of the recipients within the into the array,
+ starting at the specified array index.
+
+ The array.
+ The array index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified recipient.
+
+
+ Removes the specified recipient.
+
+ true if the recipient was removed; otherwise false.
+ The recipient.
+
+ is null.
+
+
+
+
+ Gets an enumerator for the collection of recipients.
+
+
+ Gets an enumerator for the collection of recipients.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the collection of recipients.
+
+
+ Gets an enumerator for the collection of recipients.
+
+ The enumerator.
+
+
+
+ An S/MIME signer.
+
+
+ If the X.509 certificate is known for the signer, you may wish to use a
+ as opposed to having the
+ do its own certificate lookup for the signer's .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the will be set to
+ and both the
+ and properties
+ will be initialized to empty tables.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the will be set to
+ and both the
+ and properties
+ will be initialized to empty tables.
+
+ The chain of certificates starting with the signer's certificate back to the root.
+ The signer's private key.
+
+ is null.
+ -or-
+ is null.
+
+
+ did not contain any certificates.
+ -or-
+ The certificate cannot be used for signing.
+ -or-
+ is not a private key.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the will
+ be set to and both the
+ and properties will be
+ initialized to empty tables.
+
+ The signer's certificate.
+ The signer's private key.
+
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ is not a private key.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The initial value of the will
+ be set to and both the
+ and properties will be
+ initialized to empty tables.
+
+ The signer's certificate.
+
+ is null.
+
+
+ cannot be used for signing.
+
+
+
+
+ Gets the signer's certificate.
+
+
+ The signer's certificate that contains a public key that can be used for
+ verifying the digital signature.
+
+ The signer's certificate.
+
+
+
+ Gets the certificate chain.
+
+
+ Gets the certificate chain.
+
+ The certificate chain.
+
+
+
+ Gets or sets the digest algorithm.
+
+
+ Specifies which digest algorithm to use to generate the
+ cryptographic hash of the content being signed.
+
+ The digest algorithm.
+
+
+
+ Gets the private key.
+
+
+ The private key used for signing.
+
+ The private key.
+
+
+
+ Gets or sets the signed attributes.
+
+
+ A table of attributes that should be included in the signature.
+
+ The signed attributes.
+
+
+
+ Gets or sets the unsigned attributes.
+
+
+ A table of attributes that should not be signed in the signature,
+ but still included in transport.
+
+ The unsigned attributes.
+
+
+
+ An abstract cryptography context.
+
+
+ Generally speaking, applications should not use a
+ directly, but rather via higher level APIs such as ,
+ and .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the signature protocol.
+
+
+ The signature protocol is used by
+ in order to determine what the protocol parameter of the Content-Type
+ header should be.
+
+ The signature protocol.
+
+
+
+ Gets the encryption protocol.
+
+
+ The encryption protocol is used by
+ in order to determine what the protocol parameter of the Content-Type
+ header should be.
+
+ The encryption protocol.
+
+
+
+ Gets the key exchange protocol.
+
+
+ The key exchange protocol is really only used for PGP.
+
+ The key exchange protocol.
+
+
+
+ Checks whether or not the specified protocol is supported by the .
+
+
+ Used in order to make sure that the protocol parameter value specified in either a multipart/signed
+ or multipart/encrypted part is supported by the supplied cryptography context.
+
+ true if the protocol is supported; otherwise false
+ The protocol.
+
+ is null.
+
+
+
+
+ Gets the string name of the digest algorithm for use with the micalg parameter of a multipart/signed part.
+
+
+ Maps the to the appropriate string identifier
+ as used by the micalg parameter value of a multipart/signed Content-Type
+ header.
+
+ The micalg value.
+ The digest algorithm.
+
+ is out of range.
+
+
+
+
+ Gets the digest algorithm from the micalg parameter value in a multipart/signed part.
+
+
+ Maps the micalg parameter value string back to the appropriate .
+
+ The digest algorithm.
+ The micalg parameter value.
+
+ is null.
+
+
+
+
+ Cryptographically signs the content.
+
+
+ Cryptographically signs the content using the specified signer and digest algorithm.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+ A signing certificate could not be found for .
+
+
+
+
+ Verifies the specified content using the detached signatureData.
+
+
+ Verifies the specified content using the detached signatureData.
+
+ A list of digital signatures.
+ The content.
+ The signature data.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ A certificate could not be found for one or more of the .
+
+
+
+
+ Decrypts the specified encryptedData.
+
+
+ Decrypts the specified encryptedData.
+
+ The decrypted .
+ The encrypted data.
+
+ is null.
+
+
+
+
+ Imports the public certificates or keys from the specified stream.
+
+
+ Imports the public certificates or keys from the specified stream.
+
+ The raw certificate or key data.
+
+ is null.
+
+
+ Importing keys is not supported by this cryptography context.
+
+
+
+
+ Exports the keys for the specified mailboxes.
+
+
+ Exports the keys for the specified mailboxes.
+
+ A new instance containing the exported keys.
+ The mailboxes.
+
+ is null.
+
+
+ was empty.
+
+
+ Exporting keys is not supported by this cryptography context.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ Releases all resources used by the object.
+
+ Call when you are finished using the . The
+ method leaves the in an unusable state. After
+ calling , you must release all references to the so
+ the garbage collector can reclaim the memory that the was occupying.
+
+
+
+ Creates a new for the specified protocol.
+
+
+ Creates a new for the specified protocol.
+ The default types can over overridden by calling
+ the method with the preferred type.
+
+ The for the protocol.
+ The protocol.
+
+ is null.
+
+
+ There are no supported s that support
+ the specified .
+
+
+
+
+ Registers a default or .
+
+
+ Registers the specified type as the default or
+ .
+
+ A custom subclass of or
+ .
+
+ is null.
+
+
+ is not a subclass of
+ or .
+ -or-
+ does not have a parameterless constructor.
+
+
+
+
+ Useful extensions for working with System.Data types.
+
+
+
+
+ Creates a with the specified name and value and then adds it to the command's parameters.
+
+ The database command.
+ The parameter name.
+ The parameter value.
+
+
+
+ A default implementation that uses
+ an SQLite database as a certificate and private key store.
+
+
+ The default S/MIME context is designed to be usable on any platform
+ where there exists a .NET runtime by storing certificates, CRLs, and
+ (encrypted) private keys in a SQLite database.
+
+
+
+
+ The default database path for certificates, private keys and CRLs.
+
+
+ On Microsoft Windows-based systems, this path will be something like C:\Users\UserName\AppData\Roaming\mimekit\smime.db.
+ On Unix systems such as Linux and Mac OS X, this path will be ~/.mimekit/smime.db.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Allows the program to specify its own location for the SQLite database. If the file does not exist,
+ it will be created and the necessary tables and indexes will be constructed.
+ Requires linking with Mono.Data.Sqlite.
+
+ The path to the SQLite database.
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+ Mono.Data.Sqlite is not available.
+
+
+ The user does not have access to read the specified file.
+
+
+ An error occurred reading the file.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Allows the program to specify its own password for the default database.
+ Requires linking with Mono.Data.Sqlite.
+
+ The password used for encrypting and decrypting the private keys.
+
+ Mono.Data.Sqlite is not available.
+
+
+ The user does not have access to read the database at the default location.
+
+
+ An error occurred reading the database at the default location.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Not recommended for production use as the password to unlock the private keys is hard-coded.
+ Requires linking with Mono.Data.Sqlite.
+
+
+ Mono.Data.Sqlite is not available.
+
+
+ The user does not have access to read the database at the default location.
+
+
+ An error occurred reading the database at the default location.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is useful for supplying a custom .
+
+ The certificate database.
+
+ is null.
+
+
+
+
+ Gets the X.509 certificate matching the specified selector.
+
+
+ Gets the first certificate that matches the specified selector.
+
+ The certificate on success; otherwise null.
+ The search criteria for the certificate.
+
+
+
+ Gets the private key for the certificate matching the specified selector.
+
+
+ Gets the private key for the first certificate that matches the specified selector.
+
+ The private key on success; otherwise null.
+ The search criteria for the private key.
+
+
+
+ Gets the trusted anchors.
+
+
+ A trusted anchor is a trusted root-level X.509 certificate,
+ generally issued by a Certificate Authority (CA).
+
+ The trusted anchors.
+
+
+
+ Gets the intermediate certificates.
+
+
+ An intermediate certificate is any certificate that exists between the root
+ certificate issued by a Certificate Authority (CA) and the certificate at
+ the end of the chain.
+
+ The intermediate certificates.
+
+
+
+ Gets the certificate revocation lists.
+
+
+ A Certificate Revocation List (CRL) is a list of certificate serial numbers issued
+ by a particular Certificate Authority (CA) that have been revoked, either by the CA
+ itself or by the owner of the revoked certificate.
+
+ The certificate revocation lists.
+
+
+
+ Gets the for the specified mailbox.
+
+
+ Constructs a with the appropriate certificate and
+ for the specified mailbox.
+ If the mailbox is a , the
+ property will be used instead of
+ the mailbox address for database lookups.
+
+ A .
+ The mailbox.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Gets the for the specified mailbox.
+
+
+ Constructs a with the appropriate signing certificate
+ for the specified mailbox.
+ If the mailbox is a , the
+ property will be used instead of
+ the mailbox address for database lookups.
+
+ A .
+ The mailbox.
+ The preferred digest algorithm.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+ The certificate.
+ The encryption algorithm capabilities of the client (in preferred order).
+ The timestamp.
+
+
+
+ Imports a certificate.
+
+
+ Imports the specified certificate into the database.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Imports a certificate revocation list.
+
+
+ Imports the specified certificate revocation list.
+
+ The certificate revocation list.
+
+ is null.
+
+
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+
+ Imports all of the certificates and keys from the pkcs12-encoded stream.
+
+ The raw certificate and key data.
+ The password to unlock the data.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Imports a DER-encoded certificate stream.
+
+
+ Imports all of the certificates in the DER-encoded stream.
+
+ The raw certificate(s).
+ true if the certificates are trusted.
+
+ is null.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ A digest algorithm.
+
+
+ Digest algorithms are secure hashing algorithms that are used
+ to generate unique fixed-length signatures for arbitrary data.
+ The most commonly used digest algorithms are currently MD5
+ and SHA-1, however, MD5 was successfully broken in 2008 and should
+ be avoided. In late 2013, Microsoft announced that they would be
+ retiring their use of SHA-1 in their products by 2016 with the
+ assumption that its days as an unbroken digest algorithm were
+ numbered. It is speculated that the SHA-1 digest algorithm will
+ be vulnerable to collisions, and thus no longer considered secure,
+ by 2018.
+ Microsoft and other vendors plan to move to the SHA-2 suite of
+ digest algorithms which includes the following 4 variants: SHA-224,
+ SHA-256, SHA-384, and SHA-512.
+
+
+
+
+ No digest algorithm specified.
+
+
+
+
+ The MD5 digest algorithm.
+
+
+
+
+ The SHA-1 digest algorithm.
+
+
+
+
+ The Ripe-MD/160 digest algorithm.
+
+
+
+
+ The double-SHA digest algorithm.
+
+
+
+
+ The MD2 digest algorithm.
+
+
+
+
+ The TIGER/192 digest algorithm.
+
+
+
+
+ The HAVAL 5-pass 160-bit digest algorithm.
+
+
+
+
+ The SHA-256 digest algorithm.
+
+
+
+
+ The SHA-384 digest algorithm.
+
+
+
+
+ The SHA-512 digest algorithm.
+
+
+
+
+ The SHA-224 digest algorithm.
+
+
+
+
+ The MD4 digest algorithm.
+
+
+
+
+ A collection of digital signatures.
+
+
+ When verifying a digitally signed MIME part such as a
+ or a , you will get back a collection of
+ digital signatures. Typically, a signed message will only have a single signature
+ (created by the sender of the message), but it is possible for there to be
+ multiple signatures.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The signatures.
+
+
+
+ An exception that is thrown when an error occurrs in .
+
+
+ For more information about the error condition, check the property.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The serialization info.
+ The stream context.
+
+ is null.
+
+
+
+
+ A base implementation for DKIM body filters.
+
+
+ A base implementation for DKIM body filters.
+
+
+
+
+ Get or set whether the last filtered character was a newline.
+
+
+ Gets or sets whether the last filtered character was a newline.
+
+
+
+
+ Get or set whether the current line is empty.
+
+
+ Gets or sets whether the current line is empty.
+
+
+
+
+ Get or set the number of consecutive empty lines encountered.
+
+
+ Gets or sets the number of consecutive empty lines encountered.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ A DKIM canonicalization algorithm.
+
+
+ Empirical evidence demonstrates that some mail servers and relay systems
+ modify email in transit, potentially invalidating a signature. There are two
+ competing perspectives on such modifications. For most signers, mild modification
+ of email is immaterial to the authentication status of the email. For such signers,
+ a canonicalization algorithm that survives modest in-transit modification is
+ preferred.
+ Other signers demand that any modification of the email, however minor,
+ result in a signature verification failure. These signers prefer a canonicalization
+ algorithm that does not tolerate in-transit modification of the signed email.
+
+
+
+
+ The simple canonicalization algorithm tolerates almost no modification
+ by mail servers while the message is in-transit.
+
+
+
+
+ The relaxed canonicalization algorithm tolerates common modifications
+ by mail servers while the message is in-transit such as whitespace
+ replacement and header field line rewrapping.
+
+
+
+
+ A DKIM hash stream.
+
+
+ A DKIM hash stream.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The signature algorithm.
+ The max length of data to hash.
+
+
+
+ Generate the hash.
+
+
+ Generates the hash.
+
+ The hash.
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ A is not readable.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ A is always writable.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ A is not seekable.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not reading and writing to the stream can timeout.
+
+
+ Writing to a cannot timeout.
+
+ true if reading and writing to the stream can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ The length of a indicates the
+ number of bytes that have been written to it.
+
+ The length of the stream in bytes.
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ Since it is possible to seek within a ,
+ it is possible that the position will not always be identical to the
+ length of the stream, but typically it will be.
+
+ The position of the stream.
+
+ An I/O error occurred.
+
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reading from a is not supported.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Increments the property by the number of bytes written.
+ If the updated position is greater than the current length of the stream, then
+ the property will be updated to be identical to the
+ position.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Updates the within the stream.
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ is not a valid .
+
+
+ The stream has been disposed.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Since a does not actually do anything other than
+ count bytes, this method is a no-op.
+
+
+ The stream has been disposed.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Sets the to the specified value and updates
+ to the specified value if (and only if)
+ the current position is greater than the new length value.
+
+ The desired length of the stream in bytes.
+
+ is out of range.
+
+
+ The stream has been disposed.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ A filter for the DKIM relaxed body canonicalization.
+
+
+ A filter for the DKIM relaxed body canonicalization.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A DKIM signature algorithm.
+
+
+ A DKIM signature algorithm.
+
+
+
+
+ The RSA-SHA1 signature algorithm.
+
+
+
+
+ The RSA-SHA256 signature algorithm.
+
+
+
+
+ A DKIM signature stream.
+
+
+ A DKIM signature stream.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The digest signer.
+
+ is null.
+
+
+
+
+ Get the digest signer.
+
+
+ Gets the digest signer.
+
+ The signer.
+
+
+
+ Generate the signature.
+
+
+ Generates the signature.
+
+ The signature.
+
+
+
+ Verify the DKIM signature.
+
+
+ Verifies the DKIM signature.
+
+ true if signature is valid; otherwise, false.
+ The base64 encoded DKIM signature from the b= parameter.
+
+ is null.
+
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ A is not readable.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ A is always writable.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ A is not seekable.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not reading and writing to the stream can timeout.
+
+
+ Writing to a cannot timeout.
+
+ true if reading and writing to the stream can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ The length of a indicates the
+ number of bytes that have been written to it.
+
+ The length of the stream in bytes.
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ Since it is possible to seek within a ,
+ it is possible that the position will not always be identical to the
+ length of the stream, but typically it will be.
+
+ The position of the stream.
+
+ An I/O error occurred.
+
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reading from a is not supported.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Increments the property by the number of bytes written.
+ If the updated position is greater than the current length of the stream, then
+ the property will be updated to be identical to the
+ position.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Updates the within the stream.
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ is not a valid .
+
+
+ The stream has been disposed.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Since a does not actually do anything other than
+ count bytes, this method is a no-op.
+
+
+ The stream has been disposed.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Sets the to the specified value and updates
+ to the specified value if (and only if)
+ the current position is greater than the new length value.
+
+ The desired length of the stream in bytes.
+
+ is out of range.
+
+
+ The stream has been disposed.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ A DKIM signer.
+
+
+ A DKIM signer.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The signer's private key.
+ The domain that the signer represents.
+ The selector subdividing the domain.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ is not a private key.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The file containing the private key.
+ The domain that the signer represents.
+ The selector subdividing the domain.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The file did not contain a private key.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Gets the private key.
+
+
+ The private key used for signing.
+
+ The private key.
+
+
+
+ Get the domain that the signer represents.
+
+
+ Gets the domain that the signer represents.
+
+ The domain.
+
+
+
+ Get the selector subdividing the domain.
+
+
+ Gets the selector subdividing the domain.
+
+ The selector.
+
+
+
+ Get or set the agent or user identifier.
+
+
+ Gets or sets the agent or user identifier.
+
+ The agent or user identifier.
+
+
+
+ Get or set the algorithm to use for signing.
+
+
+ Gets or sets the algorithm to use for signing.
+
+ The signature algorithm.
+
+
+
+ Get or set the public key query method.
+
+
+ Gets or sets the public key query method.
+ The value should be a colon-separated list of query methods used to
+ retrieve the public key (plain-text; OPTIONAL, default is "dns/txt"). Each
+ query method is of the form "type[/options]", where the syntax and
+ semantics of the options depend on the type and specified options.
+
+ The public key query method.
+
+
+
+ A filter for the DKIM simple body canonicalization.
+
+
+ A filter for the DKIM simple body canonicalization.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ Encryption algorithms supported by S/MIME and OpenPGP.
+
+
+ Represents the available encryption algorithms for use with S/MIME and OpenPGP.
+ RC-2/40 was required by all S/MIME v2 implementations. However, since the
+ mid-to-late 1990's, RC-2/40 has been considered to be extremely weak and starting with
+ S/MIME v3.0 (published in 1999), all S/MIME implementations are required to implement
+ support for Triple-DES (aka 3DES) and should no longer encrypt using RC-2/40 unless
+ explicitly requested to do so by the user.
+ These days, most S/MIME implementations support the AES-128 and AES-256
+ algorithms which are the recommended algorithms specified in S/MIME v3.2 and
+ should be preferred over the use of Triple-DES unless the client capabilities
+ of one or more of the recipients is unknown (or only supports Triple-DES).
+
+
+
+
+ The AES 128-bit encryption algorithm.
+
+
+
+
+ The AES 192-bit encryption algorithm.
+
+
+
+
+ The AES 256-bit encryption algorithm.
+
+
+
+
+ The Camellia 128-bit encryption algorithm.
+
+
+
+
+ The Camellia 192-bit encryption algorithm.
+
+
+
+
+ The Camellia 256-bit encryption algorithm.
+
+
+
+
+ The Cast-5 128-bit encryption algorithm.
+
+
+
+
+ The DES 56-bit encryption algorithm.
+
+
+ This is extremely weak encryption and should not be used
+ without consent from the user.
+
+
+
+
+ The Triple-DES encryption algorithm.
+
+
+ This is the weakest recommended encryption algorithm for use
+ starting with S/MIME v3 and should only be used as a fallback
+ if it is unknown what encryption algorithms are supported by
+ the recipient's mail client.
+
+
+
+
+ The IDEA 128-bit encryption algorithm.
+
+
+
+
+ The blowfish encryption algorithm (OpenPGP only).
+
+
+
+
+ The twofish encryption algorithm (OpenPGP only).
+
+
+
+
+ The RC2 40-bit encryption algorithm (S/MIME only).
+
+
+ This is extremely weak encryption and should not be used
+ without consent from the user.
+
+
+
+
+ The RC2 64-bit encryption algorithm (S/MIME only).
+
+
+ This is very weak encryption and should not be used
+ without consent from the user.
+
+
+
+
+ The RC2 128-bit encryption algorithm (S/MIME only).
+
+
+
+
+ A that uses the GnuPG keyrings.
+
+
+ A that uses the GnuPG keyrings.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ An interface for a digital certificate.
+
+
+ An interface for a digital certificate.
+
+
+
+
+ Gets the public key algorithm supported by the certificate.
+
+
+ Gets the public key algorithm supported by the certificate.
+
+ The public key algorithm.
+
+
+
+ Gets the date that the certificate was created.
+
+
+ Gets the date that the certificate was created.
+
+ The creation date.
+
+
+
+ Gets the expiration date of the certificate.
+
+
+ Gets the expiration date of the certificate.
+
+ The expiration date.
+
+
+
+ Gets the fingerprint of the certificate.
+
+
+ Gets the fingerprint of the certificate.
+
+ The fingerprint.
+
+
+
+ Gets the email address of the owner of the certificate.
+
+
+ Gets the email address of the owner of the certificate.
+
+ The email address.
+
+
+
+ Gets the name of the owner of the certificate.
+
+
+ Gets the name of the owner of the certificate.
+
+ The name of the owner.
+
+
+
+ An interface for a digital signature.
+
+
+ An interface for a digital signature.
+
+
+
+
+ Gets certificate used by the signer.
+
+
+ Gets certificate used by the signer.
+
+ The signer's certificate.
+
+
+
+ Gets the public key algorithm used for the signature.
+
+
+ Gets the public key algorithm used for the signature.
+
+ The public key algorithm.
+
+
+
+ Gets the digest algorithm used for the signature.
+
+
+ Gets the digest algorithm used for the signature.
+
+ The digest algorithm.
+
+
+
+ Gets the creation date of the digital signature.
+
+
+ Gets the creation date of the digital signature.
+
+ The creation date.
+
+
+
+ Verifies the digital signature.
+
+
+ Verifies the digital signature.
+
+ true if the signature is valid; otherwise false.
+
+ An error verifying the signature has occurred.
+
+
+
+
+ An interface for a service which locates and retrieves DKIM public keys (probably via DNS).
+
+
+ An interface for a service which locates and retrieves DKIM public keys (probably via DNS).
+ Since MimeKit itself does not implement DNS, it is up to the client to implement public key lookups
+ via DNS.
+
+
+
+
+
+ Locate and retrieves the public key for the given domain and selector.
+
+
+ Locates and retrieves the public key for the given domain and selector.
+
+ The public key.
+ A colon-separated list of query methods used to retrieve the public key. The default is "dns/txt".
+ The domain.
+ The selector.
+ The cancellation token.
+
+
+
+ An interface for an X.509 Certificate database.
+
+
+ An X.509 certificate database is used for storing certificates, metdata related to the certificates
+ (such as encryption algorithms supported by the associated client), certificate revocation lists (CRLs),
+ and private keys.
+
+
+
+
+ Find the specified certificate.
+
+
+ Searches the database for the specified certificate, returning the matching
+ record with the desired fields populated.
+
+ The matching record if found; otherwise null.
+ The certificate.
+ The desired fields.
+
+
+
+ Finds the certificates matching the specified selector.
+
+
+ Searches the database for certificates matching the selector, returning all
+ matching certificates.
+
+ The matching certificates.
+ The match selector or null to return all certificates.
+
+
+
+ Finds the private keys matching the specified selector.
+
+
+ Searches the database for certificate records matching the selector, returning the
+ private keys for each matching record.
+
+ The matching certificates.
+ The match selector or null to return all private keys.
+
+
+
+ Finds the certificate records for the specified mailbox.
+
+
+ Searches the database for certificates matching the specified mailbox that are valid
+ for the date and time specified, returning all matching records populated with the
+ desired fields.
+
+ The matching certificate records populated with the desired fields.
+ The mailbox.
+ The date and time.
+ true if a private key is required.
+ The desired fields.
+
+
+
+ Finds the certificate records matching the specified selector.
+
+
+ Searches the database for certificate records matching the selector, returning all
+ of the matching records populated with the desired fields.
+
+ The matching certificate records populated with the desired fields.
+ The match selector or null to match all certificates.
+ true if only trusted certificates should be returned.
+ The desired fields.
+
+
+
+ Add the specified certificate record.
+
+
+ Adds the specified certificate record to the database.
+
+ The certificate record.
+
+
+
+ Remove the specified certificate record.
+
+
+ Removes the specified certificate record from the database.
+
+ The certificate record.
+
+
+
+ Update the specified certificate record.
+
+
+ Updates the specified fields of the record in the database.
+
+ The certificate record.
+ The fields to update.
+
+
+
+ Finds the CRL records for the specified issuer.
+
+
+ Searches the database for CRL records matching the specified issuer, returning
+ all matching records populated with the desired fields.
+
+ The matching CRL records populated with the desired fields.
+ The issuer.
+ The desired fields.
+
+
+
+ Finds the specified certificate revocation list.
+
+
+ Searches the database for the specified CRL, returning the matching record with
+ the desired fields populated.
+
+ The matching record if found; otherwise null.
+ The certificate revocation list.
+ The desired fields.
+
+
+
+ Add the specified CRL record.
+
+
+ Adds the specified CRL record to the database.
+
+ The CRL record.
+
+
+
+ Remove the specified CRL record.
+
+
+ Removes the specified CRL record from the database.
+
+ The CRL record.
+
+
+
+ Update the specified CRL record.
+
+
+ Updates the specified fields of the record in the database.
+
+ The CRL record.
+
+
+
+ Gets a certificate revocation list store.
+
+
+ Gets a certificate revocation list store.
+
+ A certificate recovation list store.
+
+
+
+ A multipart MIME part with a ContentType of multipart/encrypted containing an encrypted MIME part.
+
+
+ This mime-type is common when dealing with PGP/MIME but is not used for S/MIME.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for signing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The private key for could not be found.
+
+
+ A public key for one or more of the could not be found.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A default has not been registered.
+
+
+ The private key for could not be found.
+
+
+ A public key for one or more of the could not be found.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for singing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ The is not supported.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for singing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ A default has not been registered.
+ -or-
+ The is not supported.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ A default has not been registered.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A public key for one or more of the could not be found.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ A default has not been registered.
+
+
+ A public key for one or more of the could not be found.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ THe specified encryption algorithm is not supported.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ A default has not been registered.
+ -or-
+ The specified encryption algorithm is not supported.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ A default has not been registered.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for singing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ The is not supported.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for signing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The private key for could not be found.
+
+
+ A public key for one or more of the could not be found.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ A default has not been registered.
+ -or-
+ The is not supported.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A default has not been registered.
+
+
+ The private key for could not be found.
+
+
+ A public key for one or more of the could not be found.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for singing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ The is not supported.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for singing and encrypting.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ A default has not been registered.
+ -or-
+ The is not supported.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by signing and encrypting the specified entity.
+
+
+ Signs the entity using the supplied signer and digest algorithm and then encrypts to
+ the specified recipients, encapsulating the result in a new multipart/encrypted part.
+
+ A new instance containing
+ the signed and encrypted version of the specified entity.
+ The signer to use to sign the entity.
+ The digest algorithm to use for signing.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The was out of range.
+
+
+ A default has not been registered.
+ -or-
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ THe specified encryption algorithm is not supported.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ A public key for one or more of the could not be found.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ A default has not been registered.
+ -or-
+ The specified encryption algorithm is not supported.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ A default has not been registered.
+
+
+ A public key for one or more of the could not be found.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ THe specified encryption algorithm is not supported.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The OpenPGP cryptography context to use for encrypting.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The encryption algorithm.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ A default has not been registered.
+ -or-
+ The specified encryption algorithm is not supported.
+
+
+
+
+ Create a multipart/encrypted MIME part by encrypting the specified entity.
+
+
+ Encrypts the entity to the specified recipients, encapsulating the result in a
+ new multipart/encrypted part.
+
+ A new instance containing
+ the encrypted version of the specified entity.
+ The recipients for the encrypted entity.
+ The entity to sign and encrypt.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+
+
+ A default has not been registered.
+
+
+
+
+ Decrypts the part.
+
+
+ Decrypts the and extracts any digital signatures in cases
+ where the content was also signed.
+
+ The decrypted entity.
+ The OpenPGP cryptography context to use for decrypting.
+ A list of digital signatures if the data was both signed and encrypted.
+
+ is null.
+
+
+ The protocol parameter was not specified.
+ -or-
+ The multipart is malformed in some way.
+
+
+ The provided does not support the protocol parameter.
+
+
+ The private key could not be found to decrypt the encrypted data.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Decrypts the part.
+
+
+ Decrypts the part.
+
+ The decrypted entity.
+ The OpenPGP cryptography context to use for decrypting.
+
+ is null.
+
+
+ The protocol parameter was not specified.
+ -or-
+ The multipart is malformed in some way.
+
+
+ The provided does not support the protocol parameter.
+
+
+ The private key could not be found to decrypt the encrypted data.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Decrypts the part.
+
+
+ Decrypts the and extracts any digital signatures in cases
+ where the content was also signed.
+
+ The decrypted entity.
+ A list of digital signatures if the data was both signed and encrypted.
+
+ The protocol parameter was not specified.
+ -or-
+ The multipart is malformed in some way.
+
+
+ A suitable for
+ decrypting could not be found.
+
+
+ The private key could not be found to decrypt the encrypted data.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Decrypts the part.
+
+
+ Decrypts the part.
+
+ The decrypted entity.
+
+ The protocol parameter was not specified.
+ -or-
+ The multipart is malformed in some way.
+
+
+ A suitable for
+ decrypting could not be found.
+
+
+ The private key could not be found to decrypt the encrypted data.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ A signed multipart, as used by both S/MIME and PGP/MIME protocols.
+
+
+ The first child of a multipart/signed is the content while the second child
+ is the detached signature data. Any other children are not defined and could
+ be anything.
+
+
+
+
+ Initializes a new instance of the class.
+
+ This constructor is used by .
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Creates a new .
+
+
+ Cryptographically signs the entity using the supplied signer and digest algorithm in
+ order to generate a detached signature and then adds the entity along with the
+ detached signature data to a new multipart/signed part.
+
+ A new instance.
+ The cryptography context to use for signing.
+ The signer.
+ The digest algorithm to use for signing.
+ The entity to sign.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The was out of range.
+
+
+ The is not supported.
+
+
+ A signing certificate could not be found for .
+
+
+ The private key could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Creates a new .
+
+
+ Cryptographically signs the entity using the supplied signer and digest algorithm in
+ order to generate a detached signature and then adds the entity along with the
+ detached signature data to a new multipart/signed part.
+
+ A new instance.
+ The OpenPGP context to use for signing.
+ The signer.
+ The digest algorithm to use for signing.
+ The entity to sign.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+
+
+ The was out of range.
+
+
+ The is not supported.
+
+
+ An error occurred in the OpenPGP subsystem.
+
+
+
+
+ Creates a new .
+
+
+ Cryptographically signs the entity using the supplied signer and digest algorithm in
+ order to generate a detached signature and then adds the entity along with the
+ detached signature data to a new multipart/signed part.
+
+ A new instance.
+ The signer.
+ The digest algorithm to use for signing.
+ The entity to sign.
+
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+
+
+ The was out of range.
+
+
+ A cryptography context suitable for signing could not be found.
+ -or-
+ The is not supported.
+
+
+ An error occurred in the OpenPGP subsystem.
+
+
+
+
+ Creates a new .
+
+
+ Cryptographically signs the entity using the supplied signer in order
+ to generate a detached signature and then adds the entity along with
+ the detached signature data to a new multipart/signed part.
+
+ A new instance.
+ The S/MIME context to use for signing.
+ The signer.
+ The entity to sign.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Creates a new .
+
+
+ Cryptographically signs the entity using the supplied signer in order
+ to generate a detached signature and then adds the entity along with
+ the detached signature data to a new multipart/signed part.
+
+ A new instance.
+ The signer.
+ The entity to sign.
+
+ is null.
+ -or-
+ is null.
+
+
+ A cryptography context suitable for signing could not be found.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Prepare the MIME entity for transport using the specified encoding constraints.
+
+
+ Prepares the MIME entity for transport using the specified encoding constraints.
+
+ The encoding constraint.
+ The maximum number of octets allowed per line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Verifies the multipart/signed part.
+
+
+ Verifies the multipart/signed part using the supplied cryptography context.
+
+ A signer info collection.
+ The cryptography context to use for verifying the signature.
+
+ is null.
+
+
+ The multipart is malformed in some way.
+
+
+ does not support verifying the signature part.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Verifies the multipart/signed part.
+
+
+ Verifies the multipart/signed part using the default cryptography context.
+
+ A signer info collection.
+
+ The protocol parameter was not specified.
+ -or-
+ The multipart is malformed in some way.
+
+
+ A cryptography context suitable for verifying the signature could not be found.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ An X.509 certificate database built on PostgreSQL.
+
+
+ An X.509 certificate database is used for storing certificates, metdata related to the certificates
+ (such as encryption algorithms supported by the associated client), certificate revocation lists (CRLs),
+ and private keys.
+ This particular database uses PostgreSQL to store the data.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new and opens a connection to the
+ PostgreSQL database using the specified connection string.
+
+ The connection string.
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+ is empty.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new using the provided Npgsql database connection.
+
+ The Npgsql connection.
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets the command to create the certificates table.
+
+
+ Constructs the command to create a certificates table suitable for storing
+ objects.
+
+ The .
+ The .
+
+
+
+ Gets the command to create the CRLs table.
+
+
+ Constructs the command to create a CRLs table suitable for storing
+ objects.
+
+ The .
+ The .
+
+
+
+ An abstract OpenPGP cryptography context which can be used for PGP/MIME.
+
+
+ Generally speaking, applications should not use a
+ directly, but rather via higher level APIs such as
+ and .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Subclasses choosing to use this constructor MUST set the ,
+ , , and the
+ properties themselves.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new using the specified public and private keyring paths.
+
+ The public keyring file path.
+ The secret keyring file path.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred while reading one of the keyring files.
+
+
+ An error occurred while parsing one of the keyring files.
+
+
+
+
+ Gets or sets the default encryption algorithm.
+
+
+ Gets or sets the default encryption algorithm.
+
+ The encryption algorithm.
+
+ The specified encryption algorithm is not supported.
+
+
+
+
+ Gets the public keyring path.
+
+
+ Gets the public keyring path.
+
+ The public key ring path.
+
+
+
+ Gets the secret keyring path.
+
+
+ Gets the secret keyring path.
+
+ The secret key ring path.
+
+
+
+ Gets the public keyring bundle.
+
+
+ Gets the public keyring bundle.
+
+ The public keyring bundle.
+
+
+
+ Gets the secret keyring bundle.
+
+
+ Gets the secret keyring bundle.
+
+ The secret keyring bundle.
+
+
+
+ Gets the signature protocol.
+
+
+ The signature protocol is used by
+ in order to determine what the protocol parameter of the Content-Type
+ header should be.
+
+ The signature protocol.
+
+
+
+ Gets the encryption protocol.
+
+
+ The encryption protocol is used by
+ in order to determine what the protocol parameter of the Content-Type
+ header should be.
+
+ The encryption protocol.
+
+
+
+ Gets the key exchange protocol.
+
+
+ Gets the key exchange protocol.
+
+ The key exchange protocol.
+
+
+
+ Checks whether or not the specified protocol is supported.
+
+
+ Used in order to make sure that the protocol parameter value specified in either a multipart/signed
+ or multipart/encrypted part is supported by the supplied cryptography context.
+
+ true if the protocol is supported; otherwise false
+ The protocol.
+
+ is null.
+
+
+
+
+ Gets the string name of the digest algorithm for use with the micalg parameter of a multipart/signed part.
+
+
+ Maps the to the appropriate string identifier
+ as used by the micalg parameter value of a multipart/signed Content-Type
+ header. For example:
+
+ AlgorithmName
+ - pgp-md5
+ - pgp-sha1
+ - pgp-ripemd160
+ - pgp-md2
+ - pgp-tiger192
+ - pgp-haval-5-160
+ - pgp-sha256
+ - pgp-sha384
+ - pgp-sha512
+ - pgp-sha224
+
+
+ The micalg value.
+ The digest algorithm.
+
+ is out of range.
+
+
+
+
+ Gets the digest algorithm from the micalg parameter value in a multipart/signed part.
+
+
+ Maps the micalg parameter value string back to the appropriate .
+
+ The digest algorithm.
+ The micalg parameter value.
+
+ is null.
+
+
+
+
+ Gets the public key associated with the mailbox address.
+
+
+ Gets the public key associated with the mailbox address.
+
+ The encryption key.
+ The mailbox.
+
+ is null.
+
+
+ The public key for the specified could not be found.
+
+
+
+
+ Gets the public keys for the specified mailbox addresses.
+
+
+ Gets the public keys for the specified mailbox addresses.
+
+ The encryption keys.
+ The mailboxes.
+
+ is null.
+
+
+ A public key for one or more of the could not be found.
+
+
+
+
+ Gets the signing key associated with the mailbox address.
+
+
+ Gets the signing key associated with the mailbox address.
+
+ The signing key.
+ The mailbox.
+
+ is null.
+
+
+ A private key for the specified could not be found.
+
+
+
+
+ Gets the password for key.
+
+
+ Gets the password for key.
+
+ The password for key.
+ The key.
+
+ The user chose to cancel the password request.
+
+
+
+
+ Gets the private key from the specified secret key.
+
+
+ Gets the private key from the specified secret key.
+
+ The private key.
+ The secret key.
+
+ is null.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Gets the private key.
+
+
+ Gets the private key.
+
+ The private key.
+ The key identifier.
+
+ The specified secret key could not be found.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Gets the equivalent for the
+ specified .
+
+
+ Maps a to the equivalent .
+
+ The hash algorithm.
+ The digest algorithm.
+
+ is out of range.
+
+
+ is not a supported digest algorithm.
+
+
+
+
+ Cryptographically signs the content.
+
+
+ Cryptographically signs the content using the specified signer and digest algorithm.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+ A signing key could not be found for .
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Cryptographically signs the content.
+
+
+ Cryptographically signs the content using the specified signer and digest algorithm.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+
+
+ The was out of range.
+
+
+ The is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Gets the equivalent for the specified
+ .
+
+
+ Gets the equivalent for the specified
+ .
+
+ The digest algorithm.
+ The hash algorithm.
+
+ is out of range.
+
+
+ does not have an equivalent value.
+
+
+
+
+ Gets the equivalent for the specified
+ .
+
+
+ Gets the equivalent for the specified
+ .
+
+ The public-key algorithm.
+ The public-key algorithm.
+
+ is out of range.
+
+
+ does not have an equivalent value.
+
+
+
+
+ Verifies the specified content using the detached signatureData.
+
+
+ Verifies the specified content using the detached signatureData.
+
+ A list of digital signatures.
+ The content.
+ The signature data.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ A public key could not be found for one or more of the .
+
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The encryption algorithm.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ A public key could not be found for one or more of the .
+
+
+ The specified encryption algorithm is not supported.
+
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The encryption algorithm.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The specified encryption algorithm is not supported.
+
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The signer.
+ The digest algorithm to use for signing.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The specified is not supported by this context.
+
+
+ The private key could not be found for .
+
+
+ A public key could not be found for one or more of the .
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The signer.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The specified encryption algorithm is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The signer.
+ The digest algorithm to use for signing.
+ The encryption algorithm.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The specified encryption algorithm is not supported.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+
+ Cryptographically signs and encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The signer.
+ The digest algorithm to use for signing.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be used for signing.
+ -or-
+ One or more of the recipient keys cannot be used for encrypting.
+ -or-
+ No recipients were specified.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+
+
+ Decrypts the specified encryptedData and extracts the digital signers if the content was also signed.
+
+
+ Decrypts the specified encryptedData and extracts the digital signers if the content was also signed.
+
+ The decrypted stream.
+ The encrypted data.
+ A list of digital signatures if the data was both signed and encrypted.
+
+ is null.
+
+
+ The private key could not be found to decrypt the stream.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+ An OpenPGP error occurred.
+
+
+
+
+ Decrypts the specified encryptedData.
+
+
+ Decrypts the specified encryptedData.
+
+ The decrypted stream.
+ The encrypted data.
+
+ is null.
+
+
+ The private key could not be found to decrypt the stream.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+ An OpenPGP error occurred.
+
+
+
+
+ Decrypts the specified encryptedData and extracts the digital signers if the content was also signed.
+
+
+ Decrypts the specified encryptedData and extracts the digital signers if the content was also signed.
+
+ The decrypted .
+ The encrypted data.
+ A list of digital signatures if the data was both signed and encrypted.
+
+ is null.
+
+
+ The private key could not be found to decrypt the stream.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+ An OpenPGP error occurred.
+
+
+
+
+ Decrypts the specified encryptedData.
+
+
+ Decrypts the specified encryptedData.
+
+ The decrypted .
+ The encrypted data.
+
+ is null.
+
+
+ The private key could not be found to decrypt the stream.
+
+
+ The user chose to cancel the password prompt.
+
+
+ 3 bad attempts were made to unlock the secret key.
+
+
+ An OpenPGP error occurred.
+
+
+
+
+ Saves the public key-ring bundle.
+
+
+ Atomically saves the public key-ring bundle to the path specified by .
+ Called by if any public keys were successfully imported.
+
+
+ An error occured while saving the public key-ring bundle.
+
+
+
+
+ Saves the secret key-ring bundle.
+
+
+ Atomically saves the secret key-ring bundle to the path specified by .
+ Called by if any secret keys were successfully imported.
+
+
+ An error occured while saving the secret key-ring bundle.
+
+
+
+
+ Imports a public pgp keyring.
+
+
+ Imports a public pgp keyring.
+
+ The pgp keyring.
+
+ is null.
+
+
+
+
+ Imports a public pgp keyring bundle.
+
+
+ Imports a public pgp keyring bundle.
+
+ The pgp keyring bundle.
+
+ is null.
+
+
+
+
+ Imports public pgp keys from the specified stream.
+
+
+ Imports public pgp keys from the specified stream.
+
+ The raw key data.
+
+ is null.
+
+
+ An error occurred while parsing the raw key-ring data
+ -or-
+ An error occured while saving the public key-ring bundle.
+
+
+
+
+ Imports a secret pgp keyring.
+
+
+ Imports a secret pgp keyring.
+
+ The pgp keyring.
+
+ is null.
+
+
+
+
+ Imports a secret pgp keyring bundle.
+
+
+ Imports a secret pgp keyring bundle.
+
+ The pgp keyring bundle.
+
+ is null.
+
+
+
+
+ Imports secret pgp keys from the specified stream.
+
+
+ Imports secret pgp keys from the specified stream.
+ The stream should consist of an armored secret keyring bundle
+ containing 1 or more secret keyrings.
+
+ The raw key data.
+
+ is null.
+
+
+ An error occurred while parsing the raw key-ring data
+ -or-
+ An error occured while saving the public key-ring bundle.
+
+
+
+
+ Exports the public keys for the specified mailboxes.
+
+
+ Exports the public keys for the specified mailboxes.
+
+ A new instance containing the exported public keys.
+ The mailboxes.
+
+ is null.
+
+
+ was empty.
+
+
+
+
+ Exports the specified public keys.
+
+
+ Exports the specified public keys.
+
+ A new instance containing the exported public keys.
+ The keys.
+
+ is null.
+
+
+
+
+ Exports the specified public keys.
+
+
+ Exports the specified public keys.
+
+ A new instance containing the exported public keys.
+ The keys.
+
+ is null.
+
+
+
+
+ An OpenPGP digital certificate.
+
+
+ An OpenPGP digital certificate.
+
+
+
+
+ Gets the public key.
+
+
+ Gets the public key.
+
+ The public key.
+
+
+
+ Gets the public key algorithm supported by the certificate.
+
+
+ Gets the public key algorithm supported by the certificate.
+
+ The public key algorithm.
+
+
+
+ Gets the date that the certificate was created.
+
+
+ Gets the date that the certificate was created.
+
+ The creation date.
+
+
+
+ Gets the expiration date of the certificate.
+
+
+ Gets the expiration date of the certificate.
+
+ The expiration date.
+
+
+
+ Gets the fingerprint of the certificate.
+
+
+ Gets the fingerprint of the certificate.
+
+ The fingerprint.
+
+
+
+ Gets the email address of the owner of the certificate.
+
+
+ Gets the email address of the owner of the certificate.
+
+ The email address.
+
+
+
+ Gets the name of the owner of the certificate.
+
+
+ Gets the name of the owner of the certificate.
+
+ The name of the owner.
+
+
+
+ An OpenPGP digital signature.
+
+
+ An OpenPGP digital signature.
+
+
+
+
+ Gets certificate used by the signer.
+
+
+ Gets certificate used by the signer.
+
+ The signer's certificate.
+
+
+
+ Gets the public key algorithm used for the signature.
+
+
+ Gets the public key algorithm used for the signature.
+
+ The public key algorithm.
+
+
+
+ Gets the digest algorithm used for the signature.
+
+
+ Gets the digest algorithm used for the signature.
+
+ The digest algorithm.
+
+
+
+ Gets the creation date of the digital signature.
+
+
+ Gets the creation date of the digital signature.
+
+ The creation date.
+
+
+
+ Verifies the digital signature.
+
+
+ Verifies the digital signature.
+
+ true if the signature is valid; otherwise false.
+
+ An error verifying the signature has occurred.
+
+
+
+
+ An exception that is thrown when a private key could not be found for a specified mailbox or key id.
+
+
+ An exception that is thrown when a private key could not be found for a specified mailbox or key id.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The serialization info.
+ The stream context.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The mailbox that could not be resolved to a valid private key.
+ A message explaining the error.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The key id that could not be resolved to a valid certificate.
+ A message explaining the error.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The key id that could not be resolved to a valid certificate.
+ A message explaining the error.
+
+ is null.
+
+
+
+
+ When overridden in a derived class, sets the
+ with information about the exception.
+
+
+ Sets the
+ with information about the exception.
+
+ The serialization info.
+ The streaming context.
+
+ is null.
+
+
+
+
+ Gets the key id that could not be found.
+
+
+ Gets the key id that could not be found.
+
+ The key id.
+
+
+
+ An enumeration of public key algorithms.
+
+
+ An enumeration of public key algorithms.
+
+
+
+
+ No public key algorithm specified.
+
+
+
+
+ The RSA algorithm.
+
+
+
+
+ The RSA encryption-only algorithm.
+
+
+
+
+ The RSA sign-only algorithm.
+
+
+
+
+ The El-Gamal encryption-only algorithm.
+
+
+
+
+ The DSA algorithm.
+
+
+
+
+ The elliptic curve algorithm.
+
+
+
+
+ The elliptic curve DSA algorithm.
+
+
+
+
+ The El-Gamal algorithm.
+
+
+
+
+ The Diffie-Hellman algorithm.
+
+
+
+
+ An exception that is thrown when a public key could not be found for a specified mailbox.
+
+
+ An exception that is thrown when a public key could not be found for a specified mailbox.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The serialization info.
+ The stream context.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The mailbox that could not be resolved to a valid private key.
+ A message explaining the error.
+
+
+
+ When overridden in a derived class, sets the
+ with information about the exception.
+
+
+ Sets the
+ with information about the exception.
+
+ The serialization info.
+ The streaming context.
+
+ is null.
+
+
+
+
+ Gets the key id that could not be found.
+
+
+ Gets the key id that could not be found.
+
+ The key id.
+
+
+
+ A secure mailbox address which includes a fingerprint for a certificate.
+
+
+ When signing or encrypting a message, it is necessary to look up the
+ X.509 certificate in order to do the actual sign or encrypt operation. One
+ way of accomplishing this is to use the email address of sender or recipient
+ as a unique identifier. However, a better approach is to use the fingerprint
+ (or 'thumbprint' in Microsoft parlance) of the user's certificate.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified fingerprint.
+
+ The character encoding to be used for encoding the name.
+ The name of the mailbox.
+ The route of the mailbox.
+ The address of the mailbox.
+ The fingerprint of the certificate belonging to the owner of the mailbox.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified fingerprint.
+
+ The name of the mailbox.
+ The route of the mailbox.
+ The address of the mailbox.
+ The fingerprint of the certificate belonging to the owner of the mailbox.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified fingerprint.
+
+ The character encoding to be used for encoding the name.
+ The name of the mailbox.
+ The address of the mailbox.
+ The fingerprint of the certificate belonging to the owner of the mailbox.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified fingerprint.
+
+ The name of the mailbox.
+ The address of the mailbox.
+ The fingerprint of the certificate belonging to the owner of the mailbox.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets the fingerprint of the certificate and/or key to use for signing or encrypting.
+
+
+
+
+ A fingerprint is a SHA-1 hash of the raw certificate data and is often used
+ as a unique identifier for a particular certificate in a certificate store.
+
+ The fingerprint of the certificate.
+
+
+
+ A Secure MIME (S/MIME) cryptography context.
+
+
+ Generally speaking, applications should not use a
+ directly, but rather via higher level APIs such as
+ and .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Enables the following encryption algorithms by default:
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the signature protocol.
+
+
+ The signature protocol is used by
+ in order to determine what the protocol parameter of the Content-Type
+ header should be.
+
+ The signature protocol.
+
+
+
+ Gets the encryption protocol.
+
+
+ The encryption protocol is used by
+ in order to determine what the protocol parameter of the Content-Type
+ header should be.
+
+ The encryption protocol.
+
+
+
+ Gets the key exchange protocol.
+
+
+ Gets the key exchange protocol.
+
+ The key exchange protocol.
+
+
+
+ Checks whether or not the specified protocol is supported by the .
+
+
+ Used in order to make sure that the protocol parameter value specified in either a multipart/signed
+ or multipart/encrypted part is supported by the supplied cryptography context.
+
+ true if the protocol is supported; otherwise false
+ The protocol.
+
+ is null.
+
+
+
+
+ Gets the string name of the digest algorithm for use with the micalg parameter of a multipart/signed part.
+
+
+ Maps the to the appropriate string identifier
+ as used by the micalg parameter value of a multipart/signed Content-Type
+ header. For example:
+
+ AlgorithmName
+ - md5
+ - sha-1
+ - sha-224
+ - sha-256
+ - sha-384
+ - sha-512
+
+
+ The micalg value.
+ The digest algorithm.
+
+ is out of range.
+
+
+
+
+ Gets the digest algorithm from the micalg parameter value in a multipart/signed part.
+
+
+ Maps the micalg parameter value string back to the appropriate .
+
+ The digest algorithm.
+ The micalg parameter value.
+
+ is null.
+
+
+
+
+ Gets the preferred rank order for the encryption algorithms; from the strongest to the weakest.
+
+
+ Gets the preferred rank order for the encryption algorithms; from the strongest to the weakest.
+
+ The preferred encryption algorithm ranking.
+
+
+
+ Gets the enabled encryption algorithms in ranked order.
+
+
+ Gets the enabled encryption algorithms in ranked order.
+
+ The enabled encryption algorithms.
+
+
+
+ Enables the encryption algorithm.
+
+
+ Enables the encryption algorithm.
+
+ The encryption algorithm.
+
+
+
+ Disables the encryption algorithm.
+
+
+ Disables the encryption algorithm.
+
+ The encryption algorithm.
+
+
+
+ Checks whether the specified encryption algorithm is enabled.
+
+
+ Determines whether the specified encryption algorithm is enabled.
+
+ true if the specified encryption algorithm is enabled; otherwise, false.
+ Algorithm.
+
+
+
+ Gets the X.509 certificate matching the specified selector.
+
+
+ Gets the first certificate that matches the specified selector.
+
+ The certificate on success; otherwise null.
+ The search criteria for the certificate.
+
+
+
+ Gets the private key for the certificate matching the specified selector.
+
+
+ Gets the private key for the first certificate that matches the specified selector.
+
+ The private key on success; otherwise null.
+ The search criteria for the private key.
+
+
+
+ Gets the trusted anchors.
+
+
+ A trusted anchor is a trusted root-level X.509 certificate,
+ generally issued by a certificate authority (CA).
+
+ The trusted anchors.
+
+
+
+ Gets the intermediate certificates.
+
+
+ An intermediate certificate is any certificate that exists between the root
+ certificate issued by a Certificate Authority (CA) and the certificate at
+ the end of the chain.
+
+ The intermediate certificates.
+
+
+
+ Gets the certificate revocation lists.
+
+
+ A Certificate Revocation List (CRL) is a list of certificate serial numbers issued
+ by a particular Certificate Authority (CA) that have been revoked, either by the CA
+ itself or by the owner of the revoked certificate.
+
+ The certificate revocation lists.
+
+
+
+ Gets the for the specified mailbox.
+
+
+ Constructs a with the appropriate certificate and
+ for the specified mailbox.
+ If the mailbox is a , the
+ property will be used instead of
+ the mailbox address.
+
+ A .
+ The mailbox.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Gets a collection of CmsRecipients for the specified mailboxes.
+
+
+ Gets a collection of CmsRecipients for the specified mailboxes.
+
+ A .
+ The mailboxes.
+
+ is null.
+
+
+ A certificate for one or more of the specified could not be found.
+
+
+
+
+ Gets the for the specified mailbox.
+
+
+ Constructs a with the appropriate signing certificate
+ for the specified mailbox.
+ If the mailbox is a , the
+ property will be used instead of
+ the mailbox address for database lookups.
+
+ A .
+ The mailbox.
+ The preferred digest algorithm.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+ The certificate.
+ The encryption algorithm capabilities of the client (in preferred order).
+ The timestamp.
+
+
+
+ Gets the OID for the digest algorithm.
+
+
+ Gets the OID for the digest algorithm.
+
+ The digest oid.
+ The digest algorithm.
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+
+
+ Compresses the specified stream.
+
+
+ Compresses the specified stream.
+
+ A new instance
+ containing the compressed content.
+ The stream to compress.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Decompress the specified stream.
+
+
+ Decompress the specified stream.
+
+ The decompressed mime part.
+ The stream to decompress.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs and encapsulates the content using the specified signer.
+
+
+ Cryptographically signs and encapsulates the content using the specified signer.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs and encapsulates the content using the specified signer and digest algorithm.
+
+
+ Cryptographically signs and encapsulates the content using the specified signer and digest algorithm.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+ A signing certificate could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs the content using the specified signer.
+
+
+ Cryptographically signs the content using the specified signer.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Cryptographically signs the content using the specified signer and digest algorithm.
+
+
+ Cryptographically signs the content using the specified signer and digest algorithm.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+ A signing certificate could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Attempts to map a
+ to a .
+
+
+ Attempts to map a
+ to a .
+
+ true if the algorithm identifier was successfully mapped; false otherwise.
+ The algorithm identifier.
+ The encryption algorithm.
+
+ is null.
+
+
+
+
+ Verifies the specified content using the detached signatureData.
+
+
+ Verifies the specified content using the detached signatureData.
+
+ A list of the digital signatures.
+ The content.
+ The detached signature data.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Verifies the digital signatures of the specified signedData and extract the original content.
+
+
+ Verifies the digital signatures of the specified signedData and extract the original content.
+
+ The list of digital signatures.
+ The signed data.
+ The unencapsulated entity.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Gets the preferred encryption algorithm to use for encrypting to the specified recipients.
+
+
+ Gets the preferred encryption algorithm to use for encrypting to the specified recipients
+ based on the encryption algorithms supported by each of the recipients, the
+ , and the .
+ If the supported encryption algorithms are unknown for any recipient, it is assumed that
+ the recipient supports at least the Triple-DES encryption algorithm.
+
+ The preferred encryption algorithm.
+ The recipients.
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted content.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Encrypts the specified content for the specified recipients.
+
+
+ Encrypts the specified content for the specified recipients.
+
+ A new instance
+ containing the encrypted data.
+ The recipients.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ A certificate for one or more of the could not be found.
+
+
+ A certificate could not be found for one or more of the .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Decrypts the specified encryptedData.
+
+
+ Decrypts the specified encryptedData.
+
+ The decrypted .
+ The encrypted data.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+ The raw certificate and key data.
+ The password to unlock the stream.
+
+ is null.
+ -or-
+ is null.
+
+
+ Importing keys is not supported by this cryptography context.
+
+
+
+
+ Exports the certificates for the specified mailboxes.
+
+
+ Exports the certificates for the specified mailboxes.
+
+ A new instance containing
+ the exported keys.
+ The mailboxes.
+
+ is null.
+
+
+ No mailboxes were specified.
+
+
+ A certificate for one or more of the could not be found.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Imports the specified certificate.
+
+
+ Imports the specified certificate.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Imports the specified certificate revocation list.
+
+
+ Imports the specified certificate revocation list.
+
+ The certificate revocation list.
+
+ is null.
+
+
+
+
+ Imports certificates (as from a certs-only application/pkcs-mime part)
+ from the specified stream.
+
+
+ Imports certificates (as from a certs-only application/pkcs-mime part)
+ from the specified stream.
+
+ The raw key data.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ An S/MIME digital certificate.
+
+
+ An S/MIME digital certificate.
+
+
+
+
+ Gets the .
+
+
+ Gets the .
+
+ The certificate.
+
+
+
+ Gets the public key algorithm supported by the certificate.
+
+
+ Gets the public key algorithm supported by the certificate.
+
+ The public key algorithm.
+
+
+
+ Gets the date that the certificate was created.
+
+
+ Gets the date that the certificate was created.
+
+ The creation date.
+
+
+
+ Gets the expiration date of the certificate.
+
+
+ Gets the expiration date of the certificate.
+
+ The expiration date.
+
+
+
+ Gets the fingerprint of the certificate.
+
+
+ Gets the fingerprint of the certificate.
+
+ The fingerprint.
+
+
+
+ Gets the email address of the owner of the certificate.
+
+
+ Gets the email address of the owner of the certificate.
+
+ The email address.
+
+
+
+ Gets the name of the owner of the certificate.
+
+
+ Gets the name of the owner of the certificate.
+
+ The name of the owner.
+
+
+
+ An S/MIME digital signature.
+
+
+ An S/MIME digital signature.
+
+
+
+
+ Gets the signer info.
+
+
+ Gets the signer info.
+
+ The signer info.
+
+
+
+ Gets the list of encryption algorithms, in preferential order,
+ that the signer's client supports.
+
+
+ Gets the list of encryption algorithms, in preferential order,
+ that the signer's client supports.
+
+ The S/MIME encryption algorithms.
+
+
+
+ Gets the certificate chain.
+
+
+ If building the certificate chain failed, this value will be null and
+ will be set.
+
+ The certificate chain.
+
+
+
+ The exception that occurred, if any, while building the certificate chain.
+
+
+ This will only be set if building the certificate chain failed.
+
+ The exception.
+
+
+
+ Gets certificate used by the signer.
+
+
+ Gets certificate used by the signer.
+
+ The signer's certificate.
+
+
+
+ Gets the public key algorithm used for the signature.
+
+
+ Gets the public key algorithm used for the signature.
+
+ The public key algorithm.
+
+
+
+ Gets the digest algorithm used for the signature.
+
+
+ Gets the digest algorithm used for the signature.
+
+ The digest algorithm.
+
+
+
+ Gets the creation date of the digital signature.
+
+
+ Gets the creation date of the digital signature.
+
+ The creation date.
+
+
+
+ Verifies the digital signature.
+
+
+ Verifies the digital signature.
+
+ true if the signature is valid; otherwise false.
+
+ An error verifying the signature has occurred.
+
+
+
+
+ The type of S/MIME data that an application/pkcs7-mime part contains.
+
+
+ The type of S/MIME data that an application/pkcs7-mime part contains.
+
+
+
+
+ S/MIME compressed data.
+
+
+
+
+ S/MIME enveloped data.
+
+
+
+
+ S/MIME signed data.
+
+
+
+
+ S/MIME certificate data.
+
+
+
+
+ The S/MIME data type is unknown.
+
+
+
+
+ An abstract X.509 certificate database built on generic SQL storage.
+
+
+ An X.509 certificate database is used for storing certificates, metdata related to the certificates
+ (such as encryption algorithms supported by the associated client), certificate revocation lists (CRLs),
+ and private keys.
+ This particular database uses SQLite to store the data.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new using the provided database connection.
+
+ The database .
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets the command to create the certificates table.
+
+
+ Constructs the command to create a certificates table suitable for storing
+ objects.
+
+ The .
+ The .
+
+
+
+ Gets the command to create the CRLs table.
+
+
+ Constructs the command to create a CRLs table suitable for storing
+ objects.
+
+ The .
+ The .
+
+
+
+ Gets the database command to select the record matching the specified certificate.
+
+
+ Gets the database command to select the record matching the specified certificate.
+
+ The database command.
+ The certificate.
+ The fields to return.
+
+
+
+ Gets the database command to select the certificate records for the specified mailbox.
+
+
+ Gets the database command to select the certificate records for the specified mailbox.
+
+ The database command.
+ The mailbox.
+ The date and time for which the certificate should be valid.
+ true
+ The fields to return.
+
+
+
+ Gets the database command to select the certificate records for the specified mailbox.
+
+
+ Gets the database command to select the certificate records for the specified mailbox.
+
+ The database command.
+ Selector.
+ If set to true trusted only.
+ true
+ The fields to return.
+
+
+
+ Gets the database command to select the CRL records matching the specified issuer.
+
+
+ Gets the database command to select the CRL records matching the specified issuer.
+
+ The database command.
+ The issuer.
+ The fields to return.
+
+
+
+ Gets the database command to select the record for the specified CRL.
+
+
+ Gets the database command to select the record for the specified CRL.
+
+ The database command.
+ The X.509 CRL.
+ The fields to return.
+
+
+
+ Gets the database command to select all CRLs in the table.
+
+
+ Gets the database command to select all CRLs in the table.
+
+ The database command.
+
+
+
+ Gets the database command to delete the specified certificate record.
+
+
+ Gets the database command to delete the specified certificate record.
+
+ The database command.
+ The certificate record.
+
+
+
+ Gets the database command to delete the specified CRL record.
+
+
+ Gets the database command to delete the specified CRL record.
+
+ The database command.
+ The record.
+
+
+
+ Gets the database command to insert the specified certificate record.
+
+
+ Gets the database command to insert the specified certificate record.
+
+ The database command.
+ The certificate record.
+
+
+
+ Gets the database command to insert the specified CRL record.
+
+
+ Gets the database command to insert the specified CRL record.
+
+ The database command.
+ The CRL record.
+
+
+
+ Gets the database command to update the specified record.
+
+
+ Gets the database command to update the specified record.
+
+ The database command.
+ The certificate record.
+ The fields to update.
+
+
+
+ Gets the database command to update the specified CRL record.
+
+
+ Gets the database command to update the specified CRL record.
+
+ The database command.
+ The CRL record.
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ An X.509 certificate database built on SQLite.
+
+
+ An X.509 certificate database is used for storing certificates, metdata related to the certificates
+ (such as encryption algorithms supported by the associated client), certificate revocation lists (CRLs),
+ and private keys.
+ This particular database uses SQLite to store the data.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new and opens a connection to the
+ SQLite database at the specified path using the Mono.Data.Sqlite binding to the native
+ SQLite library.
+ If Mono.Data.Sqlite is not available or if an alternative binding to the native
+ SQLite library is preferred, then consider using
+ instead.
+
+ The file name.
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+ The user does not have access to read the specified file.
+
+
+ An error occurred reading the file.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new using the provided SQLite database connection.
+
+ The SQLite connection.
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets the command to create the certificates table.
+
+
+ Constructs the command to create a certificates table suitable for storing
+ objects.
+
+ The .
+ The .
+
+
+
+ Gets the command to create the CRLs table.
+
+
+ Constructs the command to create a CRLs table suitable for storing
+ objects.
+
+ The .
+ The .
+
+
+
+ The method to use for identifying a certificate.
+
+
+ The method to use for identifying a certificate.
+
+
+
+
+ The identifier type is unknown.
+
+
+
+
+ Identify the certificate by its Issuer and Serial Number properties.
+
+
+
+
+ Identify the certificate by the sha1 hash of its public key.
+
+
+
+
+ An S/MIME context that does not persist certificates, private keys or CRLs.
+
+
+ A is a special S/MIME context that
+ does not use a persistent store for certificates, private keys, or CRLs.
+ Instead, certificates, private keys, and CRLs are maintained in memory only.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the X.509 certificate matching the specified selector.
+
+
+ Gets the first certificate that matches the specified selector.
+
+ The certificate on success; otherwise null.
+ The search criteria for the certificate.
+
+
+
+ Gets the private key for the certificate matching the specified selector.
+
+
+ Gets the private key for the first certificate that matches the specified selector.
+
+ The private key on success; otherwise null.
+ The search criteria for the private key.
+
+
+
+ Gets the trusted anchors.
+
+
+ A trusted anchor is a trusted root-level X.509 certificate,
+ generally issued by a certificate authority (CA).
+
+ The trusted anchors.
+
+
+
+ Gets the intermediate certificates.
+
+
+ An intermediate certificate is any certificate that exists between the root
+ certificate issued by a Certificate Authority (CA) and the certificate at
+ the end of the chain.
+
+ The intermediate certificates.
+
+
+
+ Gets the certificate revocation lists.
+
+
+ A Certificate Revocation List (CRL) is a list of certificate serial numbers issued
+ by a particular Certificate Authority (CA) that have been revoked, either by the CA
+ itself or by the owner of the revoked certificate.
+
+ The certificate revocation lists.
+
+
+
+ Gets the for the specified mailbox.
+
+
+ Constructs a with the appropriate certificate and
+ for the specified mailbox.
+ If the mailbox is a , the
+ property will be used instead of
+ the mailbox address.
+
+ A .
+ The mailbox.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Gets the for the specified mailbox.
+
+
+ Constructs a with the appropriate signing certificate
+ for the specified mailbox.
+ If the mailbox is a , the
+ property will be used instead of
+ the mailbox address for database lookups.
+
+ A .
+ The mailbox.
+ The preferred digest algorithm.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+ The certificate.
+ The encryption algorithm capabilities of the client (in preferred order).
+ The timestamp.
+
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+ The raw certificate and key data.
+ The password to unlock the stream.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Imports the specified certificate.
+
+
+ Imports the specified certificate.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Imports the specified certificate revocation list.
+
+
+ Imports the specified certificate revocation list.
+
+ The certificate revocation list.
+
+ is null.
+
+
+
+
+ An S/MIME cryptography context that uses Windows' .
+
+
+ An S/MIME cryptography context that uses Windows' .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The X.509 store location.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Constructs an S/MIME context using the current user's X.509 store location.
+
+
+
+
+ Gets the X.509 store location.
+
+
+ Gets the X.509 store location.
+
+ The store location.
+
+
+
+ Gets the X.509 certificate based on the selector.
+
+
+ Gets the X.509 certificate based on the selector.
+
+ The certificate on success; otherwise null.
+ The search criteria for the certificate.
+
+
+
+ Gets the private key based on the provided selector.
+
+
+ Gets the private key based on the provided selector.
+
+ The private key on success; otherwise null.
+ The search criteria for the private key.
+
+
+
+ Gets the trusted anchors.
+
+
+ Gets the trusted anchors.
+
+ The trusted anchors.
+
+
+
+ Gets the intermediate certificates.
+
+
+ Gets the intermediate certificates.
+
+ The intermediate certificates.
+
+
+
+ Gets the certificate revocation lists.
+
+
+ Gets the certificate revocation lists.
+
+ The certificate revocation lists.
+
+
+
+ Gets the X.509 certificate associated with the .
+
+
+ Gets the X.509 certificate associated with the .
+
+ The certificate.
+ The mailbox.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Gets the cms signer for the specified .
+
+
+ Gets the cms signer for the specified .
+
+ The cms signer.
+ The mailbox.
+ The preferred digest algorithm.
+
+ A certificate for the specified could not be found.
+
+
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+
+ Updates the known S/MIME capabilities of the client used by the recipient that owns the specified certificate.
+
+ The certificate.
+ The encryption algorithm capabilities of the client (in preferred order).
+ The timestamp.
+
+
+
+ Sign and encapsulate the content using the specified signer.
+
+
+ Sign and encapsulate the content using the specified signer.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+ A signing certificate could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Sign the content using the specified signer.
+
+
+ Sign the content using the specified signer.
+
+ A new instance
+ containing the detached signature data.
+ The signer.
+ The digest algorithm to use for signing.
+ The content.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The specified is not supported by this context.
+
+
+ A signing certificate could not be found for .
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Decrypt the encrypted data.
+
+
+ Decrypt the encrypted data.
+
+ The decrypted .
+ The encrypted data.
+
+ is null.
+
+
+ An error occurred in the cryptographic message syntax subsystem.
+
+
+
+
+ Import the specified certificate.
+
+
+ Import the specified certificate.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Import the specified certificate revocation list.
+
+
+ Import the specified certificate revocation list.
+
+ The certificate revocation list.
+
+ is null.
+
+
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+
+ Imports certificates and keys from a pkcs12-encoded stream.
+
+ The raw certificate and key data.
+ The password to unlock the stream.
+
+ is null.
+ -or-
+ is null.
+
+
+ Importing keys is not supported by this cryptography context.
+
+
+
+
+ An X.509 certificate chain.
+
+
+ An X.509 certificate chain.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new X.509 certificate chain.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new X.509 certificate chain based on the specified collection of certificates.
+
+ A collection of certificates.
+
+
+
+ Gets the index of the specified certificate within the chain.
+
+
+ Finds the index of the specified certificate, if it exists.
+
+ The index of the specified certificate if found; otherwise -1.
+ The certificate to get the index of.
+
+ is null.
+
+
+
+
+ Inserts the certificate at the specified index.
+
+
+ Inserts the certificate at the specified index in the certificates.
+
+ The index to insert the certificate.
+ The certificate.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the certificate at the specified index.
+
+
+ Removes the certificate at the specified index.
+
+ The index of the certificate to remove.
+
+ is out of range.
+
+
+
+
+ Gets or sets the certificate at the specified index.
+
+
+ Gets or sets the certificate at the specified index.
+
+ The internet certificate at the specified index.
+ The index of the certificate to get or set.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Gets the number of certificates in the chain.
+
+
+ Indicates the number of certificates in the chain.
+
+ The number of certificates.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Adds the specified certificate to the chain.
+
+
+ Adds the specified certificate to the chain.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Adds the specified range of certificates to the chain.
+
+
+ Adds the specified range of certificates to the chain.
+
+ The certificates.
+
+ is null.
+
+
+
+
+ Clears the certificate chain.
+
+
+ Removes all of the certificates from the chain.
+
+
+
+
+ Checks if the chain contains the specified certificate.
+
+
+ Determines whether or not the certificate chain contains the specified certificate.
+
+ true if the specified certificate exists;
+ otherwise false.
+ The certificate.
+
+ is null.
+
+
+
+
+ Copies all of the certificates in the chain to the specified array.
+
+
+ Copies all of the certificates within the chain into the array,
+ starting at the specified array index.
+
+ The array to copy the certificates to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified certificate from the chain.
+
+
+ Removes the specified certificate from the chain.
+
+ true if the certificate was removed; otherwise false.
+ The certificate.
+
+ is null.
+
+
+
+
+ Removes the specified range of certificates from the chain.
+
+
+ Removes the specified range of certificates from the chain.
+
+ The certificates.
+
+ is null.
+
+
+
+
+ Gets an enumerator for the list of certificates.
+
+
+ Gets an enumerator for the list of certificates.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of certificates.
+
+
+ Gets an enumerator for the list of certificates.
+
+ The enumerator.
+
+
+
+ Gets an enumerator of matching X.509 certificates based on the specified selector.
+
+
+ Gets an enumerator of matching X.509 certificates based on the specified selector.
+
+ The matching certificates.
+ The match criteria.
+
+
+
+ Gets a collection of matching X.509 certificates based on the specified selector.
+
+
+ Gets a collection of matching X.509 certificates based on the specified selector.
+
+ The matching certificates.
+ The match criteria.
+
+
+
+ An X.509 certificate database.
+
+
+ An X.509 certificate database is used for storing certificates, metadata related to the certificates
+ (such as encryption algorithms supported by the associated client), certificate revocation lists (CRLs),
+ and private keys.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The password is used to encrypt and decrypt private keys in the database and cannot be null.
+
+ The password used for encrypting and decrypting the private keys.
+
+ is null.
+
+
+
+
+ Releases unmanaged resources and performs other cleanup operations before the
+ is reclaimed by garbage collection.
+
+
+ Releases unmanaged resources and performs other cleanup operations before the
+ is reclaimed by garbage collection.
+
+
+
+
+ Gets or sets the algorithm used for encrypting the private keys.
+
+
+ The encryption algorithm should be one of the PBE (password-based encryption) algorithms
+ supported by Bouncy Castle.
+ The default algorithm is SHA-256 + AES256.
+
+ The encryption algorithm.
+
+
+
+ Gets or sets the minimum iterations.
+
+
+ The default minimum number of iterations is 1024.
+
+ The minimum iterations.
+
+
+
+ Gets or sets the size of the salt.
+
+
+ The default salt size is 20.
+
+ The size of the salt.
+
+
+
+ Gets the column names for the specified fields.
+
+
+ Gets the column names for the specified fields.
+
+ The column names.
+ The fields.
+
+
+
+ Gets the database command to select the record matching the specified certificate.
+
+
+ Gets the database command to select the record matching the specified certificate.
+
+ The database command.
+ The certificate.
+ The fields to return.
+
+
+
+ Gets the database command to select the certificate records for the specified mailbox.
+
+
+ Gets the database command to select the certificate records for the specified mailbox.
+
+ The database command.
+ The mailbox.
+ The date and time for which the certificate should be valid.
+ true if the certificate must have a private key.
+ The fields to return.
+
+
+
+ Gets the database command to select certificate records matching the specified selector.
+
+
+ Gets the database command to select certificate records matching the specified selector.
+
+ The database command.
+ Selector.
+ true if only trusted certificates should be matched.
+ true if the certificate must have a private key.
+ The fields to return.
+
+
+
+ Gets the column names for the specified fields.
+
+
+ Gets the column names for the specified fields.
+
+ The column names.
+ The fields.
+
+
+
+ Gets the database command to select the CRL records matching the specified issuer.
+
+
+ Gets the database command to select the CRL records matching the specified issuer.
+
+ The database command.
+ The issuer.
+ The fields to return.
+
+
+
+ Gets the database command to select the record for the specified CRL.
+
+
+ Gets the database command to select the record for the specified CRL.
+
+ The database command.
+ The X.509 CRL.
+ The fields to return.
+
+
+
+ Gets the database command to select all CRLs in the table.
+
+
+ Gets the database command to select all CRLs in the table.
+
+ The database command.
+
+
+
+ Gets the database command to delete the specified certificate record.
+
+
+ Gets the database command to delete the specified certificate record.
+
+ The database command.
+ The certificate record.
+
+
+
+ Gets the database command to delete the specified CRL record.
+
+
+ Gets the database command to delete the specified CRL record.
+
+ The database command.
+ The record.
+
+
+
+ Gets the value for the specified column.
+
+
+ Gets the value for the specified column.
+
+ The value.
+ The certificate record.
+ The column name.
+
+ is not a known column name.
+
+
+
+
+ Gets the value for the specified column.
+
+
+ Gets the value for the specified column.
+
+ The value.
+ The CRL record.
+ The column name.
+
+ is not a known column name.
+
+
+
+
+ Gets the database command to insert the specified certificate record.
+
+
+ Gets the database command to insert the specified certificate record.
+
+ The database command.
+ The certificate record.
+
+
+
+ Gets the database command to insert the specified CRL record.
+
+
+ Gets the database command to insert the specified CRL record.
+
+ The database command.
+ The CRL record.
+
+
+
+ Gets the database command to update the specified record.
+
+
+ Gets the database command to update the specified record.
+
+ The database command.
+ The certificate record.
+ The fields to update.
+
+
+
+ Gets the database command to update the specified CRL record.
+
+
+ Gets the database command to update the specified CRL record.
+
+ The database command.
+ The CRL record.
+
+
+
+ Find the specified certificate.
+
+
+ Searches the database for the specified certificate, returning the matching
+ record with the desired fields populated.
+
+ The matching record if found; otherwise null.
+ The certificate.
+ The desired fields.
+
+ is null.
+
+
+
+
+ Finds the certificates matching the specified selector.
+
+
+ Searches the database for certificates matching the selector, returning all
+ matching certificates.
+
+ The matching certificates.
+ The match selector or null to return all certificates.
+
+
+
+ Finds the private keys matching the specified selector.
+
+
+ Searches the database for certificate records matching the selector, returning the
+ private keys for each matching record.
+
+ The matching certificates.
+ The match selector or null to return all private keys.
+
+
+
+ Finds the certificate records for the specified mailbox.
+
+
+ Searches the database for certificates matching the specified mailbox that are valid
+ for the date and time specified, returning all matching records populated with the
+ desired fields.
+
+ The matching certificate records populated with the desired fields.
+ The mailbox.
+ The date and time.
+ true if a private key is required.
+ The desired fields.
+
+ is null.
+
+
+
+
+ Finds the certificate records matching the specified selector.
+
+
+ Searches the database for certificate records matching the selector, returning all
+ of the matching records populated with the desired fields.
+
+ The matching certificate records populated with the desired fields.
+ The match selector or null to match all certificates.
+ true if only trusted certificates should be returned.
+ The desired fields.
+
+
+
+ Add the specified certificate record.
+
+
+ Adds the specified certificate record to the database.
+
+ The certificate record.
+
+ is null.
+
+
+
+
+ Remove the specified certificate record.
+
+
+ Removes the specified certificate record from the database.
+
+ The certificate record.
+
+ is null.
+
+
+
+
+ Update the specified certificate record.
+
+
+ Updates the specified fields of the record in the database.
+
+ The certificate record.
+ The fields to update.
+
+ is null.
+
+
+
+
+ Finds the CRL records for the specified issuer.
+
+
+ Searches the database for CRL records matching the specified issuer, returning
+ all matching records populated with the desired fields.
+
+ The matching CRL records populated with the desired fields.
+ The issuer.
+ The desired fields.
+
+ is null.
+
+
+
+
+ Finds the specified certificate revocation list.
+
+
+ Searches the database for the specified CRL, returning the matching record with
+ the desired fields populated.
+
+ The matching record if found; otherwise null.
+ The certificate revocation list.
+ The desired fields.
+
+ is null.
+
+
+
+
+ Add the specified CRL record.
+
+
+ Adds the specified CRL record to the database.
+
+ The CRL record.
+
+ is null.
+
+
+
+
+ Remove the specified CRL record.
+
+
+ Removes the specified CRL record from the database.
+
+ The CRL record.
+
+ is null.
+
+
+
+
+ Update the specified CRL record.
+
+
+ Updates the specified fields of the record in the database.
+
+ The CRL record.
+
+ is null.
+
+
+
+
+ Gets a certificate revocation list store.
+
+
+ Gets a certificate revocation list store.
+
+ A certificate recovation list store.
+
+
+
+ Gets a collection of matching certificates matching the specified selector.
+
+
+ Gets a collection of matching certificates matching the specified selector.
+
+ The matching certificates.
+ The match criteria.
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ Releases all resource used by the object.
+
+ Call when you are finished using the
+ . The method leaves the
+ in an unusable state. After calling
+ , you must release all references to the
+ so the garbage collector can reclaim the memory that
+ the was occupying.
+
+
+
+ X509Certificate extension methods.
+
+
+ A collection of useful extension methods for an .
+
+
+
+
+ Gets the issuer name info.
+
+
+ For a list of available identifiers, see .
+
+ The issuer name info.
+ The certificate.
+ The name identifier.
+
+ is null.
+
+
+
+
+ Gets the issuer name info.
+
+
+ For a list of available identifiers, see .
+
+ The issuer name info.
+ The certificate.
+ The name identifier.
+
+ is null.
+
+
+
+
+ Gets the common name of the certificate.
+
+
+ Gets the common name of the certificate.
+
+ The common name.
+ The certificate.
+
+ is null.
+
+
+
+
+ Gets the subject name of the certificate.
+
+
+ Gets the subject name of the certificate.
+
+ The subject name.
+ The certificate.
+
+ is null.
+
+
+
+
+ Gets the subject email address of the certificate.
+
+
+ The email address component of the certificate's Subject identifier is
+ sometimes used as a way of looking up certificates for a particular
+ user if a fingerprint is not available.
+
+ The subject email address.
+ The certificate.
+
+ is null.
+
+
+
+
+ Gets the fingerprint of the certificate.
+
+
+ A fingerprint is a SHA-1 hash of the raw certificate data and is often used
+ as a unique identifier for a particular certificate in a certificate store.
+
+ The fingerprint.
+ The certificate.
+
+ is null.
+
+
+
+
+ Gets the key usage flags.
+
+
+ The X.509 Key Usage Flags are used to determine which operations a certificate
+ may be used for.
+
+ The key usage flags.
+ The certificate.
+
+ is null.
+
+
+
+
+ X.509 certificate record fields.
+
+
+ The record fields are used when querying the
+ for certificates.
+
+
+
+
+ The "id" field is typically just the ROWID in the database.
+
+
+
+
+ The "trusted" field is a boolean value indicating whether the certificate
+ is trusted.
+
+
+
+
+ The "algorithms" field is used for storing the last known list of
+ values that are supported by the
+ client associated with the certificate.
+
+
+
+
+ The "algorithms updated" field is used to store the timestamp of the
+ most recent update to the Algorithms field.
+
+
+
+
+ The "certificate" field is sued for storing the binary data of the actual
+ certificate.
+
+
+
+
+ The "private key" field is used to store the encrypted binary data of the
+ private key associated with the certificate, if available.
+
+
+
+
+ An X.509 certificate record.
+
+
+ Represents an X.509 certificate record loaded from a database.
+
+
+
+
+ Gets the identifier.
+
+
+ The id is typically the ROWID of the certificate in the database and is not
+ generally useful outside of the internals of the database implementation.
+
+ The identifier.
+
+
+
+ Gets the basic constraints of the certificate.
+
+
+ Gets the basic constraints of the certificate.
+
+ The basic constraints of the certificate.
+
+
+
+ Gets or sets a value indicating whether the certificate is trusted.
+
+
+ Indiciates whether or not the certificate is trusted.
+
+ true if the certificate is trusted; otherwise, false.
+
+
+
+ Gets the key usage flags for the certificate.
+
+
+ Gets the key usage flags for the certificate.
+
+ The X.509 key usage.
+
+
+
+ Gets the starting date and time where the certificate is valid.
+
+
+ Gets the starting date and time where the certificate is valid.
+
+ The date and time.
+
+
+
+ Gets the end date and time where the certificate is valid.
+
+
+ Gets the end date and time where the certificate is valid.
+
+ The date and time.
+
+
+
+ Gets the certificate issuer's name.
+
+
+ Gets the certificate issuer's name.
+
+ The issuer's name.
+
+
+
+ Gets the serial number of the certificate.
+
+
+ Gets the serial number of the certificate.
+
+ The serial number.
+
+
+
+ Gets the subject email address.
+
+
+ Gets the subject email address.
+
+ The subject email address.
+
+
+
+ Gets the fingerprint of the certificate.
+
+
+ Gets the fingerprint of the certificate.
+
+ The fingerprint.
+
+
+
+ Gets or sets the encryption algorithm capabilities.
+
+
+ Gets or sets the encryption algorithm capabilities.
+
+ The encryption algorithms.
+
+
+
+ Gets or sets the date when the algorithms were last updated.
+
+
+ Gets or sets the date when the algorithms were last updated.
+
+ The date the algorithms were updated.
+
+
+
+ Gets the certificate.
+
+
+ Gets the certificate.
+
+ The certificate.
+
+
+
+ Gets the private key.
+
+
+ Gets the private key.
+
+ The private key.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new certificate record with a private key for storing in a
+ .
+
+ The certificate.
+ The private key.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a private key.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new certificate record for storing in a .
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is only meant to be used by implementors of
+ when loading records from the database.
+
+
+
+
+ A store for X.509 certificates and keys.
+
+
+ A store for X.509 certificates and keys.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Enumerates the certificates currently in the store.
+
+
+ Enumerates the certificates currently in the store.
+
+ The certificates.
+
+
+
+ Gets the private key for the specified certificate.
+
+
+ Gets the private key for the specified certificate, if it exists.
+
+ The private key on success; otherwise null.
+ The certificate.
+
+
+
+ Adds the specified certificate to the store.
+
+
+ Adds the specified certificate to the store.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Adds the specified range of certificates to the store.
+
+
+ Adds the specified range of certificates to the store.
+
+ The certificates.
+
+ is null.
+
+
+
+
+ Removes the specified certificate from the store.
+
+
+ Removes the specified certificate from the store.
+
+ The certificate.
+
+ is null.
+
+
+
+
+ Removes the specified range of certificates from the store.
+
+
+ Removes the specified range of certificates from the store.
+
+ The certificates.
+
+ is null.
+
+
+
+
+ Imports the certificate(s) from the specified stream.
+
+
+ Imports the certificate(s) from the specified stream.
+
+ The stream to import.
+
+ is null.
+
+
+ An error occurred reading the stream.
+
+
+
+
+ Imports the certificate(s) from the specified file.
+
+
+ Imports the certificate(s) from the specified file.
+
+ The name of the file to import.
+
+ is null.
+
+
+ The specified file could not be found.
+
+
+ An error occurred reading the file.
+
+
+
+
+ Imports the certificate(s) from the specified byte array.
+
+
+ Imports the certificate(s) from the specified byte array.
+
+ The raw certificate data.
+
+ is null.
+
+
+
+
+ Imports certificates and private keys from the specified stream.
+
+
+ Imports certificates and private keys from the specified pkcs12 stream.
+
+ The stream to import.
+ The password to unlock the stream.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred reading the stream.
+
+
+
+
+ Imports certificates and private keys from the specified file.
+
+
+ Imports certificates and private keys from the specified pkcs12 stream.
+
+ The name of the file to import.
+ The password to unlock the file.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+ The specified file could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ An error occurred reading the file.
+
+
+
+
+ Imports certificates and private keys from the specified byte array.
+
+
+ Imports certificates and private keys from the specified pkcs12 stream.
+
+ The raw certificate data.
+ The password to unlock the raw data.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Exports the certificates to an unencrypted stream.
+
+
+ Exports the certificates to an unencrypted stream.
+
+ The output stream.
+
+ is null.
+
+
+ An error occurred while writing to the stream.
+
+
+
+
+ Exports the certificates to an unencrypted file.
+
+
+ Exports the certificates to an unencrypted file.
+
+ The file path to write to.
+
+ is null.
+
+
+ The specified file path is empty.
+
+
+ The specified path exceeds the maximum allowed path length of the system.
+
+
+ A directory in the specified path does not exist.
+
+
+ The user does not have access to create the specified file.
+
+
+ An error occurred while writing to the stream.
+
+
+
+
+ Exports the specified stream and password to a pkcs12 encrypted file.
+
+
+ Exports the specified stream and password to a pkcs12 encrypted file.
+
+ The output stream.
+ The password to use to lock the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+ An error occurred while writing to the stream.
+
+
+
+
+ Exports the specified stream and password to a pkcs12 encrypted file.
+
+
+ Exports the specified stream and password to a pkcs12 encrypted file.
+
+ The file path to write to.
+ The password to use to lock the private keys.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+ The specified path exceeds the maximum allowed path length of the system.
+
+
+ A directory in the specified path does not exist.
+
+
+ The user does not have access to create the specified file.
+
+
+ An error occurred while writing to the stream.
+
+
+
+
+ Gets an enumerator of matching X.509 certificates based on the specified selector.
+
+
+ Gets an enumerator of matching X.509 certificates based on the specified selector.
+
+ The matching certificates.
+ The match criteria.
+
+
+
+ Gets a collection of matching X.509 certificates based on the specified selector.
+
+
+ Gets a collection of matching X.509 certificates based on the specified selector.
+
+ The matching certificates.
+ The match criteria.
+
+
+
+ X.509 certificate revocation list record fields.
+
+
+ The record fields are used when querying the
+ for certificate revocation lists.
+
+
+
+
+ The "id" field is typically just the ROWID in the database.
+
+
+
+
+ The "delta" field is a boolean value indicating whether the certificate
+ revocation list is a delta.
+
+
+
+
+ The "issuer name" field stores the issuer name of the certificate revocation list.
+
+
+
+
+ The "this update" field stores the date and time of the most recent update.
+
+
+
+
+ The "next update" field stores the date and time of the next scheduled update.
+
+
+
+
+ The "crl" field stores the raw binary data of the certificate revocation list.
+
+
+
+
+ An X.509 certificate revocation list (CRL) record.
+
+
+ Represents an X.509 certificate revocation list record loaded from a database.
+
+
+
+
+ Gets the identifier.
+
+
+ The id is typically the ROWID of the certificate revocation list in the
+ database and is not generally useful outside of the internals of the
+ database implementation.
+
+ The identifier.
+
+
+
+ Gets whether or not this certificate revocation list is a delta.
+
+
+ Indicates whether or not this certificate revocation list is a delta.
+
+ true if th crl is delta; otherwise, false.
+
+
+
+ Gets the issuer name of the certificate revocation list.
+
+
+ Gets the issuer name of the certificate revocation list.
+
+ The issuer's name.
+
+
+
+ Gets the date and time of the most recent update.
+
+
+ Gets the date and time of the most recent update.
+
+ The date and time.
+
+
+
+ Gets the end date and time where the certificate is valid.
+
+
+ Gets the end date and time where the certificate is valid.
+
+ The date and time.
+
+
+
+ Gets the certificate revocation list.
+
+
+ Gets the certificate revocation list.
+
+ The certificate revocation list.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new CRL record for storing in a .
+
+ The certificate revocation list.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is only meant to be used by implementors of
+ when loading records from the database.
+
+
+
+
+ X.509 key usage flags.
+
+
+ The X.509 Key Usage Flags can be used to determine what operations
+ a certificate can be used for.
+ A value of indicates that
+ there are no restrictions on the use of the
+ .
+
+
+
+
+ No limitations for the key usage are set.
+
+
+ The key may be used for anything.
+
+
+
+
+ The key may only be used for enciphering data during key agreement.
+
+
+ When both the bit and the
+ bit are both set, the key
+ may be used only for enciphering data while
+ performing key agreement.
+
+
+
+
+ The key may be used for verifying signatures on
+ certificate revocation lists (CRLs).
+
+
+
+
+ The key may be used for verifying signatures on certificates.
+
+
+
+
+ The key is meant to be used for key agreement.
+
+
+
+
+ The key may be used for data encipherment.
+
+
+
+
+ The key is meant to be used for key encipherment.
+
+
+
+
+ The key may be used to verify digital signatures used to
+ provide a non-repudiation service.
+
+
+
+
+ The key may be used for digitally signing data.
+
+
+
+
+ The key may only be used for deciphering data during key agreement.
+
+
+ When both the bit and the
+ bit are both set, the key
+ may be used only for deciphering data while
+ performing key agreement.
+
+
+
+
+ Incrementally decodes content encoded with the base64 encoding.
+
+
+ Base64 is an encoding often used in MIME to encode binary content such
+ as images and other types of multi-media to ensure that the data remains
+ intact when sent via 7bit transports such as SMTP.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new base64 decoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ Incrementally encodes content using the base64 encoding.
+
+
+ Base64 is an encoding often used in MIME to encode binary content such
+ as images and other types of multi-media to ensure that the data remains
+ intact when sent via 7bit transports such as SMTP.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new base64 encoder.
+
+ true if this encoder will be used to encode rfc2047 encoded-word payloads; false otherwise.
+ The maximum number of octets allowed per line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new base64 encoder.
+
+ The maximum number of octets allowed per line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ Incrementally decodes content encoded with a Uri hex encoding.
+
+
+ This is mostly meant for decoding parameter values encoded using
+ the rules specified by rfc2184 and rfc2231.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new hex decoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ Incrementally encodes content using a Uri hex encoding.
+
+
+ This is mostly meant for decoding parameter values encoded using
+ the rules specified by rfc2184 and rfc2231.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new hex encoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ An interface for incrementally decoding content.
+
+
+ An interface for incrementally decoding content.
+
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ An interface for incrementally encoding content.
+
+
+ An interface for incrementally encoding content.
+
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ A pass-through decoder implementing the interface.
+
+
+ Simply copies data as-is from the input buffer into the output buffer.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The encoding to return in the property.
+
+ Creates a new pass-through decoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Copies the input buffer into the output buffer, verbatim.
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Copies the input buffer into the output buffer, verbatim.
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ A pass-through encoder implementing the interface.
+
+
+ Simply copies data as-is from the input buffer into the output buffer.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The encoding to return in the property.
+
+ Creates a new pass-through encoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Copies the input buffer into the output buffer, verbatim.
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Copies the input buffer into the output buffer, verbatim.
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ Q-Encoding mode.
+
+
+ The encoding mode for the 'Q' encoding used in rfc2047.
+
+
+
+
+ A mode for encoding phrases, as defined by rfc822.
+
+
+
+
+ A mode for encoding text.
+
+
+
+
+ Incrementally encodes content using a variation of the quoted-printable encoding
+ that is specifically meant to be used for rfc2047 encoded-word tokens.
+
+
+ The Q-Encoding is an encoding often used in MIME to encode textual content outside
+ of the ASCII range within an rfc2047 encoded-word token in order to ensure that
+ the text remains intact when sent via 7bit transports such as SMTP.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new rfc2047 quoted-printable encoder.
+
+ The rfc2047 encoding mode.
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ Incrementally decodes content encoded with the quoted-printable encoding.
+
+
+ Quoted-Printable is an encoding often used in MIME to textual content outside
+ of the ASCII range in order to ensure that the text remains intact when sent
+ via 7bit transports such as SMTP.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new quoted-printable decoder.
+
+
+ true if this decoder will be used to decode rfc2047 encoded-word payloads; false otherwise.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new quoted-printable decoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ Incrementally encodes content using the quoted-printable encoding.
+
+
+ Quoted-Printable is an encoding often used in MIME to encode textual content
+ outside of the ASCII range in order to ensure that the text remains intact
+ when sent via 7bit transports such as SMTP.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new quoted-printable encoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ Incrementally decodes content encoded with the Unix-to-Unix encoding.
+
+
+ The UUEncoding is an encoding that predates MIME and was used to encode
+ binary content such as images and other types of multi-media to ensure
+ that the data remained intact when sent via 7bit transports such as SMTP.
+ These days, the UUEncoding has largely been deprecated in favour of
+ the base64 encoding, however, some older mail clients still use it.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new Unix-to-Unix decoder.
+
+
+ If true, decoding begins immediately rather than after finding a begin-line.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new Unix-to-Unix decoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ Incrementally encodes content using the Unix-to-Unix encoding.
+
+
+ The UUEncoding is an encoding that predates MIME and was used to encode
+ binary content such as images and other types of multi-media to ensure
+ that the data remained intact when sent via 7bit transports such as SMTP.
+ These days, the UUEncoding has largely been deprecated in favour of
+ the base64 encoding, however, some older mail clients still use it.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new Unix-to-Unix encoder.
+
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ Incrementally decodes content encoded with the yEnc encoding.
+
+
+ The yEncoding is an encoding that is most commonly used with Usenet and
+ is a binary encoding that includes a 32-bit cyclic redundancy check.
+ For more information, see www.yenc.org.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new yEnc decoder.
+
+
+ If true, decoding begins immediately rather than after finding an =ybegin line.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new yEnc decoder.
+
+
+
+
+ Gets the checksum.
+
+
+ Gets the checksum.
+
+ The checksum.
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current decoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to decode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ A pointer to the beginning of the input buffer.
+ The length of the input buffer.
+ A pointer to the beginning of the output buffer.
+
+
+
+ Decodes the specified input into the output buffer.
+
+
+ Decodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ decoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the decoder.
+
+
+ Resets the state of the decoder.
+
+
+
+
+ Incrementally encodes content using the yEnc encoding.
+
+
+ The yEncoding is an encoding that is most commonly used with Usenet and
+ is a binary encoding that includes a 32-bit cyclic redundancy check.
+ For more information, see www.yenc.org.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new yEnc encoder.
+
+ The line length to use.
+
+
+
+ Gets the checksum.
+
+
+ Gets the checksum.
+
+ The checksum.
+
+
+
+ Clone the with its current state.
+
+
+ Creates a new with exactly the same state as the current encoder.
+
+ A new with identical state.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Estimates the length of the output.
+
+
+ Estimates the number of bytes needed to encode the specified number of input bytes.
+
+ The estimated output length.
+ The input length.
+
+
+
+ Encodes the specified input into the output buffer.
+
+
+ Encodes the specified input into the output buffer.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Encodes the specified input into the output buffer, flushing any internal buffer state as well.
+
+
+ Encodes the specified input into the output buffer, flusing any internal state as well.
+ The output buffer should be large enough to hold all of the
+ encoded input. For estimating the size needed for the output buffer,
+ see .
+
+ The number of bytes written to the output buffer.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer.
+ The output buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ is not large enough to contain the encoded content.
+ Use the method to properly determine the
+ necessary length of the byte array.
+
+
+
+
+ Resets the encoder.
+
+
+ Resets the state of the encoder.
+
+
+
+
+ A bounded stream, confined to reading and writing data to a limited subset of the overall source stream.
+
+
+ Wraps an arbitrary stream, limiting I/O operations to a subset of the source stream.
+ If the is -1, then the end of the stream is unbound.
+ When a is set to parse a persistent stream, it will construct
+ s using bounded streams instead of loading the content into memory.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ If the is less than 0, then the end of the stream
+ is unbounded.
+
+ The underlying stream.
+ The offset in the base stream that will mark the start of this substream.
+ The offset in the base stream that will mark the end of this substream.
+ true to leave the baseStream open after the
+ is disposed; otherwise, false.
+
+ is null.
+
+
+ is less than zero.
+ -or-
+ is greater than or equal to zero
+ -and- is less than .
+
+
+
+
+ Gets the underlying stream.
+
+
+ All I/O is performed on the base stream.
+
+ The underlying stream.
+
+
+
+ Gets the start boundary offset of the underlying stream.
+
+
+ The start boundary is the byte offset into the
+ that marks the beginning of the substream.
+
+ The start boundary offset of the underlying stream.
+
+
+
+ Gets the end boundary offset of the underlying stream.
+
+
+ The end boundary is the byte offset into the
+ that marks the end of the substream. If the value is less than 0,
+ then the end of the stream is treated as unbound.
+
+ The end boundary offset of the underlying stream.
+
+
+
+ Checks whether or not the underlying stream will remain open after
+ the is disposed.
+
+
+ Checks whether or not the underlying stream will remain open after
+ the is disposed.
+
+ true if the underlying stream should remain open after the
+ is disposed; otherwise, false.
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ The will only support reading if the
+ supports it.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ The will only support writing if the
+ supports it.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ The will only support seeking if the
+ supports it.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not I/O operations can timeout.
+
+
+ The will only support timing out if the
+ supports it.
+
+ true if I/O operations can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ If the property is greater than or equal to 0,
+ then the length will be calculated by subtracting the
+ from the . If the end of the stream is unbound, then the
+ will be subtracted from the length of the
+ .
+
+ The length of the stream in bytes.
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ The is relative to the .
+
+ The position of the stream.
+
+ An I/O error occurred.
+
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets a value, in miliseconds, that determines how long the stream will attempt to read before timing out.
+
+
+ Gets or sets the 's read timeout.
+
+ A value, in miliseconds, that determines how long the stream will attempt to read before timing out.
+
+
+
+ Gets or sets a value, in miliseconds, that determines how long the stream will attempt to write before timing out.
+
+
+ Gets or sets the 's write timeout.
+
+ A value, in miliseconds, that determines how long the stream will attempt to write before timing out.
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reads data from the , not allowing it to
+ read beyond the .
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Writes data to the , not allowing it to
+ write beyond the .
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Seeks within the confines of the and the .
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ is not a valid .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support seeking.
+
+
+ An I/O error occurred.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Flushes the .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Updates the to be plus
+ the specified new length. If the needs to be grown
+ to allow this, then the length of the will also be
+ updated.
+
+ The desired length of the stream in bytes.
+
+ The stream has been disposed.
+
+
+ The stream does not support setting the length.
+
+
+ An I/O error occurred.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ If the property is false, then
+ the is also disposed.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ A chained stream.
+
+
+ Chains multiple streams together such that reading or writing beyond the end
+ of one stream spills over into the next stream in the chain. The idea is to
+ make it appear is if the chain of streams is all one continuous stream.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Add the specified stream to the chained stream.
+
+
+ Adds the stream to the end of the chain.
+
+ The stream.
+ true if the
+ should remain open after the is disposed;
+ otherwise, false.
+
+ is null.
+
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ The only supports reading if all of its
+ streams support it.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ The only supports writing if all of its
+ streams support it.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ The only supports seeking if all of its
+ streams support it.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not I/O operations can timeout.
+
+
+ The only supports timeouts if all of its
+ streams support them.
+
+ true if I/O operations can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ The length of a is the combined lenths of all
+ of its chained streams.
+
+ The length of the stream in bytes.
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ It is always possible to get the position of a ,
+ but setting the position is only possible if all of its streams are seekable.
+
+ The position of the stream.
+
+ An I/O error occurred.
+
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reads up to the requested number of bytes if reading is supported. If the
+ current child stream does not have enough remaining data to complete the
+ read, the read will progress into the next stream in the chain in order
+ to complete the read.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Writes the requested number of bytes if writing is supported. If the
+ current child stream does not have enough remaining space to fit the
+ complete buffer, the data will spill over into the next stream in the
+ chain in order to complete the write.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Seeks to the specified position within the stream if all child streams
+ support seeking.
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ is not a valid .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support seeking.
+
+
+ An I/O error occurred.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ If all of the child streams support writing, then the current child stream
+ will be flushed.
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Setting the length of a is not supported.
+
+ The desired length of the stream in bytes.
+
+ The stream has been disposed.
+
+
+ The stream does not support setting the length.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ A stream which filters data as it is read or written.
+
+
+ Passes data through each as the data is read or written.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a filtered stream using the specified source stream.
+
+ The underlying stream to filter.
+
+ is null.
+
+
+
+
+ Gets the underlying source stream.
+
+
+ In general, it is not a good idea to manipulate the underlying
+ source stream because most s store
+ important state about previous bytes read from or written to
+ the source stream.
+
+ The underlying source stream.
+
+
+
+ Adds the specified filter.
+
+
+ Adds the to the end of the list of filters
+ that data will pass through as data is read from or written to the
+ underlying source stream.
+
+ The filter.
+
+ is null.
+
+
+
+
+ Checks if the filtered stream contains the specified filter.
+
+
+ Determines whether or not the filtered stream contains the specified filter.
+
+ true if the specified filter exists;
+ otherwise false.
+ The filter.
+
+ is null.
+
+
+
+
+ Remove the specified filter.
+
+
+ Removes the specified filter from the list if it exists.
+
+ true if the filter was removed; otherwise false.
+ The filter.
+
+ is null.
+
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ The will only support reading if the
+ supports it.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ The will only support writing if the
+ supports it.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ Seeking is not supported by the .
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not I/O operations can timeout.
+
+
+ The will only support timing out if the
+ supports it.
+
+ true if I/O operations can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ Getting the length of a is not supported.
+
+ The length of the stream in bytes.
+
+ The stream does not support seeking.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ Getting and setting the position of a is not supported.
+
+ The position of the stream.
+
+ The stream does not support seeking.
+
+
+
+
+ Gets or sets a value, in miliseconds, that determines how long the stream will attempt to read before timing out.
+
+
+ Gets or sets the read timeout on the stream.
+
+ A value, in miliseconds, that determines how long the stream will attempt to read before timing out.
+
+
+
+ Gets or sets a value, in miliseconds, that determines how long the stream will attempt to write before timing out.
+
+
+ Gets or sets the write timeout on the stream.
+
+ A value, in miliseconds, that determines how long the stream will attempt to write before timing out.
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reads up to the requested number of bytes, passing the data read from the stream
+ through each of the filters before finally copying the result into the provided buffer.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+ The cancellation token.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reads up to the requested number of bytes, passing the data read from the stream
+ through each of the filters before finally copying the result into the provided buffer.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Filters the provided buffer through each of the filters before finally writing
+ the result to the underlying stream.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+ The cancellation token.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Filters the provided buffer through each of the filters before finally writing
+ the result to the underlying stream.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Seeking is not supported by the .
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ The stream does not support seeking.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Flushes the state of all filters, writing any output to the underlying
+ stream and then calling on the .
+
+ The cancellation token.
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Flushes the state of all filters, writing any output to the underlying
+ stream and then calling on the .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Setting the length of a is not supported.
+
+ The desired length of the stream in bytes.
+
+ The stream has been disposed.
+
+
+ The stream does not support setting the length.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ An interface allowing for a cancellable stream reading operation.
+
+
+ This interface is meant to extend the functionality of a ,
+ allowing the to have much finer-grained canellability.
+ When a custom stream implementation also implements this interface,
+ the will opt to use this interface
+ instead of the normal
+ API to read data from the stream.
+ This is really useful when parsing a message or other MIME entity
+ directly from a network-based stream.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ When a custom stream implementation also implements this interface,
+ the will opt to use this interface
+ instead of the normal
+ API to read data from the stream.
+ This is really useful when parsing a message or other MIME entity
+ directly from a network-based stream.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+ The cancellation token.
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ When a custom stream implementation also implements this interface,
+ writing a or
+ to the custom stream will opt to use this interface
+ instead of the normal
+ API to write data to the stream.
+ This is really useful when writing a message or other MIME entity
+ directly to a network-based stream.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+ The cancellation token
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+ The cancellation token.
+
+
+
+ A stream useful for measuring the amount of data written.
+
+
+ A keeps track of the number of bytes
+ that have been written to it. This is useful, for example, when you
+ need to know how large a is without
+ actually writing it to disk or into a memory buffer.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ A is not readable.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ A is always writable.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ A is always seekable.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not reading and writing to the stream can timeout.
+
+
+ Writing to a cannot timeout.
+
+ true if reading and writing to the stream can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ The length of a indicates the
+ number of bytes that have been written to it.
+
+ The length of the stream in bytes.
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ Since it is possible to seek within a ,
+ it is possible that the position will not always be identical to the
+ length of the stream, but typically it will be.
+
+ The position of the stream.
+
+ An I/O error occurred.
+
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reading from a is not supported.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ The stream has been disposed.
+
+
+ The stream does not support reading.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Increments the property by the number of bytes written.
+ If the updated position is greater than the current length of the stream, then
+ the property will be updated to be identical to the
+ position.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Updates the within the stream.
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ is not a valid .
+
+
+ The stream has been disposed.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ Since a does not actually do anything other than
+ count bytes, this method is a no-op.
+
+
+ The stream has been disposed.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Sets the to the specified value and updates
+ to the specified value if (and only if)
+ the current position is greater than the new length value.
+
+ The desired length of the stream in bytes.
+
+ is out of range.
+
+
+ The stream has been disposed.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ An efficient memory stream implementation that sacrifices the ability to
+ get access to the internal byte buffer in order to drastically improve
+ performance.
+
+
+ Instead of resizing an internal byte array, the
+ chains blocks of non-contiguous memory. This helps improve performance by avoiding
+ unneeded copying of data from the old array to the newly allocated array as well
+ as the zeroing of the newly allocated array.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with an initial memory block
+ of 2048 bytes.
+
+
+
+
+ Copies the memory stream into a byte array.
+
+
+ Copies all of the stream data into a newly allocated byte array.
+
+ The array.
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ The is always readable.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ The is always writable.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ The is always seekable.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Checks whether or not reading and writing to the stream can timeout.
+
+
+ The does not support timing out.
+
+ true if reading and writing to the stream can timeout; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ Gets the length of the stream, in bytes.
+
+ The length of the stream, in bytes.
+
+ The stream has been disposed.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ Gets or sets the current position within the stream.
+
+ The position of the stream.
+
+ An I/O error occurred.
+
+
+ The stream does not support seeking.
+
+
+ The stream has been disposed.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ Writes the entire buffer to the stream and advances the current position
+ within the stream by the number of bytes written, adding memory blocks as
+ needed in order to contain the newly written bytes.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ The stream does not support writing.
+
+
+ An I/O error occurred.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ Sets the position within the current stream.
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ is not a valid .
+
+
+ The stream has been disposed.
+
+
+ An I/O error occurred.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ This method does not do anything.
+
+
+ The stream has been disposed.
+
+
+
+
+ Sets the length of the stream.
+
+
+ Sets the length of the stream.
+
+ The desired length of the stream in bytes.
+
+ is out of range.
+
+
+ The stream has been disposed.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ A filter that armors lines beginning with "From " by encoding the 'F' with the
+ Quoted-Printable encoding.
+
+
+ From-armoring is a workaround to prevent receiving clients (or servers)
+ that uses the mbox file format for local storage from munging the line
+ by prepending a ">", as is typical with the mbox format.
+ This armoring technique ensures that the receiving client will still
+ be able to verify S/MIME signatures.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A filter that can be used to determine the most efficient Content-Transfer-Encoding.
+
+
+ Keeps track of the content that gets passed through the filter in order to
+ determine the most efficient to use.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the best encoding given the specified constraints.
+
+
+ Gets the best encoding given the specified constraints.
+
+ The best encoding.
+ The encoding constraint.
+ The maximum allowable line length (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Filters the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Filters the specified input, flushing all internally buffered data to the output.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A charset filter for incrementally converting text streams from
+ one charset encoding to another.
+
+
+ Incrementally converts text from one charset encoding to another.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new to convert text from the specified
+ source encoding into the target charset encoding.
+
+ Source encoding name.
+ Target encoding name.
+
+ is null.
+ -or-
+ is null.
+
+
+ The is not supported by the system.
+ -or-
+ The is not supported by the system.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new to convert text from the specified
+ source encoding into the target charset encoding.
+
+ Source code page.
+ Target code page.
+
+ is less than zero or greater than 65535.
+ -or-
+ is less than zero or greater than 65535.
+
+
+ The is not supported by the system.
+ -or-
+ The is not supported by the system.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new to convert text from the specified
+ source encoding into the target charset encoding.
+
+ Source encoding.
+ Target encoding.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets the source encoding.
+
+
+ Gets the source encoding.
+
+ The source encoding.
+
+
+
+ Gets the target encoding.
+
+
+ Gets the target encoding.
+
+ The target encoding.
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A filter for decoding MIME content.
+
+
+ Uses a to incrementally decode data.
+
+
+
+
+ Gets the decoder used by this filter.
+
+
+ Gets the decoder used by this filter.
+
+ The decoder.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the decoder supports.
+
+ The encoding.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new using the specified decoder.
+
+ A specific decoder for the filter to use.
+
+ is null.
+
+
+
+
+ Create a filter that will decode the specified encoding.
+
+
+ Creates a new for the specified encoding.
+
+ A new decoder filter.
+ The encoding to create a filter for.
+
+
+
+ Create a filter that will decode the specified encoding.
+
+
+ Creates a new for the specified encoding.
+
+ A new decoder filter.
+ The name of the encoding to create a filter for.
+
+ is null.
+
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A filter that will convert from Windows/DOS line endings to Unix line endings.
+
+
+ Converts from Windows/DOS line endings to Unix line endings.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ Ensure that the stream ends with a new line.
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A filter for encoding MIME content.
+
+
+ Uses a to incrementally encode data.
+
+
+
+
+ Gets the encoder used by this filter.
+
+
+ Gets the encoder used by this filter.
+
+ The encoder.
+
+
+
+ Gets the encoding.
+
+
+ Gets the encoding that the encoder supports.
+
+ The encoding.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new using the specified encoder.
+
+ A specific encoder for the filter to use.
+
+
+
+ Create a filter that will encode using specified encoding.
+
+
+ Creates a new for the specified encoding.
+
+ A new encoder filter.
+ The encoding to create a filter for.
+
+
+
+ Create a filter that will encode using specified encoding.
+
+
+ Creates a new for the specified encoding.
+
+ A new encoder filter.
+ The name of the encoding to create a filter for.
+
+ is null.
+
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ An interface for incrementally filtering data.
+
+
+ An interface for incrementally filtering data.
+
+
+
+
+ Filters the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+
+
+ Filters the specified input, flushing all internally buffered data to the output.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A base implementation for MIME filters.
+
+
+ A base implementation for MIME filters.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the output buffer.
+
+
+ Gets the output buffer.
+
+ The output buffer.
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Filters the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Filters the specified input, flushing all internally buffered data to the output.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ Saves the remaining input for the next round of processing.
+
+
+ Saves the remaining input for the next round of processing.
+
+ The input buffer.
+ The starting index of the buffer to save.
+ The length of the buffer to save, starting at .
+
+
+
+ Ensures that the output buffer is greater than or equal to the specified size.
+
+
+ Ensures that the output buffer is greater than or equal to the specified size.
+
+ The minimum size needed.
+ If set to true, the current output should be preserved.
+
+
+
+ A filter that simply passes data through without any processing.
+
+
+ Passes data through without any processing.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Filters the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+
+
+ Filters the specified input, flushing all internally buffered data to the output.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes of the input to filter.
+ The starting index of the output in the returned buffer.
+ The length of the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A filter for stripping trailing whitespace from lines in a textual stream.
+
+
+ Strips trailing whitespace from lines in a textual stream.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A filter that will convert from Unix line endings to Windows/DOS line endings.
+
+
+ Converts from Unix line endings to Windows/DOS line endings.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ Ensure that the stream ends with a new line.
+
+
+
+ Filter the specified input.
+
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ The length of the input buffer, starting at .
+ The output index.
+ The output length.
+ If set to true, all internally buffered data should be flushed to the output buffer.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A flowed text to HTML converter.
+
+
+ Used to convert flowed text (as described in rfc3676) into HTML.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new flowed text to HTML converter.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set whether the trailing space on a wrapped line should be deleted.
+
+
+ Gets or sets whether the trailing space on a wrapped line should be deleted.
+ The flowed text format defines a Content-Type parameter called "delsp" which can
+ have a value of "yes" or "no". If the parameter exists and the value is "yes", then
+ should be set to true, otherwise
+ should be set to false.
+
+
+
+
+ true if the trailing space on a wrapped line should be deleted; otherwise, false.
+
+
+
+ Get or set the text that will be appended to the end of the output.
+
+
+ Gets or sets the text that will be appended to the end of the output.
+ The footer must be set before conversion begins.
+
+ The footer.
+
+
+
+ Get or set the footer format.
+
+
+ Gets or sets the footer format.
+
+ The footer format.
+
+
+
+ Get or set text that will be prepended to the beginning of the output.
+
+
+ Gets or sets the text that will be prepended to the beginning of the output.
+ The header must be set before conversion begins.
+
+ The header.
+
+
+
+ Get or set the header format.
+
+
+ Gets or sets the header format.
+
+ The header format.
+
+
+
+ Get or set the method to use for custom
+ filtering of HTML tags and content.
+
+
+ Get or set the method to use for custom
+ filtering of HTML tags and content.
+
+ The html tag callback.
+
+
+
+ Get or set whether or not the converter should only output an HTML fragment.
+
+
+ Gets or sets whether or not the converter should only output an HTML fragment.
+
+ true if the converter should only output an HTML fragment; otherwise, false.
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ A flowed text to text converter.
+
+
+ Unwraps the flowed text format described in rfc3676.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new flowed text to text converter.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set whether the trailing space on a wrapped line should be deleted.
+
+
+ Gets or sets whether the trailing space on a wrapped line should be deleted.
+ The flowed text format defines a Content-Type parameter called "delsp" which can
+ have a value of "yes" or "no". If the parameter exists and the value is "yes", then
+ should be set to true, otherwise
+ should be set to false.
+
+ true if the trailing space on a wrapped line should be deleted; otherwise, false.
+
+
+
+ Get or set the text that will be appended to the end of the output.
+
+
+ Gets or sets the text that will be appended to the end of the output.
+ The footer must be set before conversion begins.
+
+ The footer.
+
+
+
+ Get or set text that will be prepended to the beginning of the output.
+
+
+ Gets or sets the text that will be prepended to the beginning of the output.
+ The header must be set before conversion begins.
+
+ The header.
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ An enumeration of possible header and footer formats.
+
+
+ An enumeration of possible header and footer formats.
+
+
+
+
+ The header or footer contains plain text.
+
+
+
+
+ The header or footer contains properly formatted HTML.
+
+
+
+
+ An HTML attribute.
+
+
+ An HTML attribute.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new HTML attribute with the given id and value.
+
+ The attribute identifier.
+ The attribute value.
+
+ is not a valid value.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new HTML attribute with the given name and value.
+
+ The attribute name.
+ The attribute value.
+
+ is null.
+
+
+
+
+ Get the HTML attribute identifier.
+
+
+ Gets the HTML attribute identifier.
+
+
+
+
+ The attribute identifier.
+
+
+
+ Get the name of the attribute.
+
+
+ Gets the name of the attribute.
+
+
+
+
+ The name of the attribute.
+
+
+
+ Get the value of the attribute.
+
+
+ Gets the value of the attribute.
+
+
+
+
+ The value of the attribute.
+
+
+
+ A readonly collection of HTML attributes.
+
+
+ A readonly collection of HTML attributes.
+
+
+
+
+ An empty attribute collection.
+
+
+ An empty attribute collection.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ A collection of attributes.
+
+
+
+ Get the number of attributes in the collection.
+
+
+ Gets the number of attributes in the collection.
+
+ The number of attributes in the collection.
+
+
+
+ Get the at the specified index.
+
+
+ Gets the at the specified index.
+
+ The HTML attribute at the specified index.
+ The index.
+
+ is out of range.
+
+
+
+
+ Gets an enumerator for the attribute collection.
+
+
+ Gets an enumerator for the attribute collection.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the attribute collection.
+
+
+ Gets an enumerator for the attribute collection.
+
+ The enumerator.
+
+
+
+ HTML attribute identifiers.
+
+
+ HTML attribute identifiers.
+
+
+
+
+ An unknown HTML attribute identifier.
+
+
+
+
+ The "abbr" attribute.
+
+
+
+
+ The "accept" attribute.
+
+
+
+
+ The "accept-charset" attribute.
+
+
+
+
+ The "accesskey" attribute.
+
+
+
+
+ The "action" attribute.
+
+
+
+
+ The "align" attribute.
+
+
+
+
+ The "alink" attribute.
+
+
+
+
+ The "alt" attribute.
+
+
+
+
+ The "archive" attribute.
+
+
+
+
+ The "axis" attribute.
+
+
+
+
+ The "background" attribute.
+
+
+
+
+ The "bgcolor" attribute.
+
+
+
+
+ The "border" attribute.
+
+
+
+
+ The "cellpadding" attribute.
+
+
+
+
+ The "cellspacing" attribute.
+
+
+
+
+ The "char" attribute.
+
+
+
+
+ The "charoff" attribute.
+
+
+
+
+ The "charset" attribute.
+
+
+
+
+ The "checked" attribute.
+
+
+
+
+ The "cite" attribute.
+
+
+
+
+ The "class" attribute.
+
+
+
+
+ The "classid" attribute.
+
+
+
+
+ The "clear" attribute.
+
+
+
+
+ The "code" attribute.
+
+
+
+
+ The "codebase" attribute.
+
+
+
+
+ The "codetype" attribute.
+
+
+
+
+ The "color" attribute.
+
+
+
+
+ The "cols" attribute.
+
+
+
+
+ The "colspan" attribute.
+
+
+
+
+ The "compact" attribute.
+
+
+
+
+ The "content" attribute.
+
+
+
+
+ The "coords" attribute.
+
+
+
+
+ The "data" attribute.
+
+
+
+
+ The "datetime" attribute.
+
+
+
+
+ The "declare" attribute.
+
+
+
+
+ The "defer" attribute.
+
+
+
+
+ The "dir" attribute.
+
+
+
+
+ The "disabled" attribute.
+
+
+
+
+ The "dynsrc" attribute.
+
+
+
+
+ The "enctype" attribute.
+
+
+
+
+ The "face" attribute.
+
+
+
+
+ The "for" attribute.
+
+
+
+
+ The "frame" attribute.
+
+
+
+
+ The "frameborder" attribute.
+
+
+
+
+ The "headers" attribute.
+
+
+
+
+ The "height" attribute.
+
+
+
+
+ The "href" attribute.
+
+
+
+
+ The "hreflang" attribute.
+
+
+
+
+ The "hspace" attribute.
+
+
+
+
+ The "http-equiv" attribute.
+
+
+
+
+ The "id" attribute.
+
+
+
+
+ The "ismap" attribute.
+
+
+
+
+ The "label" attribute.
+
+
+
+
+ The "lang" attribute.
+
+
+
+
+ The "language" attribute.
+
+
+
+
+ The "leftmargin" attribute.
+
+
+
+
+ The "link" attribute.
+
+
+
+
+ The "longdesc" attribute.
+
+
+
+
+ The "lowsrc" attribute.
+
+
+
+
+ The "marginheight" attribute.
+
+
+
+
+ The "marginwidth" attribute.
+
+
+
+
+ The "maxlength" attribute.
+
+
+
+
+ The "media" attribute.
+
+
+
+
+ The "method" attribute.
+
+
+
+
+ The "multiple" attribute.
+
+
+
+
+ The "name" attribute.
+
+
+
+
+ The "nohref" attribute.
+
+
+
+
+ The "noresize" attribute.
+
+
+
+
+ The "noshade" attribute.
+
+
+
+
+ The "nowrap" attribute.
+
+
+
+
+ The "object" attribute.
+
+
+
+
+ The "profile" attribute.
+
+
+
+
+ The "prompt" attribute.
+
+
+
+
+ The "readonly" attribute.
+
+
+
+
+ The "rel" attribute.
+
+
+
+
+ The "rev" attribute.
+
+
+
+
+ The "rows" attribute.
+
+
+
+
+ The "rowspan" attribute.
+
+
+
+
+ The "rules" attribute.
+
+
+
+
+ The "scheme" attribute.
+
+
+
+
+ The "scope" attribute.
+
+
+
+
+ The "scrolling" attribute.
+
+
+
+
+ The "selected" attribute.
+
+
+
+
+ The "shape" attribute.
+
+
+
+
+ The "size" attribute.
+
+
+
+
+ The "span" attribute.
+
+
+
+
+ The "src" attribute.
+
+
+
+
+ The "standby" attribute.
+
+
+
+
+ The "start" attribute.
+
+
+
+
+ The "style" attribute.
+
+
+
+
+ The "summary" attribute.
+
+
+
+
+ The "tabindex" attribute.
+
+
+
+
+ The "target" attribute.
+
+
+
+
+ The "text" attribute.
+
+
+
+
+ The "title" attribute.
+
+
+
+
+ The "topmargin" attribute.
+
+
+
+
+ The "type" attribute.
+
+
+
+
+ The "usemap" attribute.
+
+
+
+
+ The "valign" attribute.
+
+
+
+
+ The "value" attribute.
+
+
+
+
+ The "valuetype" attribute.
+
+
+
+
+ The "version" attribute.
+
+
+
+
+ The "vlink" attribute.
+
+
+
+
+ The "vspace" attribute.
+
+
+
+
+ The "width" attribute.
+
+
+
+
+ The "xmlns" attribute.
+
+
+
+
+ extension methods.
+
+
+ extension methods.
+
+
+
+
+ Converts the enum value into the equivalent attribute name.
+
+
+ Converts the enum value into the equivalent attribute name.
+
+ The attribute name.
+ The enum value.
+
+
+
+ Converts the attribute name into the equivalent attribute id.
+
+
+ Converts the attribute name into the equivalent attribute id.
+
+ The attribute id.
+ The attribute name.
+
+
+
+ An HTML entity decoder.
+
+
+ An HTML entity decoder.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Push the specified character into the HTML entity decoder.
+
+
+ Pushes the specified character into the HTML entity decoder.
+ The first character pushed MUST be the '&' character.
+
+ true if the character was accepted; otherwise, false.
+ The character.
+
+ is the first character being pushed and was not the '&' character.
+
+
+
+
+ Get the decoded entity value.
+
+
+ Gets the decoded entity value.
+
+ The value.
+
+
+
+ Reset the entity decoder.
+
+
+ Resets the entity decoder.
+
+
+
+
+ An HTML namespace.
+
+
+ An HTML namespace.
+
+
+
+
+ The namespace is "http://www.w3.org/1999/xhtml".
+
+
+
+
+ The namespace is "http://www.w3.org/1998/Math/MathML".
+
+
+
+
+ The namespace is "http://www.w3.org/2000/svg".
+
+
+
+
+ The namespace is "http://www.w3.org/1999/xlink".
+
+
+
+
+ The namespace is "http://www.w3.org/XML/1998/namespace".
+
+
+
+
+ The namespace is "http://www.w3.org/2000/xmlns/".
+
+
+
+
+ extension methods.
+
+
+ extension methods.
+
+
+
+
+ Converts the enum value into the equivalent namespace url.
+
+
+ Converts the enum value into the equivalent namespace url.
+
+ The tag name.
+ The enum value.
+
+
+
+ Converts the tag name into the equivalent tag id.
+
+
+ Converts the tag name into the equivalent tag id.
+
+ The tag id.
+ The namespace.
+
+
+
+ An HTML tag callback delegate.
+
+
+ The delegate is called when a converter
+ is ready to write a new HTML tag, allowing developers to customize
+ whether the tag gets written at all, which attributes get written, etc.
+
+
+
+
+ The HTML tag context.
+ The HTML writer.
+
+
+
+ An HTML tag context.
+
+
+ An HTML tag context used with the delegate.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The HTML tag identifier.
+
+ is invalid.
+
+
+
+
+ Get the HTML tag attributes.
+
+
+ Gets the HTML tag attributes.
+
+
+
+
+ The attributes.
+
+
+
+ Get or set whether or not the end tag should be deleted.
+
+
+ Gets or sets whether or not the end tag should be deleted.
+
+ true if the end tag should be deleted; otherwise, false.
+
+
+
+ Get or set whether or not the tag should be deleted.
+
+
+ Gets or sets whether or not the tag should be deleted.
+
+ true if the tag should be deleted; otherwise, false.
+
+
+
+ Get or set whether or not the should be invoked for the end tag.
+
+
+ Gets or sets whether or not the should be invoked for the end tag.
+
+ true if the callback should be invoked for end tag; otherwise, false.
+
+
+
+ Get whether or not the tag is an empty element.
+
+
+ Gets whether or not the tag is an empty element.
+
+ true if the tag is an empty element; otherwise, false.
+
+
+
+ Get whether or not the tag is an end tag.
+
+
+ Gets whether or not the tag is an end tag.
+
+
+
+
+ true if the tag is an end tag; otherwise, false.
+
+
+
+ Get or set whether or not the inner content of the tag should be suppressed.
+
+
+ Gets or sets whether or not the inner content of the tag should be suppressed.
+
+ true if the inner content should be suppressed; otherwise, false.
+
+
+
+ Get the HTML tag identifier.
+
+
+ Gets the HTML tag identifier.
+
+
+
+
+ The HTML tag identifier.
+
+
+
+ Get the HTML tag name.
+
+
+ Gets the HTML tag name.
+
+
+
+
+ The HTML tag name.
+
+
+
+ Write the HTML tag.
+
+
+ Writes the HTML tag to the given .
+
+ The HTML writer.
+
+ is null.
+
+
+
+
+ Write the HTML tag.
+
+
+ Writes the HTML tag to the given .
+
+
+
+
+ The HTML writer.
+ true if the should also be written; otherwise, false.
+
+ is null.
+
+
+
+
+ HTML tag identifiers.
+
+
+ HTML tag identifiers.
+
+
+
+
+ An unknown HTML tag identifier.
+
+
+
+
+ The HTML <a> tag.
+
+
+
+
+ The HTML <abbr> tag.
+
+
+
+
+ The HTML <acronym> tag.
+
+
+
+
+ The HTML <address> tag.
+
+
+
+
+ The HTML <applet> tag.
+
+
+
+
+ The HTML <area> tag.
+
+
+
+
+ The HTML <article> tag.
+
+
+
+
+ The HTML <aside> tag.
+
+
+
+
+ The HTML <audio> tag.
+
+
+
+
+ The HTML <b> tag.
+
+
+
+
+ The HTML <base> tag.
+
+
+
+
+ The HTML <basefont> tag.
+
+
+
+
+ The HTML <bdi> tag.
+
+
+
+
+ The HTML <bdo> tag.
+
+
+
+
+ The HTML <bgsound> tag.
+
+
+
+
+ The HTML <big> tag.
+
+
+
+
+ The HTML <blink> tag.
+
+
+
+
+ The HTML <blockquote> tag.
+
+
+
+
+ The HTML <body> tag.
+
+
+
+
+ The HTML <br> tag.
+
+
+
+
+ The HTML <button> tag.
+
+
+
+
+ The HTML <canvas> tag.
+
+
+
+
+ The HTML <caption> tag.
+
+
+
+
+ The HTML <center> tag.
+
+
+
+
+ The HTML <cite> tag.
+
+
+
+
+ The HTML <code> tag.
+
+
+
+
+ The HTML <col> tag.
+
+
+
+
+ The HTML <colgroup> tag.
+
+
+
+
+ The HTML <command> tag.
+
+
+
+
+ The HTML comment tag.
+
+
+
+
+ The HTML <datalist> tag.
+
+
+
+
+ The HTML <dd> tag.
+
+
+
+
+ The HTML <del> tag.
+
+
+
+
+ The HTML <details> tag.
+
+
+
+
+ The HTML <dfn> tag.
+
+
+
+
+ The HTML <dialog> tag.
+
+
+
+
+ The HTML <dir> tag.
+
+
+
+
+ The HTML <div> tag.
+
+
+
+
+ The HTML <dl> tag.
+
+
+
+
+ The HTML <dt> tag.
+
+
+
+
+ The HTML <em> tag.
+
+
+
+
+ The HTML <embed> tag.
+
+
+
+
+ The HTML <fieldset> tag.
+
+
+
+
+ The HTML <figcaption> tag.
+
+
+
+
+ The HTML <figure> tag.
+
+
+
+
+ The HTML <font> tag.
+
+
+
+
+ The HTML <footer> tag.
+
+
+
+
+ The HTML <form> tag.
+
+
+
+
+ The HTML <frame> tag.
+
+
+
+
+ The HTML <frameset> tag.
+
+
+
+
+ The HTML <h1> tag.
+
+
+
+
+ The HTML <h2> tag.
+
+
+
+
+ The HTML <h3> tag.
+
+
+
+
+ The HTML <h4> tag.
+
+
+
+
+ The HTML <h5> tag.
+
+
+
+
+ The HTML <h6> tag.
+
+
+
+
+ The HTML <head> tag.
+
+
+
+
+ The HTML <header> tag.
+
+
+
+
+ The HTML <hr> tag.
+
+
+
+
+ The HTML <html> tag.
+
+
+
+
+ The HTML <i> tag.
+
+
+
+
+ The HTML <iframe> tag.
+
+
+
+
+ The HTML <image> tag.
+
+
+
+
+ The HTML <input> tag.
+
+
+
+
+ The HTML <ins> tag.
+
+
+
+
+ The HTML <isindex> tag.
+
+
+
+
+ The HTML <kbd> tag.
+
+
+
+
+ The HTML <keygen> tag.
+
+
+
+
+ The HTML <label> tag.
+
+
+
+
+ The HTML <legend> tag.
+
+
+
+
+ The HTML <li> tag.
+
+
+
+
+ The HTML <link> tag.
+
+
+
+
+ The HTML <listing> tag.
+
+
+
+
+ The HTML <main> tag.
+
+
+
+
+ The HTML <map> tag.
+
+
+
+
+ The HTML <mark> tag.
+
+
+
+
+ The HTML <marquee> tag.
+
+
+
+
+ The HTML <menu> tag.
+
+
+
+
+ The HTML <menuitem> tag.
+
+
+
+
+ The HTML <meta> tag.
+
+
+
+
+ The HTML <meter> tag.
+
+
+
+
+ The HTML <nav> tag.
+
+
+
+
+ The HTML <nextid> tag.
+
+
+
+
+ The HTML <nobr> tag.
+
+
+
+
+ The HTML <noembed> tag.
+
+
+
+
+ The HTML <noframes> tag.
+
+
+
+
+ The HTML <noscript> tag.
+
+
+
+
+ The HTML <object> tag.
+
+
+
+
+ The HTML <ol> tag.
+
+
+
+
+ The HTML <optgroup> tag.
+
+
+
+
+ The HTML <option> tag.
+
+
+
+
+ The HTML <output> tag.
+
+
+
+
+ The HTML <p> tag.
+
+
+
+
+ The HTML <param> tag.
+
+
+
+
+ The HTML <plaintext> tag.
+
+
+
+
+ The HTML <pre> tag.
+
+
+
+
+ The HTML <progress> tag.
+
+
+
+
+ The HTML <q> tag.
+
+
+
+
+ The HTML <rp> tag.
+
+
+
+
+ The HTML <rt> tag.
+
+
+
+
+ The HTML <ruby> tag.
+
+
+
+
+ The HTML <s> tag.
+
+
+
+
+ The HTML <samp> tag.
+
+
+
+
+ The HTML <script> tag.
+
+
+
+
+ The HTML <section> tag.
+
+
+
+
+ The HTML <select> tag.
+
+
+
+
+ The HTML <small> tag.
+
+
+
+
+ The HTML <source> tag.
+
+
+
+
+ The HTML <span> tag.
+
+
+
+
+ The HTML <strike> tag.
+
+
+
+
+ The HTML <strong> tag.
+
+
+
+
+ The HTML <style> tag.
+
+
+
+
+ The HTML <sub> tag.
+
+
+
+
+ The HTML <summary> tag.
+
+
+
+
+ The HTML <sup> tag.
+
+
+
+
+ The HTML <table> tag.
+
+
+
+
+ The HTML <tbody> tag.
+
+
+
+
+ The HTML <td> tag.
+
+
+
+
+ The HTML <textarea> tag.
+
+
+
+
+ The HTML <tfoot> tag.
+
+
+
+
+ The HTML <th> tag.
+
+
+
+
+ The HTML <thread> tag.
+
+
+
+
+ The HTML <time> tag.
+
+
+
+
+ The HTML <title> tag.
+
+
+
+
+ The HTML <tr> tag.
+
+
+
+
+ The HTML <track> tag.
+
+
+
+
+ The HTML <tt> tag.
+
+
+
+
+ The HTML <u> tag.
+
+
+
+
+ The HTML <ul> tag.
+
+
+
+
+ The HTML <var> tag.
+
+
+
+
+ The HTML <video> tag.
+
+
+
+
+ The HTML <wbr> tag.
+
+
+
+
+ The HTML <xml> tag.
+
+
+
+
+ The HTML <xmp> tag.
+
+
+
+
+ extension methods.
+
+
+ extension methods.
+
+
+
+
+ Converts the enum value into the equivalent tag name.
+
+
+ Converts the enum value into the equivalent tag name.
+
+ The tag name.
+ The enum value.
+
+
+
+ Converts the tag name into the equivalent tag id.
+
+
+ Converts the tag name into the equivalent tag id.
+
+ The tag id.
+ The tag name.
+
+
+
+ Determines whether or not the HTML tag is an empty element.
+
+
+ Determines whether or not the HTML tag is an empty element.
+
+ true if the tag is an empty element; otherwise, false.
+ Identifier.
+
+
+
+ Determines whether or not the HTML tag is a formatting element.
+
+
+ Determines whether or not the HTML tag is a formatting element.
+
+ true if the HTML tag is a formatting element; otherwise, false.
+ The HTML tag identifier.
+
+
+
+ An HTML to HTML converter.
+
+
+ Used to convert HTML into HTML.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new HTML to HTML converter.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set whether or not executable scripts should be stripped from the output.
+
+
+ Gets or sets whether or not executable scripts should be stripped from the output.
+
+ true if executable scripts should be filtered; otherwise, false.
+
+
+
+ Get or set the text that will be appended to the end of the output.
+
+
+ Gets or sets the text that will be appended to the end of the output.
+ The footer must be set before conversion begins.
+
+ The footer.
+
+
+
+ Get or set the footer format.
+
+
+ Gets or sets the footer format.
+
+ The footer format.
+
+
+
+ Get or set text that will be prepended to the beginning of the output.
+
+
+ Gets or sets the text that will be prepended to the beginning of the output.
+ The header must be set before conversion begins.
+
+ The header.
+
+
+
+ Get or set the header format.
+
+
+ Gets or sets the header format.
+
+ The header format.
+
+
+
+ Get or set the method to use for custom
+ filtering of HTML tags and content.
+
+
+ Get or set the method to use for custom
+ filtering of HTML tags and content.
+
+ The html tag callback.
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ An abstract HTML token class.
+
+
+ An abstract HTML token class.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The kind of token.
+
+
+
+ Get the kind of HTML token that this object represents.
+
+
+ Gets the kind of HTML token that this object represents.
+
+ The kind of token.
+
+
+
+ Write the HTML token to a .
+
+
+ Writes the HTML token to a .
+
+ The output.
+
+ is null.
+
+
+
+
+ Returns a that represents the current .
+
+
+ Returns a that represents the current .
+
+ A that represents the current .
+
+
+
+ An HTML comment token.
+
+
+ An HTML comment token.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The comment text.
+ true if the comment is bogus; otherwise, false.
+
+ is null.
+
+
+
+
+ Get the comment.
+
+
+ Gets the comment.
+
+ The comment.
+
+
+
+ Get whether or not the comment is a bogus comment.
+
+
+ Gets whether or not the comment is a bogus comment.
+
+ true if the comment is bogus; otherwise, false.
+
+
+
+ Write the HTML comment to a .
+
+
+ Writes the HTML comment to a .
+
+ The output.
+
+ is null.
+
+
+
+
+ An HTML token constisting of character data.
+
+
+ An HTML token consisting of character data.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The kind of character data.
+ The character data.
+
+ is not a valid .
+
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The character data.
+
+ is null.
+
+
+
+
+ Get the character data.
+
+
+ Gets the character data.
+
+ The character data.
+
+
+
+ Write the HTML character data to a .
+
+
+ Writes the HTML character data to a ,
+ encoding it if it isn't already encoded.
+
+ The output.
+
+ is null.
+
+
+
+
+ An HTML token constisting of [CDATA[.
+
+
+ An HTML token consisting of [CDATA[.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The character data.
+
+ is null.
+
+
+
+
+ Write the HTML character data to a .
+
+
+ Writes the HTML character data to a ,
+ encoding it if it isn't already encoded.
+
+ The output.
+
+ is null.
+
+
+
+
+ An HTML token constisting of script data.
+
+
+ An HTML token consisting of script data.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The script data.
+
+ is null.
+
+
+
+
+ Write the HTML script data to a .
+
+
+ Writes the HTML script data to a ,
+ encoding it if it isn't already encoded.
+
+ The output.
+
+ is null.
+
+
+
+
+ An HTML tag token.
+
+
+ An HTML tag token.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The name of the tag.
+ The attributes.
+ true if the tag is an empty element; otherwise, false.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The name of the tag.
+ true if the tag is an end tag; otherwise, false.
+
+ is null.
+
+
+
+
+ Get the attributes.
+
+
+ Gets the attributes.
+
+ The attributes.
+
+
+
+ Get the HTML tag identifier.
+
+
+ Gets the HTML tag identifier.
+
+ The HTML tag identifier.
+
+
+
+ Get whether or not the tag is an empty element.
+
+
+ Gets whether or not the tag is an empty element.
+
+ true if the tag is an empty element; otherwise, false.
+
+
+
+ Get whether or not the tag is an end tag.
+
+
+ Gets whether or not the tag is an end tag.
+
+ true if the tag is an end tag; otherwise, false.
+
+
+
+ Get the name of the tag.
+
+
+ Gets the name of the tag.
+
+ The name.
+
+
+
+ Write the HTML tag to a .
+
+
+ Writes the HTML tag to a .
+
+ The output.
+
+ is null.
+
+
+
+
+ An HTML DOCTYPE token.
+
+
+ An HTML DOCTYPE token.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Get whether or not quirks-mode should be forced.
+
+
+ Gets whether or not quirks-mode should be forced.
+
+ true if quirks-mode should be forced; otherwise, false.
+
+
+
+ Get or set the DOCTYPE name.
+
+
+ Gets or sets the DOCTYPE name.
+
+ The name.
+
+
+
+ Get or set the public identifier.
+
+
+ Gets or sets the public identifier.
+
+ The public identifier.
+
+
+
+ Get the public keyword that was used.
+
+
+ Gets the public keyword that was used.
+
+ The public keyword or null if it wasn't used.
+
+
+
+ Get or set the system identifier.
+
+
+ Gets or sets the system identifier.
+
+ The system identifier.
+
+
+
+ Get the system keyword that was used.
+
+
+ Gets the system keyword that was used.
+
+ The system keyword or null if it wasn't used.
+
+
+
+ Write the DOCTYPE tag to a .
+
+
+ Writes the DOCTYPE tag to a .
+
+ The output.
+
+ is null.
+
+
+
+
+ An HTML tokenizer.
+
+
+ Tokenizes HTML text, emitting an for each token it encounters.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The .
+
+
+
+ Get or set whether or not the tokenizer should decode character references.
+
+
+ Gets or sets whether or not the tokenizer should decode character references.
+ Character references in attribute values will still be decoded
+ even if this value is set to false.
+
+ true if character references should be decoded; otherwise, false.
+
+
+
+ Get the current HTML namespace detected by the tokenizer.
+
+
+ Gets the current HTML namespace detected by the tokenizer.
+
+ The html namespace.
+
+
+
+ Gets the current line number.
+
+
+ This property is most commonly used for error reporting, but can be called
+ at any time. The starting value for this property is 1.
+ Combined with , a value of 1,1 indicates
+ the start of the document.
+
+ The current line number.
+
+
+
+ Gets the current line position.
+
+
+ This property is most commonly used for error reporting, but can be called
+ at any time. The starting value for this property is 1.
+ Combined with , a value of 1,1 indicates
+ the start of the document.
+
+ The current line number.
+
+
+
+ Get the current state of the tokenizer.
+
+
+ Gets the current state of the tokenizer.
+
+ The current state of the tokenizer.
+
+
+
+ Create a DOCTYPE token.
+
+
+ Creates a DOCTYPE token.
+
+ The DOCTYPE token.
+
+
+
+ Create an HTML comment token.
+
+
+ Creates an HTML comment token.
+
+ The HTML comment token.
+ The comment.
+ true if the comment is bogus; otherwise, false.
+
+
+
+ Create an HTML character data token.
+
+
+ Creates an HTML character data token.
+
+ The HTML character data token.
+ The character data.
+
+
+
+ Create an HTML character data token.
+
+
+ Creates an HTML character data token.
+
+ The HTML character data token.
+ The character data.
+
+
+
+ Create an HTML script data token.
+
+
+ Creates an HTML script data token.
+
+ The HTML script data token.
+ The script data.
+
+
+
+ Create an HTML tag token.
+
+
+ Creates an HTML tag token.
+
+ The HTML tag token.
+ The tag name.
+ true if the tag is an end tag; otherwise, false.
+
+
+
+ Create an attribute.
+
+
+ Creates an attribute.
+
+ The attribute.
+ THe attribute name.
+
+
+
+ Reads the next token.
+
+
+ Reads the next token.
+
+ true if the next token was read; otherwise, false.
+ THe token that was read.
+
+
+
+ The HTML tokenizer state.
+
+
+ The HTML tokenizer state.
+
+
+
+
+ The data state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#data-state.
+
+
+
+
+ The character reference in data state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#character-reference-in-data-state.
+
+
+
+
+ The RCDATA state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rcdata-state.
+
+
+
+
+ The character reference in RCDATA state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#character-reference-in-rcdata-state.
+
+
+
+
+ The RAWTEXT state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rawtext-state.
+
+
+
+
+ The script data state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-state.
+
+
+
+
+ The PLAINTEXT state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#plaintext-state.
+
+
+
+
+ The tag open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#tag-open-state.
+
+
+
+
+ The end tag open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#end-tag-open-state.
+
+
+
+
+ The tag name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#tag-name-state.
+
+
+
+
+ The RCDATA less-than state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rcdata-less-than-sign-state.
+
+
+
+
+ The RCDATA end tag open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rcdata-end-tag-open-state.
+
+
+
+
+ The RCDATA end tag name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rcdata-end-tag-name-state.
+
+
+
+
+ The RAWTEXT less-than state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rawtext-less-than-sign-state.
+
+
+
+
+ The RAWTEXT end tag open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rawtext-end-tag-open-state.
+
+
+
+
+ The RAWTEXT end tag name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#rawtext-end-tag-name-state.
+
+
+
+
+ The script data less-than state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-less-than-sign-state.
+
+
+
+
+ The script data end tag open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-end-tag-open-state.
+
+
+
+
+ The script data end tag name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-end-tag-name-state.
+
+
+
+
+ The script data escape start state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escape-start-state.
+
+
+
+
+ The script data escape start state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escape-start-dash-state.
+
+
+
+
+ The script data escaped state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escaped-state.
+
+
+
+
+ The script data escaped dash state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escaped-dash-state.
+
+
+
+
+ The script data escaped dash dash state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escaped-dash-dash-state.
+
+
+
+
+ The script data escaped less-than state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escaped-less-than-sign-state.
+
+
+
+
+ The script data escaped end tag open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escaped-end-tag-open-state.
+
+
+
+
+ The script data escaped end tag name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-escaped-end-tag-name-state.
+
+
+
+
+ The script data double escape start state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-double-escape-start-state.
+
+
+
+
+ The script data double escaped state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-double-escaped-state.
+
+
+
+
+ The script data double escaped dash state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-double-escaped-dash-state.
+
+
+
+
+ The script data double escaped dash dash state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-double-escaped-dash-dash-state.
+
+
+
+
+ The script data double escaped less-than state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-double-escaped-less-than-sign-state.
+
+
+
+
+ The script data double escape end state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#script-data-double-escape-end-state.
+
+
+
+
+ The before attribute name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#before-attribute-name-state.
+
+
+
+
+ The attribute name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#attribute-name-state.
+
+
+
+
+ The after attribute name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-attribute-name-state.
+
+
+
+
+ The beforw attribute value state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#before-attribute-value-state.
+
+
+
+
+ The attribute value quoted state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#attribute-value-(double-quoted)-state.
+
+
+
+
+ The attribute value unquoted state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#attribute-value-(unquoted)-state.
+
+
+
+
+ The character reference in attribute value state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#character-reference-in-attribute-value-state.
+
+
+
+
+ The after attribute value quoted state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-attribute-value-(quoted)-state.
+
+
+
+
+ The self-closing start tag state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#self-closing-start-tag-state.
+
+
+
+
+ The bogus comment state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#bogus-comment-state.
+
+
+
+
+ The markup declaration open state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#markup-declaration-open-state.
+
+
+
+
+ The comment start state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#comment-start-state.
+
+
+
+
+ The comment start dash state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#comment-start-dash-state.
+
+
+
+
+ The comment state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#comment-state.
+
+
+
+
+ The comment end dash state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#comment-end-dash-state.
+
+
+
+
+ The comment end state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#comment-end-state.
+
+
+
+
+ The comment end bang state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#comment-end-bang-state.
+
+
+
+
+ The DOCTYPE state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#doctype-state.
+
+
+
+
+ The before DOCTYPE name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#before-doctype-name-state.
+
+
+
+
+ The DOCTYPE name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#doctype-name-state.
+
+
+
+
+ The after DOCTYPE name state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-doctype-name-state.
+
+
+
+
+ The after DOCTYPE public keyword state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-doctype-public-keyword-state.
+
+
+
+
+ The before DOCTYPE public identifier state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#before-doctype-public-identifier-state.
+
+
+
+
+ The DOCTYPE public identifier quoted state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#doctype-public-identifier-(double-quoted)-state.
+
+
+
+
+ The after DOCTYPE public identifier state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-doctype-public-identifier-state.
+
+
+
+
+ The between DOCTYPE public and system identifiers state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#between-doctype-public-and-system-identifiers-state.
+
+
+
+
+ The after DOCTYPE system keyword state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-doctype-system-keyword-state.
+
+
+
+
+ The before DOCTYPE system identifier state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#before-doctype-system-identifier-state.
+
+
+
+
+ The DOCTYPE system identifier quoted state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#doctype-system-identifier-(double-quoted)-state.
+
+
+
+
+ The after DOCTYPE system identifier state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#after-doctype-system-identifier-state.
+
+
+
+
+ The bogus DOCTYPE state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#bogus-doctype-state.
+
+
+
+
+ The CDATA section state as described at
+
+ http://www.w3.org/TR/html5/syntax.html#cdata-section-state.
+
+
+
+
+ The end of file state.
+
+
+
+
+ The kinds of tokens that the can emit.
+
+
+ The kinds of tokens that the can emit.
+
+
+
+
+ A token consisting of [CDATA[.
+
+
+
+
+ An HTML comment token.
+
+
+
+
+ A token consisting of character data.
+
+
+
+
+ An HTML DOCTYPE token.
+
+
+
+
+ A token consisting of script data.
+
+
+
+
+ An HTML tag token.
+
+
+
+
+ A collection of HTML-related utility methods.
+
+
+ A collection of HTML-related utility methods.
+
+
+
+
+ Encode an HTML attribute value.
+
+
+ Encodes an HTML attribute value.
+
+ The to output the result.
+ The attribute value to encode.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+ The character to use for quoting the attribute value.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the value.
+
+
+ is not a valid quote character.
+
+
+
+
+ Encode an HTML attribute value.
+
+
+ Encodes an HTML attribute value.
+
+ The encoded attribute value.
+ The attribute value to encode.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+ The character to use for quoting the attribute value.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the value.
+
+
+ is not a valid quote character.
+
+
+
+
+ Encode an HTML attribute value.
+
+
+ Encodes an HTML attribute value.
+
+ The to output the result.
+ The attribute value to encode.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+ The character to use for quoting the attribute value.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the value.
+
+
+ is not a valid quote character.
+
+
+
+
+ Encode an HTML attribute value.
+
+
+ Encodes an HTML attribute value.
+
+ The to output the result.
+ The attribute value to encode.
+ The character to use for quoting the attribute value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a valid quote character.
+
+
+
+
+ Encode an HTML attribute value.
+
+
+ Encodes an HTML attribute value.
+
+ The encoded attribute value.
+ The attribute value to encode.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+ The character to use for quoting the attribute value.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the value.
+
+
+ is not a valid quote character.
+
+
+
+
+ Encode an HTML attribute value.
+
+
+ Encodes an HTML attribute value.
+
+ The encoded attribute value.
+ The attribute value to encode.
+ The character to use for quoting the attribute value.
+
+ is null.
+
+
+ is not a valid quote character.
+
+
+
+
+ Encode HTML character data.
+
+
+ Encodes HTML character data.
+
+ The to output the result.
+ The character data to encode.
+ The starting index of the character data.
+ The number of characters in the data.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the data.
+
+
+
+
+ Encode HTML character data.
+
+
+ Encodes HTML character data.
+
+ THe encoded character data.
+ The character data to encode.
+ The starting index of the character data.
+ The number of characters in the data.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the data.
+
+
+
+
+ Encode HTML character data.
+
+
+ Encodes HTML character data.
+
+ The to output the result.
+ The character data to encode.
+ The starting index of the character data.
+ The number of characters in the data.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the data.
+
+
+
+
+ Encode HTML character data.
+
+
+ Encodes HTML character data.
+
+ The to output the result.
+ The character data to encode.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Encode HTML character data.
+
+
+ Encodes HTML character data.
+
+ THe encoded character data.
+ The character data to encode.
+ The starting index of the character data.
+ The number of characters in the data.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the data.
+
+
+
+
+ Encode HTML character data.
+
+
+ Encodes HTML character data.
+
+ THe encoded character data.
+ The character data to encode.
+
+ is null.
+
+
+
+
+ Decode HTML character data.
+
+
+ Decodes HTML character data.
+
+ The to output the result.
+ The character data to decode.
+ The starting index of the character data.
+ The number of characters in the data.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the data.
+
+
+
+
+ Decode HTML character data.
+
+
+ Decodes HTML character data.
+
+ The to output the result.
+ The character data to decode.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Decode HTML character data.
+
+
+ Decodes HTML character data.
+
+ The decoded character data.
+ The character data to decode.
+ The starting index of the character data.
+ The number of characters in the data.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the data.
+
+
+
+
+ Decode HTML character data.
+
+
+ Decodes HTML character data.
+
+ The decoded character data.
+ The character data to decode.
+
+ is null.
+
+
+
+
+ An HTML writer.
+
+
+ An HTML writer.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The output stream.
+ The encoding to use for the output.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The output text writer.
+
+ is null.
+
+
+
+
+ Releas unmanaged resources and perform other cleanup operations before the
+ is reclaimed by garbage collection.
+
+
+ Releases unmanaged resources and performs other cleanup operations before the
+ is reclaimed by garbage collection.
+
+
+
+
+ Get the current state of the writer.
+
+
+ Gets the current state of the writer.
+
+ The state of the writer.
+
+
+
+ Write the attribute to the output stream.
+
+
+ Writes the attribute to the output stream.
+
+ The attribute identifier.
+ A buffer containing the attribute value.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+
+ is not a valid HTML attribute identifier.
+
+
+ is null.
+
+
+ is less than zero or greater than the length of
+ .
+ -or-
+ and do not specify
+ a valid range in the .
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute to the output stream.
+
+
+ Writes the attribute to the output stream.
+
+ The attribute name.
+ A buffer containing the attribute value.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is less than zero or greater than the length of
+ .
+ -or-
+ and do not specify
+ a valid range in the .
+
+
+ is an invalid attribute name.
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute to the output stream.
+
+
+ Writes the attribute to the output stream.
+
+ The attribute identifier.
+ The attribute value.
+
+ is not a valid HTML attribute identifier.
+
+
+ is null.
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute to the output stream.
+
+
+ Writes the attribute to the output stream.
+
+
+
+
+ The attribute name.
+ The attribute value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is an invalid attribute name.
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute to the output stream.
+
+
+ Writes the attribute to the output stream.
+
+
+
+
+ The attribute.
+
+ is null.
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute name to the output stream.
+
+
+ Writes the attribute name to the output stream.
+
+ The attribute identifier.
+
+ is not a valid HTML attribute identifier.
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute name to the output stream.
+
+
+ Writes the attribute name to the output stream.
+
+
+
+
+ The attribute name.
+
+ is null.
+
+
+ is an invalid attribute name.
+
+
+ The is not in a state that allows writing attributes.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute value to the output stream.
+
+
+ Writes the attribute value to the output stream.
+
+ A buffer containing the attribute value.
+ The starting index of the attribute value.
+ The number of characters in the attribute value.
+
+ is null.
+
+
+ is less than zero or greater than the length of
+ .
+ -or-
+ and do not specify
+ a valid range in the .
+
+
+ The is not in a state that allows writing attribute values.
+
+
+ The has been disposed.
+
+
+
+
+ Write the attribute value to the output stream.
+
+
+ Writes the attribute value to the output stream.
+
+
+
+
+ The attribute value.
+
+ is null.
+
+
+ The is not in a state that allows writing attribute values.
+
+
+ The has been disposed.
+
+
+
+
+ Write an empty element tag.
+
+
+ Writes an empty element tag.
+
+ The HTML tag identifier.
+
+ is not a valid HTML tag identifier.
+
+
+ The has been disposed.
+
+
+
+
+ Write an empty element tag.
+
+
+ Writes an empty element tag.
+
+ The name of the HTML tag.
+
+ is null.
+
+
+ is not a valid HTML tag.
+
+
+ The has been disposed.
+
+
+
+
+ Write an end tag.
+
+
+ Writes an end tag.
+
+ The HTML tag identifier.
+
+ is not a valid HTML tag identifier.
+
+
+ The has been disposed.
+
+
+
+
+ Write an end tag.
+
+
+ Writes an end tag.
+
+ The name of the HTML tag.
+
+ is null.
+
+
+ is not a valid HTML tag.
+
+
+ The has been disposed.
+
+
+
+
+ Write a buffer containing HTML markup directly to the output, without escaping special characters.
+
+
+ Writes a buffer containing HTML markup directly to the output, without escaping special characters.
+
+ The buffer containing HTML markup.
+ The index of the first character to write.
+ The number of characters to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of
+ .
+ -or-
+ and do not specify
+ a valid range in the .
+
+
+ The has been disposed.
+
+
+
+
+ Write a string containing HTML markup directly to the output, without escaping special characters.
+
+
+ Writes a string containing HTML markup directly to the output, without escaping special characters.
+
+ The string containing HTML markup.
+
+ is null.
+
+
+ The has been disposed.
+
+
+
+
+ Write a start tag.
+
+
+ Writes a start tag.
+
+ The HTML tag identifier.
+
+ is not a valid HTML tag identifier.
+
+
+ The has been disposed.
+
+
+
+
+ Write a start tag.
+
+
+ Writes a start tag.
+
+ The name of the HTML tag.
+
+ is null.
+
+
+ is not a valid HTML tag.
+
+
+ The has been disposed.
+
+
+
+
+ Write text to the output stream, escaping special characters.
+
+
+ Writes text to the output stream, escaping special characters.
+
+ The text buffer.
+ The index of the first character to write.
+ The number of characters to write.
+
+ is null.
+
+
+ is less than zero or greater than the length of
+ .
+ -or-
+ and do not specify
+ a valid range in the .
+
+
+ The has been disposed.
+
+
+
+
+ Write text to the output stream, escaping special characters.
+
+
+ Writes text to the output stream, escaping special characters.
+
+ The text.
+
+ is null.
+
+
+ The has been disposed.
+
+
+
+
+ Write a token to the output stream.
+
+
+ Writes a token that was emitted by the
+ to the output stream.
+
+ The HTML token.
+
+ is null.
+
+
+ The has been disposed.
+
+
+
+
+ Flush any remaining state to the output stream.
+
+
+ Flushes any remaining state to the output stream.
+
+
+ The has been disposed.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases any unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ Releases all resource used by the object.
+
+ Call when you are finished using the . The
+ method leaves the in an unusable state. After calling
+ , you must release all references to the so the garbage
+ collector can reclaim the memory that the was occupying.
+
+
+
+ An enumeration of possible states of a .
+
+
+ An enumeration of possible states of a .
+
+
+
+
+ The is not within a tag. In this state, the
+ can only write a tag or text.
+
+
+
+
+ The is inside a tag but has not started to write an attribute. In this
+ state, the can write an attribute, another tag, or text.
+
+
+
+
+ The is inside an attribute. In this state, the
+ can append a value to the current attribute, start the next attribute, or write another tag or text.
+
+
+
+
+ An abstract class for converting text from one format to another.
+
+
+ An abstract class for converting text from one format to another.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Get or set whether the encoding of the input is detected from the byte order mark or
+ determined by the property.
+
+
+ Gets or sets whether the encoding of the input is detected from the byte order mark or
+ determined by the property.
+
+ true if detect encoding from byte order mark; otherwise, false.
+
+
+
+ Get or set the input encoding.
+
+
+ Gets or sets the input encoding.
+
+ The input encoding.
+
+ is null.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get or set the output encoding.
+
+
+ Gets or sets the output encoding.
+
+ The output encoding.
+
+ is null.
+
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set the size of the input stream buffer.
+
+
+ Gets or sets the size of the input stream buffer.
+
+ The size of the input stream buffer.
+
+ is less than or equal to 0.
+
+
+
+
+ Get or set the size of the output stream buffer.
+
+
+ Gets or sets the size of the output stream buffer.
+
+ The size of the output stream buffer.
+
+ is less than or equal to 0.
+
+
+
+
+ Convert the contents of from the to the
+ and writes the resulting text to .
+
+
+ Converts the contents of from the to the
+ and writes the resulting text to .
+
+ The source stream.
+ The destination stream.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The source stream.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Convert the contents of from the to the
+ and writes the resulting text to .
+
+
+ Converts the contents of from the to the
+ and writes the resulting text to .
+
+ The text reader.
+ The destination stream.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Convert text from the to the .
+
+
+ Converts text from the to the .
+
+
+
+
+ The converted text.
+ The text to convert.
+
+ is null.
+
+
+
+
+ An enumeration of text formats.
+
+
+ An enumeration of text formats.
+
+
+
+
+ The plain text format.
+
+
+
+
+ The flowed text format (as described in rfc3676).
+
+
+
+
+ The HTML text format.
+
+
+
+
+ The enriched text format.
+
+
+
+
+ The compressed rich text format.
+
+
+
+
+ The rich text format.
+
+
+
+
+ A text to flowed text converter.
+
+
+ Wraps text to conform with the flowed text format described in rfc3676.
+ The Content-Type header for the wrapped output text should be set to
+ text/plain; format=flowed; delsp=yes.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new text to flowed text converter.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set the text that will be appended to the end of the output.
+
+
+ Gets or sets the text that will be appended to the end of the output.
+ The footer must be set before conversion begins.
+
+ The footer.
+
+
+
+ Get or set text that will be prepended to the beginning of the output.
+
+
+ Gets or sets the text that will be prepended to the beginning of the output.
+ The header must be set before conversion begins.
+
+ The header.
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ A text to HTML converter.
+
+
+ Used to convert plain text into HTML.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new text to HTML converter.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set the text that will be appended to the end of the output.
+
+
+ Gets or sets the text that will be appended to the end of the output.
+ The footer must be set before conversion begins.
+
+ The footer.
+
+
+
+ Get or set the footer format.
+
+
+ Gets or sets the footer format.
+
+ The footer format.
+
+
+
+ Get or set text that will be prepended to the beginning of the output.
+
+
+ Gets or sets the text that will be prepended to the beginning of the output.
+ The header must be set before conversion begins.
+
+ The header.
+
+
+
+ Get or set the header format.
+
+
+ Gets or sets the header format.
+
+ The header format.
+
+
+
+ Get or set the method to use for custom
+ filtering of HTML tags and content.
+
+
+ Get or set the method to use for custom
+ filtering of HTML tags and content.
+
+ The html tag callback.
+
+
+
+ Get or set whether or not the converter should only output an HTML fragment.
+
+
+ Gets or sets whether or not the converter should only output an HTML fragment.
+
+ true if the converter should only output an HTML fragment; otherwise, false.
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ A text to text converter.
+
+
+ A text to text converter.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new text to text converter.
+
+
+
+
+ Get the input format.
+
+
+ Gets the input format.
+
+ The input format.
+
+
+
+ Get the output format.
+
+
+ Gets the output format.
+
+ The output format.
+
+
+
+ Get or set the text that will be appended to the end of the output.
+
+
+ Gets or sets the text that will be appended to the end of the output.
+ The footer must be set before conversion begins.
+
+ The footer.
+
+
+
+ Get or set the footer format.
+
+
+ Gets or sets the footer format.
+
+ The footer format.
+
+
+
+ Get or set text that will be prepended to the beginning of the output.
+
+
+ Gets or sets the text that will be prepended to the beginning of the output.
+ The header must be set before conversion begins.
+
+ The header.
+
+
+
+ Convert the contents of from the to the
+ and uses the to write the resulting text.
+
+
+ Converts the contents of from the to the
+ and uses the to write the resulting text.
+
+ The text reader.
+ The text writer.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ An Aho-Corasick Trie graph.
+
+
+ An Aho-Corasick Trie graph.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ true if searching should ignore case; otherwise, false.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Add the specified search pattern.
+
+
+ Adds the specified search pattern.
+
+ The search pattern.
+
+ is null.
+
+
+ cannot be an empty string.
+
+
+
+
+ Search the text for any of the patterns added to the trie.
+
+
+ Searches the text for any of the patterns added to the trie.
+
+ The first index of a matched pattern if successful; otherwise, -1.
+ The text to search.
+ The starting index of the text.
+ The number of characters to search, starting at .
+ The pattern that was matched.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the string.
+
+
+
+
+ Search the text for any of the patterns added to the trie.
+
+
+ Searches the text for any of the patterns added to the trie.
+
+ The first index of a matched pattern if successful; otherwise, -1.
+ The text to search.
+ The starting index of the text.
+ The pattern that was matched.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Search the text for any of the patterns added to the trie.
+
+
+ Searches the text for any of the patterns added to the trie.
+
+ The first index of a matched pattern if successful; otherwise, -1.
+ The text to search.
+ The pattern that was matched.
+
+ is null.
+
+
+
+
+ A filter to decompress a compressed RTF stream.
+
+
+ Used to decompress a compressed RTF stream.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new converter filter.
+
+
+
+
+ Gets the compression mode.
+
+
+ At least 12 bytes from the stream must be processed before this property value will
+ be accurate.
+
+ The compression mode.
+
+
+
+ Gets a value indicating whether the crc32 is valid.
+
+
+ Until all data has been processed, this property will always return false.
+
+ true if the crc32 is valid; otherwise, false.
+
+
+
+ Filter the specified input.
+
+ Filters the specified input buffer starting at the given index,
+ spanning across the specified number of bytes.
+ The filtered output.
+ The input buffer.
+ The starting index of the input buffer.
+ Length.
+ Output index.
+ Output length.
+ If set to true flush.
+
+
+
+ Resets the filter.
+
+
+ Resets the filter.
+
+
+
+
+ A RTF compression mode.
+
+
+ A RTF compression mode.
+
+
+
+
+ The compression mode is not known.
+
+
+
+
+ The RTF stream is not compressed.
+
+
+
+
+ The RTF stream is compressed.
+
+
+
+
+ The TNEF attach flags.
+
+
+ The enum contains a list of possible values for
+ the property.
+
+
+
+
+ No AttachFlags set.
+
+
+
+
+ The attachment is invisible in HTML bodies.
+
+
+
+
+ The attachment is invisible in RTF bodies.
+
+
+
+
+ The attachment is referenced (and rendered) by the HTML body.
+
+
+
+
+ The TNEF attach method.
+
+
+ The enum contains a list of possible values for
+ the property.
+
+
+
+
+ No AttachMethod specified.
+
+
+
+
+ The attachment is a binary blob and SHOULD appear in the
+ attribute.
+
+
+
+
+ The attachment is an embedded TNEF message stream and MUST appear
+ in the property of the
+ attribute.
+
+
+
+
+ The attachment is an OLE stream and MUST appear
+ in the property of the
+ attribute.
+
+
+
+
+ A TNEF attribute level.
+
+
+ A TNEF attribute level.
+
+
+
+
+ The attribute is a message-level attribute.
+
+
+
+
+ The attribute is an attachment-level attribute.
+
+
+
+
+ A TNEF attribute tag.
+
+
+ A TNEF attribute tag.
+
+
+
+
+ A Null TNEF attribute.
+
+
+
+
+ The Owner TNEF attribute.
+
+
+
+
+ The SentFor TNEF attribute.
+
+
+
+
+ The Delegate TNEF attribute.
+
+
+
+
+ The OriginalMessageClass TNEF attribute.
+
+
+
+
+ The DateStart TNEF attribute.
+
+
+
+
+ The DateEnd TNEF attribute.
+
+
+
+
+ The AidOwner TNEF attribute.
+
+
+
+
+ The RequestResponse TNEF attribute.
+
+
+
+
+ The From TNEF attribute.
+
+
+
+
+ The Subject TNEF attribute.
+
+
+
+
+ The DateSent TNEF attribute.
+
+
+
+
+ The DateReceived TNEF attribute.
+
+
+
+
+ The MessageStatus TNEF attribute.
+
+
+
+
+ The MessageClass TNEF attribute.
+
+
+
+
+ The MessageId TNEF attribute.
+
+
+
+
+ The ParentId TNEF attribute.
+
+
+
+
+ The ConversationId TNEF attribute.
+
+
+
+
+ The Body TNEF attribute.
+
+
+
+
+ The Priority TNEF attribute.
+
+
+
+
+ The AttachData TNEF attribute.
+
+
+
+
+ The AttachTitle TNEF attribute.
+
+
+
+
+ The AttachMetaFile TNEF attribute.
+
+
+
+
+ The AttachCreateDate TNEF attribute.
+
+
+
+
+ The AttachModifyDate TNEF attribute.
+
+
+
+
+ The DateModified TNEF attribute.
+
+
+
+
+ The AttachTransportFilename TNEF attribute.
+
+
+
+
+ The AttachRenderData TNEF attribute.
+
+
+
+
+ The MapiProperties TNEF attribute.
+
+
+
+
+ The RecipientTable TNEF attribute.
+
+
+
+
+ The Attachment TNEF attribute.
+
+
+
+
+ The TnefVersion TNEF attribute.
+
+
+
+
+ The OemCodepage TNEF attribute.
+
+
+
+
+ A TNEF compliance mode.
+
+
+ A TNEF compliance mode.
+
+
+
+
+ Use a loose compliance mode, attempting to ignore invalid or corrupt data.
+
+
+
+
+ Use a very strict compliance mode, aborting the parser at the first sign of
+ invalid or corrupted data.
+
+
+
+
+ A bitfield of potential TNEF compliance issues.
+
+
+ A bitfield of potential TNEF compliance issues.
+
+
+
+
+ The TNEF stream has no errors.
+
+
+
+
+ The TNEF stream has too many attributes.
+
+
+
+
+ The TNEF stream has one or more invalid attributes.
+
+
+
+
+ The TNEF stream has one or more attributes with invalid checksums.
+
+
+
+
+ The TNEF stream has one more more attributes with an invalid length.
+
+
+
+
+ The TNEF stream has one or more attributes with an invalid level.
+
+
+
+
+ The TNEF stream has one or more attributes with an invalid value.
+
+
+
+
+ The TNEF stream has one or more attributes with an invalid date value.
+
+
+
+
+ The TNEF stream has one or more invalid MessageClass attributes.
+
+
+
+
+ The TNEF stream has one or more invalid MessageCodepage attributes.
+
+
+
+
+ The TNEF stream has one or more invalid property lengths.
+
+
+
+
+ The TNEF stream has one or more invalid row counts.
+
+
+
+
+ The TNEF stream has an invalid signature value.
+
+
+
+
+ The TNEF stream has an invalid version value.
+
+
+
+
+ The TNEF stream is nested too deeply.
+
+
+
+
+ The TNEF stream is truncated.
+
+
+
+
+ The TNEF stream has one or more unsupported property types.
+
+
+
+
+ A TNEF exception.
+
+
+ A occurs when when a TNEF stream is found to be
+ corrupted and cannot be read any futher.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The serialization info.
+ The stream context.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The error message.
+ The inner exception.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The error message.
+
+
+
+ A TNEF name identifier.
+
+
+ A TNEF name identifier.
+
+
+
+
+ Gets the property set GUID.
+
+
+ Gets the property set GUID.
+
+ The property set GUID.
+
+
+
+ Gets the kind of TNEF name identifier.
+
+
+ Gets the kind of TNEF name identifier.
+
+ The kind of identifier.
+
+
+
+ Gets the name, if available.
+
+
+ If the is , then this property will be available.
+
+ The name.
+
+
+
+ Gets the identifier, if available.
+
+
+ If the is , then this property will be available.
+
+ The identifier.
+
+
+
+ Initializes a new instance of the struct.
+
+
+ Creates a new with the specified integer identifier.
+
+ The property set GUID.
+ The identifier.
+
+
+
+ Initializes a new instance of the struct.
+
+
+ Creates a new with the specified string identifier.
+
+ The property set GUID.
+ The name.
+
+
+
+ Serves as a hash function for a object.
+
+
+ Serves as a hash function for a object.
+
+ A hash code for this instance that is suitable for use in hashing algorithms
+ and data structures such as a hash table.
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Determines whether the specified is equal to the current .
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ The kind of TNEF name identifier.
+
+
+ The kind of TNEF name identifier.
+
+
+
+
+ The property name is an integer.
+
+
+
+
+ The property name is a string.
+
+
+
+
+ A MIME part containing Microsoft TNEF data.
+
+
+ Represents an application/ms-tnef or application/vnd.ms-tnef part.
+ TNEF (Transport Neutral Encapsulation Format) attachments are most often
+ sent by Microsoft Outlook clients.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with a Content-Type of application/vnd.ms-tnef
+ and a Content-Disposition value of "attachment" and a filename paremeter with a
+ value of "winmail.dat".
+
+
+
+
+ Converts the TNEF content into a .
+
+
+ TNEF data often contains properties that map to
+ headers. TNEF data also often contains file attachments which will be
+ mapped to MIME parts.
+
+ A message representing the TNEF data in MIME format.
+
+ The property is null.
+
+
+
+
+ Extracts the embedded attachments from the TNEF data.
+
+
+ Parses the TNEF data and extracts all of the embedded file attachments.
+
+ The attachments.
+
+ The property is null.
+
+
+
+
+ A TNEF property identifier.
+
+
+ A TNEF property identifier.
+
+
+
+
+ The MAPI property PR_AB_DEFAULT_DIR.
+
+
+
+
+ The MAPI property PR_AB_DEFAULT_PAB.
+
+
+
+
+ The MAPI property PR_AB_PROVIDER_ID.
+
+
+
+
+ The MAPI property PR_AB_PROVIDERS.
+
+
+
+
+ The MAPI property PR_AB_SEARCH_PATH.
+
+
+
+
+ The MAPI property PR_AB_SEARCH_PATH_UPDATE.
+
+
+
+
+ The MAPI property PR_ACCESS.
+
+
+
+
+ The MAPI property PR_ACCESS_LEVEL.
+
+
+
+
+ The MAPI property PR_ACCOUNT.
+
+
+
+
+ The MAPI property PR_ACKNOWLEDGEMENT_MODE.
+
+
+
+
+ The MAPI property PR_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ALTERNATE_RECIPIENT.
+
+
+
+
+ The MAPI property PR_ALTERNATE_RECIPIENT_ALLOWED.
+
+
+
+
+ The MAPI property PR_ANR.
+
+
+
+
+ The MAPI property PR_ASSISTANT.
+
+
+
+
+ The MAPI property PR_ASSISTANT_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_ASSOC_CONTENT_COUNT.
+
+
+
+
+ The MAPI property PR_ATTACH_ADDITIONAL_INFO.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_BASE.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_ID.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_LOCATION.
+
+
+
+
+ The MAPI property PR_ATTACH_DATA_BIN or PR_ATTACH_DATA_OBJ.
+
+
+
+
+ The MAPI property PR_ATTACH_DISPOSITION.
+
+
+
+
+ The MAPI property PR_ATTACH_ENCODING.
+
+
+
+
+ The MAPI property PR_ATTACH_EXTENSION.
+
+
+
+
+ The MAPI property PR_ATTACH_FILENAME.
+
+
+
+
+ The MAPI property PR_ATTACH_FLAGS.
+
+
+
+
+ The MAPI property PR_ATTACH_LONG_FILENAME.
+
+
+
+
+ The MAPI property PR_ATTACH_LONG_PATHNAME.
+
+
+
+
+ The MAPI property PR_ATTACHMENT_X400_PARAMETERS.
+
+
+
+
+ The MAPI property PR_ATTACH_METHOD.
+
+
+
+
+ The MAPI property PR_ATTACH_MIME_SEQUENCE.
+
+
+
+
+ The MAPI property PR_ATTACH_MIME_TAG.
+
+
+
+
+ The MAPI property PR_ATTACH_NETSCAPE_MAC_INFO.
+
+
+
+
+ The MAPI property PR_ATTACH_NUM.
+
+
+
+
+ The MAPI property PR_ATTACH_PATHNAME.
+
+
+
+
+ The MAPI property PR_ATTACH_RENDERING.
+
+
+
+
+ The MAPI property PR_ATTACH_SIZE.
+
+
+
+
+ The MAPI property PR_ATTACH_TAG.
+
+
+
+
+ The MAPI property PR_ATTACH_TRANSPORT_NAME.
+
+
+
+
+ The MAPI property PR_AUTHORIZING_USERS.
+
+
+
+
+ The MAPI property PR_AUTO_FORWARDED.
+
+
+
+
+ The MAPI property PR_AUTO_FORWARDING_COMMENT.
+
+
+
+
+ The MAPI property PR_AUTO_RESPONSE_SUPPRESS.
+
+
+
+
+ The MAPI property PR_BEEPER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BIRTHDAY.
+
+
+
+
+ The MAPI property PR_BODY.
+
+
+
+
+ The MAPI property PR_BODY_CONTENT_ID.
+
+
+
+
+ The MAPI property PR_BODY_CONTENT_LOCATION.
+
+
+
+
+ The MAPI property PR_BODY_CRC.
+
+
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_BUSINESS_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS_HOME_PAGE.
+
+
+
+
+ The MAPI property PR_CALLBACK_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CAR_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CELLULAR_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CHILDRENS_NAMES.
+
+
+
+
+ The MAPI property PR_CLIENT_SUBMIT_TIME.
+
+
+
+
+ The MAPI property PR_COMMENT.
+
+
+
+
+ The MAPI property PR_COMMON_VIEWS_ENTRYID.
+
+
+
+
+ The MAPI property PR_COMPANY_MAIN_PHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_COMPANY_NAME.
+
+
+
+
+ The MAPI property PR_COMPUTER_NETWORK_NAME.
+
+
+
+
+ The MAPI property PR_CONTACT_ADDRTYPES.
+
+
+
+
+ The MAPI property PR_CONTACT_DEFAULT_ADDRESS_INDEX.
+
+
+
+
+ The MAPI property PR_CONTACT_EMAIL_ADDRESSES.
+
+
+
+
+ The MAPI property PR_CONTACT_ENTRYIDS.
+
+
+
+
+ The MAPI property PR_CONTACT_VERSION.
+
+
+
+
+ The MAPI property PR_CONTAINER_CLASS.
+
+
+
+
+ The MAPI property PR_CONTAINER_CONTENTS.
+
+
+
+
+ The MAPI property PR_CONTAINER_FLAGS.
+
+
+
+
+ The MAPI property PR_CONTAINER_HIERARCHY.
+
+
+
+
+ The MAPI property PR_CONTAINER_MODIFY_VERSION.
+
+
+
+
+ The MAPI property PR_CONTENT_CONFIDENTIALITY_ALGORITHM_ID.
+
+
+
+
+ The MAPI property PR_CONTENT_CORRELATOR.
+
+
+
+
+ The MAPI property PR_CONTENT_COUNT.
+
+
+
+
+ The MAPI property PR_CONTENT_IDENTIFIER.
+
+
+
+
+ The MAPI property PR_CONTENT_INTEGRITY_CHECK.
+
+
+
+
+ The MAPI property PR_CONTENT_LENGTH.
+
+
+
+
+ The MAPI property PR_CONTENT_RETURN_REQUESTED.
+
+
+
+
+ The MAPI property PR_CONTENTS_SORT_ORDER.
+
+
+
+
+ The MAPI property PR_CONTENT_UNREAD.
+
+
+
+
+ The MAPI property PR_CONTROL_FLAGS.
+
+
+
+
+ The MAPI property PR_CONTROL_ID.
+
+
+
+
+ The MAPI property PR_CONTROL_STRUCTURE.
+
+
+
+
+ The MAPI property PR_CONTROL_TYPE.
+
+
+
+
+ The MAPI property PR_CONVERSATION_INDEX.
+
+
+
+
+ The MAPI property PR_CONVERSATION_KEY.
+
+
+
+
+ The MAPI property PR_CONVERSATION_TOPIC.
+
+
+
+
+ The MAPI property PR_CONVERSATION_EITS.
+
+
+
+
+ The MAPI property PR_CONVERSION_PROHIBITED.
+
+
+
+
+ The MAPI property PR_CONVERSION_WITH_LOSS_PROHIBITED.
+
+
+
+
+ The MAPI property PR_CONVERTED_EITS.
+
+
+
+
+ The MAPI property PR_CORRELATE.
+
+
+
+
+ The MAPI property PR_CORRELATE_MTSID.
+
+
+
+
+ The MAPI property PR_COUNTRY.
+
+
+
+
+ The MAPI property PR_CREATE_TEMPLATES.
+
+
+
+
+ The MAPI property PR_CREATION_TIME.
+
+
+
+
+ The MAPI property PR_CREATION_VERSION.
+
+
+
+
+ The MAPI property PR_CURRENT_VERSION.
+
+
+
+
+ The MAPI property PR_CUSTOMER_ID.
+
+
+
+
+ The MAPI property PR_DEFAULT_PROFILE.
+
+
+
+
+ The MAPI property PR_DEFAULT_STORE.
+
+
+
+
+ The MAPI property PR_DEFAULT_VIEW_ENTRYID.
+
+
+
+
+ The MAPI property PR_DEF_CREATE_DL.
+
+
+
+
+ The MAPI property PR_DEF_CREATE_MAILUSER.
+
+
+
+
+ The MAPI property PR_DEFERRED_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_DELEGATION.
+
+
+
+
+ The MAPI property PR_DELETE_AFTER_SUBMIT.
+
+
+
+
+ The MAPI property PR_DELIVER_TIME.
+
+
+
+
+ The MAPI property PR_DELIVERY_POINT.
+
+
+
+
+ The MAPI property PR_DELTAX.
+
+
+
+
+ The MAPI property PR_DELTAY.
+
+
+
+
+ The MAPI property PR_DEPARTMENT_NAME.
+
+
+
+
+ The MAPI property PR_DEPTH.
+
+
+
+
+ The MAPI property PR_DETAILS_TABLE.
+
+
+
+
+ The MAPI property PR_DISCARD_REASON.
+
+
+
+
+ The MAPI property PR_DISCLOSE_RECIPIENTS.
+
+
+
+
+ The MAPI property PR_DISCLOSURE_OF_RECIPIENTS.
+
+
+
+
+ The MAPI property PR_DISCRETE_VALUES.
+
+
+
+
+ The MAPI property PR_DISC_VAL.
+
+
+
+
+ The MAPI property PR_DISPLAY_BCC.
+
+
+
+
+ The MAPI property PR_DISPLAY_CC.
+
+
+
+
+ The MAPI property PR_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_DISPLAY_NAME_PREFIX.
+
+
+
+
+ The MAPI property PR_DISPLAY_TO.
+
+
+
+
+ The MAPI property PR_DISPLAY_TYPE.
+
+
+
+
+ The MAPI property PR_DL_EXPANSION_HISTORY.
+
+
+
+
+ The MAPI property PR_DL_EXPANSION_PROHIBITED.
+
+
+
+
+ The MAPI property PR_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_END_DATE.
+
+
+
+
+ The MAPI property PR_ENTRYID.
+
+
+
+
+ The MAPI property PR_EXPAND_BEGIN_TIME.
+
+
+
+
+ The MAPI property PR_EXPANDED_BEGIN_TIME.
+
+
+
+
+ The MAPI property PR_EXPANDED_END_TIME.
+
+
+
+
+ The MAPI property PR_EXPAND_END_TIME.
+
+
+
+
+ The MAPI property PR_EXPIRY_TIME.
+
+
+
+
+ The MAPI property PR_EXPLICIT_CONVERSION.
+
+
+
+
+ The MAPI property PR_FILTERING_HOOKS.
+
+
+
+
+ The MAPI property PR_FINDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_FOLDER_ASSOCIATED_CONTENTS.
+
+
+
+
+ The MAPI property PR_FOLDER_TYPE.
+
+
+
+
+ The MAPI property PR_FORM_CATEGORY.
+
+
+
+
+ The MAPI property PR_FORM_CATEGORY_SUB.
+
+
+
+
+ The MAPI property PR_FORM_CLSID.
+
+
+
+
+ The MAPI property PR_FORM_CONTACT_NAME.
+
+
+
+
+ The MAPI property PR_FORM_DESIGNER_GUID.
+
+
+
+
+ The MAPI property PR_FORM_DESIGNER_NAME.
+
+
+
+
+ The MAPI property PR_FORM_HIDDEN.
+
+
+
+
+ The MAPI property PR_FORM_HOST_MAP.
+
+
+
+
+ The MAPI property PR_FORM_MESSAGE_BEHAVIOR.
+
+
+
+
+ The MAPI property PR_FORM_VERSION.
+
+
+
+
+ The MAPI property PR_FTP_SITE.
+
+
+
+
+ The MAPI property PR_GENDER.
+
+
+
+
+ The MAPI property PR_GENERATION.
+
+
+
+
+ The MAPI property PR_GIVEN_NAME.
+
+
+
+
+ The MAPI property PR_GOVERNMENT_ID_NUMBER.
+
+
+
+
+ The MAPI property PR_HASTTACH.
+
+
+
+
+ The MAPI property PR_HEADER_FOLDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_HOBBIES.
+
+
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_HOME_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_ICON.
+
+
+
+
+ The MAPI property PR_IDENTITY_DISPLAY.
+
+
+
+
+ The MAPI property PR_IDENTITY_ENTRYID.
+
+
+
+
+ The MAPI property PR_IDENTITY_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IMPLICIT_CONVERSION_PROHIBITED.
+
+
+
+
+ The MAPI property PR_IMPORTANCE.
+
+
+
+
+ The MAPI property PR_INCOMPLETE_COPY.
+
+
+
+
+ The Internet mail override charset.
+
+
+
+
+ The Internet mail override format.
+
+
+
+
+ The MAPI property PR_INITIAL_DETAILS_PANE.
+
+
+
+
+ The MAPI property PR_INITIALS.
+
+
+
+
+ The MAPI property PR_IN_REPLY_TO_ID.
+
+
+
+
+ The MAPI property PR_INSTANCE_KEY.
+
+
+
+
+ The MAPI property PR_INTERNET_APPROVED.
+
+
+
+
+ The MAPI property PR_INTERNET_ARTICLE_NUMBER.
+
+
+
+
+ The MAPI property PR_INTERNET_CONTROL.
+
+
+
+
+ The MAPI property PR_INTERNET_CPID.
+
+
+
+
+ The MAPI property PR_INTERNET_DISTRIBUTION.
+
+
+
+
+ The MAPI property PR_INTERNET_FOLLOWUP_TO.
+
+
+
+
+ The MAPI property PR_INTERNET_LINES.
+
+
+
+
+ The MAPI property PR_INTERNET_MESSAGE_ID.
+
+
+
+
+ The MAPI property PR_INTERNET_NEWSGROUPS.
+
+
+
+
+ The MAPI property PR_INTERNET_NNTP_PATH.
+
+
+
+
+ The MAPI property PR_INTERNET_ORGANIZATION.
+
+
+
+
+ The MAPI property PR_INTERNET_PRECEDENCE.
+
+
+
+
+ The MAPI property PR_INTERNET_REFERENCES.
+
+
+
+
+ The MAPI property PR_IPM_ID.
+
+
+
+
+ The MAPI property PR_IPM_OUTBOX_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_OUTBOX_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IPM_RETURN_REQUESTED.
+
+
+
+
+ The MAPI property PR_IPM_SENTMAIL_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_SENTMAIL_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IPM_SUBTREE_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_SUBTREE_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IPM_WASTEBASKET_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_WASTEBASKET_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ISDN_NUMBER.
+
+
+
+
+ The MAPI property PR_KEYWORD.
+
+
+
+
+ The MAPI property PR_LANGUAGE.
+
+
+
+
+ The MAPI property PR_LANGUAGES.
+
+
+
+
+ The MAPI property PR_LAST_MODIFICATION_TIME.
+
+
+
+
+ The MAPI property PR_LATEST_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_LIST_HELP.
+
+
+
+
+ The MAPI property PR_LIST_SUBSCRIBE.
+
+
+
+
+ The MAPI property PR_LIST_UNSUBSCRIBE.
+
+
+
+
+ The MAPI property PR_LOCALITY.
+
+
+
+
+ The MAPI property PR_LOCALLY_DELIVERED.
+
+
+
+
+ The MAPI property PR_LOCATION.
+
+
+
+
+ The MAPI property PR_LOCK_BRANCH_ID.
+
+
+
+
+ The MAPI property PR_LOCK_DEPTH.
+
+
+
+
+ The MAPI property PR_LOCK_ENLISTMENT_CONTEXT.
+
+
+
+
+ The MAPI property PR_LOCK_EXPIRY_TIME.
+
+
+
+
+ The MAPI property PR_LOCK_PERSISTENT.
+
+
+
+
+ The MAPI property PR_LOCK_RESOURCE_DID.
+
+
+
+
+ The MAPI property PR_LOCK_RESOURCE_FID.
+
+
+
+
+ The MAPI property PR_LOCK_RESOURCE_MID.
+
+
+
+
+ The MAPI property PR_LOCK_SCOPE.
+
+
+
+
+ The MAPI property PR_LOCK_TIMEOUT.
+
+
+
+
+ The MAPI property PR_LOCK_TYPE.
+
+
+
+
+ The MAPI property PR_MAIL_PERMISSION.
+
+
+
+
+ The MAPI property PR_MANAGER_NAME.
+
+
+
+
+ The MAPI property PR_MAPPING_SIGNATURE.
+
+
+
+
+ The MAPI property PR_MDB_PROVIDER.
+
+
+
+
+ The MAPI property PR_MESSAGE_ATTACHMENTS.
+
+
+
+
+ The MAPI property PR_MESSAGE_CC_ME.
+
+
+
+
+ The MAPI property PR_MESSAGE_CLASS.
+
+
+
+
+ The MAPI property PR_MESSAGE_CODEPAGE.
+
+
+
+
+ The MAPI property PR_MESSAGE_DELIVERY_ID.
+
+
+
+
+ The MAPI property PR_MESSAGE_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_MESSAGE_DOWNLOAD_TIME.
+
+
+
+
+ The MAPI property PR_MESSAGE_FLAGS.
+
+
+
+
+ The MAPI property PR_MESSAGE_RECIPIENTS.
+
+
+
+
+ The MAPI property PR_MESSAGE_RECIP_ME.
+
+
+
+
+ The MAPI property PR_MESSAGE_SECURITY_LABEL.
+
+
+
+
+ The MAPI property PR_MESSAGE_SIZE.
+
+
+
+
+ The MAPI property PR_MESSAGE_SUBMISSION_ID.
+
+
+
+
+ The MAPI property PR_MESSAGE_TOKEN.
+
+
+
+
+ The MAPI property PR_MESSAGE_TO_ME.
+
+
+
+
+ The MAPI property PR_MHS_COMMON_NAME.
+
+
+
+
+ The MAPI property PR_MIDDLE_NAME.
+
+
+
+
+ The MAPI property PR_MINI_ICON.
+
+
+
+
+ The MAPI property PR_MOBILE_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_MODIFY_VERSION.
+
+
+
+
+ The MAPI property PR_MSG_STATUS.
+
+
+
+
+ The MAPI property PR_NDR_DIAG_CODE.
+
+
+
+
+ The MAPI property PR_NDR_REASON_CODE.
+
+
+
+
+ The MAPI property PR_NDR_STATUS_CODE.
+
+
+
+
+ The MAPI property PR_NEWSGROUP_NAME.
+
+
+
+
+ The MAPI property PR_NICKNAME.
+
+
+
+
+ The MAPI property PR_NNTP_XREF.
+
+
+
+
+ The MAPI property PR_NON_RECEIPT_NOTIFICATION_REQUESTED.
+
+
+
+
+ The MAPI property PR_NON_RECEIPT_REASON.
+
+
+
+
+ The MAPI property PR_NORMALIZED_SUBJECT.
+
+
+
+
+ The MAPI property PR_NT_SECURITY_DESCRIPTOR.
+
+
+
+
+ The MAPI property PR_NULL.
+
+
+
+
+ The MAPI property PR_OBJECT_TYPE.
+
+
+
+
+ The MAPI property PR_OBSOLETE_IPMS.
+
+
+
+
+ The MAPI property PR_OFFICE2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OFFICE_LOCATION.
+
+
+
+
+ The MAPI property PR_OFFICE_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OOF_REPLY_TIME.
+
+
+
+
+ The MAPI property PR_ORGANIZATIONAL_ID_NUMBER.
+
+
+
+
+ The MAPI property PR_ORIG_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_BCC.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_CC.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_TO.
+
+
+
+
+ The MAPI property PR_ORIGINAL_EITS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ADRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIPIENT_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENSITIVITY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SUBJECT.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SUBMIT_TIME.
+
+
+
+
+ The MAPI property PR_ORIGINATING_MTA_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_AND_DL_EXPANSION_HISTORY.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_DELIVERY_REPORT_REQUESTED.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_NON_DELIVERY_REPORT_REQUESTED.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_REQUESTED_ALTERNATE_RECIPIENT.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_RETURN_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGIN_CHECK.
+
+
+
+
+ The MAPI property PR_ORIG_MESSAGE_CLASS.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_OTHER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OWNER_APPT_ID.
+
+
+
+
+ The MAPI property PR_OWN_STORE_ENTRYID.
+
+
+
+
+ The MAPI property PR_PAGER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_PARENT_DISPLAY.
+
+
+
+
+ The MAPI property PR_PARENT_ENTRYID.
+
+
+
+
+ The MAPI property PR_PARENT_KEY.
+
+
+
+
+ The MAPI property PR_PERSONAL_HOME_PAGE.
+
+
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_BUREAU_FAX_DELIVERY.
+
+
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_MODE.
+
+
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_REPORT_REQUEST.
+
+
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_ADDRESS.
+
+
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_ADDRESS_REQUESTED.
+
+
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_PROHIBITED.
+
+
+
+
+ The MAPI property PR_PHYSICAL_RENDITION_ATTRIBUTES.
+
+
+
+
+ The MAPI property PR_POSTAL_ADDRESS.
+
+
+
+
+ The MAPI property PR_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_POST_FOLDER_ENTRIES.
+
+
+
+
+ The MAPI property PR_POST_FOLDER_NAMES.
+
+
+
+
+ The MAPI property PR_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_POST_REPLY_DENIED.
+
+
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_ENTRIES.
+
+
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_NAMES.
+
+
+
+
+ The MAPI property PR_PREFERRED_BY_NAME.
+
+
+
+
+ The MAPI property PR_PREPROCESS.
+
+
+
+
+ The MAPI property PR_PRIMARY_CAPABILITY.
+
+
+
+
+ The MAPI property PR_PRIMARY_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_PRIMARY_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_PRIORITY.
+
+
+
+
+ The MAPI property PR_PROFESSION.
+
+
+
+
+ The MAPI property PR_PROFILE_NAME.
+
+
+
+
+ The MAPI property PR_PROOF_OF_DELIVERY.
+
+
+
+
+ The MAPI property PR_PROOF_OF_DELIVERY_REQUESTED.
+
+
+
+
+ The MAPI property PR_PROOF_OF_SUBMISSION.
+
+
+
+
+ The MAPI property PR_PROOF_OF_SUBMISSION_REQUESTED.
+
+
+
+
+ The MAPI property PR_PROP_ID_SECURE_MAX.
+
+
+
+
+ The MAPI property PR_PROP_ID_SECURE_MIN.
+
+
+
+
+ The MAPI property PR_PROVIDER_DISPLAY.
+
+
+
+
+ The MAPI property PR_PROVIDER_DLL_NAME.
+
+
+
+
+ The MAPI property PR_PROVIDER_ORDINAL.
+
+
+
+
+ The MAPI property PR_PROVIDER_SUBMIT_TIME.
+
+
+
+
+ The MAPI property PR_PROVIDER_UID.
+
+
+
+
+ The MAPI property PR_PUID.
+
+
+
+
+ The MAPI property PR_RADIO_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ENTRYID.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_READ_RECEIPT_ENTRYID.
+
+
+
+
+ The MAPI property PR_READ_RECEIPT_REQUESTED.
+
+
+
+
+ The MAPI property PR_READ_RECEIPT_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_RECEIPT_TIME.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_ENTRYID.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_NAME.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_RECEIVE_FOLDER_SETTINGS.
+
+
+
+
+ The MAPI property PR_RECIPIENT_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_RECIPIENT_NUMBER_FOR_ADVICE.
+
+
+
+
+ The MAPI property PR_RECIPIENT_REASSIGNMENT_PROHIBITED.
+
+
+
+
+ The MAPI property PR_RECIPIENT_STATUS.
+
+
+
+
+ The MAPI property PR_RECIPIENT_TYPE.
+
+
+
+
+ The MAPI property PR_RECORD_KEY.
+
+
+
+
+ The MAPI property PR_REDIRECTION_HISTORY.
+
+
+
+
+ The MAPI property PR_REFERRED_BY_NAME.
+
+
+
+
+ The MAPI property PR_REGISTERED_MAIL_TYPE.
+
+
+
+
+ The MAPI property PR_RELATED_IPMS.
+
+
+
+
+ The MAPI property PR_REMOTE_PROGRESS.
+
+
+
+
+ The MAPI property PR_REMOTE_PROGRESS_TEXT.
+
+
+
+
+ The MAPI property PR_REMOTE_VALIDATE_OK.
+
+
+
+
+ The MAPI property PR_RENDERING_POSITION.
+
+
+
+
+ The MAPI property PR_REPLY_RECIPIENT_ENTRIES.
+
+
+
+
+ The MAPI property PR_REPLY_RECIPIENT_NAMES.
+
+
+
+
+ The MAPI property PR_REPLY_REQUESTED.
+
+
+
+
+ The MAPI property PR_REPLY_TIME.
+
+
+
+
+ The MAPI property PR_REPORT_ENTRYID.
+
+
+
+
+ The MAPI property PR_REPORTING_DLL_NAME.
+
+
+
+
+ The MAPI property PR_REPORTING_MTA_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_REPORT_NAME.
+
+
+
+
+ The MAPI property PR_REPORT_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_REPORT_TAG.
+
+
+
+
+ The MAPI property PR_REPORT_TEXT.
+
+
+
+
+ The MAPI property PR_REPORT_TIME.
+
+
+
+
+ The MAPI property PR_REQUESTED_DELIVERY_METHOD.
+
+
+
+
+ The MAPI property PR_RESOURCE_FLAGS.
+
+
+
+
+ The MAPI property PR_RESOURCE_METHODS.
+
+
+
+
+ The MAPI property PR_RESOURCE_PATH.
+
+
+
+
+ The MAPI property PR_RESOURCE_TYPE.
+
+
+
+
+ The MAPI property PR_RESPONSE_REQUESTED.
+
+
+
+
+ The MAPI property PR_RESPONSIBILITY.
+
+
+
+
+ The MAPI property PR_RETURNED_IPM.
+
+
+
+
+ The MAPI property PR_ROWID.
+
+
+
+
+ The MAPI property PR_ROW_TYPE.
+
+
+
+
+ The MAPI property PR_RTF_COMPRESSED.
+
+
+
+
+ The MAPI property PR_RTF_IN_SYNC.
+
+
+
+
+ The MAPI property PR_SYNC_BODY_COUNT.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_BODY_CRC.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_BODY_TAG.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_PREFIX_COUNT.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_TRAILING_COUNT.
+
+
+
+
+ The MAPI property PR_SEARCH.
+
+
+
+
+ The MAPI property PR_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_SECURITY.
+
+
+
+
+ The MAPI property PR_SELECTABLE.
+
+
+
+
+ The MAPI property PR_SENDER_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_SENDER_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_SENDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_SENDER_NAME.
+
+
+
+
+ The MAPI property PR_SENDER_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_SEND_INTERNET_ENCODING.
+
+
+
+
+ The MAPI property PR_SEND_RECALL_REPORT.
+
+
+
+
+ The MAPI property PR_SEND_RICH_INFO.
+
+
+
+
+ The MAPI property PR_SENSITIVITY.
+
+
+
+
+ The MAPI property PR_SENTMAIL_ENTRYID.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_ENTRYID.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_SERVICE_DELETE_FILES.
+
+
+
+
+ The MAPI property PR_SERVICE_DLL_NAME.
+
+
+
+
+ The MAPI property PR_SERVICE_ENTRY_NAME.
+
+
+
+
+ The MAPI property PR_SERVICE_EXTRA_UIDS.
+
+
+
+
+ The MAPI property PR_SERVICE_NAME.
+
+
+
+
+ The MAPI property PR_SERVICES.
+
+
+
+
+ The MAPI property PR_SERVICE_SUPPORT_FILES.
+
+
+
+
+ The MAPI property PR_SERVICE_UID.
+
+
+
+
+ The MAPI property PR_SEVEN_BIT_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_SMTP_ADDRESS.
+
+
+
+
+ The MAPI property PR_SPOOLER_STATUS.
+
+
+
+
+ The MAPI property PR_SPOUSE_NAME.
+
+
+
+
+ The MAPI property PR_START_DATE.
+
+
+
+
+ The MAPI property PR_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_STATUS.
+
+
+
+
+ The MAPI property PR_STATUS_CODE.
+
+
+
+
+ The MAPI property PR_STATUS_STRING.
+
+
+
+
+ The MAPI property PR_STORE_ENTRYID.
+
+
+
+
+ The MAPI property PR_STORE_PROVIDERS.
+
+
+
+
+ The MAPI property PR_STORE_RECORD_KEY.
+
+
+
+
+ The MAPI property PR_STORE_STATE.
+
+
+
+
+ The MAPI property PR_STORE_SUPPORT_MASK.
+
+
+
+
+ The MAPI property PR_STREET_ADDRESS.
+
+
+
+
+ The MAPI property PR_SUBFOLDERS.
+
+
+
+
+ The MAPI property PR_SUBJECT.
+
+
+
+
+ The MAPI property PR_SUBJECT_IPM.
+
+
+
+
+ The MAPI property PR_SUBJECT_PREFIX.
+
+
+
+
+ The MAPI property PR_SUBMIT_FLAGS.
+
+
+
+
+ The MAPI property PR_SUPERSEDES.
+
+
+
+
+ The MAPI property PR_SUPPLEMENTARY_INFO.
+
+
+
+
+ The MAPI property PR_SURNAME.
+
+
+
+
+ The MAPI property PR_TELEX_NUMBER.
+
+
+
+
+ The MAPI property PR_TEMPLATEID.
+
+
+
+
+ The MAPI property PR_TITLE.
+
+
+
+
+ The MAPI property PR_TNEF_CORRELATION_KEY.
+
+
+
+
+ The MAPI property PR_TRANSMITABLE_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_TRANSPORT_KEY.
+
+
+
+
+ The MAPI property PR_TRANSPORT_MESSAGE_HEADERS.
+
+
+
+
+ The MAPI property PR_TRANSPORT_PROVIDERS.
+
+
+
+
+ The MAPI property PR_TRANSPORT_STATUS.
+
+
+
+
+ The MAPI property PR_TTYTDD_PHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_TYPE_OF_MTS_USER.
+
+
+
+
+ The MAPI property PR_USER_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_USER_X509_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_VALID_FOLDER_MASK.
+
+
+
+
+ The MAPI property PR_VIEWS_ENTRYID.
+
+
+
+
+ The MAPI property PR_WEDDING_ANNIVERSARY.
+
+
+
+
+ The MAPI property PR_X400_CONTENT_TYPE.
+
+
+
+
+ The MAPI property PR_X400_DEFERRED_DELIVERY_CANCEL.
+
+
+
+
+ The MAPI property PR_XPOS.
+
+
+
+
+ The MAPI property PR_YPOS.
+
+
+
+
+ A TNEF property reader.
+
+
+ A TNEF property reader.
+
+
+
+
+ Gets a value indicating whether the current property is an embedded TNEF message.
+
+
+ Gets a value indicating whether the current property is an embedded TNEF message.
+
+ true if the current property is an embedded TNEF message; otherwise, false.
+
+
+
+ Gets a value indicating whether or not the current property has multiple values.
+
+
+ Gets a value indicating whether or not the current property has multiple values.
+
+ true if the current property has multiple values; otherwise, false.
+
+
+
+ Gets a value indicating whether or not the current property is a named property.
+
+
+ Gets a value indicating whether or not the current property is a named property.
+
+ true if the current property is a named property; otherwise, false.
+
+
+
+ Gets a value indicating whether the current property contains object values.
+
+
+ Gets a value indicating whether the current property contains object values.
+
+ true if the current property contains object values; otherwise, false.
+
+
+
+ Gets the number of properties available.
+
+
+ Gets the number of properties available.
+
+ The property count.
+
+
+
+ Gets the property name identifier.
+
+
+ Gets the property name identifier.
+
+ The property name identifier.
+
+
+
+ Gets the property tag.
+
+
+ Gets the property tag.
+
+ The property tag.
+
+
+
+ Gets the length of the raw value.
+
+
+ Gets the length of the raw value.
+
+ The length of the raw value.
+
+
+
+ Gets the raw value stream offset.
+
+
+ Gets the raw value stream offset.
+
+ The raw value stream offset.
+
+
+
+ Gets the number of table rows available.
+
+
+ Gets the number of table rows available.
+
+ The row count.
+
+
+
+ Gets the number of values available.
+
+
+ Gets the number of values available.
+
+ The value count.
+
+
+
+ Gets the type of the value.
+
+
+ Gets the type of the value.
+
+ The type of the value.
+
+
+
+ Gets the embedded TNEF message reader.
+
+
+ Gets the embedded TNEF message reader.
+
+ The embedded TNEF message reader.
+
+ The property does not contain any more values.
+ -or-
+ The property value is not an embedded message.
+
+
+
+
+ Gets the raw value of the attribute or property as a stream.
+
+
+ Gets the raw value of the attribute or property as a stream.
+
+ The raw value stream.
+
+ The property does not contain any more values.
+
+
+
+
+ Advances to the next MAPI property.
+
+
+ Advances to the next MAPI property.
+
+ true if there is another property available to be read; otherwise false.
+
+ The TNEF data is corrupt or invalid.
+
+
+
+
+ Advances to the next table row of properties.
+
+
+ Advances to the next table row of properties.
+
+ true if there is another row available to be read; otherwise false.
+
+ The TNEF data is corrupt or invalid.
+
+
+
+
+ Advances to the next value in the TNEF stream.
+
+
+ Advances to the next value in the TNEF stream.
+
+ true if there is another value available to be read; otherwise false.
+
+ The TNEF data is corrupt or invalid.
+
+
+
+
+ Reads the raw attribute or property value as a sequence of bytes.
+
+
+ Reads the raw attribute or property value as a sequence of bytes.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ An I/O error occurred.
+
+
+
+
+ Reads the raw attribute or property value as a sequence of unicode characters.
+
+
+ Reads the raw attribute or property value as a sequence of unicode characters.
+
+ The total number of characters read into the buffer. This can be less than the number of characters
+ requested if that many bytes are not currently available, or zero (0) if the end of the stream has been
+ reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of characters to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain characters starting
+ at the specified .
+
+
+ An I/O error occurred.
+
+
+
+
+ Reads the value.
+
+
+ Reads an attribute or property value as its native type.
+
+ The value.
+
+ There are no more values to read or the value could not be read.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a boolean.
+
+
+ Reads any integer-based attribute or property value as a boolean.
+
+ The value as a boolean.
+
+ There are no more values to read or the value could not be read as a boolean.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a byte array.
+
+
+ Reads any string, binary blob, Class ID, or Object attribute or property value as a byte array.
+
+ The value as a byte array.
+
+ There are no more values to read or the value could not be read as a byte array.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a date and time.
+
+
+ Reads any date and time attribute or property value as a .
+
+ The value as a date and time.
+
+ There are no more values to read or the value could not be read as a date and time.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a double.
+
+
+ Reads any numeric attribute or property value as a double.
+
+ The value as a double.
+
+ There are no more values to read or the value could not be read as a double.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a float.
+
+
+ Reads any numeric attribute or property value as a float.
+
+ The value as a float.
+
+ There are no more values to read or the value could not be read as a float.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a GUID.
+
+
+ Reads any Class ID value as a GUID.
+
+ The value as a GUID.
+
+ There are no more values to read or the value could not be read as a GUID.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a 16-bit integer.
+
+
+ Reads any integer-based attribute or property value as a 16-bit integer.
+
+ The value as a 16-bit integer.
+
+ There are no more values to read or the value could not be read as a 16-bit integer.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a 32-bit integer.
+
+
+ Reads any integer-based attribute or property value as a 32-bit integer.
+
+ The value as a 32-bit integer.
+
+ There are no more values to read or the value could not be read as a 32-bit integer.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a 64-bit integer.
+
+
+ Reads any integer-based attribute or property value as a 64-bit integer.
+
+ The value as a 64-bit integer.
+
+ There are no more values to read or the value could not be read as a 64-bit integer.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Reads the value as a string.
+
+
+ Reads any string or binary blob values as a string.
+
+ The value as a string.
+
+ There are no more values to read or the value could not be read as a string.
+
+
+ The TNEF stream is truncated and the value could not be read.
+
+
+
+
+ Serves as a hash function for a object.
+
+
+ Serves as a hash function for a object.
+
+ A hash code for this instance that is suitable for use in hashing algorithms
+ and data structures such as a hash table.
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Determines whether the specified is equal to the current .
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ A TNEF property tag.
+
+
+ A TNEF property tag.
+
+
+
+
+ The MAPI property PR_AB_DEFAULT_DIR.
+
+
+ The MAPI property PR_AB_DEFAULT_DIR.
+
+
+
+
+ The MAPI property PR_AB_DEFAULT_PAB.
+
+
+ The MAPI property PR_AB_DEFAULT_PAD.
+
+
+
+
+ The MAPI property PR_AB_PROVIDER_ID.
+
+
+ The MAPI property PR_AB_PROVIDER_ID.
+
+
+
+
+ The MAPI property PR_AB_PROVIDERS.
+
+
+ The MAPI property PR_AB_PROVIDERS.
+
+
+
+
+ The MAPI property PR_AB_SEARCH_PATH.
+
+
+ The MAPI property PR_AB_SEARCH_PATH.
+
+
+
+
+ The MAPI property PR_AB_SEARCH_PATH_UPDATE.
+
+
+ The MAPI property PR_AB_SEARCH_PATH_UPDATE.
+
+
+
+
+ The MAPI property PR_ACCESS.
+
+
+ The MAPI property PR_ACCESS.
+
+
+
+
+ The MAPI property PR_ACCESS_LEVEL.
+
+
+ The MAPI property PR_ACCESS_LEVEL.
+
+
+
+
+ The MAPI property PR_ACCOUNT.
+
+
+ The MAPI property PR_ACCOUNT.
+
+
+
+
+ The MAPI property PR_ACCOUNT.
+
+
+ The MAPI property PR_ACCOUNT.
+
+
+
+
+ The MAPI property PR_ACKNOWLEDGEMENT_MODE.
+
+
+ The MAPI property PR_ACKNOWLEDGEMENT_MODE.
+
+
+
+
+ The MAPI property PR_ADDRTYPE.
+
+
+ The MAPI property PR_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ADDRTYPE.
+
+
+ The MAPI property PR_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ALTERNATE_RECIPIENT.
+
+
+ The MAPI property PR_ALTERNATE_RECIPIENT.
+
+
+
+
+ The MAPI property PR_ALTERNATE_RECIPIENT_ALLOWED.
+
+
+ The MAPI property PR_ALTERNATE_RECIPIENT_ALLOWED.
+
+
+
+
+ The MAPI property PR_ANR.
+
+
+ The MAPI property PR_ANR.
+
+
+
+
+ The MAPI property PR_ANR.
+
+
+ The MAPI property PR_ANR.
+
+
+
+
+ The MAPI property PR_ASSISTANT.
+
+
+ The MAPI property PR_ASSISTANT.
+
+
+
+
+ The MAPI property PR_ASSISTANT.
+
+
+ The MAPI property PR_ASSISTANT.
+
+
+
+
+ The MAPI property PR_ASSISTANT_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_ASSISTANT_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_ASSISTANT_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_ASSISTANT_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_ASSOC_CONTENT_COUNT.
+
+
+ The MAPI property PR_ASSOC_CONTENT_COUNT.
+
+
+
+
+ The MAPI property PR_ATTACH_ADDITIONAL_INFO.
+
+
+ The MAPI property PR_ATTACH_ADDITIONAL_INFO.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_BASE.
+
+
+ The MAPI property PR_ATTACH_CONTENT_BASE.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_BASE.
+
+
+ The MAPI property PR_ATTACH_CONTENT_BASE.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_ID.
+
+
+ The MAPI property PR_ATTACH_CONTENT_ID.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_ID.
+
+
+ The MAPI property PR_ATTACH_CONTENT_ID.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_LOCATION.
+
+
+ The MAPI property PR_ATTACH_CONTENT_LOCATION.
+
+
+
+
+ The MAPI property PR_ATTACH_CONTENT_LOCATION.
+
+
+ The MAPI property PR_ATTACH_CONTENT_LOCATION.
+
+
+
+
+ The MAPI property PR_ATTACH_DATA.
+
+
+ The MAPI property PR_ATTACH_DATA.
+
+
+
+
+ The MAPI property PR_ATTACH_DATA.
+
+
+ The MAPI property PR_ATTACH_DATA.
+
+
+
+
+ The MAPI property PR_ATTACH_DISPOSITION.
+
+
+ The MAPI property PR_ATTACH_DISPOSITION.
+
+
+
+
+ The MAPI property PR_ATTACH_DISPOSITION.
+
+
+ The MAPI property PR_ATTACH_DISPOSITION.
+
+
+
+
+ The MAPI property PR_ATTACH_ENCODING.
+
+
+ The MAPI property PR_ATTACH_ENCODING.
+
+
+
+
+ The MAPI property PR_ATTACH_EXTENSION.
+
+
+ The MAPI property PR_ATTACH_EXTENSION.
+
+
+
+
+ The MAPI property PR_ATTACH_EXTENSION.
+
+
+ The MAPI property PR_ATTACH_EXTENSION.
+
+
+
+
+ The MAPI property PR_ATTACH_FILENAME.
+
+
+ The MAPI property PR_ATTACH_FILENAME.
+
+
+
+
+ The MAPI property PR_ATTACH_FILENAME.
+
+
+ The MAPI property PR_ATTACH_FILENAME.
+
+
+
+
+ The MAPI property PR_ATTACH_FLAGS.
+
+
+ The MAPI property PR_ATTACH_FLAGS.
+
+
+
+
+ The MAPI property PR_ATTACH_LONG_FILENAME.
+
+
+ The MAPI property PR_ATTACH_LONG_FILENAME.
+
+
+
+
+ The MAPI property PR_ATTACH_LONG_FILENAME.
+
+
+ The MAPI property PR_ATTACH_LONG_FILENAME.
+
+
+
+
+ The MAPI property PR_ATTACH_LONG_PATHNAME.
+
+
+ The MAPI property PR_ATTACH_LONG_PATHNAME.
+
+
+
+
+ The MAPI property PR_ATTACH_LONG_PATHNAME.
+
+
+ The MAPI property PR_ATTACH_LONG_PATHNAME.
+
+
+
+
+ The MAPI property PR_ATTACHMENT_X400_PARAMETERS.
+
+
+ The MAPI property PR_ATTACHMENT_X400_PARAMETERS.
+
+
+
+
+ The MAPI property PR_ATTACH_METHOD.
+
+
+ The MAPI property PR_ATTACH_METHOD.
+
+
+
+
+ The MAPI property PR_ATTACH_MIME_SEQUENCE.
+
+
+ The MAPI property PR_ATTACH_MIME_SEQUENCE.
+
+
+
+
+ The MAPI property PR_ATTACH_MIME_TAG.
+
+
+ The MAPI property PR_ATTACH_MIME_TAG.
+
+
+
+
+ The MAPI property PR_ATTACH_MIME_TAG.
+
+
+ The MAPI property PR_ATTACH_MIME_TAG.
+
+
+
+
+ The MAPI property PR_ATTACH_NETSCAPE_MAC_INFO.
+
+
+ The MAPI property PR_ATTACH_NETSCAPE_MAC_INFO.
+
+
+
+
+ The MAPI property PR_ATTACH_NUM.
+
+
+ The MAPI property PR_ATTACH_NUM.
+
+
+
+
+ The MAPI property PR_ATTACH_PATHNAME.
+
+
+ The MAPI property PR_ATTACH_PATHNAME.
+
+
+
+
+ The MAPI property PR_ATTACH_PATHNAME.
+
+
+ The MAPI property PR_ATTACH_PATHNAME.
+
+
+
+
+ The MAPI property PR_ATTACH_RENDERING.
+
+
+ The MAPI property PR_ATTACH_RENDERING.
+
+
+
+
+ The MAPI property PR_ATTACH_SIZE.
+
+
+ The MAPI property PR_ATTACH_SIZE.
+
+
+
+
+ The MAPI property PR_ATTACH_TAG.
+
+
+ The MAPI property PR_ATTACH_TAG.
+
+
+
+
+ The MAPI property PR_ATTACH_TRANSPORT_NAME.
+
+
+ The MAPI property PR_ATTACH_TRANSPORT_NAME.
+
+
+
+
+ The MAPI property PR_ATTACH_TRANSPORT_NAME.
+
+
+ The MAPI property PR_ATTACH_TRANSPORT_NAME.
+
+
+
+
+ The MAPI property PR_AUTHORIZING_USERS.
+
+
+ The MAPI property PR_AUTHORIZING_USERS.
+
+
+
+
+ The MAPI property PR_AUTOFORWARDED.
+
+
+ The MAPI property PR_AUTOFORWARDED.
+
+
+
+
+ The MAPI property PR_AUTOFORWARDING_COMMENT.
+
+
+ The MAPI property PR_AUTOFORWARDING_COMMENT.
+
+
+
+
+ The MAPI property PR_AUTOFORWARDING_COMMENT.
+
+
+ The MAPI property PR_AUTOFORWARDING_COMMENT.
+
+
+
+
+ The MAPI property PR_AUTORESPONSE_SUPPRESS.
+
+
+ The MAPI property PR_AUTORESPONSE_SUPPRESS.
+
+
+
+
+ The MAPI property PR_BEEPER_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_BEEPER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BEEPER_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_BEEPER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BIRTHDAY.
+
+
+ The MAPI property PR_BIRTHDAY.
+
+
+
+
+ The MAPI property PR_BODY.
+
+
+ The MAPI property PR_BODY.
+
+
+
+
+ The MAPI property PR_BODY.
+
+
+ The MAPI property PR_BODY.
+
+
+
+
+ The MAPI property PR_BODY_CONTENT_ID.
+
+
+ The MAPI property PR_BODY_CONTENT_ID.
+
+
+
+
+ The MAPI property PR_BODY_CONTENT_ID.
+
+
+ The MAPI property PR_BODY_CONTENT_ID.
+
+
+
+
+ The MAPI property PR_BODY_CONTENT_LOCATION.
+
+
+ The MAPI property PR_BODY_CONTENT_LOCATION.
+
+
+
+
+ The MAPI property PR_BODY_CONTENT_LOCATION.
+
+
+ The MAPI property PR_BODY_CONTENT_LOCATION.
+
+
+
+
+ The MAPI property PR_BODY_CRC.
+
+
+ The MAPI property PR_BODY_CRC.
+
+
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+ The MAPI property PR_BODY_HTML.
+
+
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_BUSINESS2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_CITY.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_CITY.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_COUNTRY.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_COUNTRY.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_CODE.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_CODE.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_STREET.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_STREET.
+
+
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_STREET.
+
+
+ The MAPI property PR_BUSINESS_ADDRESS_POSTAL_STREET.
+
+
+
+
+ The MAPI property PR_BUSINESS_FAX_NUMBER.
+
+
+ The MAPI property PR_BUSINESS_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS_FAX_NUMBER.
+
+
+ The MAPI property PR_BUSINESS_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_BUSINESS_HOME_PAGE.
+
+
+ The MAPI property PR_BUSINESS_HOME_PAGE.
+
+
+
+
+ The MAPI property PR_BUSINESS_HOME_PAGE.
+
+
+ The MAPI property PR_BUSINESS_HOME_PAGE.
+
+
+
+
+ The MAPI property PR_CALLBACK_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_CALLBACK_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CALLBACK_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_CALLBACK_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CAR_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_CAR_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CAR_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_CAR_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_CHILDRENS_NAMES.
+
+
+ The MAPI property PR_CHILDRENS_NAMES.
+
+
+
+
+ The MAPI property PR_CHILDRENS_NAMES.
+
+
+ The MAPI property PR_CHILDRENS_NAMES.
+
+
+
+
+ The MAPI property PR_CLIENT_SUBMIT_TIME.
+
+
+ The MAPI property PR_CLIENT_SUBMIT_TIME.
+
+
+
+
+ The MAPI property PR_COMMENT.
+
+
+ The MAPI property PR_COMMENT.
+
+
+
+
+ The MAPI property PR_COMMENT.
+
+
+ The MAPI property PR_COMMENT.
+
+
+
+
+ The MAPI property PR_COMMON_VIEWS_ENTRYID.
+
+
+ The MAPI property PR_COMMON_VIEWS_ENTRYID.
+
+
+
+
+ The MAPI property PR_COMPANY_MAIN_PHONE_NUMBER.
+
+
+ The MAPI property PR_COMPANY_MAIN_PHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_COMPANY_MAIN_PHONE_NUMBER.
+
+
+ The MAPI property PR_COMPANY_MAIN_PHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_COMPANY_NAME.
+
+
+ The MAPI property PR_COMPANY_NAME.
+
+
+
+
+ The MAPI property PR_COMPANY_NAME.
+
+
+ The MAPI property PR_COMPANY_NAME.
+
+
+
+
+ The MAPI property PR_COMPUTER_NETWORK_NAME.
+
+
+ The MAPI property PR_COMPUTER_NETWORK_NAME.
+
+
+
+
+ The MAPI property PR_COMPUTER_NETWORK_NAME.
+
+
+ The MAPI property PR_COMPUTER_NETWORK_NAME.
+
+
+
+
+ The MAPI property PR_CONTACT_ADDRTYPES.
+
+
+ The MAPI property PR_CONTACT_ADDRTYPES.
+
+
+
+
+ The MAPI property PR_CONTACT_ADDRTYPES.
+
+
+ The MAPI property PR_CONTACT_ADDRTYPES.
+
+
+
+
+ The MAPI property PR_CONTACT_DEFAULT_ADDRESS_INDEX.
+
+
+ The MAPI property PR_CONTACT_DEFAULT_ADDRESS_INDEX.
+
+
+
+
+ The MAPI property PR_CONTACT_EMAIL_ADDRESSES.
+
+
+ The MAPI property PR_CONTACT_EMAIL_ADDRESSES.
+
+
+
+
+ The MAPI property PR_CONTACT_EMAIL_ADDRESSES.
+
+
+ The MAPI property PR_CONTACT_EMAIL_ADDRESSES.
+
+
+
+
+ The MAPI property PR_CONTACT_ENTRYIDS.
+
+
+ The MAPI property PR_CONTACT_ENTRYIDS.
+
+
+
+
+ The MAPI property PR_CONTACT_VERSION.
+
+
+ The MAPI property PR_CONTACT_VERSION.
+
+
+
+
+ The MAPI property PR_CONTAINER_CLASS.
+
+
+ The MAPI property PR_CONTAINER_CLASS.
+
+
+
+
+ The MAPI property PR_CONTAINER_CLASS.
+
+
+ The MAPI property PR_CONTAINER_CLASS.
+
+
+
+
+ The MAPI property PR_CONTAINER_CONTENTS.
+
+
+ The MAPI property PR_CONTAINER_CONTENTS.
+
+
+
+
+ The MAPI property PR_CONTAINER_FLAGS.
+
+
+ The MAPI property PR_CONTAINER_FLAGS.
+
+
+
+
+ The MAPI property PR_CONTAINER_HIERARCHY.
+
+
+ The MAPI property PR_CONTAINER_HIERARCHY.
+
+
+
+
+ The MAPI property PR_CONTAINER_MODIFY_VERSION.
+
+
+ The MAPI property PR_CONTAINER_MODIFY_VERSION.
+
+
+
+
+ The MAPI property PR_CONTENT_CONFIDENTIALITY_ALGORITHM_ID.
+
+
+ The MAPI property PR_CONTENT_CONFIDENTIALITY_ALGORITHM_ID.
+
+
+
+
+ The MAPI property PR_CONTENT_CORRELATOR.
+
+
+ The MAPI property PR_CONTENT_CORRELATOR.
+
+
+
+
+ The MAPI property PR_CONTENT_COUNT.
+
+
+ The MAPI property PR_CONTENT_COUNT.
+
+
+
+
+ The MAPI property PR_CONTENT_IDENTIFIER.
+
+
+ The MAPI property PR_CONTENT_IDENTIFIER.
+
+
+
+
+ The MAPI property PR_CONTENT_IDENTIFIER.
+
+
+ The MAPI property PR_CONTENT_IDENTIFIER.
+
+
+
+
+ The MAPI property PR_CONTENT_INTEGRITY_CHECK.
+
+
+ The MAPI property PR_CONTENT_INTEGRITY_CHECK.
+
+
+
+
+ The MAPI property PR_CONTENT_LENGTH.
+
+
+ The MAPI property PR_CONTENT_LENGTH.
+
+
+
+
+ The MAPI property PR_CONTENT_RETURN_REQUESTED.
+
+
+ The MAPI property PR_CONTENT_RETURN_REQUESTED.
+
+
+
+
+ The MAPI property PR_CONTENTS_SORT_ORDER.
+
+
+ The MAPI property PR_CONTENTS_SORT_ORDER.
+
+
+
+
+ The MAPI property PR_CONTENT_UNREAD.
+
+
+ The MAPI property PR_CONTENT_UNREAD.
+
+
+
+
+ The MAPI property PR_CONTROL_FLAGS.
+
+
+ The MAPI property PR_CONTROL_FLAGS.
+
+
+
+
+ The MAPI property PR_CONTROL_ID.
+
+
+ The MAPI property PR_CONTROL_ID.
+
+
+
+
+ The MAPI property PR_CONTROL_STRUCTURE.
+
+
+ The MAPI property PR_CONTROL_STRUCTURE.
+
+
+
+
+ The MAPI property PR_CONTROL_TYPE.
+
+
+ The MAPI property PR_CONTROL_TYPE.
+
+
+
+
+ The MAPI property PR_CONVERSATION_INDEX.
+
+
+ The MAPI property PR_CONVERSATION_INDEX.
+
+
+
+
+ The MAPI property PR_CONVERSATION_KEY.
+
+
+ The MAPI property PR_CONVERSATION_KEY.
+
+
+
+
+ The MAPI property PR_CONVERSATION_TOPIC.
+
+
+ The MAPI property PR_CONVERSATION_TOPIC.
+
+
+
+
+ The MAPI property PR_CONVERSATION_TOPIC.
+
+
+ The MAPI property PR_CONVERSATION_TOPIC.
+
+
+
+
+ The MAPI property PR_CONVERSION_EITS.
+
+
+ The MAPI property PR_CONVERSION_EITS.
+
+
+
+
+ The MAPI property PR_CONVERSION_PROHIBITED.
+
+
+ The MAPI property PR_CONVERSION_PROHIBITED.
+
+
+
+
+ The MAPI property PR_CONVERSION_WITH_LOSS_PROHIBITED.
+
+
+ The MAPI property PR_CONVERSION_WITH_LOSS_PROHIBITED.
+
+
+
+
+ The MAPI property PR_CONVERTED_EITS.
+
+
+ The MAPI property PR_CONVERTED_EITS.
+
+
+
+
+ The MAPI property PR_CORRELATE.
+
+
+ The MAPI property PR_CORRELATE.
+
+
+
+
+ The MAPI property PR_CORRELATE_MTSID.
+
+
+ The MAPI property PR_CORRELATE_MTSID.
+
+
+
+
+ The MAPI property PR_COUNTRY.
+
+
+ The MAPI property PR_COUNTRY.
+
+
+
+
+ The MAPI property PR_COUNTRY.
+
+
+ The MAPI property PR_COUNTRY.
+
+
+
+
+ The MAPI property PR_CREATE_TEMPLATES.
+
+
+ The MAPI property PR_CREATE_TEMPLATES.
+
+
+
+
+ The MAPI property PR_CREATION_TIME.
+
+
+ The MAPI property PR_CREATION_TIME.
+
+
+
+
+ The MAPI property PR_CREATION_VERSION.
+
+
+ The MAPI property PR_CREATION_VERSION.
+
+
+
+
+ The MAPI property PR_CURRENT_VERSION.
+
+
+ The MAPI property PR_CURRENT_VERSION.
+
+
+
+
+ The MAPI property PR_CUSTOMER_ID.
+
+
+ The MAPI property PR_CUSTOMER_ID.
+
+
+
+
+ The MAPI property PR_CUSTOMER_ID.
+
+
+ The MAPI property PR_CUSTOMER_ID.
+
+
+
+
+ The MAPI property PR_DEFAULT_PROFILE.
+
+
+ The MAPI property PR_DEFAULT_PROFILE.
+
+
+
+
+ The MAPI property PR_DEFAULT_STORE.
+
+
+ The MAPI property PR_DEFAULT_STORE.
+
+
+
+
+ The MAPI property PR_DEFAULT_VIEW_ENTRYID.
+
+
+ The MAPI property PR_DEFAULT_VIEW_ENTRYID.
+
+
+
+
+ The MAPI property PR_DEF_CREATE_DL.
+
+
+ The MAPI property PR_DEF_CREATE_DL.
+
+
+
+
+ The MAPI property PR_DEF_CREATE_MAILUSER.
+
+
+ The MAPI property PR_DEF_CREATE_MAILUSER.
+
+
+
+
+ The MAPI property PR_DEFERRED_DELIVERY_TIME.
+
+
+ The MAPI property PR_DEFERRED_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_DELEGATION.
+
+
+ The MAPI property PR_DELEGATION.
+
+
+
+
+ The MAPI property PR_DELETE_AFTER_SUBMIT.
+
+
+ The MAPI property PR_DELETE_AFTER_SUBMIT.
+
+
+
+
+ The MAPI property PR_DELIVER_TIME.
+
+
+ The MAPI property PR_DELIVER_TIME.
+
+
+
+
+ The MAPI property PR_DELIVERY_POINT.
+
+
+ The MAPI property PR_DELIVERY_POINT.
+
+
+
+
+ The MAPI property PR_DELTAX.
+
+
+ The MAPI property PR_DELTAX.
+
+
+
+
+ The MAPI property PR_DELTAY.
+
+
+ The MAPI property PR_DELTAY.
+
+
+
+
+ The MAPI property PR_DEPARTMENT_NAME.
+
+
+ The MAPI property PR_DEPARTMENT_NAME.
+
+
+
+
+ The MAPI property PR_DEPARTMENT_NAME.
+
+
+ The MAPI property PR_DEPARTMENT_NAME.
+
+
+
+
+ The MAPI property PR_DEPTH.
+
+
+ The MAPI property PR_DEPTH.
+
+
+
+
+ The MAPI property PR_DETAILS_TABLE.
+
+
+ The MAPI property PR_DETAILS_TABLE.
+
+
+
+
+ The MAPI property PR_DISCARD_REASON.
+
+
+ The MAPI property PR_DISCARD_REASON.
+
+
+
+
+ The MAPI property PR_DISCLOSE_RECIPIENTS.
+
+
+ The MAPI property PR_DISCLOSE_RECIPIENTS.
+
+
+
+
+ The MAPI property PR_DISCLOSURE_OF_RECIPIENTS.
+
+
+ The MAPI property PR_DISCLOSURE_OF_RECIPIENTS.
+
+
+
+
+ The MAPI property PR_DISCRETE_VALUES.
+
+
+ The MAPI property PR_DISCRETE_VALUES.
+
+
+
+
+ The MAPI property PR_DISC_VAL.
+
+
+ The MAPI property PR_DISC_VAL.
+
+
+
+
+ The MAPI property PR_DISPLAY_BCC.
+
+
+ The MAPI property PR_DISPLAY_BCC.
+
+
+
+
+ The MAPI property PR_DISPLAY_BCC.
+
+
+ The MAPI property PR_DISPLAY_BCC.
+
+
+
+
+ The MAPI property PR_DISPLAY_CC.
+
+
+ The MAPI property PR_DISPLAY_CC.
+
+
+
+
+ The MAPI property PR_DISPLAY_CC.
+
+
+ The MAPI property PR_DISPLAY_CC.
+
+
+
+
+ The MAPI property PR_DISPLAY_NAME.
+
+
+ The MAPI property PR_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_DISPLAY_NAME.
+
+
+ The MAPI property PR_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_DISPLAY_NAME_PREFIX.
+
+
+ The MAPI property PR_DISPLAY_NAME_PREFIX.
+
+
+
+
+ The MAPI property PR_DISPLAY_NAME_PREFIX.
+
+
+ The MAPI property PR_DISPLAY_NAME_PREFIX.
+
+
+
+
+ The MAPI property PR_DISPLAY_TO.
+
+
+ The MAPI property PR_DISPLAY_TO.
+
+
+
+
+ The MAPI property PR_DISPLAY_TO.
+
+
+ The MAPI property PR_DISPLAY_TO.
+
+
+
+
+ The MAPI property PR_DISPLAY_TYPE.
+
+
+ The MAPI property PR_DISPLAY_TYPE.
+
+
+
+
+ The MAPI property PR_DL_EXPANSION_HISTORY.
+
+
+ The MAPI property PR_DL_EXPANSION_HISTORY.
+
+
+
+
+ The MAPI property PR_DL_EXPANSION_PROHIBITED.
+
+
+ The MAPI property PR_DL_EXPANSION_PROHIBITED.
+
+
+
+
+ The MAPI property PR_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_END_DATE.
+
+
+ The MAPI property PR_END_DATE.
+
+
+
+
+ The MAPI property PR_ENTRYID.
+
+
+ The MAPI property PR_ENTRYID.
+
+
+
+
+ The MAPI property PR_EXPAND_BEGIN_TIME.
+
+
+ The MAPI property PR_EXPAND_BEGIN_TIME.
+
+
+
+
+ The MAPI property PR_EXPANDED_BEGIN_TIME.
+
+
+ The MAPI property PR_EXPANDED_BEGIN_TIME.
+
+
+
+
+ The MAPI property PR_EXPANDED_END_TIME.
+
+
+ The MAPI property PR_EXPANDED_END_TIME.
+
+
+
+
+ The MAPI property PR_EXPAND_END_TIME.
+
+
+ The MAPI property PR_EXPAND_END_TIME.
+
+
+
+
+ The MAPI property PR_EXPIRY_TIME.
+
+
+ The MAPI property PR_EXPIRY_TIME.
+
+
+
+
+ The MAPI property PR_EXPLICIT_CONVERSION.
+
+
+ The MAPI property PR_EXPLICIT_CONVERSION.
+
+
+
+
+ The MAPI property PR_FILTERING_HOOKS.
+
+
+ The MAPI property PR_FILTERING_HOOKS.
+
+
+
+
+ The MAPI property PR_FINDER_ENTRYID.
+
+
+ The MAPI property PR_FINDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_FOLDER_ASSOCIATED_CONTENTS.
+
+
+ The MAPI property PR_FOLDER_ASSOCIATED_CONTENTS.
+
+
+
+
+ The MAPI property PR_FOLDER_TYPE.
+
+
+ The MAPI property PR_FOLDER_TYPE.
+
+
+
+
+ The MAPI property PR_FORM_CATEGORY.
+
+
+ The MAPI property PR_FORM_CATEGORY.
+
+
+
+
+ The MAPI property PR_FORM_CATEGORY.
+
+
+ The MAPI property PR_FORM_CATEGORY.
+
+
+
+
+ The MAPI property PR_FORM_CATEGORY_SUB.
+
+
+ The MAPI property PR_FORM_CATEGORY_SUB.
+
+
+
+
+ The MAPI property PR_FORM_CATEGORY_SUB.
+
+
+ The MAPI property PR_FORM_CATEGORY_SUB.
+
+
+
+
+ The MAPI property PR_FORM_CLSID.
+
+
+ The MAPI property PR_FORM_CLSID.
+
+
+
+
+ The MAPI property PR_FORM_CONTACT_NAME.
+
+
+ The MAPI property PR_FORM_CONTACT_NAME.
+
+
+
+
+ The MAPI property PR_FORM_CONTACT_NAME.
+
+
+ The MAPI property PR_FORM_CONTACT_NAME.
+
+
+
+
+ The MAPI property PR_FORM_DESIGNER_GUID.
+
+
+ The MAPI property PR_FORM_DESIGNER_GUID.
+
+
+
+
+ The MAPI property PR_FORM_DESIGNER_NAME.
+
+
+ The MAPI property PR_FORM_DESIGNER_NAME.
+
+
+
+
+ The MAPI property PR_FORM_DESIGNER_NAME.
+
+
+ The MAPI property PR_FORM_DESIGNER_NAME.
+
+
+
+
+ The MAPI property PR_FORM_HIDDEN.
+
+
+ The MAPI property PR_FORM_HIDDEN.
+
+
+
+
+ The MAPI property PR_FORM_HOST_MAP.
+
+
+ The MAPI property PR_FORM_HOST_MAP.
+
+
+
+
+ The MAPI property PR_FORM_MESSAGE_BEHAVIOR.
+
+
+ The MAPI property PR_FORM_MESSAGE_BEHAVIOR.
+
+
+
+
+ The MAPI property PR_FORM_VERSION.
+
+
+ The MAPI property PR_FORM_VERSION.
+
+
+
+
+ The MAPI property PR_FORM_VERSION.
+
+
+ The MAPI property PR_FORM_VERSION.
+
+
+
+
+ The MAPI property PR_FTP_SITE.
+
+
+ The MAPI property PR_FTP_SITE.
+
+
+
+
+ The MAPI property PR_FTP_SITE.
+
+
+ The MAPI property PR_FTP_SITE.
+
+
+
+
+ The MAPI property PR_GENDER.
+
+
+ The MAPI property PR_GENDER.
+
+
+
+
+ The MAPI property PR_GENERATION.
+
+
+ The MAPI property PR_GENERATION.
+
+
+
+
+ The MAPI property PR_GENERATION.
+
+
+ The MAPI property PR_GENERATION.
+
+
+
+
+ The MAPI property PR_GIVEN_NAME.
+
+
+ The MAPI property PR_GIVEN_NAME.
+
+
+
+
+ The MAPI property PR_GIVEN_NAME.
+
+
+ The MAPI property PR_GIVEN_NAME.
+
+
+
+
+ The MAPI property PR_GOVERNMENT_ID_NUMBER.
+
+
+ The MAPI property PR_GOVERNMENT_ID_NUMBER.
+
+
+
+
+ The MAPI property PR_GOVERNMENT_ID_NUMBER.
+
+
+ The MAPI property PR_GOVERNMENT_ID_NUMBER.
+
+
+
+
+ The MAPI property PR_HASATTACH.
+
+
+ The MAPI property PR_HASATTACH.
+
+
+
+
+ The MAPI property PR_HEADER_FOLDER_ENTRYID.
+
+
+ The MAPI property PR_HEADER_FOLDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_HOBBIES.
+
+
+ The MAPI property PR_HOBBIES.
+
+
+
+
+ The MAPI property PR_HOBBIES.
+
+
+ The MAPI property PR_HOBBIES.
+
+
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_HOME2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_CITY.
+
+
+ The MAPI property PR_HOME_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_CITY.
+
+
+ The MAPI property PR_HOME_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_COUNTRY.
+
+
+ The MAPI property PR_HOME_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_COUNTRY.
+
+
+ The MAPI property PR_HOME_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_POSTAL_CODE.
+
+
+ The MAPI property PR_HOME_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_POSTAL_CODE.
+
+
+ The MAPI property PR_HOME_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_POST_OFFICE_BOX.
+
+
+ The MAPI property PR_HOME_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_POST_OFFICE_BOX.
+
+
+ The MAPI property PR_HOME_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_STATE_OR_PROVINCE.
+
+
+ The MAPI property PR_HOME_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_STATE_OR_PROVINCE.
+
+
+ The MAPI property PR_HOME_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_STREET.
+
+
+ The MAPI property PR_HOME_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_HOME_ADDRESS_STREET.
+
+
+ The MAPI property PR_HOME_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_HOME_FAX_NUMBER.
+
+
+ The MAPI property PR_HOME_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME_FAX_NUMBER.
+
+
+ The MAPI property PR_HOME_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_HOME_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_HOME_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_HOME_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_ICON.
+
+
+ The MAPI property PR_ICON.
+
+
+
+
+ The MAPI property PR_IDENTITY_DISPLAY.
+
+
+ The MAPI property PR_IDENTITY_DISPLAY.
+
+
+
+
+ The MAPI property PR_IDENTITY_DISPLAY.
+
+
+ The MAPI property PR_IDENTITY_DISPLAY.
+
+
+
+
+ The MAPI property PR_IDENTITY_ENTRYID.
+
+
+ The MAPI property PR_IDENTITY_ENTRYID.
+
+
+
+
+ The MAPI property PR_IDENTITY_SEARCH_KEY.
+
+
+ The MAPI property PR_IDENTITY_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IMPLICIT_CONVERSION_PROHIBITED.
+
+
+ The MAPI property PR_IMPLICIT_CONVERSION_PROHIBITED.
+
+
+
+
+ The MAPI property PR_IMPORTANCE.
+
+
+ The MAPI property PR_IMPORTANCE.
+
+
+
+
+ The MAPI property PR_INCOMPLETE_COPY.
+
+
+ The MAPI property PR_INCOMPLETE_COPY.
+
+
+
+
+ The Internet mail override charset.
+
+
+ The Internet mail override charset.
+
+
+
+
+ The Internet mail override format.
+
+
+ The Internet mail override format.
+
+
+
+
+ The MAPI property PR_INITIAL_DETAILS_PANE.
+
+
+ The MAPI property PR_INITIAL_DETAILS_PANE.
+
+
+
+
+ The MAPI property PR_INITIALS.
+
+
+ The MAPI property PR_INITIALS.
+
+
+
+
+ The MAPI property PR_INITIALS.
+
+
+ The MAPI property PR_INITIALS.
+
+
+
+
+ The MAPI property PR_IN_REPLY_TO_ID.
+
+
+ The MAPI property PR_IN_REPLY_TO_ID.
+
+
+
+
+ The MAPI property PR_IN_REPLY_TO_ID.
+
+
+ The MAPI property PR_IN_REPLY_TO_ID.
+
+
+
+
+ The MAPI property PR_INSTANCE_KEY.
+
+
+ The MAPI property PR_INSTANCE_KEY.
+
+
+
+
+ The MAPI property PR_INTERNET_APPROVED.
+
+
+ The MAPI property PR_INTERNET_APPROVED.
+
+
+
+
+ The MAPI property PR_INTERNET_APPROVED.
+
+
+ The MAPI property PR_INTERNET_APPROVED.
+
+
+
+
+ The MAPI property PR_INTERNET_ARTICLE_NUMBER.
+
+
+ The MAPI property PR_INTERNET_ARTICLE_NUMBER.
+
+
+
+
+ The MAPI property PR_INTERNET_CONTROL.
+
+
+ The MAPI property PR_INTERNET_CONTROL.
+
+
+
+
+ The MAPI property PR_INTERNET_CONTROL.
+
+
+ The MAPI property PR_INTERNET_CONTROL.
+
+
+
+
+ The MAPI property PR_INTERNET_CPID.
+
+
+ The MAPI property PR_INTERNET_CPID.
+
+
+
+
+ The MAPI property PR_INTERNET_DISTRIBUTION.
+
+
+ The MAPI property PR_INTERNET_DISTRIBUTION.
+
+
+
+
+ The MAPI property PR_INTERNET_DISTRIBUTION.
+
+
+ The MAPI property PR_INTERNET_DISTRIBUTION.
+
+
+
+
+ The MAPI property PR_INTERNET_FOLLOWUP_TO.
+
+
+ The MAPI property PR_INTERNET_FOLLOWUP_TO.
+
+
+
+
+ The MAPI property PR_INTERNET_FOLLOWUP_TO.
+
+
+ The MAPI property PR_INTERNET_FOLLOWUP_TO.
+
+
+
+
+ The MAPI property PR_INTERNET_LINES.
+
+
+ The MAPI property PR_INTERNET_LINES.
+
+
+
+
+ The MAPI property PR_INTERNET_MESSAGE_ID.
+
+
+ The MAPI property PR_INTERNET_MESSAGE_ID.
+
+
+
+
+ The MAPI property PR_INTERNET_MESSAGE_ID.
+
+
+ The MAPI property PR_INTERNET_MESSAGE_ID.
+
+
+
+
+ The MAPI property PR_INTERNET_NEWSGROUPS.
+
+
+ The MAPI property PR_INTERNET_NEWSGROUPS.
+
+
+
+
+ The MAPI property PR_INTERNET_NEWSGROUPS.
+
+
+ The MAPI property PR_INTERNET_NEWSGROUPS.
+
+
+
+
+ The MAPI property PR_INTERNET_NNTP_PATH.
+
+
+ The MAPI property PR_INTERNET_NNTP_PATH.
+
+
+
+
+ The MAPI property PR_INTERNET_NNTP_PATH.
+
+
+ The MAPI property PR_INTERNET_NNTP_PATH.
+
+
+
+
+ The MAPI property PR_INTERNET_ORGANIZATION.
+
+
+ The MAPI property PR_INTERNET_ORGANIZATION.
+
+
+
+
+ The MAPI property PR_INTERNET_ORGANIZATION.
+
+
+ The MAPI property PR_INTERNET_ORGANIZATION.
+
+
+
+
+ The MAPI property PR_INTERNET_PRECEDENCE.
+
+
+ The MAPI property PR_INTERNET_PRECEDENCE.
+
+
+
+
+ The MAPI property PR_INTERNET_PRECEDENCE.
+
+
+ The MAPI property PR_INTERNET_PRECEDENCE.
+
+
+
+
+ The MAPI property PR_INTERNET_REFERENCES.
+
+
+ The MAPI property PR_INTERNET_REFERENCES.
+
+
+
+
+ The MAPI property PR_INTERNET_REFERENCES.
+
+
+ The MAPI property PR_INTERNET_REFERENCES.
+
+
+
+
+ The MAPI property PR_IPM_ID.
+
+
+ The MAPI property PR_IPM_ID.
+
+
+
+
+ The MAPI property PR_IPM_OUTBOX_ENTRYID.
+
+
+ The MAPI property PR_IPM_OUTBOX_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_OUTBOX_SEARCH_KEY.
+
+
+ The MAPI property PR_IPM_OUTBOX_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IPM_RETURN_REQUESTED.
+
+
+ The MAPI property PR_IPM_RETURN_REQUESTED.
+
+
+
+
+ The MAPI property PR_IPM_SENTMAIL_ENTRYID.
+
+
+ The MAPI property PR_IPM_SENTMAIL_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_SENTMAIL_SEARCH_KEY.
+
+
+ The MAPI property PR_IPM_SENTMAIL_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IPM_SUBTREE_ENTRYID.
+
+
+ The MAPI property PR_IPM_SUBTREE_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_SUBTREE_SEARCH_KEY.
+
+
+ The MAPI property PR_IPM_SUBTREE_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_IPM_WASTEBASKET_ENTRYID.
+
+
+ The MAPI property PR_IPM_WASTEBASKET_ENTRYID.
+
+
+
+
+ The MAPI property PR_IPM_WASTEBASKET_SEARCH_KEY.
+
+
+ The MAPI property PR_IPM_WASTEBASKET_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ISDN_NUMBER.
+
+
+ The MAPI property PR_ISDN_NUMBER.
+
+
+
+
+ The MAPI property PR_ISDN_NUMBER.
+
+
+ The MAPI property PR_ISDN_NUMBER.
+
+
+
+
+ The MAPI property PR_KEYWORD.
+
+
+ The MAPI property PR_KEYWORD.
+
+
+
+
+ The MAPI property PR_KEYWORD.
+
+
+ The MAPI property PR_KEYWORD.
+
+
+
+
+ The MAPI property PR_LANGUAGE.
+
+
+ The MAPI property PR_LANGUAGE.
+
+
+
+
+ The MAPI property PR_LANGUAGE.
+
+
+ The MAPI property PR_LANGUAGE.
+
+
+
+
+ The MAPI property PR_LANGUAGES.
+
+
+ The MAPI property PR_LANGUAGES.
+
+
+
+
+ The MAPI property PR_LANGUAGES.
+
+
+ The MAPI property PR_LANGUAGES.
+
+
+
+
+ The MAPI property PR_LAST_MODIFICATION_TIME.
+
+
+ The MAPI property PR_LAST_MODIFICATION_TIME.
+
+
+
+
+ The MAPI property PR_LATEST_DELIVERY_TIME.
+
+
+ The MAPI property PR_LATEST_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_LIST_HELP.
+
+
+ The MAPI property PR_LIST_HELP.
+
+
+
+
+ The MAPI property PR_LIST_HELP.
+
+
+ The MAPI property PR_LIST_HELP.
+
+
+
+
+ The MAPI property PR_LIST_SUBSCRIBE.
+
+
+ The MAPI property PR_LIST_SUBSCRIBE.
+
+
+
+
+ The MAPI property PR_LIST_SUBSCRIBE.
+
+
+ The MAPI property PR_LIST_SUBSCRIBE.
+
+
+
+
+ The MAPI property PR_LIST_UNSUBSCRIBE.
+
+
+ The MAPI property PR_LIST_UNSUBSCRIBE.
+
+
+
+
+ The MAPI property PR_LIST_UNSUBSCRIBE.
+
+
+ The MAPI property PR_LIST_UNSUBSCRIBE.
+
+
+
+
+ The MAPI property PR_LOCALITY.
+
+
+ The MAPI property PR_LOCALITY.
+
+
+
+
+ The MAPI property PR_LOCALITY.
+
+
+ The MAPI property PR_LOCALITY.
+
+
+
+
+ The MAPI property PR_LOCATION.
+
+
+ The MAPI property PR_LOCATION.
+
+
+
+
+ The MAPI property PR_LOCATION.
+
+
+ The MAPI property PR_LOCATION.
+
+
+
+
+ The MAPI property PR_LOCK_BRANCH_ID.
+
+
+ The MAPI property PR_LOCK_BRANCH_ID.
+
+
+
+
+ The MAPI property PR_LOCK_DEPTH.
+
+
+ The MAPI property PR_LOCK_DEPTH.
+
+
+
+
+ The MAPI property PR_LOCK_ENLISTMENT_CONTEXT.
+
+
+ The MAPI property PR_LOCK_ENLISTMENT_CONTEXT.
+
+
+
+
+ The MAPI property PR_LOCK_EXPIRY_TIME.
+
+
+ The MAPI property PR_LOCK_EXPIRY_TIME.
+
+
+
+
+ The MAPI property PR_LOCK_PERSISTENT.
+
+
+ The MAPI property PR_LOCK_PERSISTENT.
+
+
+
+
+ The MAPI property PR_LOCK_RESOURCE_DID.
+
+
+ The MAPI property PR_LOCK_RESOURCE_DID.
+
+
+
+
+ The MAPI property PR_LOCK_RESOURCE_FID.
+
+
+ The MAPI property PR_LOCK_RESOURCE_FID.
+
+
+
+
+ The MAPI property PR_LOCK_RESOURCE_MID.
+
+
+ The MAPI property PR_LOCK_RESOURCE_MID.
+
+
+
+
+ The MAPI property PR_LOCK_SCOPE.
+
+
+ The MAPI property PR_LOCK_SCOPE.
+
+
+
+
+ The MAPI property PR_LOCK_TIMEOUT.
+
+
+ The MAPI property PR_LOCK_TIMEOUT.
+
+
+
+
+ The MAPI property PR_LOCK_TYPE.
+
+
+ The MAPI property PR_LOCK_TYPE.
+
+
+
+
+ The MAPI property PR_MAIL_PERMISSION.
+
+
+ The MAPI property PR_MAIL_PERMISSION.
+
+
+
+
+ The MAPI property PR_MANAGER_NAME.
+
+
+ The MAPI property PR_MANAGER_NAME.
+
+
+
+
+ The MAPI property PR_MANAGER_NAME.
+
+
+ The MAPI property PR_MANAGER_NAME.
+
+
+
+
+ The MAPI property PR_MAPPING_SIGNATURE.
+
+
+ The MAPI property PR_MAPPING_SIGNATURE.
+
+
+
+
+ The MAPI property PR_MDB_PROVIDER.
+
+
+ The MAPI property PR_MDB_PROVIDER.
+
+
+
+
+ The MAPI property PR_MESSAGE_ATTACHMENTS.
+
+
+ The MAPI property PR_MESSAGE_ATTACHMENTS.
+
+
+
+
+ The MAPI property PR_MESSAGE_CC_ME.
+
+
+ The MAPI property PR_MESSAGE_CC_ME.
+
+
+
+
+ The MAPI property PR_MESSAGE_CLASS.
+
+
+ The MAPI property PR_MESSAGE_CLASS.
+
+
+
+
+ The MAPI property PR_MESSAGE_CLASS.
+
+
+ The MAPI property PR_MESSAGE_CLASS.
+
+
+
+
+ The MAPI property PR_MESSAGE_CODEPAGE.
+
+
+ The MAPI property PR_MESSAGE_CODEPAGE.
+
+
+
+
+ The MAPI property PR_MESSAGE_DELIVERY_ID.
+
+
+ The MAPI property PR_MESSAGE_DELIVERY_ID.
+
+
+
+
+ The MAPI property PR_MESSAGE_DELIVERY_TIME.
+
+
+ The MAPI property PR_MESSAGE_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_MESSAGE_DOWNLOAD_TIME.
+
+
+ The MAPI property PR_MESSAGE_DOWNLOAD_TIME.
+
+
+
+
+ The MAPI property PR_MESSAGE_FLAGS.
+
+
+ The MAPI property PR_MESSAGE_FLAGS.
+
+
+
+
+ The MAPI property PR_MESSAGE_RECIPIENTS.
+
+
+ The MAPI property PR_MESSAGE_RECIPIENTS.
+
+
+
+
+ The MAPI property PR_MESSAGE_RECIP_ME.
+
+
+ The MAPI property PR_MESSAGE_RECIP_ME.
+
+
+
+
+ The MAPI property PR_MESSAGE_SECURITY_LABEL.
+
+
+ The MAPI property PR_MESSAGE_SECURITY_LABEL.
+
+
+
+
+ The MAPI property PR_MESSAGE_SIZE.
+
+
+ The MAPI property PR_MESSAGE_SIZE.
+
+
+
+
+ The MAPI property PR_MESSAGE_SUBMISSION_ID.
+
+
+ The MAPI property PR_MESSAGE_SUBMISSION_ID.
+
+
+
+
+ The MAPI property PR_MESSAGE_TOKEN.
+
+
+ The MAPI property PR_MESSAGE_TOKEN.
+
+
+
+
+ The MAPI property PR_MESSAGE_TO_ME.
+
+
+ The MAPI property PR_MESSAGE_TO_ME.
+
+
+
+
+ The MAPI property PR_MHS_COMMON_NAME.
+
+
+ The MAPI property PR_MHS_COMMON_NAME.
+
+
+
+
+ The MAPI property PR_MHS_COMMON_NAME.
+
+
+ The MAPI property PR_MHS_COMMON_NAME.
+
+
+
+
+ The MAPI property PR_MIDDLE_NAME.
+
+
+ The MAPI property PR_MIDDLE_NAME.
+
+
+
+
+ The MAPI property PR_MIDDLE_NAME.
+
+
+ The MAPI property PR_MIDDLE_NAME.
+
+
+
+
+ The MAPI property PR_MINI_ICON.
+
+
+ The MAPI property PR_MINI_ICON.
+
+
+
+
+ The MAPI property PR_MOBILE_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_MOBILE_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_MOBILE_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_MOBILE_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_MODIFY_VERSION.
+
+
+ The MAPI property PR_MODIFY_VERSION.
+
+
+
+
+ The MAPI property PR_MSG_STATUS.
+
+
+ The MAPI property PR_MSG_STATUS.
+
+
+
+
+ The MAPI property PR_NDR_DIAG_CODE.
+
+
+ The MAPI property PR_NDR_DIAG_CODE.
+
+
+
+
+ The MAPI property PR_NDR_REASON_CODE.
+
+
+ The MAPI property PR_NDR_REASON_CODE.
+
+
+
+
+ The MAPI property PR_NDR_STATUS_CODE.
+
+
+ The MAPI property PR_NDR_STATUS_CODE.
+
+
+
+
+ The MAPI property PR_NEWSGROUP_NAME.
+
+
+ The MAPI property PR_NEWSGROUP_NAME.
+
+
+
+
+ The MAPI property PR_NEWSGROUP_NAME.
+
+
+ The MAPI property PR_NEWSGROUP_NAME.
+
+
+
+
+ The MAPI property PR_NICKNAME.
+
+
+ The MAPI property PR_NICKNAME.
+
+
+
+
+ The MAPI property PR_NICKNAME.
+
+
+ The MAPI property PR_NICKNAME.
+
+
+
+
+ The MAPI property PR_NNTP_XREF.
+
+
+ The MAPI property PR_NNTP_XREF.
+
+
+
+
+ The MAPI property PR_NNTP_XREF.
+
+
+ The MAPI property PR_NNTP_XREF.
+
+
+
+
+ The MAPI property PR_NON_RECEIPT_NOTIFICATION_REQUESTED.
+
+
+ The MAPI property PR_NON_RECEIPT_NOTIFICATION_REQUESTED.
+
+
+
+
+ The MAPI property PR_NON_RECEIPT_REASON.
+
+
+ The MAPI property PR_NON_RECEIPT_REASON.
+
+
+
+
+ The MAPI property PR_NORMALIZED_SUBJECT.
+
+
+ The MAPI property PR_NORMALIZED_SUBJECT.
+
+
+
+
+ The MAPI property PR_NORMALIZED_SUBJECT.
+
+
+ The MAPI property PR_NORMALIZED_SUBJECT.
+
+
+
+
+ The MAPI property PR_NT_SECURITY_DESCRIPTOR.
+
+
+ The MAPI property PR_NT_SECURITY_DESCRIPTOR.
+
+
+
+
+ The MAPI property PR_NULL.
+
+
+ The MAPI property PR_NULL.
+
+
+
+
+ The MAPI property PR_OBJECT_TYPE.
+
+
+ The MAPI property PR_OBJECT_TYPE.
+
+
+
+
+ The MAPI property PR_OBSOLETE_IPMS.
+
+
+ The MAPI property PR_OBSOLETE_IPMS.
+
+
+
+
+ The MAPI property PR_OFFICE2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_OFFICE2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OFFICE2_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_OFFICE2_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OFFICE_LOCATION.
+
+
+ The MAPI property PR_OFFICE_LOCATION.
+
+
+
+
+ The MAPI property PR_OFFICE_LOCATION.
+
+
+ The MAPI property PR_OFFICE_LOCATION.
+
+
+
+
+ The MAPI property PR_OFFICE_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_OFFICE_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OFFICE_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_OFFICE_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OOF_REPLY_TYPE.
+
+
+ The MAPI property PR_OOF_REPLY_TYPE.
+
+
+
+
+ The MAPI property PR_ORGANIZATIONAL_ID_NUMBER.
+
+
+ The MAPI property PR_ORGANIZATIONAL_ID_NUMBER.
+
+
+
+
+ The MAPI property PR_ORGANIZATIONAL_ID_NUMBER.
+
+
+ The MAPI property PR_ORGANIZATIONAL_ID_NUMBER.
+
+
+
+
+ The MAPI property PR_ORIG_ENTRYID.
+
+
+ The MAPI property PR_ORIG_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ENTRYID.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_NAME.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_NAME.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_SEARCH_KEY.
+
+
+ The MAPI property PR_ORIGINAL_AUTHOR_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DELIVERY_TIME.
+
+
+ The MAPI property PR_ORIGINAL_DELIVERY_TIME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_BCC.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_BCC.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_BCC.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_BCC.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_CC.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_CC.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_CC.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_CC.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_NAME.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_NAME.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_TO.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_TO.
+
+
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_TO.
+
+
+ The MAPI property PR_ORIGINAL_DISPLAY_TO.
+
+
+
+
+ The MAPI property PR_ORIGINAL_EITS.
+
+
+ The MAPI property PR_ORIGINAL_EITS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_ENTRYID.
+
+
+ The MAPI property PR_ORIGINAL_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ENTRYID.
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIP_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIPIENT_NAME.
+
+
+ The MAPI property PR_ORIGINALLY_INTENDED_RECIPIENT_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SEARCH_KEY.
+
+
+ The MAPI property PR_ORIGINAL_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ENTRYID.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_NAME.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_NAME.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENDER_SEARCH_KEY.
+
+
+ The MAPI property PR_ORIGINAL_SENDER_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENSITIVITY.
+
+
+ The MAPI property PR_ORIGINAL_SENSITIVITY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ENTRYID.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_ENTRYID.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_NAME.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_NAME.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_SEARCH_KEY.
+
+
+ The MAPI property PR_ORIGINAL_SENT_REPRESENTING_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SUBJECT.
+
+
+ The MAPI property PR_ORIGINAL_SUBJECT.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SUBJECT.
+
+
+ The MAPI property PR_ORIGINAL_SUBJECT.
+
+
+
+
+ The MAPI property PR_ORIGINAL_SUBMIT_TIME.
+
+
+ The MAPI property PR_ORIGINAL_SUBMIT_TIME.
+
+
+
+
+ The MAPI property PR_ORIGINATING_MTA_CERTIFICATE.
+
+
+ The MAPI property PR_ORIGINATING_MTA_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_AND_DL_EXPANSION_HISTORY.
+
+
+ The MAPI property PR_ORIGINATOR_AND_DL_EXPANSION_HISTORY.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_CERTIFICATE.
+
+
+ The MAPI property PR_ORIGINATOR_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_DELIVERY_REPORT_REQUESTED.
+
+
+ The MAPI property PR_ORIGINATOR_DELIVERY_REPORT_REQUESTED.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_NON_DELIVERY_REPORT_REQUESTED.
+
+
+ The MAPI property PR_ORIGINATOR_NON_DELIVERY_REPORT_REQUESTED.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_REQUESTED_ALTERNATE_RECIPIENT.
+
+
+ The MAPI property PR_ORIGINATOR_REQUESTED_ALTERNATE_RECIPIENT.
+
+
+
+
+ The MAPI property PR_ORIGINATOR_RETURN_ADDRESS.
+
+
+ The MAPI property PR_ORIGINATOR_RETURN_ADDRESS.
+
+
+
+
+ The MAPI property PR_ORIGIN_CHECK.
+
+
+ The MAPI property PR_ORIGIN_CHECK.
+
+
+
+
+ The MAPI property PR_ORIG_MESSAGE_CLASS.
+
+
+ The MAPI property PR_ORIG_MESSAGE_CLASS.
+
+
+
+
+ The MAPI property PR_ORIG_MESSAGE_CLASS.
+
+
+ The MAPI property PR_ORIG_MESSAGE_CLASS.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_CITY.
+
+
+ The MAPI property PR_OTHER_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_CITY.
+
+
+ The MAPI property PR_OTHER_ADDRESS_CITY.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_COUNTRY.
+
+
+ The MAPI property PR_OTHER_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_COUNTRY.
+
+
+ The MAPI property PR_OTHER_ADDRESS_COUNTRY.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_POSTAL_CODE.
+
+
+ The MAPI property PR_OTHER_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_POSTAL_CODE.
+
+
+ The MAPI property PR_OTHER_ADDRESS_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_POST_OFFICE_BOX.
+
+
+ The MAPI property PR_OTHER_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_POST_OFFICE_BOX.
+
+
+ The MAPI property PR_OTHER_ADDRESS_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_STATE_OR_PROVINCE.
+
+
+ The MAPI property PR_OTHER_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_STATE_OR_PROVINCE.
+
+
+ The MAPI property PR_OTHER_ADDRESS_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_STREET.
+
+
+ The MAPI property PR_OTHER_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_OTHER_ADDRESS_STREET.
+
+
+ The MAPI property PR_OTHER_ADDRESS_STREET.
+
+
+
+
+ The MAPI property PR_OTHER_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_OTHER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OTHER_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_OTHER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_OWNER_APPT_ID.
+
+
+ The MAPI property PR_OWNER_APPT_ID.
+
+
+
+
+ The MAPI property PR_OWN_STORE_ENTRYID.
+
+
+ The MAPI property PR_OWN_STORE_ENTRYID.
+
+
+
+
+ The MAPI property PR_PAGER_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_PAGER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_PAGER_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_PAGER_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_PARENT_DISPLAY.
+
+
+ The MAPI property PR_PARENT_DISPLAY.
+
+
+
+
+ The MAPI property PR_PARENT_DISPLAY.
+
+
+ The MAPI property PR_PARENT_DISPLAY.
+
+
+
+
+ The MAPI property PR_PARENT_ENTRYID.
+
+
+ The MAPI property PR_PARENT_ENTRYID.
+
+
+
+
+ The MAPI property PR_PARENT_KEY.
+
+
+ The MAPI property PR_PARENT_KEY.
+
+
+
+
+ The MAPI property PR_PERSONAL_HOME_PAGE.
+
+
+ The MAPI property PR_PERSONAL_HOME_PAGE.
+
+
+
+
+ The MAPI property PR_PERSONAL_HOME_PAGE.
+
+
+ The MAPI property PR_PERSONAL_HOME_PAGE.
+
+
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_BUREAU_FAX_DELIVERY.
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_BUREAU_FAX_DELIVERY.
+
+
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_MODE.
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_MODE.
+
+
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_REPORT_REQUEST.
+
+
+ The MAPI property PR_PHYSICAL_DELIVERY_REPORT_REQUEST.
+
+
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_ADDRESS.
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_ADDRESS.
+
+
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_ADDRESS_REQUESTED.
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_ADDRESS_REQUESTED.
+
+
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_PROHIBITED.
+
+
+ The MAPI property PR_PHYSICAL_FORWARDING_PROHIBITED.
+
+
+
+
+ The MAPI property PR_PHYSICAL_RENDITION_ATTRIBUTES.
+
+
+ The MAPI property PR_PHYSICAL_RENDITION_ATTRIBUTES.
+
+
+
+
+ The MAPI property PR_POSTAL_ADDRESS.
+
+
+ The MAPI property PR_POSTAL_ADDRESS.
+
+
+
+
+ The MAPI property PR_POSTAL_ADDRESS.
+
+
+ The MAPI property PR_POSTAL_ADDRESS.
+
+
+
+
+ The MAPI property PR_POSTAL_CODE.
+
+
+ The MAPI property PR_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_POSTAL_CODE.
+
+
+ The MAPI property PR_POSTAL_CODE.
+
+
+
+
+ The MAPI property PR_POST_FOLDER_ENTRIES.
+
+
+ The MAPI property PR_POST_FOLDER_ENTRIES.
+
+
+
+
+ The MAPI property PR_POST_FOLDER_NAMES.
+
+
+ The MAPI property PR_POST_FOLDER_NAMES.
+
+
+
+
+ The MAPI property PR_POST_FOLDER_NAMES.
+
+
+ The MAPI property PR_POST_FOLDER_NAMES.
+
+
+
+
+ The MAPI property PR_POST_OFFICE_BOX.
+
+
+ The MAPI property PR_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_POST_OFFICE_BOX.
+
+
+ The MAPI property PR_POST_OFFICE_BOX.
+
+
+
+
+ The MAPI property PR_POST_REPLY_DENIED.
+
+
+ The MAPI property PR_POST_REPLY_DENIED.
+
+
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_ENTRIES.
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_ENTRIES.
+
+
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_NAMES.
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_NAMES.
+
+
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_NAMES.
+
+
+ The MAPI property PR_POST_REPLY_FOLDER_NAMES.
+
+
+
+
+ The MAPI property PR_PREFERRED_BY_NAME.
+
+
+ The MAPI property PR_PREFERRED_BY_NAME.
+
+
+
+
+ The MAPI property PR_PREFERRED_BY_NAME.
+
+
+ The MAPI property PR_PREFERRED_BY_NAME.
+
+
+
+
+ The MAPI property PR_PREPROCESS.
+
+
+ The MAPI property PR_PREPROCESS.
+
+
+
+
+ The MAPI property PR_PRIMARY_CAPABILITY.
+
+
+ The MAPI property PR_PRIMARY_CAPABILITY.
+
+
+
+
+ The MAPI property PR_PRIMARY_FAX_NUMBER.
+
+
+ The MAPI property PR_PRIMARY_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_PRIMARY_FAX_NUMBER.
+
+
+ The MAPI property PR_PRIMARY_FAX_NUMBER.
+
+
+
+
+ The MAPI property PR_PRIMARY_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_PRIMARY_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_PRIMARY_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_PRIMARY_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_PRIORITY.
+
+
+ The MAPI property PR_PRIORITY.
+
+
+
+
+ The MAPI property PR_PROFESSION.
+
+
+ The MAPI property PR_PROFESSION.
+
+
+
+
+ The MAPI property PR_PROFESSION.
+
+
+ The MAPI property PR_PROFESSION.
+
+
+
+
+ The MAPI property PR_PROFILE_NAME.
+
+
+ The MAPI property PR_PROFILE_NAME.
+
+
+
+
+ The MAPI property PR_PROFILE_NAME.
+
+
+ The MAPI property PR_PROFILE_NAME.
+
+
+
+
+ The MAPI property PR_PROOF_OF_DELIVERY.
+
+
+ The MAPI property PR_PROOF_OF_DELIVERY.
+
+
+
+
+ The MAPI property PR_PROOF_OF_DELIVERY_REQUESTED.
+
+
+ The MAPI property PR_PROOF_OF_DELIVERY_REQUESTED.
+
+
+
+
+ The MAPI property PR_PROOF_OF_SUBMISSION.
+
+
+ The MAPI property PR_PROOF_OF_SUBMISSION.
+
+
+
+
+ The MAPI property PR_PROOF_OF_SUBMISSION_REQUESTED.
+
+
+ The MAPI property PR_PROOF_OF_SUBMISSION_REQUESTED.
+
+
+
+
+ The MAPI property PR_PROVIDER_DISPLAY.
+
+
+ The MAPI property PR_PROVIDER_DISPLAY.
+
+
+
+
+ The MAPI property PR_PROVIDER_DISPLAY.
+
+
+ The MAPI property PR_PROVIDER_DISPLAY.
+
+
+
+
+ The MAPI property PR_PROVIDER_DLL_NAME.
+
+
+ The MAPI property PR_PROVIDER_DLL_NAME.
+
+
+
+
+ The MAPI property PR_PROVIDER_DLL_NAME.
+
+
+ The MAPI property PR_PROVIDER_DLL_NAME.
+
+
+
+
+ The MAPI property PR_PROVIDER_ORDINAL.
+
+
+ The MAPI property PR_PROVIDER_ORDINAL.
+
+
+
+
+ The MAPI property PR_PROVIDER_SUBMIT_TIME.
+
+
+ The MAPI property PR_PROVIDER_SUBMIT_TIME.
+
+
+
+
+ The MAPI property PR_PROVIDER_UID.
+
+
+ The MAPI property PR_PROVIDER_UID.
+
+
+
+
+ The MAPI property PR_PUID.
+
+
+ The MAPI property PR_PUID.
+
+
+
+
+ The MAPI property PR_RADIO_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_RADIO_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_RADIO_TELEPHONE_NUMBER.
+
+
+ The MAPI property PR_RADIO_TELEPHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ADDRTYPE.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ADDRTYPE.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ENTRYID.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_ENTRYID.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_NAME.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_NAME.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_RCVD_REPRESENTING_SEARCH_KEY.
+
+
+ The MAPI property PR_RCVD_REPRESENTING_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_READ_RECEIPT_ENTRYID.
+
+
+ The MAPI property PR_READ_RECEIPT_ENTRYID.
+
+
+
+
+ The MAPI property PR_READ_RECEIPT_REQUESTED.
+
+
+ The MAPI property PR_READ_RECEIPT_REQUESTED.
+
+
+
+
+ The MAPI property PR_READ_RECEIPT_SEARCH_KEY.
+
+
+ The MAPI property PR_READ_RECEIPT_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_RECEIPT_TIME.
+
+
+ The MAPI property PR_RECEIPT_TIME.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_ADDRTYPE.
+
+
+ The MAPI property PR_RECEIVED_BY_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_ADDRTYPE.
+
+
+ The MAPI property PR_RECEIVED_BY_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_RECEIVED_BY_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_RECEIVED_BY_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_ENTRYID.
+
+
+ The MAPI property PR_RECEIVED_BY_ENTRYID.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_NAME.
+
+
+ The MAPI property PR_RECEIVED_BY_NAME.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_NAME.
+
+
+ The MAPI property PR_RECEIVED_BY_NAME.
+
+
+
+
+ The MAPI property PR_RECEIVED_BY_SEARCH_KEY.
+
+
+ The MAPI property PR_RECEIVED_BY_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_RECEIVE_FOLDER_SETTINGS.
+
+
+ The MAPI property PR_RECEIVE_FOLDER_SETTINGS.
+
+
+
+
+ The MAPI property PR_RECIPIENT_CERTIFICATE.
+
+
+ The MAPI property PR_RECIPIENT_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_RECIPIENT_NUMBER_FOR_ADVICE.
+
+
+ The MAPI property PR_RECIPIENT_NUMBER_FOR_ADVICE.
+
+
+
+
+ The MAPI property PR_RECIPIENT_NUMBER_FOR_ADVICE.
+
+
+ The MAPI property PR_RECIPIENT_NUMBER_FOR_ADVICE.
+
+
+
+
+ The MAPI property PR_RECIPIENT_REASSIGNMENT_PROHIBITED.
+
+
+ The MAPI property PR_RECIPIENT_REASSIGNMENT_PROHIBITED.
+
+
+
+
+ The MAPI property PR_RECIPIENT_STATUS.
+
+
+ The MAPI property PR_RECIPIENT_STATUS.
+
+
+
+
+ The MAPI property PR_RECIPIENT_TYPE.
+
+
+ The MAPI property PR_RECIPIENT_TYPE.
+
+
+
+
+ The MAPI property PR_REDIRECTION_HISTORY.
+
+
+ The MAPI property PR_REDIRECTION_HISTORY.
+
+
+
+
+ The MAPI property PR_REFERRED_BY_NAME.
+
+
+ The MAPI property PR_REFERRED_BY_NAME.
+
+
+
+
+ The MAPI property PR_REFERRED_BY_NAME.
+
+
+ The MAPI property PR_REFERRED_BY_NAME.
+
+
+
+
+ The MAPI property PR_REGISTERED_MAIL_TYPE.
+
+
+ The MAPI property PR_REGISTERED_MAIL_TYPE.
+
+
+
+
+ The MAPI property PR_RELATED_IPMS.
+
+
+ The MAPI property PR_RELATED_IPMS.
+
+
+
+
+ The MAPI property PR_REMOTE_PROGRESS.
+
+
+ The MAPI property PR_REMOTE_PROGRESS.
+
+
+
+
+ The MAPI property PR_REMOTE_PROGRESS_TEXT.
+
+
+ The MAPI property PR_REMOTE_PROGRESS_TEXT.
+
+
+
+
+ The MAPI property PR_REMOTE_PROGRESS_TEXT.
+
+
+ The MAPI property PR_REMOTE_PROGRESS_TEXT.
+
+
+
+
+ The MAPI property PR_REMOTE_VALIDATE_OK.
+
+
+ The MAPI property PR_REMOTE_VALIDATE_OK.
+
+
+
+
+ The MAPI property PR_RENDERING_POSITION.
+
+
+ The MAPI property PR_RENDERING_POSITION.
+
+
+
+
+ The MAPI property PR_REPLY_RECIPIENT_ENTRIES.
+
+
+ The MAPI property PR_REPLY_RECIPIENT_ENTRIES.
+
+
+
+
+ The MAPI property PR_REPLY_RECIPIENT_NAMES.
+
+
+ The MAPI property PR_REPLY_RECIPIENT_NAMES.
+
+
+
+
+ The MAPI property PR_REPLY_RECIPIENT_NAMES.
+
+
+ The MAPI property PR_REPLY_RECIPIENT_NAMES.
+
+
+
+
+ The MAPI property PR_REPLY_REQUESTED.
+
+
+ The MAPI property PR_REPLY_REQUESTED.
+
+
+
+
+ The MAPI property PR_REPLY_TIME.
+
+
+ The MAPI property PR_REPLY_TIME.
+
+
+
+
+ The MAPI property PR_REPORT_ENTRYID.
+
+
+ The MAPI property PR_REPORT_ENTRYID.
+
+
+
+
+ The MAPI property PR_REPORTING_DL_NAME.
+
+
+ The MAPI property PR_REPORTING_DL_NAME.
+
+
+
+
+ The MAPI property PR_REPORTING_MTA_CERTIFICATE.
+
+
+ The MAPI property PR_REPORTING_MTA_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_REPORT_NAME.
+
+
+ The MAPI property PR_REPORT_NAME.
+
+
+
+
+ The MAPI property PR_REPORT_NAME.
+
+
+ The MAPI property PR_REPORT_NAME.
+
+
+
+
+ The MAPI property PR_REPORT_SEARCH_KEY.
+
+
+ The MAPI property PR_REPORT_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_REPORT_TAG.
+
+
+ The MAPI property PR_REPORT_TAG.
+
+
+
+
+ The MAPI property PR_REPORT_TEXT.
+
+
+ The MAPI property PR_REPORT_TEXT.
+
+
+
+
+ The MAPI property PR_REPORT_TEXT.
+
+
+ The MAPI property PR_REPORT_TEXT.
+
+
+
+
+ The MAPI property PR_REPORT_TIME.
+
+
+ The MAPI property PR_REPORT_TIME.
+
+
+
+
+ The MAPI property PR_REQUESTED_DELIVERY_METHOD.
+
+
+ The MAPI property PR_REQUESTED_DELIVERY_METHOD.
+
+
+
+
+ The MAPI property PR_RESOURCE_FLAGS.
+
+
+ The MAPI property PR_RESOURCE_FLAGS.
+
+
+
+
+ The MAPI property PR_RESOURCE_METHODS.
+
+
+ The MAPI property PR_RESOURCE_METHODS.
+
+
+
+
+ The MAPI property PR_RESOURCE_PATH.
+
+
+ The MAPI property PR_RESOURCE_PATH.
+
+
+
+
+ The MAPI property PR_RESOURCE_PATH.
+
+
+ The MAPI property PR_RESOURCE_PATH.
+
+
+
+
+ The MAPI property PR_RESOURCE_TYPE.
+
+
+ The MAPI property PR_RESOURCE_TYPE.
+
+
+
+
+ The MAPI property PR_RESPONSE_REQUESTED.
+
+
+ The MAPI property PR_RESPONSE_REQUESTED.
+
+
+
+
+ The MAPI property PR_RESPONSIBILITY.
+
+
+ The MAPI property PR_RESPONSIBILITY.
+
+
+
+
+ The MAPI property PR_RETURNED_IPM.
+
+
+ The MAPI property PR_RETURNED_IPM.
+
+
+
+
+ The MAPI property PR_ROWID.
+
+
+ The MAPI property PR_ROWID.
+
+
+
+
+ The MAPI property PR_ROW_TYPE.
+
+
+ The MAPI property PR_ROW_TYPE.
+
+
+
+
+ The MAPI property PR_RTF_COMPRESSED.
+
+
+ The MAPI property PR_RTF_COMPRESSED.
+
+
+
+
+ The MAPI property PR_RTF_IN_SYNC.
+
+
+ The MAPI property PR_RTF_IN_SYNC.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_BODY_COUNT.
+
+
+ The MAPI property PR_RTF_SYNC_BODY_COUNT.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_BODY_CRC.
+
+
+ The MAPI property PR_RTF_SYNC_BODY_CRC.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_BODY_TAG.
+
+
+ The MAPI property PR_RTF_SYNC_BODY_TAG.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_BODY_TAG.
+
+
+ The MAPI property PR_RTF_SYNC_BODY_TAG.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_PREFIX_COUNT.
+
+
+ The MAPI property PR_RTF_SYNC_PREFIX_COUNT.
+
+
+
+
+ The MAPI property PR_RTF_SYNC_TRAILING_COUNT.
+
+
+ The MAPI property PR_RTF_SYNC_TRAILING_COUNT.
+
+
+
+
+ The MAPI property PR_SEARCH.
+
+
+ The MAPI property PR_SEARCH.
+
+
+
+
+ The MAPI property PR_SEARCH_KEY.
+
+
+ The MAPI property PR_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_SECURITY.
+
+
+ The MAPI property PR_SECURITY.
+
+
+
+
+ The MAPI property PR_SELECTABLE.
+
+
+ The MAPI property PR_SELECTABLE.
+
+
+
+
+ The MAPI property PR_SENDER_ADDRTYPE.
+
+
+ The MAPI property PR_SENDER_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_SENDER_ADDRTYPE.
+
+
+ The MAPI property PR_SENDER_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_SENDER_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_SENDER_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_SENDER_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_SENDER_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_SENDER_ENTRYID.
+
+
+ The MAPI property PR_SENDER_ENTRYID.
+
+
+
+
+ The MAPI property PR_SENDER_NAME.
+
+
+ The MAPI property PR_SENDER_NAME.
+
+
+
+
+ The MAPI property PR_SENDER_NAME.
+
+
+ The MAPI property PR_SENDER_NAME.
+
+
+
+
+ The MAPI property PR_SENDER_SEARCH_KEY.
+
+
+ The MAPI property PR_SENDER_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_SEND_INTERNET_ENCODING.
+
+
+ The MAPI property PR_SEND_INTERNET_ENCODING.
+
+
+
+
+ The MAPI property PR_SEND_RECALL_REPORT
+
+
+ The MAPI property PR_SEND_RECALL_REPORT.
+
+
+
+
+ The MAPI property PR_SEND_RICH_INFO.
+
+
+ The MAPI property PR_SEND_RICH_INFO.
+
+
+
+
+ The MAPI property PR_SENSITIVITY.
+
+
+ The MAPI property PR_SENSITIVITY.
+
+
+
+
+ The MAPI property PR_SENTMAIL_ENTRYID.
+
+
+ The MAPI property PR_SENTMAIL_ENTRYID.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_ADDRTYPE.
+
+
+ The MAPI property PR_SENT_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_ADDRTYPE.
+
+
+ The MAPI property PR_SENT_REPRESENTING_ADDRTYPE.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+ The MAPI property PR_SENT_REPRESENTING_EMAIL_ADDRESS.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_ENTRYID.
+
+
+ The MAPI property PR_SENT_REPRESENTING_ENTRYID.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_NAME.
+
+
+ The MAPI property PR_SENT_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_NAME.
+
+
+ The MAPI property PR_SENT_REPRESENTING_NAME.
+
+
+
+
+ The MAPI property PR_SENT_REPRESENTING_SEARCH_KEY.
+
+
+ The MAPI property PR_SENT_REPRESENTING_SEARCH_KEY.
+
+
+
+
+ The MAPI property PR_SERVICE_DELETE_FILES.
+
+
+ The MAPI property PR_SERVICE_DELETE_FILES.
+
+
+
+
+ The MAPI property PR_SERVICE_DELETE_FILES.
+
+
+ The MAPI property PR_SERVICE_DELETE_FILES.
+
+
+
+
+ The MAPI property PR_SERVICE_DLL_NAME.
+
+
+ The MAPI property PR_SERVICE_DLL_NAME.
+
+
+
+
+ The MAPI property PR_SERVICE_DLL_NAME.
+
+
+ The MAPI property PR_SERVICE_DLL_NAME.
+
+
+
+
+ The MAPI property PR_SERVICE_ENTRY_NAME.
+
+
+ The MAPI property PR_SERVICE_ENTRY_NAME.
+
+
+
+
+ The MAPI property PR_SERVICE_EXTRA_UIDS.
+
+
+ The MAPI property PR_SERVICE_EXTRA_UIDS.
+
+
+
+
+ The MAPI property PR_SERVICE_NAME.
+
+
+ The MAPI property PR_SERVICE_NAME.
+
+
+
+
+ The MAPI property PR_SERVICE_NAME.
+
+
+ The MAPI property PR_SERVICE_NAME.
+
+
+
+
+ The MAPI property PR_SERVICES.
+
+
+ The MAPI property PR_SERVICES.
+
+
+
+
+ The MAPI property PR_SERVICE_SUPPORT_FILES.
+
+
+ The MAPI property PR_SERVICE_SUPPORT_FILES.
+
+
+
+
+ The MAPI property PR_SERVICE_SUPPORT_FILES.
+
+
+ The MAPI property PR_SERVICE_SUPPORT_FILES.
+
+
+
+
+ The MAPI property PR_SERVICE_UID.
+
+
+ The MAPI property PR_SERVICE_UID.
+
+
+
+
+ The MAPI property PR_SEVEN_BIT_DISPLAY_NAME.
+
+
+ The MAPI property PR_SEVEN_BIT_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_SMTP_ADDRESS.
+
+
+ The MAPI property PR_SMTP_ADDRESS.
+
+
+
+
+ The MAPI property PR_SMTP_ADDRESS.
+
+
+ The MAPI property PR_SMTP_ADDRESS.
+
+
+
+
+ The MAPI property PR_SPOOLER_STATUS.
+
+
+ The MAPI property PR_SPOOLER_STATUS.
+
+
+
+
+ The MAPI property PR_SPOUSE_NAME.
+
+
+ The MAPI property PR_SPOUSE_NAME.
+
+
+
+
+ The MAPI property PR_SPOUSE_NAME.
+
+
+ The MAPI property PR_SPOUSE_NAME.
+
+
+
+
+ The MAPI property PR_START_DATE.
+
+
+ The MAPI property PR_START_DATE.
+
+
+
+
+ The MAPI property PR_STATE_OR_PROVINCE.
+
+
+ The MAPI property PR_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_STATE_OR_PROVINCE.
+
+
+ The MAPI property PR_STATE_OR_PROVINCE.
+
+
+
+
+ The MAPI property PR_STATUS.
+
+
+ The MAPI property PR_STATUS.
+
+
+
+
+ The MAPI property PR_STATUS_CODE.
+
+
+ The MAPI property PR_STATUS_CODE.
+
+
+
+
+ The MAPI property PR_STATUS_STRING.
+
+
+ The MAPI property PR_STATUS_STRING.
+
+
+
+
+ The MAPI property PR_STATUS_STRING.
+
+
+ The MAPI property PR_STATUS_STRING.
+
+
+
+
+ The MAPI property PR_STORE_ENTRYID.
+
+
+ The MAPI property PR_STORE_ENTRYID.
+
+
+
+
+ The MAPI property PR_STORE_PROVIDERS.
+
+
+ The MAPI property PR_STORE_PROVIDERS.
+
+
+
+
+ The MAPI property PR_STORE_RECORD_KEY.
+
+
+ The MAPI property PR_STORE_RECORD_KEY.
+
+
+
+
+ The MAPI property PR_STORE_STATE.
+
+
+ The MAPI property PR_STORE_STATE.
+
+
+
+
+ The MAPI property PR_STORE_SUPPORT_MASK.
+
+
+ The MAPI property PR_STORE_SUPPORT_MASK.
+
+
+
+
+ The MAPI property PR_STREET_ADDRESS.
+
+
+ The MAPI property PR_STREET_ADDRESS.
+
+
+
+
+ The MAPI property PR_STREET_ADDRESS.
+
+
+ The MAPI property PR_STREET_ADDRESS.
+
+
+
+
+ The MAPI property PR_SUBFOLDERS.
+
+
+ The MAPI property PR_SUBFOLDERS.
+
+
+
+
+ The MAPI property PR_SUBJECT.
+
+
+ The MAPI property PR_SUBJECT.
+
+
+
+
+ The MAPI property PR_SUBJECT.
+
+
+ The MAPI property PR_SUBJECT.
+
+
+
+
+ The MAPI property PR_SUBJECT_IPM.
+
+
+ The MAPI property PR_SUBJECT_IPM.
+
+
+
+
+ The MAPI property PR_SUBJECT_PREFIX.
+
+
+ The MAPI property PR_SUBJECT_PREFIX.
+
+
+
+
+ The MAPI property PR_SUBJECT_PREFIX.
+
+
+ The MAPI property PR_SUBJECT_PREFIX.
+
+
+
+
+ The MAPI property PR_SUBMIT_FLAGS.
+
+
+ The MAPI property PR_SUBMIT_FLAGS.
+
+
+
+
+ The MAPI property PR_SUPERSEDES.
+
+
+ The MAPI property PR_SUPERSEDES.
+
+
+
+
+ The MAPI property PR_SUPERSEDES.
+
+
+ The MAPI property PR_SUPERSEDES.
+
+
+
+
+ The MAPI property PR_SUPPLEMENTARY_INFO.
+
+
+ The MAPI property PR_SUPPLEMENTARY_INFO.
+
+
+
+
+ The MAPI property PR_SUPPLEMENTARY_INFO.
+
+
+ The MAPI property PR_SUPPLEMENTARY_INFO.
+
+
+
+
+ The MAPI property PR_SURNAME.
+
+
+ The MAPI property PR_SURNAME.
+
+
+
+
+ The MAPI property PR_SURNAME.
+
+
+ The MAPI property PR_SURNAME.
+
+
+
+
+ The MAPI property PR_TELEX_NUMBER.
+
+
+ The MAPI property PR_TELEX_NUMBER.
+
+
+
+
+ The MAPI property PR_TELEX_NUMBER.
+
+
+ The MAPI property PR_TELEX_NUMBER.
+
+
+
+
+ The MAPI property PR_TEMPLATEID.
+
+
+ The MAPI property PR_TEMPLATEID.
+
+
+
+
+ The MAPI property PR_TITLE.
+
+
+ The MAPI property PR_TITLE.
+
+
+
+
+ The MAPI property PR_TITLE.
+
+
+ The MAPI property PR_TITLE.
+
+
+
+
+ The MAPI property PR_TNEF_CORRELATION_KEY.
+
+
+ The MAPI property PR_TNEF_CORRELATION_KEY.
+
+
+
+
+ The MAPI property PR_TRANSMITABLE_DISPLAY_NAME.
+
+
+ The MAPI property PR_TRANSMITABLE_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_TRANSMITABLE_DISPLAY_NAME.
+
+
+ The MAPI property PR_TRANSMITABLE_DISPLAY_NAME.
+
+
+
+
+ The MAPI property PR_TRANSPORT_KEY.
+
+
+ The MAPI property PR_TRANSPORT_KEY.
+
+
+
+
+ The MAPI property PR_TRANSPORT_MESSAGE_HEADERS.
+
+
+ The MAPI property PR_TRANSPORT_MESSAGE_HEADERS.
+
+
+
+
+ The MAPI property PR_TRANSPORT_MESSAGE_HEADERS.
+
+
+ The MAPI property PR_TRANSPORT_MESSAGE_HEADERS.
+
+
+
+
+ The MAPI property PR_TRANSPORT_PROVIDERS.
+
+
+ The MAPI property PR_TRANSPORT_PROVIDERS.
+
+
+
+
+ The MAPI property PR_TRANSPORT_STATUS.
+
+
+ The MAPI property PR_TRANSPORT_STATUS.
+
+
+
+
+ The MAPI property PR_TTYDD_PHONE_NUMBER.
+
+
+ The MAPI property PR_TTYDD_PHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_TTYDD_PHONE_NUMBER.
+
+
+ The MAPI property PR_TTYDD_PHONE_NUMBER.
+
+
+
+
+ The MAPI property PR_TYPE_OF_MTS_USER.
+
+
+ The MAPI property PR_TYPE_OF_MTS_USER.
+
+
+
+
+ The MAPI property PR_USER_CERTIFICATE.
+
+
+ The MAPI property PR_USER_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_USER_X509_CERTIFICATE.
+
+
+ The MAPI property PR_USER_X509_CERTIFICATE.
+
+
+
+
+ The MAPI property PR_VALID_FOLDER_MASK.
+
+
+ The MAPI property PR_VALID_FOLDER_MASK.
+
+
+
+
+ The MAPI property PR_VIEWS_ENTRYID.
+
+
+ The MAPI property PR_VIEWS_ENTRYID.
+
+
+
+
+ The MAPI property PR_WEDDING_ANNIVERSARY.
+
+
+ The MAPI property PR_WEDDING_ANNIVERSARY.
+
+
+
+
+ The MAPI property PR_X400_CONTENT_TYPE.
+
+
+ The MAPI property PR_X400_CONTENT_TYPE.
+
+
+
+
+ The MAPI property PR_X400_DEFERRED_DELIVERY_CANCEL.
+
+
+ The MAPI property PR_X400_DEFERRED_DELIVERY_CANCEL.
+
+
+
+
+ The MAPI property PR_XPOS.
+
+
+ The MAPI property PR_XPOS.
+
+
+
+
+ The MAPI property PR_YPOS.
+
+
+ The MAPI property PR_YPOS.
+
+
+
+
+ Gets the property identifier.
+
+
+ Gets the property identifier.
+
+ The identifier.
+
+
+
+ Gets a value indicating whether or not the property contains multiple values.
+
+
+ Gets a value indicating whether or not the property contains multiple values.
+
+ true if the property contains multiple values; otherwise, false.
+
+
+
+ Gets a value indicating whether or not the property has a special name.
+
+
+ Gets a value indicating whether or not the property has a special name.
+
+ true if the property has a special name; otherwise, false.
+
+
+
+ Gets a value indicating whether the property value type is valid.
+
+
+ Gets a value indicating whether the property value type is valid.
+
+ true if the property value type is valid; otherwise, false.
+
+
+
+ Gets the property's value type (including the multi-valued bit).
+
+
+ Gets the property's value type (including the multi-valued bit).
+
+ The property's value type.
+
+
+
+ Gets the type of the value that the property contains.
+
+
+ Gets the type of the value that the property contains.
+
+ The type of the value.
+
+
+
+ Initializes a new instance of the struct.
+
+
+ Creates a new based on a 32-bit integer tag as read from
+ a TNEF stream.
+
+ The property tag.
+
+
+
+ Initializes a new instance of the struct.
+
+
+ Creates a new based on a
+ and .
+
+ The property identifier.
+ The property type.
+
+
+
+ Casts an integer tag value into a TNEF property tag.
+
+
+ Casts an integer tag value into a TNEF property tag.
+
+ A that represents the integer tag value.
+ The integer tag value.
+
+
+
+ Casts a TNEF property tag into a 32-bit integer value.
+
+
+ Casts a TNEF property tag into a 32-bit integer value.
+
+ A 32-bit integer value representing the TNEF property tag.
+ The TNEF property tag.
+
+
+
+ Serves as a hash function for a object.
+
+
+ Serves as a hash function for a object.
+
+ A hash code for this instance that is suitable for use in hashing algorithms
+ and data structures such as a hash table.
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Determines whether the specified is equal to the current .
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ Returns a that represents the current .
+
+
+ Returns a that represents the current .
+
+ A that represents the current .
+
+
+
+ Returns a new where the type has been changed to .
+
+
+ Returns a new where the type has been changed to .
+
+ The unicode equivalent of the property tag.
+
+
+
+ The type of value that a TNEF property contains.
+
+
+ The type of value that a TNEF property contains.
+
+
+
+
+ The type of the property is unspecified.
+
+
+
+
+ The property has a null value.
+
+
+
+
+ The property has a signed 16-bit value.
+
+
+
+
+ The property has a signed 32-bit value.
+
+
+
+
+ THe property has a 32-bit floating point value.
+
+
+
+
+ The property has a 64-bit floating point value.
+
+
+
+
+ The property has a 64-bit integer value representing 1/10000th of a monetary unit (i.e., 1/100th of a cent).
+
+
+
+
+ The property has a 64-bit integer value specifying the number of 100ns periods since Jan 1, 1601.
+
+
+
+
+ The property has a 32-bit error value.
+
+
+
+
+ The property has a boolean value.
+
+
+
+
+ The property has an embedded object value.
+
+
+
+
+ The property has a signed 64-bit value.
+
+
+
+
+ The property has a null-terminated 8-bit character string value.
+
+
+
+
+ The property has a null-terminated unicode character string value.
+
+
+
+
+ The property has a 64-bit integer value specifying the number of 100ns periods since Jan 1, 1601.
+
+
+
+
+ The property has an OLE GUID value.
+
+
+
+
+ The property has a binary blob value.
+
+
+
+
+ A flag indicating that the property contains multiple values.
+
+
+
+
+ A TNEF reader.
+
+
+ A TNEF reader.
+
+
+
+
+ Gets the attachment key value.
+
+
+ Gets the attachment key value.
+
+ The attachment key value.
+
+
+
+ Gets the current attribute's level.
+
+
+ Gets the current attribute's level.
+
+ The current attribute's level.
+
+
+
+ Gets the length of the current attribute's raw value.
+
+
+ Gets the length of the current attribute's raw value.
+
+ The length of the current attribute's raw value.
+
+
+
+ Gets the stream offset of the current attribute's raw value.
+
+
+ Gets the stream offset of the current attribute's raw value.
+
+ The stream offset of the current attribute's raw value.
+
+
+
+ Gets the current attribute's tag.
+
+
+ Gets the current attribute's tag.
+
+ The current attribute's tag.
+
+
+
+ Gets the compliance mode.
+
+
+ Gets the compliance mode.
+
+ The compliance mode.
+
+
+
+ Gets the current compliance status of the TNEF stream.
+
+
+ Gets the current compliance status of the TNEF stream.
+ As the reader progresses, this value may change if errors are encountered.
+
+ The compliance status.
+
+
+
+ Gets the message codepage.
+
+
+ Gets the message codepage.
+
+ The message codepage.
+
+
+
+ Gets the TNEF property reader.
+
+
+ Gets the TNEF property reader.
+
+ The TNEF property reader.
+
+
+
+ Gets the current stream offset.
+
+
+ Gets the current stream offset.
+
+ The stream offset.
+
+
+
+ Gets the TNEF version.
+
+
+ Gets the TNEF version.
+
+ The TNEF version.
+
+
+
+ Initializes a new instance of the class.
+
+
+ When reading a TNEF stream using the mode,
+ a will be thrown immediately at the first sign of
+ invalid or corrupted data.
+ When reading a TNEF stream using the mode,
+ however, compliance issues are accumulated in the
+ property, but exceptions are not raised unless the stream is too corrupted to continue.
+
+ The input stream.
+ The default message codepage.
+ The compliance mode.
+
+ is null.
+
+
+ is not a valid codepage.
+
+
+ is not a supported codepage.
+
+
+ The TNEF stream is corrupted or invalid.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new for the specified input stream.
+
+ The input stream.
+
+ is null.
+
+
+
+
+ Releases unmanaged resources and performs other cleanup operations before the
+ is reclaimed by garbage collection.
+
+
+ Releases unmanaged resources and performs other cleanup operations before the
+ is reclaimed by garbage collection.
+
+
+
+
+ Advances to the next attribute in the TNEF stream.
+
+
+ Advances to the next attribute in the TNEF stream.
+
+ true if there is another attribute available to be read; otherwise false.
+
+ The TNEF stream is corrupted or invalid.
+
+
+
+
+ Reads the raw attribute value data from the underlying TNEF stream.
+
+
+ Reads the raw attribute value data from the underlying TNEF stream.
+
+ The total number of bytes read into the buffer. This can be less than the number
+ of bytes requested if that many bytes are not available, or zero (0) if the end of the
+ value has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ An I/O error occurred.
+
+
+
+
+ Resets the compliance status.
+
+
+ Resets the compliance status.
+
+
+
+
+ Closes the TNEF reader and the underlying stream.
+
+
+ Closes the TNEF reader and the underlying stream.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ Releases all resource used by the object.
+
+ Call when you are finished using the . The
+ method leaves the in an unusable state. After calling
+ , you must release all references to the so the garbage
+ collector can reclaim the memory that the was occupying.
+
+
+
+ A stream for reading raw values from a or .
+
+
+ A stream for reading raw values from a or .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a stream for reading a raw value from the .
+
+ The .
+ The end offset.
+
+
+
+ Checks whether or not the stream supports reading.
+
+
+ The is always readable.
+
+ true if the stream supports reading; otherwise, false.
+
+
+
+ Checks whether or not the stream supports writing.
+
+
+ Writing to a is not supported.
+
+ true if the stream supports writing; otherwise, false.
+
+
+
+ Checks whether or not the stream supports seeking.
+
+
+ Seeking within a is not supported.
+
+ true if the stream supports seeking; otherwise, false.
+
+
+
+ Gets the length of the stream, in bytes.
+
+
+ Getting the length of a is not supported.
+
+ The length of the stream in bytes.
+
+ The stream does not support seeking.
+
+
+
+
+ Gets or sets the current position within the stream.
+
+
+ Getting and setting the position of a is not supported.
+
+ The position of the stream.
+
+ The stream does not support seeking.
+
+
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+
+ Reads a sequence of bytes from the stream and advances the position
+ within the stream by the number of bytes read.
+
+ The total number of bytes read into the buffer. This can be less than the number of bytes requested if that many
+ bytes are not currently available, or zero (0) if the end of the stream has been reached.
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+ The stream has been disposed.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes a sequence of bytes to the stream and advances the current
+ position within this stream by the number of bytes written.
+
+
+ The does not support writing.
+
+ The buffer to write.
+ The offset of the first byte to write.
+ The number of bytes to write.
+
+ The stream does not support writing.
+
+
+
+
+ Sets the position within the current stream.
+
+
+ The does not support seeking.
+
+ The new position within the stream.
+ The offset into the stream relative to the .
+ The origin to seek from.
+
+ The stream does not support seeking.
+
+
+
+
+ Clears all buffers for this stream and causes any buffered data to be written
+ to the underlying device.
+
+
+ The does not support writing.
+
+
+ The stream does not support writing.
+
+
+
+
+ Sets the length of the stream.
+
+
+ The does not support setting the length.
+
+ The desired length of the stream in bytes.
+
+ The stream does not support setting the length.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ The underlying is not disposed.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ The 32-bit cyclic redundancy check (CRC) algorithm.
+
+
+ A cyclic redundancy check is a form of integrity check to make sure
+ that a block of data has not been corrupted.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new CRC32 context.
+
+ The initial value.
+
+
+
+ Clones the CRC32 context and state.
+
+
+ Clones the CRC32 context and state.
+
+
+
+
+ Gets the computed checksum.
+
+
+ Gets the computed checksum.
+
+ The checksum.
+
+
+
+ Updates the CRC based on the specified block of data.
+
+
+ Updates the CRC based on the specified block of data.
+
+ The buffer to read data into.
+ The offset into the buffer to start reading data.
+ The number of bytes to read.
+
+ is null.
+
+
+ is less than zero or greater than the length of .
+ -or-
+ The is not large enough to contain bytes starting
+ at the specified .
+
+
+
+
+ Updates the CRC based on the specified byte.
+
+
+ Updates the CRC based on the specified byte.
+
+ The byte value.
+
+
+
+ Resets the checksum so that the context can be reused.
+
+
+ Resets the checksum so that the context can be reused.
+
+
+
+
+ Utility methods to parse and format rfc822 date strings.
+
+
+ Utility methods to parse and format rfc822 date strings.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed date.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed date.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the supplied buffer starting at the specified index.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed date.
+
+ is null.
+
+
+ is not within the range of the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the supplied buffer starting at the specified index.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed date.
+
+ is null.
+
+
+ is not within the range of the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the specified buffer.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed date.
+
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the specified buffer.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed date.
+
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the specified text.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input text.
+ The parsed date.
+
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses an rfc822 date and time from the specified text.
+
+ true, if the date was successfully parsed, false otherwise.
+ The input text.
+ The parsed date.
+
+ is null.
+
+
+
+
+ Formats the as an rfc822 date string.
+
+
+ Formats the date and time in the format specified by rfc822, suitable for use
+ in the Date header of MIME messages.
+
+ The formatted string.
+ The date.
+
+
+
+ MIME utility methods.
+
+
+ Various utility methods that don't belong anywhere else.
+
+
+
+
+ A string comparer that performs a case-insensitive ordinal string comparison.
+
+
+ A string comparer that performs a case-insensitive ordinal string comparison.
+
+
+
+
+ Generates a Message-Id.
+
+
+ Generates a new Message-Id using the supplied domain.
+
+ The message identifier.
+ A domain to use.
+
+ is null.
+
+
+ is invalid.
+
+
+
+
+ Generates a Message-Id.
+
+
+ Generates a new Message-Id using the local machine's domain.
+
+ The message identifier.
+
+
+
+ Enumerates the message-id references such as those that can be found in
+ the In-Reply-To or References header.
+
+
+ Incrementally parses Message-Ids (such as those from a References header
+ in a MIME message) from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The references.
+ The raw byte buffer to parse.
+ The index into the buffer to start parsing.
+ The length of the buffer to parse.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Enumerates the message-id references such as those that can be found in
+ the In-Reply-To or References header.
+
+
+ Incrementally parses Message-Ids (such as those from a References header
+ in a MIME message) from the specified text.
+
+ The references.
+ The text to parse.
+
+ is null.
+
+
+
+
+ Parses a Message-Id header value.
+
+
+ Parses the Message-Id value, returning the addr-spec portion of the msg-id token.
+
+ The addr-spec portion of the msg-id token.
+ The raw byte buffer to parse.
+ The index into the buffer to start parsing.
+ The length of the buffer to parse.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Parses a Message-Id header value.
+
+
+ Parses the Message-Id value, returning the addr-spec portion of the msg-id token.
+
+ The addr-spec portion of the msg-id token.
+ The text to parse.
+
+ is null.
+
+
+
+
+ Tries to parse a version from a header such as Mime-Version.
+
+
+ Parses a MIME version string from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the version was successfully parsed, false otherwise.
+ The raw byte buffer to parse.
+ The index into the buffer to start parsing.
+ The length of the buffer to parse.
+ The parsed version.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse a version from a header such as Mime-Version.
+
+
+ Parses a MIME version string from the specified text.
+
+ true, if the version was successfully parsed, false otherwise.
+ The text to parse.
+ The parsed version.
+
+ is null.
+
+
+
+
+ Tries to parse a version from a header such as Mime-Version.
+
+
+ Parses a MIME version string from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the version was successfully parsed, false otherwise.
+ The raw byte buffer to parse.
+ The index into the buffer to start parsing.
+ The length of the buffer to parse.
+ The parsed version.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse a version from a header such as Mime-Version.
+
+
+ Parses a MIME version string from the specified text.
+
+ true, if the version was successfully parsed, false otherwise.
+ The text to parse.
+ The parsed version.
+
+ is null.
+
+
+
+
+ Tries to parse the value of a Content-Transfer-Encoding header.
+
+
+ Parses a Content-Transfer-Encoding header value.
+
+ true, if the encoding was successfully parsed, false otherwise.
+ The text to parse.
+ The parsed encoding.
+
+ is null.
+
+
+
+
+ Quotes the specified text.
+
+
+ Quotes the specified text, enclosing it in double-quotes and escaping
+ any backslashes and double-quotes within.
+
+ The quoted text.
+ The text to quote.
+
+ is null.
+
+
+
+
+ Unquotes the specified text.
+
+
+ Unquotes the specified text, removing any escaped backslashes within.
+
+ The unquoted text.
+ The text to unquote.
+
+ is null.
+
+
+
+
+ An optimized version of StringComparer.OrdinalIgnoreCase.
+
+
+ An optimized version of StringComparer.OrdinalIgnoreCase.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Compare the input strings for equality.
+
+
+ Compares the input strings for equality.
+
+ trueif and refer to the same object,
+ or and are equal,
+ or and are null;
+ otherwise, false.
+ A string to compare to .
+ A string to compare to .
+
+
+
+ Get the hash code for the specified string.
+
+
+ Get the hash code for the specified string.
+
+ A 32-bit signed hash code calculated from the value of the parameter.
+ The string.
+
+ is null.
+
+
+
+
+ Utility methods for encoding and decoding rfc2047 encoded-word tokens.
+
+
+ Utility methods for encoding and decoding rfc2047 encoded-word tokens.
+
+
+
+
+ Decodes the phrase.
+
+
+ Decodes the phrase(s) starting at the given index and spanning across
+ the specified number of bytes using the supplied parser options.
+
+ The decoded phrase.
+ The parser options to use.
+ The phrase to decode.
+ The starting index.
+ The number of bytes to decode.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Decodes the phrase.
+
+
+ Decodes the phrase(s) starting at the given index and spanning across
+ the specified number of bytes using the default parser options.
+
+ The decoded phrase.
+ The phrase to decode.
+ The starting index.
+ The number of bytes to decode.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Decodes the phrase.
+
+
+ Decodes the phrase(s) within the specified buffer using the supplied parser options.
+
+ The decoded phrase.
+ The parser options to use.
+ The phrase to decode.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Decodes the phrase.
+
+
+ Decodes the phrase(s) within the specified buffer using the default parser options.
+
+ The decoded phrase.
+ The phrase to decode.
+
+ is null.
+
+
+
+
+ Decodes unstructured text.
+
+
+ Decodes the unstructured text buffer starting at the given index and spanning
+ across the specified number of bytes using the supplied parser options.
+
+ The decoded text.
+ The parser options to use.
+ The text to decode.
+ The starting index.
+ The number of bytes to decode.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Decodes unstructured text.
+
+
+ Decodes the unstructured text buffer starting at the given index and spanning
+ across the specified number of bytes using the default parser options.
+
+ The decoded text.
+ The text to decode.
+ The starting index.
+ The number of bytes to decode.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Decodes unstructured text.
+
+
+ Decodes the unstructured text buffer using the specified parser options.
+
+ The decoded text.
+ The parser options to use.
+ The text to decode.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Decodes unstructured text.
+
+
+ Decodes the unstructured text buffer using the default parser options.
+
+ The decoded text.
+ The text to decode.
+
+ is null.
+
+
+
+
+ Encodes the phrase.
+
+
+ Encodes the phrase according to the rules of rfc2047 using
+ the specified charset encoding and formatting options.
+
+ The encoded phrase.
+ The formatting options
+ The charset encoding.
+ The phrase to encode.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Encodes the phrase.
+
+
+ Encodes the phrase according to the rules of rfc2047 using
+ the specified charset encoding.
+
+ The encoded phrase.
+ The charset encoding.
+ The phrase to encode.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Encodes the unstructured text.
+
+
+ Encodes the unstructured text according to the rules of rfc2047
+ using the specified charset encoding and formatting options.
+
+ The encoded text.
+ The formatting options
+ The charset encoding.
+ The text to encode.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Encodes the unstructured text.
+
+
+ Encodes the unstructured text according to the rules of rfc2047
+ using the specified charset encoding.
+
+ The encoded text.
+ The charset encoding.
+ The text to encode.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ A collection of attachments.
+
+
+ The is only used when building a message body with a .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+ If is true, then the attachments
+ are treated as if they are linked to another .
+
+ If set to true; the attachments are treated as linked resources.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the number of attachments currently in the collection.
+
+
+ Indicates the number of attachments in the collection.
+
+ The number of attachments.
+
+
+
+ Gets whther or not the collection is read-only.
+
+
+ A is never read-only.
+
+ true if the collection is read only; otherwise, false.
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the at the specified index.
+
+ The attachment at the specified index.
+ The index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the specified data as an attachment using the supplied Content-Type.
+ The file name parameter is used to set the Content-Location.
+ For a list of known mime-types and their associated file extensions, see
+ http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types
+
+ The newly added attachment .
+ The name of the file.
+ The file data.
+ The mime-type of the file.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the specified data as an attachment using the supplied Content-Type.
+ The file name parameter is used to set the Content-Location.
+ For a list of known mime-types and their associated file extensions, see
+ http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types
+
+ The newly added attachment .
+ The name of the file.
+ The content stream.
+ The mime-type of the file.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+ -or-
+ The stream cannot be read.
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the data as an attachment, using the specified file name for deducing
+ the mime-type by extension and for setting the Content-Location.
+
+ The newly added attachment .
+ The name of the file.
+ The file data to attach.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the stream as an attachment, using the specified file name for deducing
+ the mime-type by extension and for setting the Content-Location.
+
+ The newly added attachment .
+ The name of the file.
+ The content stream.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+ -or-
+ The stream cannot be read
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the specified file as an attachment using the supplied Content-Type.
+ For a list of known mime-types and their associated file extensions, see
+ http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types
+
+ The newly added attachment .
+ The name of the file.
+ The mime-type of the file.
+
+ is null.
+ -or-
+ is null.
+
+
+ The specified file path is empty.
+
+
+ The specified file could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the specified file as an attachment.
+
+ The newly added attachment .
+ The name of the file.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Add the specified attachment.
+
+
+ Adds the specified as an attachment.
+
+ The attachment.
+
+ is null.
+
+
+
+
+ Clears the attachment collection.
+
+
+ Removes all attachments from the collection.
+
+
+
+
+ Checks if the collection contains the specified attachment.
+
+
+ Determines whether or not the collection contains the specified attachment.
+
+ true if the specified attachment exists;
+ otherwise false.
+ The attachment.
+
+ is null.
+
+
+
+
+ Copies all of the attachments in the collection to the specified array.
+
+
+ Copies all of the attachments within the into the array,
+ starting at the specified array index.
+
+ The array to copy the attachments to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Gets the index of the requested attachment, if it exists.
+
+
+ Finds the index of the specified attachment, if it exists.
+
+ The index of the requested attachment; otherwise -1.
+ The attachment.
+
+ is null.
+
+
+
+
+ Inserts the specified attachment at the given index.
+
+
+ Inserts the attachment at the specified index.
+
+ The index to insert the attachment.
+ The attachment.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified attachment.
+
+
+ Removes the specified attachment.
+
+ true if the attachment was removed; otherwise false.
+ The attachment.
+
+ is null.
+
+
+
+
+ Removes the attachment at the specified index.
+
+
+ Removes the attachment at the specified index.
+
+ The index.
+
+ is out of range.
+
+
+
+
+ Gets an enumerator for the list of attachments.
+
+
+ Gets an enumerator for the list of attachments.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of attachments.
+
+
+ Gets an enumerator for the list of attachments.
+
+ The enumerator.
+
+
+
+ A message body builder.
+
+
+ is a helper class for building common MIME body structures.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the attachments.
+
+
+ Represents a collection of file attachments that will be included in the message.
+
+ The attachments.
+
+
+
+ Gets the linked resources.
+
+
+ Linked resources are a special type of attachment which are linked to from the .
+
+ The linked resources.
+
+
+
+ Gets or sets the text body.
+
+
+ Represents the plain-text formatted version of the message body.
+
+ The text body.
+
+
+
+ Gets or sets the html body.
+
+
+ Represents the html formatted version of the message body and may link to any of the .
+
+ The html body.
+
+
+
+ Constructs the message body based on the text-based bodies, the linked resources, and the attachments.
+
+
+ Combines the , , ,
+ and into the proper MIME structure suitable for display in many common
+ mail clients.
+
+ The message body.
+
+
+
+ A class representing a Content-Disposition header value.
+
+
+ The Content-Disposition header is a way for the originating client to
+ suggest to the receiving client whether to present the part to the user
+ as an attachment or as part of the content (inline).
+
+
+
+
+ The attachment disposition.
+
+
+ Indicates that the should be treated as an attachment.
+
+
+
+
+ The form-data disposition.
+
+
+ Indicates that the should be treated as form data.
+
+
+
+
+ The inline disposition.
+
+
+ Indicates that the should be rendered inline.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The disposition should either be
+ or .
+
+ The disposition.
+
+ is null.
+
+
+ is not "attachment" or "inline".
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This is identical to with a disposition
+ value of .
+
+
+
+
+ Gets or sets the disposition.
+
+
+ The disposition is typically either "attachment" or "inline".
+
+ The disposition.
+
+ is null.
+
+
+ is an invalid disposition value.
+
+
+
+
+ Gets or sets a value indicating whether the is an attachment.
+
+
+ A convenience property to determine if the entity should be considered an attachment or not.
+
+ true if the is an attachment; otherwise, false.
+
+
+
+ Gets the parameters.
+
+
+ In addition to specifying whether the entity should be treated as an
+ attachment vs displayed inline, the Content-Disposition header may also
+ contain parameters to provide further information to the receiving client
+ such as the file attributes.
+
+ The parameters.
+
+
+
+ Gets or sets the name of the file.
+
+
+ When set, this can provide a useful hint for a default file name for the
+ content when the user decides to save it to disk.
+
+ The name of the file.
+
+
+
+ Gets or sets the creation-date parameter.
+
+
+ Refers to the date and time that the content file was created on the
+ originating system. This parameter serves little purpose and is
+ typically not used by mail clients.
+
+ The creation date.
+
+
+
+ Gets or sets the modification-date parameter.
+
+
+ Refers to the date and time that the content file was last modified on
+ the originating system. This parameter serves little purpose and is
+ typically not used by mail clients.
+
+ The modification date.
+
+
+
+ Gets or sets the read-date parameter.
+
+
+ Refers to the date and time that the content file was last read on the
+ originating system. This parameter serves little purpose and is typically
+ not used by mail clients.
+
+ The read date.
+
+
+
+ Gets or sets the size parameter.
+
+
+ When set, the size parameter typically refers to the original size of the
+ content on disk. This parameter is rarely used by mail clients as it serves
+ little purpose.
+
+ The size.
+
+
+
+ Serializes the to a string,
+ optionally encoding the parameters.
+
+
+ Creates a string-representation of the ,
+ optionally encoding the parameters as they would be encoded for trabsport.
+
+ The serialized string.
+ The formatting options.
+ The charset to be used when encoding the parameter values.
+ If set to true, the parameter values will be encoded.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Serializes the to a string,
+ optionally encoding the parameters.
+
+
+ Creates a string-representation of the ,
+ optionally encoding the parameters as they would be encoded for trabsport.
+
+ The serialized string.
+ The charset to be used when encoding the parameter values.
+ If set to true, the parameter values will be encoded.
+
+ is null.
+
+
+
+
+ Returns a that represents the current
+ .
+
+
+ Creates a string-representation of the .
+
+ A that represents the current
+ .
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The parser options.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed disposition.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed disposition.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the specified index.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The parser options.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed disposition.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the specified index.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed disposition.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Disposition value from the specified buffer.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The parser options.
+ The input buffer.
+ The parsed disposition.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Disposition value from the specified buffer.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed disposition.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a Content-Disposition value from the supplied text.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The parser options.
+ The text to parse.
+ The parsed disposition.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a Content-Disposition value from the supplied text.
+
+ true, if the disposition was successfully parsed, false otherwise.
+ The text to parse.
+ The parsed disposition.
+
+ is null.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The parsed .
+ The parser options.
+ The input buffer.
+ The start index of the buffer.
+ The length of the buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The parsed .
+ The input buffer.
+ The start index of the buffer.
+ The length of the buffer.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the specified index.
+
+ The parsed .
+ The parser options.
+ The input buffer.
+ The start index of the buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the supplied buffer starting at the specified index.
+
+ The parsed .
+ The input buffer.
+ The start index of the buffer.
+
+ is null.
+
+
+ is out of range.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the supplied buffer.
+
+ The parsed .
+ The parser options.
+ The input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the supplied buffer.
+
+ The parsed .
+ The input buffer.
+
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified text into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the specified text.
+
+ The parsed .
+ The parser options.
+ The input text.
+
+ is null.
+ -or-
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified text into a new instance of the class.
+
+
+ Parses a Content-Disposition value from the specified text.
+
+ The parsed .
+ The input text.
+
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ An enumeration of all supported content transfer encodings.
+ .
+
+
+ Some older mail software is unable to properly deal with
+ data outside of the ASCII range, so it is sometimes
+ necessary to encode the content of MIME entities.
+
+
+
+
+ The default encoding (aka no encoding at all).
+
+
+
+
+ The 7bit content transfer encoding.
+
+
+ This encoding should be restricted to textual content
+ in the US-ASCII range.
+
+
+
+
+ The 8bit content transfer encoding.
+
+
+ This encoding should be restricted to textual content
+ outside of the US-ASCII range but may not be supported
+ by all transport services such as older SMTP servers
+ that do not support the 8BITMIME extension.
+
+
+
+
+ The binary content transfer encoding.
+
+
+ This encoding is simply unencoded binary data. Typically not
+ supported by standard message transport services such as SMTP.
+
+
+
+
+ The base64 content transfer encoding.
+ .
+
+
+ This encoding is typically used for encoding binary data
+ or textual content in a largely 8bit charset encoding and
+ is supported by all message transport services.
+
+
+
+
+ The quoted printable content transfer encoding.
+ .
+
+
+ This encoding is used for textual content that is in a charset
+ that has a minority of characters outside of the US-ASCII range
+ (such as ISO-8859-1 and other single-byte charset encodings) and
+ is supported by all message transport services.
+
+
+
+
+ The uuencode content transfer encoding.
+ .
+
+
+ This is an obsolete encoding meant for encoding binary
+ data and has largely been superceeded by .
+
+
+
+
+ Encapsulates a content stream used by .
+
+
+ A represents the content of a .
+ The content has both a stream and an encoding (typically ).
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ When creating new s, the
+ should typically be unless the
+ has already been encoded.
+
+ The content stream.
+ The stream encoding.
+
+ is null.
+
+
+ does not support reading.
+ -or-
+ does not support seeking.
+
+
+
+
+ Gets or sets the content encoding.
+
+
+ If the was parsed from an existing stream, the
+ encoding will be identical to the ,
+ otherwise it will typically be .
+
+ The content encoding.
+
+
+
+ Gets the content stream.
+
+
+ Gets the content stream.
+
+ The stream.
+
+
+
+ Opens the decoded content stream.
+
+
+ Provides a means of reading the decoded content without having to first write it to another
+ stream using .
+
+ The decoded content stream.
+
+
+
+ Copies the content stream to the specified output stream.
+
+
+ This is equivalent to simply using to
+ copy the content stream to the output stream except that this method is
+ cancellable.
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Decodes the content stream into another stream.
+
+
+ Uses the to decode the content stream to the output stream.
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ A class representing a Content-Type header value.
+
+
+ The Content-Type header is a way for the originating client to
+ suggest to the receiving client the mime-type of the content and,
+ depending on that mime-type, presentation options such as charset.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new based on the media type and subtype provided.
+
+ Media type.
+ Media subtype.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets or sets the type of the media.
+
+
+ Represents the media type of the . Examples include
+ "text", "image", and "application". This string should
+ always be treated as case-insensitive.
+
+ The type of the media.
+
+ is null.
+
+
+
+
+ Gets or sets the media subtype.
+
+
+ Represents the media subtype of the . Examples include
+ "html", "jpeg", and "octet-stream". This string should
+ always be treated as case-insensitive.
+
+ The media subtype.
+
+ is null.
+
+
+
+
+ Gets the parameters.
+
+
+ In addition to the media type and subtype, the Content-Type header may also
+ contain parameters to provide further hints to the receiving client as to
+ how to process or display the content.
+
+ The parameters.
+
+
+
+ Gets or sets the boundary parameter.
+
+
+ This is a special parameter on entities, designating to the
+ parser a unique string that should be considered the boundary marker for each sub-part.
+
+ The boundary.
+
+
+
+ Gets or sets the charset parameter.
+
+
+ Text-based entities will often include a charset parameter
+ so that the receiving client can properly render the text.
+
+ The charset.
+
+
+
+ Gets or sets the format parameter.
+
+
+ The format parameter is typically use with text/plain
+ entities and will either have a value of "fixed" or "flowed".
+
+ The charset.
+
+
+
+ Gets the simple mime-type.
+
+
+ Gets the simple mime-type.
+
+ The mime-type.
+
+
+
+ Gets or sets the name parameter.
+
+
+ The name parameter is a way for the originiating client to suggest
+ to the receiving client a display-name for the content, which may
+ be used by the receiving client if it cannot display the actual
+ content to the user.
+
+ The name.
+
+
+
+ Checks if the this instance of matches
+ the specified media type and subtype.
+
+
+ If the specified or
+ are "*", they match anything.
+
+ true if the matches the
+ provided media type and subtype.
+ The media type.
+ The media subtype.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Checks if the this instance of matches
+ the specified MIME media type and subtype.
+
+
+ If the specified or
+ are "*", they match anything.
+
+ true if the matches the
+ provided media type and subtype.
+ The media type.
+ The media subtype.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Serializes the to a string,
+ optionally encoding the parameters.
+
+
+ Creates a string-representation of the , optionally encoding
+ the parameters as they would be encoded for transport.
+
+ The serialized string.
+ The formatting options.
+ The charset to be used when encoding the parameter values.
+ If set to true, the parameter values will be encoded.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Serializes the to a string,
+ optionally encoding the parameters.
+
+
+ Creates a string-representation of the , optionally encoding
+ the parameters as they would be encoded for transport.
+
+ The serialized string.
+ The charset to be used when encoding the parameter values.
+ If set to true, the parameter values will be encoded.
+
+ is null.
+
+
+
+
+ Returns a that represents the current
+ .
+
+
+ Creates a string-representation of the .
+
+ A that represents the current
+ .
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The parser options.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed content type.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed content type.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the specified index.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The parser options.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed content type.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the specified index.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed content type.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Type value from the specified buffer.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The parser options.
+ The input buffer.
+ The parsed content type.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a Content-Type value from the specified buffer.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed content type.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a Content-Type value from the specified text.
+
+ true, if the content type was successfully parsed, false otherwise.
+ THe parser options.
+ The text to parse.
+ The parsed content type.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a Content-Type value from the specified text.
+
+ true, if the content type was successfully parsed, false otherwise.
+ The text to parse.
+ The parsed content type.
+
+ is null.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The parsed .
+ The parser options.
+ The input buffer.
+ The start index of the buffer.
+ The length of the buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The parsed .
+ The input buffer.
+ The start index of the buffer.
+ The length of the buffer.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the specified index.
+
+ The parsed .
+ The parser options.
+ The input buffer.
+ The start index of the buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Type value from the supplied buffer starting at the specified index.
+
+ The parsed .
+ The input buffer.
+ The start index of the buffer.
+
+ is null.
+
+
+ is out of range.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Type value from the specified buffer.
+
+ The parsed .
+ The parser options.
+ The input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified input buffer into a new instance of the class.
+
+
+ Parses a Content-Type value from the specified buffer.
+
+ The parsed .
+ The input buffer.
+
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified text into a new instance of the class.
+
+
+ Parses a Content-Type value from the specified text.
+
+ The parsed .
+ The parser options.
+ The text.
+
+ is null.
+ -or-
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ Parse the specified text into a new instance of the class.
+
+
+ Parses a Content-Type value from the specified text.
+
+ The parsed .
+ The text.
+
+ is null.
+
+
+ The could not be parsed.
+
+
+
+
+ A domain list.
+
+
+ Represents a list of domains, such as those that an email was routed through.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new based on the domains provided.
+
+ A domain list.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the index of the requested domain, if it exists.
+
+
+ Finds the index of the specified domain, if it exists.
+
+ The index of the requested domain; otherwise -1.
+ The domain.
+
+ is null.
+
+
+
+
+ Insert the domain at the specified index.
+
+
+ Inserts the domain at the specified index in the list.
+
+ The index to insert the domain.
+ The domain to insert.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the domain at the specified index.
+
+
+ Removes the domain at the specified index.
+
+ The index.
+
+ is out of range.
+
+
+
+
+ Gets or sets the domain at the specified index.
+
+
+ Gets or sets the domain at the specified index.
+
+ The domain at the specified index.
+ The index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Add the specified domain.
+
+
+ Adds the specified domain to the end of the list.
+
+ The domain.
+
+ is null.
+
+
+
+
+ Clears the domain list.
+
+
+ Removes all of the domains in the list.
+
+
+
+
+ Checks if the contains the specified domain.
+
+
+ Determines whether or not the domain list contains the specified domain.
+
+ true if the specified domain is contained;
+ otherwise false.
+ The domain.
+
+ is null.
+
+
+
+
+ Copies all of the domains in the to the specified array.
+
+
+ Copies all of the domains within the into the array,
+ starting at the specified array index.
+
+ The array to copy the domains to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified domain.
+
+
+ Removes the first instance of the specified domain from the list if it exists.
+
+ true if the domain was removed; otherwise false.
+ The domain.
+
+ is null.
+
+
+
+
+ Gets the number of domains in the .
+
+
+ Indicates the number of domains in the list.
+
+ The number of domains.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Gets an enumerator for the list of domains.
+
+
+ Gets an enumerator for the list of domains.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of domains.
+
+
+ Gets an enumerator for the list of domains.
+
+ The enumerator.
+
+
+
+ Returns a string representation of the list of domains.
+
+
+ Each non-empty domain string will be prepended by an '@'.
+ If there are multiple domains in the list, they will be separated by a comma.
+
+ A string representing the .
+
+
+
+ Tries to parse a list of domains.
+
+
+ Attempts to parse a from the text buffer starting at the
+ specified index. The index will only be updated if a was
+ successfully parsed.
+
+ true if a was successfully parsed;
+ false otherwise.
+ The buffer to parse.
+ The index to start parsing.
+ An index of the end of the input.
+ A flag indicating whether or not an
+ exception should be thrown on error.
+ The parsed DomainList.
+
+
+
+ Tries to parse a list of domains.
+
+
+ Attempts to parse a from the supplied text. The index
+ will only be updated if a was successfully parsed.
+
+ true if a was successfully parsed;
+ false otherwise.
+ The text to parse.
+ The parsed DomainList.
+
+ is null.
+
+
+
+
+ A content encoding constraint.
+
+
+ Not all message transports support binary or 8-bit data, so it becomes
+ necessary to constrain the content encoding to a subset of the possible
+ Content-Transfer-Encoding values.
+
+
+
+
+ There are no encoding constraints, the content may contain any byte.
+
+
+
+
+ The content may contain bytes with the high bit set, but must not contain any zero-bytes.
+
+
+
+
+ The content may only contain bytes within the 7-bit ASCII range.
+
+
+
+
+ A New-Line format.
+
+
+ There are two commonly used line-endings used by modern Operating Systems.
+ Unix-based systems such as Linux and Mac OS use a single character ('\n' aka LF)
+ to represent the end of line where-as Windows (or DOS) uses a sequence of two
+ characters ("\r\n" aka CRLF). Most text-based network protocols such as SMTP,
+ POP3, and IMAP use the CRLF sequence as well.
+
+
+
+
+ The Unix New-Line format ("\n").
+
+
+
+
+ The DOS New-Line format ("\r\n").
+
+
+
+
+ Format options for serializing various MimeKit objects.
+
+
+ Represents the available options for formatting MIME messages
+ and entities when writing them to a stream.
+
+
+
+
+ The default formatting options.
+
+
+ If a custom is not passed to methods such as
+ ,
+ the default options will be used.
+
+
+
+
+ Gets the maximum line length used by the encoders. The encoders
+ use this value to determine where to place line breaks.
+
+
+ Specifies the maximum line length to use when line-wrapping headers.
+
+ The maximum line length.
+
+
+
+ Gets or sets the new-line format.
+
+
+ Specifies the new-line encoding to use when writing the message
+ or entity to a stream.
+
+ The new-line format.
+
+ cannot be changed.
+
+
+
+
+ Gets the message headers that should be hidden.
+
+
+ Specifies the set of headers that should be removed when
+ writing a to a stream.
+ This is primarily meant for the purposes of removing Bcc
+ and Resent-Bcc headers when sending via a transport such as
+ SMTP.
+
+ The message headers.
+
+
+
+ Gets or sets whether the new "Internationalized Email" formatting standards should be used.
+
+
+ The new "Internationalized Email" format is defined by
+ rfc6530 and
+ rfc6532.
+ This feature should only be used when formatting messages meant to be sent via
+ SMTP using the SMTPUTF8 extension (rfc6531)
+ or when appending messages to an IMAP folder via UTF8 APPEND
+ (rfc6855).
+
+ true if the new internationalized formatting should be used; otherwise, false.
+
+ cannot be changed.
+
+
+
+
+ Gets or sets whether the formatter should allow mixed charsets in the headers.
+
+
+ When this option is enabled, the MIME formatter will try to use US-ASCII and/or
+ ISO-8859-1 to encode headers when appropriate rather than being forced to use the
+ specified charset for all encoded-word tokens in order to maximize readability.
+ Unfortunately, mail clients like Outlook and Thunderbird do not treat
+ encoded-word tokens individually and assume that all tokens are encoded using the
+ charset declared in the first encoded-word token despite the specification
+ explicitly stating that each encoded-word token should be treated independently.
+ The Thunderbird bug can be tracked at
+
+ https://bugzilla.mozilla.org/show_bug.cgi?id=317263.
+
+ true if the formatter should be allowed to use ISO-8859-1 when encoding headers; otherwise, false.
+
+
+
+ The method to use for encoding Content-Type and Content-Disposition parameter values.
+
+
+ The method to use for encoding Content-Type and Content-Disposition parameter
+ values when the is set to
+ .
+ The MIME specifications specify that the proper method for encoding Content-Type
+ and Content-Disposition parameter values is the method described in
+ rfc2231. However, it is common for
+ some older email clients to improperly encode using the method described in
+ rfc2047 instead.
+
+ The parameter encoding method that will be used.
+
+ is not a valid value.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new set of formatting options for use with methods such as
+ .
+
+
+
+
+ Clones an instance of .
+
+
+ Clones the formatting options.
+
+ An exact copy of the .
+
+
+
+ Get the default formatting options in a thread-safe way.
+
+
+ Gets the default formatting options in a thread-safe way.
+
+ The default formatting options.
+
+
+
+ An address group, as specified by rfc0822.
+
+
+ Group addresses are rarely used anymore. Typically, if you see a group address,
+ it will be of the form: "undisclosed-recipients: ;".
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name and list of addresses. The
+ specified text encoding is used when encoding the name according to the rules of rfc2047.
+
+ The character encoding to be used for encoding the name.
+ The name of the group.
+ A list of addresses.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name and list of addresses.
+
+ The name of the group.
+ A list of addresses.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name. The specified
+ text encoding is used when encoding the name according to the rules of rfc2047.
+
+ The character encoding to be used for encoding the name.
+ The name of the group.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name.
+
+ The name of the group.
+
+
+
+ Clone the group address.
+
+
+ Clones the group address.
+
+ The cloned group address.
+
+
+
+ Gets the members of the group.
+
+
+ Represents the member addresses of the group. Typically the member addresses
+ will be of the variety, but it is possible
+ for groups to contain other groups.
+
+ The list of members.
+
+
+
+ Returns a string representation of the ,
+ optionally encoding it for transport.
+
+
+ Returns a string containing the formatted group of addresses. If the
+ parameter is true, then the name of the group and all member addresses will be encoded
+ according to the rules defined in rfc2047, otherwise the names will not be encoded at all and
+ will therefor only be suitable for display purposes.
+
+ A string representing the .
+ The formatting options.
+ If set to true, the will be encoded.
+
+ is null.
+
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Compares two group addresses to determine if they are identical or not.
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed group address.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed group address.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed group address.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed group address.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The parsed group address.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed group address.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The text.
+ The parsed group address.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The text.
+ The parsed group address.
+
+ is null.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The text.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a single . If the address is not a group address or
+ there is more than a single group address, then parsing will fail.
+
+ The parsed .
+ The text.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ A class representing a Message or MIME header.
+
+
+ Represents a single header field and value pair.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message or entity header for the specified field and
+ value pair. The encoding is used to determine which charset to use
+ when encoding the value according to the rules of rfc2047.
+
+ The character encoding that should be used to
+ encode the header value.
+ The header identifier.
+ The value of the header.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a valid .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message or entity header for the specified field and
+ value pair. The encoding is used to determine which charset to use
+ when encoding the value according to the rules of rfc2047.
+
+ The charset that should be used to encode the
+ header value.
+ The header identifier.
+ The value of the header.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a valid .
+
+
+ is not supported.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message or entity header for the specified field and
+ value pair with the UTF-8 encoding.
+
+ The header identifier.
+ The value of the header.
+
+ is null.
+
+
+ is not a valid .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message or entity header for the specified field and
+ value pair. The encoding is used to determine which charset to use
+ when encoding the value according to the rules of rfc2047.
+
+ The character encoding that should be used
+ to encode the header value.
+ The name of the header field.
+ The value of the header.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message or entity header for the specified field and
+ value pair. The encoding is used to determine which charset to use
+ when encoding the value according to the rules of rfc2047.
+
+ The charset that should be used to encode the
+ header value.
+ The name of the header field.
+ The value of the header.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+ is not supported.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message or entity header for the specified field and
+ value pair with the UTF-8 encoding.
+
+ The name of the header field.
+ The value of the header.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Clone the header.
+
+
+ Clones the header, copying the current RawValue.
+
+ A copy of the header with its current state.
+
+
+
+ Gets the stream offset of the beginning of the header.
+
+
+ If the offset is set, it refers to the byte offset where it
+ was found in the stream it was parsed from.
+
+ The stream offset.
+
+
+
+ Gets the name of the header field.
+
+
+ Represents the field name of the header.
+
+ The name of the header field.
+
+
+
+ Gets the header identifier.
+
+
+ This property is mainly used for switch-statements for performance reasons.
+
+ The header identifier.
+
+
+
+ Gets the raw field name of the header.
+
+
+ Contains the raw field name of the header.
+
+ The raw field name of the header.
+
+
+
+ Gets the raw value of the header.
+
+
+ Contains the raw value of the header, before any decoding or charset conversion.
+
+ The raw value of the header.
+
+
+
+ Gets or sets the header value.
+
+
+ Represents the decoded header value and is suitable for displaying to the user.
+
+ The header value.
+
+ is null.
+
+
+
+
+ Gets the header value using the specified character encoding.
+
+
+ If the raw header value does not properly encode non-ASCII text, the decoder
+ will fall back to a default charset encoding. Sometimes, however, this
+ default charset fallback is wrong and the mail client may wish to override
+ that default charset on a per-header basis.
+ By using this method, the client is able to override the fallback charset
+ on a per-header basis.
+
+ The value.
+ The character encoding to use as a fallback.
+
+
+
+ Gets the header value using the specified charset.
+
+
+ If the raw header value does not properly encode non-ASCII text, the decoder
+ will fall back to a default charset encoding. Sometimes, however, this
+ default charset fallback is wrong and the mail client may wish to override
+ that default charset on a per-header basis.
+ By using this method, the client is able to override the fallback charset
+ on a per-header basis.
+
+ The value.
+ The charset to use as a fallback.
+
+
+
+ Sets the header value using the specified formatting options and character encoding.
+
+
+ When a particular charset is desired for encoding the header value
+ according to the rules of rfc2047, this method should be used
+ instead of the setter.
+
+ The formatting options.
+ A character encoding.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Sets the header value using the specified character encoding.
+
+
+ When a particular charset is desired for encoding the header value
+ according to the rules of rfc2047, this method should be used
+ instead of the setter.
+
+ A character encoding.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Sets the header value using the specified formatting options and charset.
+
+
+ When a particular charset is desired for encoding the header value
+ according to the rules of rfc2047, this method should be used
+ instead of the setter.
+
+ The formatting options.
+ A charset encoding.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ is not supported.
+
+
+
+
+ Sets the header value using the specified charset.
+
+
+ When a particular charset is desired for encoding the header value
+ according to the rules of rfc2047, this method should be used
+ instead of the setter.
+
+ A charset encoding.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not supported.
+
+
+
+
+ Returns a string representation of the header.
+
+
+ Formats the header field and value in a way that is suitable for display.
+
+ A string representing the .
+
+
+
+ Unfold the specified header value.
+
+
+ Unfolds the header value so that it becomes suitable for display.
+ Since is already unfolded, this method is really
+ only needed when working with raw header strings.
+
+ The unfolded header value.
+ The header text.
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a header from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the header was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed header.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a header from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the header was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed header.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a header from the supplied buffer starting at the specified index.
+
+ true, if the header was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed header.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a header from the supplied buffer starting at the specified index.
+
+ true, if the header was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed header.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a header from the specified buffer.
+
+ true, if the header was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The parsed header.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a header from the specified buffer.
+
+ true, if the header was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed header.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a header from the specified text.
+
+ true, if the header was successfully parsed, false otherwise.
+ The parser options to use.
+ The text to parse.
+ The parsed header.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a header from the specified text.
+
+ true, if the header was successfully parsed, false otherwise.
+ The text to parse.
+ The parsed header.
+
+ is null.
+
+
+
+
+ An enumeration of common header fields.
+
+
+ Comparing enum values is not only faster, but less error prone than
+ comparing strings.
+
+
+
+
+ The Ad-Hoc header field.
+
+
+
+
+ The Apparently-To header field.
+
+
+
+
+ The Approved header field.
+
+
+
+
+ The Article header field.
+
+
+
+
+ The Bcc header field.
+
+
+
+
+ The Bytes header field.
+
+
+
+
+ The Cc header field.
+
+
+
+
+ The Comments header field.
+
+
+
+
+ The Content-Base header field.
+
+
+
+
+ The Content-Class header field.
+
+
+
+
+ The Content-Description header field.
+
+
+
+
+ The Content-Disposition header field.
+
+
+
+
+ The Content-Duration header field.
+
+
+
+
+ The Content-Id header field.
+
+
+
+
+ The Content-Language header field.
+
+
+
+
+ The Content-Length header field.
+
+
+
+
+ The Content-Location header field.
+
+
+
+
+ The Content-Md5 header field.
+
+
+
+
+ The Content-Transfer-Encoding header field.
+
+
+
+
+ The Content-Type header field.
+
+
+
+
+ The Control header field.
+
+
+
+
+ The Date header field.
+
+
+
+
+ The Deferred-Delivery header field.
+
+
+
+
+ The Disposition-Notification-Options header field.
+
+
+
+
+ The Disposition-Notification-To header field.
+
+
+
+
+ The Distribution header field.
+
+
+
+
+ The DKIM-Signature header field.
+
+
+
+
+ The DomainKey-Signature header field.
+
+
+
+
+ The Encoding header field.
+
+
+
+
+ The Encrypted header field.
+
+
+
+
+ The Expires header field.
+
+
+
+
+ The Expiry-Date header field.
+
+
+
+
+ The Followup-To header field.
+
+
+
+
+ The From header field.
+
+
+
+
+ The Importance header field.
+
+
+
+
+ The In-Reply-To header field.
+
+
+
+
+ The Keywords header field.
+
+
+
+
+ The Lines header field.
+
+
+
+
+ The List-Help header field.
+
+
+
+
+ The List-Subscribe header field.
+
+
+
+
+ The List-Unsubscribe header field.
+
+
+
+
+ The Message-Id header field.
+
+
+
+
+ The MIME-Version header field.
+
+
+
+
+ The Newsgroups header field.
+
+
+
+
+ The Nntp-Posting-Host header field.
+
+
+
+
+ The Organization header field.
+
+
+
+
+ The Original-Recipient header field.
+
+
+
+
+ The Path header field.
+
+
+
+
+ The Precedence header field.
+
+
+
+
+ The Priority header field.
+
+
+
+
+ The Received header field.
+
+
+
+
+ The References header field.
+
+
+
+
+ The Reply-By header field.
+
+
+
+
+ The Reply-To header field.
+
+
+
+
+ The Resent-Bcc header field.
+
+
+
+
+ The Resent-Cc header field.
+
+
+
+
+ The Resent-Date header field.
+
+
+
+
+ The Resent-From header field.
+
+
+
+
+ The Resent-Message-Id header field.
+
+
+
+
+ The Resent-Reply-To header field.
+
+
+
+
+ The Resent-Sender header field.
+
+
+
+
+ The Resent-To header field.
+
+
+
+
+ The Return-Path header field.
+
+
+
+
+ The Return-Receipt-To header field.
+
+
+
+
+ The Sender header field.
+
+
+
+
+ The Sensitivity header field.
+
+
+
+
+ The Status header field.
+
+
+
+
+ The Subject header field.
+
+
+
+
+ The Summary header field.
+
+
+
+
+ The Supersedes header field.
+
+
+
+
+ The To header field.
+
+
+
+
+ The User-Agent header field.
+
+
+
+
+ The X-Mailer header field.
+
+
+
+
+ The X-MSMail-Priority header field.
+
+
+
+
+ The X-Priority header field.
+
+
+
+
+ The X-Status header field.
+
+
+
+
+ An unknown header field.
+
+
+
+
+ extension methods.
+
+
+ extension methods.
+
+
+
+
+ Converts the enum value into the equivalent header field name.
+
+
+ Converts the enum value into the equivalent header field name.
+
+ The header name.
+ The enum value.
+
+
+
+ A list of s.
+
+
+ Represents a list of headers as found in a
+ or .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new empty header list.
+
+
+
+
+ Adds a header with the specified field and value.
+
+
+ Adds a new header for the specified field and value pair.
+
+ The header identifier.
+ The header value.
+
+ is null.
+
+
+ is not a valid .
+
+
+
+
+ Adds a header with the specified field and value.
+
+
+ Adds a new header for the specified field and value pair.
+
+ The name of the header field.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Adds a header with the specified field and value.
+
+
+ Adds a new header for the specified field and value pair.
+
+ The header identifier.
+ The character encoding to use for the value.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a valid .
+
+
+
+
+ Adds a header with the specified field and value.
+
+
+ Adds a new header for the specified field and value pair.
+
+ The name of the header field.
+ The character encoding to use for the value.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Checks if the contains a header with the specified field name.
+
+
+ Determines whether or not the header list contains the specified header.
+
+ true if the requested header exists;
+ otherwise false.
+ The header identifier.
+
+ is not a valid .
+
+
+
+
+ Checks if the contains a header with the specified field name.
+
+
+ Determines whether or not the header list contains the specified header.
+
+ true if the requested header exists;
+ otherwise false.
+ The name of the header field.
+
+ is null.
+
+
+
+
+ Gets the index of the requested header, if it exists.
+
+
+ Finds the first index of the specified header, if it exists.
+
+ The index of the requested header; otherwise -1.
+ The header id.
+
+ is not a valid .
+
+
+
+
+ Gets the index of the requested header, if it exists.
+
+
+ Finds the first index of the specified header, if it exists.
+
+ The index of the requested header; otherwise -1.
+ The name of the header field.
+
+ is null.
+
+
+
+
+ Inserts a header with the specified field and value at the given index.
+
+
+ Inserts the header at the specified index in the list.
+
+ The index to insert the header.
+ The header identifier.
+ The header value.
+
+ is null.
+
+
+ is not a valid .
+ -or-
+ is out of range.
+
+
+
+
+ Inserts a header with the specified field and value at the given index.
+
+
+ Inserts the header at the specified index in the list.
+
+ The index to insert the header.
+ The name of the header field.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+ is out of range.
+
+
+
+
+ Inserts a header with the specified field and value at the given index.
+
+
+ Inserts the header at the specified index in the list.
+
+ The index to insert the header.
+ The header identifier.
+ The character encoding to use for the value.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a valid .
+ -or-
+ is out of range.
+
+
+
+
+ Inserts a header with the specified field and value at the given index.
+
+
+ Inserts the header at the specified index in the list.
+
+ The index to insert the header.
+ The name of the header field.
+ The character encoding to use for the value.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+ is out of range.
+
+
+
+
+ Gets the last index of the requested header, if it exists.
+
+
+ Finds the last index of the specified header, if it exists.
+
+ The last index of the requested header; otherwise -1.
+ The header id.
+
+ is not a valid .
+
+
+
+
+ Gets the last index of the requested header, if it exists.
+
+
+ Finds the last index of the specified header, if it exists.
+
+ The last index of the requested header; otherwise -1.
+ The name of the header field.
+
+ is null.
+
+
+
+
+ Removes the first occurance of the specified header field.
+
+
+ Removes the first occurance of the specified header field, if any exist.
+
+ true if the first occurance of the specified
+ header was removed; otherwise false.
+ The header identifier.
+
+ is is not a valid .
+
+
+
+
+ Removes the first occurance of the specified header field.
+
+
+ Removes the first occurance of the specified header field, if any exist.
+
+ true if the first occurance of the specified
+ header was removed; otherwise false.
+ The name of the header field.
+
+ is null.
+
+
+
+
+ Removes all of the headers matching the specified field name.
+
+
+ Removes all of the headers matching the specified field name.
+
+ The header identifier.
+
+ is not a valid .
+
+
+
+
+ Removes all of the headers matching the specified field name.
+
+
+ Removes all of the headers matching the specified field name.
+
+ The name of the header field.
+
+ is null.
+
+
+
+
+ Replaces all headers with identical field names with the single specified header.
+
+
+ Replaces all headers with identical field names with the single specified header.
+ If no headers with the specified field name exist, it is simply added.
+
+ The header identifier.
+ The character encoding to use for the value.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a valid .
+
+
+
+
+ Replaces all headers with identical field names with the single specified header.
+
+
+ Replaces all headers with identical field names with the single specified header.
+ If no headers with the specified field name exist, it is simply added.
+
+ The header identifier.
+ The header value.
+
+ is null.
+
+
+ is not a valid .
+
+
+
+
+ Replaces all headers with identical field names with the single specified header.
+
+
+ Replaces all headers with identical field names with the single specified header.
+ If no headers with the specified field name exist, it is simply added.
+
+ The name of the header field.
+ The character encoding to use for the value.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Replaces all headers with identical field names with the single specified header.
+
+
+ Replaces all headers with identical field names with the single specified header.
+ If no headers with the specified field name exist, it is simply added.
+
+ The name of the header field.
+ The header value.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Gets or sets the value of the first occurance of a header
+ with the specified field name.
+
+
+ Gets or sets the value of the first occurance of a header
+ with the specified field name.
+
+ The value of the first occurrance of the specified header if it exists; otherwise null.
+ The header identifier.
+
+ is null.
+
+
+
+
+ Gets or sets the value of the first occurance of a header
+ with the specified field name.
+
+
+ Gets or sets the value of the first occurance of a header
+ with the specified field name.
+
+ The value of the first occurrance of the specified header if it exists; otherwise null.
+ The name of the header field.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes all of the headers to the output stream.
+
+ The formatting options.
+ The output stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes all of the headers to the output stream.
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Gets the number of headers in the list.
+
+
+ Gets the number of headers in the list.
+
+ The number of headers.
+
+
+
+ Gets whether or not the header list is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Adds the specified header.
+
+
+ Adds the specified header to the end of the header list.
+
+ The header to add.
+
+ is null.
+
+
+
+
+ Clears the header list.
+
+
+ Removes all of the headers from the list.
+
+
+
+
+ Checks if the contains the specified header.
+
+
+ Determines whether or not the header list contains the specified header.
+
+ true if the specified header is contained;
+ otherwise, false.
+ The header.
+
+ is null.
+
+
+
+
+ Copies all of the headers in the to the specified array.
+
+
+ Copies all of the headers within the into the array,
+ starting at the specified array index.
+
+ The array to copy the headers to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified header.
+
+
+ Removes the specified header from the list if it exists.
+
+ true if the specified header was removed;
+ otherwise false.
+ The header.
+
+ is null.
+
+
+
+
+ Replaces all headers with identical field names with the single specified header.
+
+
+ Replaces all headers with identical field names with the single specified header.
+ If no headers with the specified field name exist, it is simply added.
+
+ The header.
+
+ is null.
+
+
+
+
+ Gets the index of the requested header, if it exists.
+
+
+ Finds the index of the specified header, if it exists.
+
+ The index of the requested header; otherwise -1.
+ The header.
+
+ is null.
+
+
+
+
+ Inserts the specified header at the given index.
+
+
+ Inserts the header at the specified index in the list.
+
+ The index to insert the header.
+ The header.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the header at the specified index.
+
+
+ Removes the header at the specified index.
+
+ The index.
+
+ is out of range.
+
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the at the specified index.
+
+ The header at the specified index.
+ The index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Gets an enumerator for the list of headers.
+
+
+ Gets an enumerator for the list of headers.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of headers.
+
+
+ Gets an enumerator for the list of headers.
+
+ The enumerator.
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ specified .
+
+ The parsed list of headers.
+ The parser options.
+ The stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the headers.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ default .
+
+ The parsed list of headers.
+ The stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified file.
+
+
+ Loads a from the file at the give file path,
+ using the specified .
+
+ The parsed list of headers.
+ The parser options.
+ The name of the file to load.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the headers.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified file.
+
+
+ Loads a from the file at the give file path,
+ using the default .
+
+ The parsed list of headers.
+ The name of the file to load.
+ A cancellation token.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the headers.
+
+
+ An I/O error occurred.
+
+
+
+
+ Header list changed action.
+
+
+ Specifies the way that a was changed.
+
+
+
+
+ A header was added.
+
+
+
+
+ A header was changed.
+
+
+
+
+ A header was removed.
+
+
+
+
+ The header list was cleared.
+
+
+
+
+ A collection of groups.
+
+
+ A collection of groups used with
+ .
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Gets the number of groups in the collection.
+
+
+ Gets the number of groups in the collection.
+
+ The number of groups.
+
+
+
+ Gets whether or not the header list collection is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the at the specified index.
+
+ The group of headers at the specified index.
+ The index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Adds the group of headers to the collection.
+
+
+ Adds the group of headers to the collection.
+
+ The group of headers.
+
+ is null.
+
+
+
+
+ Clears the header list collection.
+
+
+ Removes all of the groups from the collection.
+
+
+
+
+ Checks if the collection contains the specified group of headers.
+
+
+ Determines whether or not the collection contains the specified group of headers.
+
+ true if the specified group of headers is contained;
+ otherwise, false.
+ The group of headers.
+
+ is null.
+
+
+
+
+ Copies all of the header groups in the to the specified array.
+
+
+ Copies all of the header groups within the into the array,
+ starting at the specified array index.
+
+ The array to copy the headers to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified header group.
+
+
+ Removes the specified header group from the collection, if it exists.
+
+ true if the specified header group was removed;
+ otherwise false.
+ The group of headers.
+
+ is null.
+
+
+
+
+ Gets an enumerator for the groups of headers.
+
+
+ Gets an enumerator for the groups of headers.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the groups of headers.
+
+
+ Gets an enumerator for the groups of headers.
+
+ The enumerator.
+
+
+
+ An interface for content stream encapsulation as used by .
+
+
+ Implemented by .
+
+
+
+
+ Gets the content encoding.
+
+
+ If the is not encoded, this value will be
+ . Otherwise, it will be
+ set to the raw content encoding of the stream.
+
+ The encoding.
+
+
+
+ Gets the content stream.
+
+
+ Gets the content stream.
+
+ The stream.
+
+
+
+ Opens the decoded content stream.
+
+
+ Provides a means of reading the decoded content without having to first write it to another
+ stream using .
+
+ The decoded content stream.
+
+
+
+ Decodes the content stream into another stream.
+
+
+ If the content stream is encoded, this method will decode it into the
+ output stream using a suitable decoder.
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was cancelled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Copies the content stream to the specified output stream.
+
+
+ Copies the data from into .
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was cancelled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ An internet address, as specified by rfc0822.
+
+
+ A can be any type of address defined by the
+ original Internet Message specification.
+ There are effectively two (2) types of addresses: mailboxes and groups.
+ Mailbox addresses are what are most commonly known as email addresses and are
+ represented by the class.
+ Group addresses are themselves lists of addresses and are represented by the
+ class. While rare, it is still important to handle these
+ types of addresses. They typically only contain mailbox addresses, but may also
+ contain other group addresses.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes the and properties of the internet address.
+
+ The character encoding to be used for encoding the name.
+ The name of the mailbox or group.
+
+ is null.
+
+
+
+
+ Gets or sets the character encoding to use when encoding the name of the address.
+
+
+ The character encoding is used to convert the property, if it is set,
+ to a stream of bytes when encoding the internet address for transport.
+
+ The character encoding.
+
+ is null.
+
+
+
+
+ Gets or sets the display name of the address.
+
+
+ A name is optional and is typically set to the name of the person
+ or group that own the internet address.
+
+ The name of the address.
+
+
+
+ Clone the address.
+
+
+ Clones the address.
+
+ The cloned address.
+
+
+
+ Compares two internet addresses.
+
+
+ Compares two internet addresses for the purpose of sorting.
+
+ The sort order of the current internet address compared to the other internet address.
+ The internet address to compare to.
+
+ is null.
+
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Compares two internet addresses to determine if they are identical or not.
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ Returns a string representation of the ,
+ optionally encoding it for transport.
+
+
+ If the parameter is true, then this method will return
+ an encoded version of the internet address according to the rules described in rfc2047.
+ However, if the parameter is false, then this method will
+ return a string suitable only for display purposes.
+
+ A string representing the .
+ The formatting options.
+ If set to true, the will be encoded.
+
+ is null.
+
+
+
+
+ Returns a string representation of the ,
+ optionally encoding it for transport.
+
+
+ If the parameter is true, then this method will return
+ an encoded version of the internet address according to the rules described in rfc2047.
+ However, if the parameter is false, then this method will
+ return a string suitable only for display purposes.
+
+ A string representing the .
+ If set to true, the will be encoded.
+
+
+
+ Returns a string representation of a suitable for display.
+
+
+ The string returned by this method is suitable only for display purposes.
+
+ A string representing the .
+
+
+
+ Raises the internal changed event used by to keep headers in sync.
+
+
+ This method is called whenever a property of the internet address is changed.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed address.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed address.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed address.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed address.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The parsed address.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed address.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a single or . If the text contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The text.
+ The parsed address.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a single or . If the text contains
+ more data, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The text.
+ The parsed address.
+
+ is null.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single or . If the buffer contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a single or . If the text contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The text.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a single or . If the text contains
+ more data, then parsing will fail.
+
+ The parsed .
+ The text.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ A list of email addresses.
+
+
+ An may contain any number of addresses of any type
+ defined by the original Internet Message specification.
+ There are effectively two (2) types of addresses: mailboxes and groups.
+ Mailbox addresses are what are most commonly known as email addresses and are
+ represented by the class.
+ Group addresses are themselves lists of addresses and are represented by the
+ class. While rare, it is still important to handle these
+ types of addresses. They typically only contain mailbox addresses, but may also
+ contain other group addresses.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new containing the supplied addresses.
+
+ An initial list of addresses.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new, empty, .
+
+
+
+
+ Recursively gets all of the mailboxes contained within the .
+
+
+ This API is useful for collecting a flattened list of
+ recipients for use with sending via SMTP or for encrypting via S/MIME or PGP/MIME.
+
+ The mailboxes.
+
+
+
+ Gets the index of the specified address.
+
+
+ Finds the index of the specified address, if it exists.
+
+ The index of the specified address if found; otherwise -1.
+ The address to get the index of.
+
+ is null.
+
+
+
+
+ Inserts the address at the specified index.
+
+
+ Inserts the address at the specified index in the list.
+
+ The index to insert the address.
+ The address.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the address at the specified index.
+
+
+ Removes the address at the specified index.
+
+ The index of the address to remove.
+
+ is out of range.
+
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the at the specified index.
+
+ The internet address at the specified index.
+ The index of the address to get or set.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Gets the number of addresses in the .
+
+
+ Indicates the number of addresses in the list.
+
+ The number of addresses.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Adds the specified address.
+
+
+ Adds the specified address to the end of the address list.
+
+ The address.
+
+ is null.
+
+
+
+
+ Adds a collection of addresses.
+
+
+ Adds a range of addresses to the end of the address list.
+
+ A colelction of addresses.
+
+ is null.
+
+
+
+
+ Clears the address list.
+
+
+ Removes all of the addresses from the list.
+
+
+
+
+ Checks if the contains the specified address.
+
+
+ Determines whether or not the address list contains the specified address.
+
+ true if the specified address exists;
+ otherwise false.
+ The address.
+
+ is null.
+
+
+
+
+ Copies all of the addresses in the to the specified array.
+
+
+ Copies all of the addresses within the into the array,
+ starting at the specified array index.
+
+ The array to copy the addresses to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified address.
+
+
+ Removes the specified address.
+
+ true if the address was removed; otherwise false.
+ The address.
+
+ is null.
+
+
+
+
+ Gets an enumerator for the list of addresses.
+
+
+ Gets an enumerator for the list of addresses.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of addresses.
+
+
+ Gets an enumerator for the list of addresses.
+
+ The enumerator.
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Determines whether the specified is equal to the current .
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ Compares two internet address lists.
+
+
+ Compares two internet address lists for the purpose of sorting.
+
+ The sort order of the current internet address list compared to the other internet address list.
+ The internet address list to compare to.
+
+ is null.
+
+
+
+
+ Returns a string representation of the email addresses in the ,
+ optionally encoding them for transport.
+
+
+ If is true, each address in the list will be encoded
+ according to the rules defined in rfc2047.
+ If there are multiple addresses in the list, they will be separated by a comma.
+
+ A string representing the .
+ The formatting options.
+ If set to true, each in the list will be encoded.
+
+
+
+ Returns a string representation of the email addresses in the ,
+ optionally encoding them for transport.
+
+
+ If is true, each address in the list will be encoded
+ according to the rules defined in rfc2047.
+ If there are multiple addresses in the list, they will be separated by a comma.
+
+ A string representing the .
+ If set to true, each in the list will be encoded.
+
+
+
+ Returns a string representation of the email addresses in the .
+
+
+ If there are multiple addresses in the list, they will be separated by a comma.
+
+ A string representing the .
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed addresses.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed addresses.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the specified index.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed addresses.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the specified index.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed addresses.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the specified buffer.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The parsed addresses.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the specified buffer.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed addresses.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a list of addresses from the specified text.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The parser options to use.
+ The text.
+ The parsed addresses.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a list of addresses from the specified text.
+
+ true, if the address list was successfully parsed, false otherwise.
+ The text.
+ The parsed addresses.
+
+ is null.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the given index
+ and spanning across the specified number of bytes.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the specified index.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the supplied buffer starting at the specified index.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the specified buffer.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a list of addresses from the specified buffer.
+
+ The parsed .
+ The input buffer.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a list of addresses from the specified text.
+
+ The parsed .
+ The parser options to use.
+ The text.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a list of addresses from the specified text.
+
+ The parsed .
+ The text.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Explicit cast to convert a to a
+ .
+
+
+ Casts a to a
+ in cases where you might want to make use of the System.Net.Mail APIs.
+
+ The equivalent .
+ The addresses.
+
+ contains one or more group addresses and cannot be converted.
+
+
+
+
+ Explicit cast to convert a
+ to a .
+
+
+ Casts a to a
+ in cases where you might want to make use of the the superior MimeKit APIs.
+
+ The equivalent .
+ The mail address.
+
+
+
+ A mailbox address, as specified by rfc822.
+
+
+ Represents a mailbox address (commonly referred to as an email address)
+ for a single recipient.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name, address and route. The
+ specified text encoding is used when encoding the name according to the rules of rfc2047.
+
+ The character encoding to be used for encoding the name.
+ The name of the mailbox.
+ The route of the mailbox.
+ The address of the mailbox.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name, address and route.
+
+ The name of the mailbox.
+ The route of the mailbox.
+ The address of the mailbox.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name and address. The
+ specified text encoding is used when encoding the name according to the rules of rfc2047.
+
+ The character encoding to be used for encoding the name.
+ The name of the mailbox.
+ The address of the mailbox.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified name and address.
+
+ The name of the mailbox.
+ The address of the mailbox.
+
+ is null.
+
+
+
+
+ Clone the mailbox address.
+
+
+ Clones the mailbox address.
+
+ The cloned mailbox address.
+
+
+
+ Gets the mailbox route.
+
+
+ A route is convention that is rarely seen in modern email systems, but is supported
+ for compatibility with email archives.
+
+ The mailbox route.
+
+
+
+ Gets or sets the mailbox address.
+
+
+ Represents the actual email address and is in the form of "name@example.com".
+
+ The mailbox address.
+
+ is null.
+
+
+
+
+ Gets whether or not the address is an international address.
+
+
+ International addresses are addresses that contain international
+ characters in either their local-parts or their domains.
+ For more information, see section 3.2 of
+ rfc6532.
+
+ true if the address is an international address; otherwise, false.
+
+
+
+ Returns a string representation of the ,
+ optionally encoding it for transport.
+
+
+ Returns a string containing the formatted mailbox address. If the
+ parameter is true, then the mailbox name will be encoded according to the rules defined
+ in rfc2047, otherwise the name will not be encoded at all and will therefor only be suitable
+ for display purposes.
+
+ A string representing the .
+ The formatting options.
+ If set to true, the will be encoded.
+
+ is null.
+
+
+
+
+ Determines whether the specified is equal to the current .
+
+
+ Compares two mailbox addresses to determine if they are identical or not.
+
+ The to compare with the current .
+ true if the specified is equal to the current
+ ; otherwise, false.
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed mailbox address.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+ The parsed mailbox address.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed mailbox address.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The starting index of the input buffer.
+ The parsed mailbox address.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The input buffer.
+ The parsed mailbox address.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Tries to parse the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The input buffer.
+ The parsed mailbox address.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The parser options to use.
+ The text.
+ The parsed mailbox address.
+
+ is null.
+
+
+
+
+ Tries to parse the given text into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ true, if the address was successfully parsed, false otherwise.
+ The text.
+ The parsed mailbox address.
+
+ is null.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+ -or-
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+ The number of bytes in the input buffer to parse.
+
+ is null.
+
+
+ and do not specify
+ a valid range in the byte array.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+ The starting index of the input buffer.
+
+ is null.
+
+
+ is out of range.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The input buffer.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given input buffer into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The input buffer.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The parser options to use.
+ The text.
+
+ is null.
+ -or-
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Parses the given text into a new instance.
+
+
+ Parses a single . If the address is not a mailbox address or
+ there is more than a single mailbox address, then parsing will fail.
+
+ The parsed .
+ The text.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Explicit cast to convert a to a
+ .
+
+
+ Casts a to a
+ in cases where you might want to make use of the System.Net.Mail APIs.
+
+ The equivalent .
+ The mailbox.
+
+
+
+ Explicit cast to convert a
+ to a .
+
+
+ Casts a to a
+ in cases where you might want to make use of the the superior MimeKit APIs.
+
+ The equivalent .
+ The mail address.
+
+
+
+ A message delivery status MIME part.
+
+
+ A message delivery status MIME part is a machine readable notification denoting the
+ delivery status of a message and has a MIME-type of message/delivery-status.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Get the groups of delivery status fields.
+
+
+ Gets the groups of delivery status fields. The first group of fields
+ contains the per-message fields while each of the following groups
+ contains fields that pertain to particular recipients of the message.
+
+ The fields.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ A message disposition notification MIME part.
+
+
+ A message disposition notification MIME part is a machine readable notification
+ denoting the disposition of a message once it has been successfully delivered
+ and has a MIME-type of message/disposition-notification.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+
+
+
+ Get the disposition notification fields.
+
+
+ Gets the disposition notification fields.
+
+ The fields.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ A list of Message-Ids.
+
+
+ Used by the property.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new, empty, .
+
+
+
+
+ Clones the .
+
+
+ Creates an exact copy of the .
+
+ An exact copy of the .
+
+
+
+ Gets the index of the requested Message-Id, if it exists.
+
+
+ Finds the index of the specified Message-Id, if it exists.
+
+ The index of the requested Message-Id; otherwise -1.
+ The Message-Id.
+
+ is null.
+
+
+
+
+ Insert the Message-Id at the specified index.
+
+
+ Inserts the Message-Id at the specified index in the list.
+
+ The index to insert the Message-Id.
+ The Message-Id to insert.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the Message-Id at the specified index.
+
+
+ Removes the Message-Id at the specified index.
+
+ The index.
+
+ is out of range.
+
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the Message-Id at the specified index.
+
+ The Message-Id at the specified index.
+ The index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Add the specified Message-Id.
+
+
+ Adds the specified Message-Id to the end of the list.
+
+ The Message-Id.
+
+ is null.
+
+
+
+
+ Add a collection of Message-Id items.
+
+
+ Adds a collection of Message-Id items to append to the list.
+
+ The Message-Id items to add.
+
+ is null.
+
+
+
+
+ Clears the Message-Id list.
+
+
+ Removes all of the Message-Ids in the list.
+
+
+
+
+ Checks if the contains the specified Message-Id.
+
+
+ Determines whether or not the list contains the specified Message-Id.
+
+ true if the specified Message-Id is contained;
+ otherwise false.
+ The Message-Id.
+
+ is null.
+
+
+
+
+ Copies all of the Message-Ids in the to the specified array.
+
+
+ Copies all of the Message-Ids within the into the array,
+ starting at the specified array index.
+
+ The array to copy the Message-Ids to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified Message-Id.
+
+
+ Removes the first instance of the specified Message-Id from the list if it exists.
+
+ true if the specified Message-Id was removed;
+ otherwise false.
+ The Message-Id.
+
+ is null.
+
+
+
+
+ Gets the number of Message-Ids in the .
+
+
+ Indicates the number of Message-Ids in the list.
+
+ The number of Message-Ids.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Gets an enumerator for the list of Message-Ids.
+
+
+ Gets an enumerator for the list of Message-Ids.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of Message-Ids.
+
+
+ Gets an enumerator for the list of Message-Ids.
+
+ The enumerator.
+
+
+
+ Returns a string representation of the list of Message-Ids.
+
+
+ Each Message-Id will be surrounded by angle brackets.
+ If there are multiple Message-Ids in the list, they will be separated by whitespace.
+
+ A string representing the .
+
+
+
+ An enumeration of message importance values.
+
+
+ Indicates the importance of a message.
+
+
+
+
+ The message is of low importance.
+
+
+
+
+ The message is of normal importance.
+
+
+
+
+ The message is of high importance.
+
+
+
+
+ A MIME part containing a as its content.
+
+
+ Represents MIME entities such as those with a Content-Type of message/rfc822 or message/news.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The message subtype.
+ An array of initialization parameters: headers and message parts.
+
+ is null.
+ -or-
+ is null.
+
+
+ contains more than one .
+ -or-
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new MIME message entity with the specified subtype.
+
+ The message subtype.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message/rfc822 MIME entity.
+
+
+
+
+ Gets or sets the message content.
+
+
+ Gets or sets the message content.
+
+ The message content.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Prepare the MIME entity for transport using the specified encoding constraints.
+
+
+ Prepares the MIME entity for transport using the specified encoding constraints.
+
+ The encoding constraint.
+ The maximum number of octets allowed per line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Writes the to the output stream.
+
+
+ Writes the MIME entity and its message to the output stream.
+
+ The formatting options.
+ The output stream.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ A MIME part containing a partial message as its content.
+
+
+ The "message/partial" MIME-type is used to split large messages into
+ multiple parts, typically to work around transport systems that have size
+ limitations (for example, some SMTP servers limit have a maximum message
+ size that they will accept).
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new message/partial entity.
+ Three (3) parameters must be specified in the Content-Type header
+ of a message/partial: id, number, and total.
+ The "id" parameter is a unique identifier used to match the parts together.
+ The "number" parameter is the sequential (1-based) index of the partial message fragment.
+ The "total" parameter is the total number of pieces that make up the complete message.
+
+ The id value shared among the partial message parts.
+ The (1-based) part number for this partial message part.
+ The total number of partial message parts.
+
+ is null.
+
+
+ is less than 1.
+ -or-
+ is less than .
+
+
+
+
+ Gets the "id" parameter of the Content-Type header.
+
+
+ The "id" parameter is a unique identifier used to match the parts together.
+
+ The identifier.
+
+
+
+ Gets the "number" parameter of the Content-Type header.
+
+
+ The "number" parameter is the sequential (1-based) index of the partial message fragment.
+
+ The part number.
+
+
+
+ Gets the "total" parameter of the Content-Type header.
+
+
+ The "total" parameter is the total number of pieces that make up the complete message.
+
+ The total number of parts.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Splits the specified message into multiple messages.
+
+
+ Splits the specified message into multiple messages, each with a
+ message/partial body no larger than the max size specified.
+
+ An enumeration of partial messages.
+ The message.
+ The maximum size for each message body.
+
+ is null.
+
+
+ is less than 1.
+
+
+
+
+ Joins the specified message/partial parts into the complete message.
+
+
+ Combines all of the message/partial fragments into its original,
+ complete, message.
+
+ The re-combined message.
+ The parser options to use.
+ The list of partial message parts.
+
+ is null.
+ -or-
+ is null.
+
+
+ The last partial does not have a Total.
+ -or-
+ The number of partials provided does not match the expected count.
+ -or-
+ One or more partials is missing.
+
+
+
+
+ Joins the specified message/partial parts into the complete message.
+
+
+ Combines all of the message/partial fragments into its original,
+ complete, message.
+
+ The re-combined message.
+ The list of partial message parts.
+
+ is null.
+
+
+
+
+ An enumeration of message priority values.
+
+
+ Indicates the priority of a message.
+
+
+
+
+ The message has normal priority.
+
+
+
+
+ The message has non-urgent priority.
+
+
+
+
+ The message has urgent priority.
+
+
+
+
+ An abstract MIME entity.
+
+
+ A MIME entity is really just a node in a tree structure of MIME parts in a MIME message.
+ There are 3 basic types of entities: , ,
+ and (which is actually just a special variation of
+ who's content is another MIME message/document). All other types are
+ derivatives of one of those.
+
+
+
+
+ Initializes a new instance of the class
+ based on the .
+
+
+ Custom subclasses MUST implement this constructor
+ in order to register it using .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes the based on the provided media type and subtype.
+
+ The media type.
+ The media subtype.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes the to the one provided.
+
+ The content type.
+
+ is null.
+
+
+
+
+ Tries to use the given object to initialize the appropriate property.
+
+
+ Initializes the appropriate property based on the type of the object.
+
+ The object.
+ true if the object was recognized and used; false otherwise.
+
+
+
+ Gets the list of headers.
+
+
+ Represents the list of headers for a MIME part. Typically, the headers of
+ a MIME part will be various Content-* headers such as Content-Type or
+ Content-Disposition, but may include just about anything.
+
+ The list of headers.
+
+
+
+ Gets or sets the content disposition.
+
+
+ Represents the pre-parsed Content-Disposition header value, if present.
+ If the Content-Disposition header is not set, then this property will
+ be null.
+
+ The content disposition.
+
+
+
+ Gets the type of the content.
+
+
+ The Content-Type header specifies information about the type of content contained
+ within the MIME entity.
+
+ The type of the content.
+
+
+
+ Gets or sets the base content URI.
+
+
+ The Content-Base header specifies the base URI for the
+ in cases where the is a relative URI.
+ The Content-Base URI must be an absolute URI.
+ For more information, see rfc2110.
+
+ The base content URI or null.
+
+ is not an absolute URI.
+
+
+
+
+ Gets or sets the content location.
+
+
+ The Content-Location header specifies the URI for a MIME entity and can be
+ either absolute or relative.
+ Setting a Content-Location URI allows other objects
+ within the same multipart/related container to reference this part by URI. This
+ can be useful, for example, when constructing an HTML message body that needs to
+ reference image attachments.
+ For more information, see rfc2110.
+
+ The content location or null.
+
+
+
+ Gets or sets the content identifier.
+
+
+ The Content-Id header is used for uniquely identifying a particular entity and
+ uses the same syntax as the Message-Id header on MIME messages.
+ Setting a Content-Id allows other objects within the same
+ multipart/related container to reference this part by its unique identifier, typically
+ by using a "cid:" URI in an HTML-formatted message body. This can be useful, for example,
+ when the HTML-formatted message body needs to reference image attachments.
+
+ The content identifier.
+
+
+
+ Gets a value indicating whether this is an attachment.
+
+
+ If the Content-Disposition header is set and has a value of "attachment",
+ then this property returns true. Otherwise it is assumed that the
+ is not meant to be treated as an attachment.
+
+ true if this is an attachment; otherwise, false.
+
+
+
+ Returns a that represents the current .
+
+
+ Returns a that represents the current .
+
+ A that represents the current .
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Prepare the MIME entity for transport using the specified encoding constraints.
+
+
+ Prepares the MIME entity for transport using the specified encoding constraints.
+
+ The encoding constraint.
+ The maximum allowable length for a line (not counting the CRLF). Must be between 72 and 998 (inclusive).
+
+ is not between 72 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes the headers to the output stream, followed by a blank line.
+ Subclasses should override this method to write the content of the entity.
+
+ The formatting options.
+ The output stream.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes the headers to the output stream, followed by a blank line.
+ Subclasses should override this method to write the content of the entity.
+
+ The formatting options.
+ The output stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes the entity to the output stream.
+
+ The output stream.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes the entity to the output stream.
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified file.
+
+
+ Writes the to the specified file using the provided formatting options.
+
+ The formatting options.
+ The file.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The operation was canceled via the cancellation token.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to write to the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified file.
+
+
+ Writes the to the specified file using the provided formatting options.
+
+ The formatting options.
+ The file.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The operation was canceled via the cancellation token.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to write to the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified file.
+
+
+ Writes the to the specified file using the default formatting options.
+
+ The file.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The operation was canceled via the cancellation token.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to write to the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the to the specified file.
+
+
+ Writes the to the specified file using the default formatting options.
+
+ The file.
+ A cancellation token.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The operation was canceled via the cancellation token.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to write to the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Removes the header.
+
+
+ Removes all headers matching the specified name without
+ calling .
+
+ The name of the header.
+
+
+
+ Sets the header.
+
+
+ Sets the header to the specified value without
+ calling .
+
+ The name of the header.
+ The value of the header.
+
+
+
+ Sets the header using the raw value.
+
+
+ Sets the header to the specified value without
+ calling .
+
+ The name of the header.
+ The raw value of the header.
+
+
+
+ Called when the headers change in some way.
+
+
+ Whenever a header is added, changed, or removed, this method will
+ be called in order to allow custom subclasses
+ to update their state.
+ Overrides of this method should call the base method so that their
+ superclass may also update its own state.
+
+ The type of change.
+ The header being added, changed or removed.
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ specified .
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save mmeory usage, but also improve
+ performance.
+
+ The parsed MIME entity.
+ The parser options.
+ The stream.
+ true if the stream is persistent; otherwise false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ specified .
+
+ The parsed MIME entity.
+ The parser options.
+ The stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ default .
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save mmeory usage, but also improve
+ performance.
+
+ The parsed MIME entity.
+ The stream.
+ true if the stream is persistent; otherwise false.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ default .
+
+ The parsed MIME entity.
+ The stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified file.
+
+
+ Loads a from the file at the give file path,
+ using the specified .
+
+ The parsed entity.
+ The parser options.
+ The name of the file to load.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified file.
+
+
+ Loads a from the file at the give file path,
+ using the default .
+
+ The parsed entity.
+ The name of the file to load.
+ A cancellation token.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified content stream.
+
+
+ This method is mostly meant for use with APIs such as
+ where the headers are parsed separately from the content.
+
+ The parsed MIME entity.
+ The parser options.
+ The Content-Type of the stream.
+ The content stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified content stream.
+
+
+ This method is mostly meant for use with APIs such as
+ where the headers are parsed separately from the content.
+
+ The parsed MIME entity.
+ The Content-Type of the stream.
+ The content stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ MIME entity constructor arguments.
+
+
+ MIME entity constructor arguments.
+
+
+
+
+ The format of the MIME stream.
+
+
+ The format of the MIME stream.
+
+
+
+
+ The stream contains a single MIME entity or message.
+
+
+
+
+ The stream is in the Unix mbox format and may contain
+ more than a single message.
+
+
+
+
+ The default stream format.
+
+
+
+
+ An iterator for a MIME tree structure.
+
+
+ Walks the MIME tree structure of a in depth-first order.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new for the specified message.
+
+ The message.
+
+ is null.
+
+
+
+
+ Releases unmanaged resources and performs other cleanup operations before
+ the is reclaimed by garbage collection.
+
+
+ Releases unmanaged resources and performs other cleanup operations before
+ the is reclaimed by garbage collection.
+
+
+
+
+ Gets the top-level message.
+
+
+ Gets the top-level message.
+
+ The message.
+
+
+
+ Gets the parent of the current entity.
+
+
+ After an iterator is created or after the method is called,
+ the method must be called to advance the iterator to the
+ first entity of the message before reading the value of the Parent property;
+ otherwise, Parent throws a . Parent
+ also throws a if the last call to
+ returned false, which indicates the end of the message.
+ If the current entity is the top-level entity of the message, then the parent
+ will be null; otherwise the parent will be either be a
+ or a .
+
+ The parent entity.
+
+ Either has not been called or
+ has moved beyond the end of the message.
+
+
+
+
+ Gets the current entity.
+
+
+ After an iterator is created or after the method is called,
+ the method must be called to advance the iterator to the
+ first entity of the message before reading the value of the Current property;
+ otherwise, Current throws a . Current
+ also throws a if the last call to
+ returned false, which indicates the end of the message.
+
+ The current entity.
+
+ Either has not been called or
+ has moved beyond the end of the message.
+
+
+
+
+ Gets the current entity.
+
+
+ After an iterator is created or after the method is called,
+ the method must be called to advance the iterator to the
+ first entity of the message before reading the value of the Current property;
+ otherwise, Current throws a . Current
+ also throws a if the last call to
+ returned false, which indicates the end of the message.
+
+ The current entity.
+
+ Either has not been called or
+ has moved beyond the end of the message.
+
+
+
+
+ Gets the path specifier for the current entity.
+
+
+ After an iterator is created or after the method is called,
+ the method must be called to advance the iterator to the
+ first entity of the message before reading the value of the PathSpecifier property;
+ otherwise, PathSpecifier throws a .
+ PathSpecifier also throws a if the
+ last call to returned false, which indicates the end of
+ the message.
+
+ The path specifier.
+
+ Either has not been called or
+ has moved beyond the end of the message.
+
+
+
+
+ Gets the depth of the current entity.
+
+
+ After an iterator is created or after the method is called,
+ the method must be called to advance the iterator to the
+ first entity of the message before reading the value of the Depth property;
+ otherwise, Depth throws a . Depth
+ also throws a if the last call to
+ returned false, which indicates the end of the message.
+
+ The depth.
+
+ Either has not been called or
+ has moved beyond the end of the message.
+
+
+
+
+ Advances the iterator to the next depth-first entity of the tree structure.
+
+
+ After an iterator is created or after the method is called,
+ an iterator is positioned before the first entity of the message, and the first
+ call to the MoveNext method moves the iterator to the first entity of the message.
+ If MoveNext advances beyond the last entity of the message, MoveNext returns false.
+ When the iterator is at this position, subsequent calls to MoveNext also return
+ false until is called.
+
+ true if the iterator was successfully advanced to the next entity; otherwise, false.
+
+
+
+ Advances to the entity specified by the path specifier.
+
+
+ Advances the iterator to the entity specified by the path specifier which
+ must be in the same format as returned by .
+ If the iterator has already advanced beyond the entity at the specified
+ path, the iterator will and advance as normal.
+
+ true if advancing to the specified entity was successful; otherwise, false.
+ The path specifier.
+
+ is null.
+
+
+ is empty.
+
+
+ is in an invalid format.
+
+
+
+
+ Resets the iterator to its initial state.
+
+
+ Resets the iterator to its initial state.
+
+
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+
+ Releases the unmanaged resources used by the and
+ optionally releases the managed resources.
+
+ true to release both managed and unmanaged resources;
+ false to release only the unmanaged resources.
+
+
+
+ Releases all resources used by the object.
+
+ Call when you are finished using the . The
+ method leaves the in an unusable state. After
+ calling , you must release all references to the so
+ the garbage collector can reclaim the memory that the was occupying.
+
+
+
+ A MIME message.
+
+
+ A message consists of header fields and, optionally, a body.
+ The body of the message can either be plain text or it can be a
+ tree of MIME entities such as a text/plain MIME part and a collection
+ of file attachments.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ An array of initialization parameters: headers and message parts.
+
+ is null.
+
+
+ contains more than one .
+ -or-
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new MIME message, specifying details at creation time.
+
+ The list of addresses in the From header.
+ The list of addresses in the To header.
+ The subject of the message.
+ The body of the message.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new MIME message.
+
+
+
+
+ Gets or sets the mbox marker.
+
+
+ Set by the when parsing attached message/rfc822 parts
+ so that the message/rfc822 part can be reserialized back to its original form.
+
+ The mbox marker.
+
+
+
+ Gets the list of headers.
+
+
+ Represents the list of headers for a message. Typically, the headers of
+ a message will contain transmission headers such as From and To along
+ with metadata headers such as Subject and Date, but may include just
+ about anything.
+ To access any MIME headers other than
+ , you will need to access the
+ property of the .
+
+
+ The list of headers.
+
+
+
+ Get or set the value of the Importance header.
+
+
+ Gets or sets the value of the Importance header.
+
+ The importance.
+
+ is not a valid .
+
+
+
+
+ Get or set the value of the Priority header.
+
+
+ Gets or sets the value of the Priority header.
+
+ The priority.
+
+ is not a valid .
+
+
+
+
+ Gets or sets the address in the Sender header.
+
+
+ The sender may differ from the addresses in if
+ the message was sent by someone on behalf of someone else.
+
+ The address in the Sender header.
+
+
+
+ Gets or sets the address in the Resent-Sender header.
+
+
+ The resent sender may differ from the addresses in if
+ the message was sent by someone on behalf of someone else.
+
+ The address in the Resent-Sender header.
+
+
+
+ Gets the list of addresses in the From header.
+
+
+ The "From" header specifies the author(s) of the message.
+ If more than one is added to the
+ list of "From" addresses, the should be set to the
+ single of the personal actually sending
+ the message.
+
+ The list of addresses in the From header.
+
+
+
+ Gets the list of addresses in the Resent-From header.
+
+
+ The "Resent-From" header specifies the author(s) of the messagebeing
+ resent.
+ If more than one is added to the
+ list of "Resent-From" addresses, the should
+ be set to the single of the personal actually
+ sending the message.
+
+ The list of addresses in the Resent-From header.
+
+
+
+ Gets the list of addresses in the Reply-To header.
+
+
+ When the list of addresses in the Reply-To header is not empty,
+ it contains the address(es) where the author(s) of the message prefer
+ that replies be sent.
+ When the list of addresses in the Reply-To header is empty,
+ replies should be sent to the mailbox(es) specified in the From
+ header.
+
+ The list of addresses in the Reply-To header.
+
+
+
+ Gets the list of addresses in the Resent-Reply-To header.
+
+
+ When the list of addresses in the Resent-Reply-To header is not empty,
+ it contains the address(es) where the author(s) of the resent message prefer
+ that replies be sent.
+ When the list of addresses in the Resent-Reply-To header is empty,
+ replies should be sent to the mailbox(es) specified in the Resent-From
+ header.
+
+ The list of addresses in the Resent-Reply-To header.
+
+
+
+ Gets the list of addresses in the To header.
+
+
+ The addresses in the To header are the primary recipients of
+ the message.
+
+ The list of addresses in the To header.
+
+
+
+ Gets the list of addresses in the Resent-To header.
+
+
+ The addresses in the Resent-To header are the primary recipients of
+ the message.
+
+ The list of addresses in the Resent-To header.
+
+
+
+ Gets the list of addresses in the Cc header.
+
+
+ The addresses in the Cc header are secondary recipients of the message
+ and are usually not the individuals being directly addressed in the
+ content of the message.
+
+ The list of addresses in the Cc header.
+
+
+
+ Gets the list of addresses in the Resent-Cc header.
+
+
+ The addresses in the Resent-Cc header are secondary recipients of the message
+ and are usually not the individuals being directly addressed in the
+ content of the message.
+
+ The list of addresses in the Resent-Cc header.
+
+
+
+ Gets the list of addresses in the Bcc header.
+
+
+ Recipients in the Blind-Carpbon-Copy list will not be visible to
+ the other recipients of the message.
+
+ The list of addresses in the Bcc header.
+
+
+
+ Gets the list of addresses in the Resent-Bcc header.
+
+
+ Recipients in the Resent-Bcc list will not be visible to
+ the other recipients of the message.
+
+ The list of addresses in the Resent-Bcc header.
+
+
+
+ Gets or sets the subject of the message.
+
+
+ The Subject is typically a short string denoting the topic of the message.
+ Replies will often use "Re: " followed by the Subject of the original message.
+
+ The subject of the message.
+
+ is null.
+
+
+
+
+ Gets or sets the date of the message.
+
+
+ If the date is not explicitly set before the message is written to a stream,
+ the date will default to the exact moment when it is written to said stream.
+
+ The date of the message.
+
+
+
+ Gets or sets the Resent-Date of the message.
+
+
+ Gets or sets the Resent-Date of the message.
+
+ The Resent-Date of the message.
+
+
+
+ Gets or sets the list of references to other messages.
+
+
+ The References header contains a chain of Message-Ids back to the
+ original message that started the thread.
+
+ The references.
+
+
+
+ Gets or sets the Message-Id that this message is in reply to.
+
+
+ If the message is a reply to another message, it will typically
+ use the In-Reply-To header to specify the Message-Id of the
+ original message being replied to.
+
+ The message id that this message is in reply to.
+
+ is improperly formatted.
+
+
+
+
+ Gets or sets the message identifier.
+
+
+ The Message-Id is meant to be a globally unique identifier for
+ a message.
+ can be used
+ to generate this value.
+
+ The message identifier.
+
+ is null.
+
+
+ is improperly formatted.
+
+
+
+
+ Gets or sets the Resent-Message-Id header.
+
+
+ The Resent-Message-Id is meant to be a globally unique identifier for
+ a message.
+ can be used
+ to generate this value.
+
+ The Resent-Message-Id.
+
+ is null.
+
+
+ is improperly formatted.
+
+
+
+
+ Gets or sets the MIME-Version.
+
+
+ The MIME-Version header specifies the version of the MIME specification
+ that the message was created for.
+
+ The MIME version.
+
+ is null.
+
+
+
+
+ Gets or sets the body of the message.
+
+
+ The body of the message can either be plain text or it can be a
+ tree of MIME entities such as a text/plain MIME part and a collection
+ of file attachments.
+ For a convenient way of constructing message bodies, see the
+ class.
+
+ The body of the message.
+
+
+
+ Gets the text body of the message if it exists.
+
+
+ Gets the text content of the first text/plain body part that is found (in depth-first
+ search order) which is not an attachment.
+
+ The text body if it exists; otherwise, null.
+
+
+
+ Gets the html body of the message if it exists.
+
+
+ Gets the HTML-formatted body of the message if it exists.
+
+ The html body if it exists; otherwise, null.
+
+
+
+ Gets the text body in the specified format.
+
+
+ Gets the text body in the specified format, if it exists.
+
+ The text body in the desired format if it exists; otherwise, null.
+ The desired text format.
+
+
+
+ Gets the body parts of the message.
+
+
+ Traverses over the MIME tree, enumerating all of the objects,
+ but does not traverse into the bodies of attached messages.
+
+ The body parts.
+
+
+
+ Gets the attachments.
+
+
+ Traverses over the MIME tree, enumerating all of the objects that
+ have a Content-Disposition header set to "attachment".
+
+ The attachments.
+
+
+
+ Returns a that represents the current .
+
+
+ Returns a that represents the current .
+ Note: In general, the string returned from this method SHOULD NOT be used for serializing
+ the message to disk. It is recommended that you use instead.
+
+ A that represents the current .
+
+
+
+ Dispatches to the specific visit method for this MIME message.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Prepare the message for transport using the specified encoding constraints.
+
+
+ Prepares the message for transport using the specified encoding constraints.
+
+ The encoding constraint.
+ The maximum allowable length for a line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Writes the message to the specified output stream.
+
+
+ Writes the message to the output stream using the provided formatting options.
+
+ The formatting options.
+ The output stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the message to the specified output stream.
+
+
+ Writes the message to the output stream using the default formatting options.
+
+ The output stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the message to the specified file.
+
+
+ Writes the message to the specified file using the provided formatting options.
+
+ The formatting options.
+ The file.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The operation was canceled via the cancellation token.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to write to the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Writes the message to the specified file.
+
+
+ Writes the message to the specified file using the default formatting options.
+
+ The file.
+ A cancellation token.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ The operation was canceled via the cancellation token.
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to write to the specified file.
+
+
+ An I/O error occurred.
+
+
+
+
+ Digitally sign the message using a DomainKeys Identified Mail (DKIM) signature.
+
+
+ Digitally signs the message using a DomainKeys Identified Mail (DKIM) signature.
+
+ The formatting options.
+ The DKIM signer.
+ The list of header fields to sign.
+ The header canonicalization algorithm.
+ The body canonicalization algorithm.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ does not contain the 'From' header.
+ -or-
+ contains one or more of the following headers: Return-Path,
+ Received, Comments, Keywords, Bcc, Resent-Bcc, or DKIM-Signature.
+
+
+
+
+ Digitally sign the message using a DomainKeys Identified Mail (DKIM) signature.
+
+
+ Digitally signs the message using a DomainKeys Identified Mail (DKIM) signature.
+
+ The DKIM signer.
+ The headers to sign.
+ The header canonicalization algorithm.
+ The body canonicalization algorithm.
+
+ is null.
+ -or-
+ is null.
+
+
+ does not contain the 'From' header.
+ -or-
+ contains one or more of the following headers: Return-Path,
+ Received, Comments, Keywords, Bcc, Resent-Bcc, or DKIM-Signature.
+
+
+
+
+ Verify the specified DKIM-Signature header.
+
+
+ Verifies the specified DKIM-Signature header.
+
+ true if the DKIM-Signature is valid; otherwise, false.
+ The formatting options.
+ The DKIM-Signature header.
+ The public key locator service.
+ The cancellation token.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ is not a DKIM-Signature header.
+
+
+ The DKIM-Signature header value is malformed.
+
+
+ The operation was canceled via the cancellation token.
+
+
+
+
+ Verify the specified DKIM-Signature header.
+
+
+ Verifies the specified DKIM-Signature header.
+
+ true if the DKIM-Signature is valid; otherwise, false.
+ The DKIM-Signature header.
+ The public key locator service.
+ The cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a DKIM-Signature header.
+
+
+ The DKIM-Signature header value is malformed.
+
+
+ The operation was canceled via the cancellation token.
+
+
+
+
+ Sign the message using the specified cryptography context and digest algorithm.
+
+
+ If either of the Resent-Sender or Resent-From headers are set, then the message
+ will be signed using the Resent-Sender (or first mailbox in the Resent-From)
+ address as the signer address, otherwise the Sender or From address will be
+ used instead.
+
+ The cryptography context.
+ The digest algorithm.
+
+ is null.
+
+
+ The has not been set.
+ -or-
+ A sender has not been specified.
+
+
+ The was out of range.
+
+
+ The is not supported.
+
+
+ A signing certificate could not be found for the sender.
+
+
+ The private key could not be found for the sender.
+
+
+
+
+ Sign the message using the specified cryptography context and the SHA-1 digest algorithm.
+
+
+ If either of the Resent-Sender or Resent-From headers are set, then the message
+ will be signed using the Resent-Sender (or first mailbox in the Resent-From)
+ address as the signer address, otherwise the Sender or From address will be
+ used instead.
+
+ The cryptography context.
+
+ is null.
+
+
+ The has not been set.
+ -or-
+ A sender has not been specified.
+
+
+ A signing certificate could not be found for the sender.
+
+
+ The private key could not be found for the sender.
+
+
+
+
+ Encrypt the message to the sender and all of the recipients
+ using the specified cryptography context.
+
+
+ If either of the Resent-Sender or Resent-From headers are set, then the message
+ will be encrypted to all of the addresses specified in the Resent headers
+ (Resent-Sender, Resent-From, Resent-To, Resent-Cc, and Resent-Bcc),
+ otherwise the message will be encrypted to all of the addresses specified in
+ the standard address headers (Sender, From, To, Cc, and Bcc).
+
+ The cryptography context.
+
+ is null.
+
+
+ An unknown type of cryptography context was used.
+
+
+ The has not been set.
+ -or-
+ No recipients have been specified.
+
+
+ A certificate could not be found for one or more of the recipients.
+
+
+ The public key could not be found for one or more of the recipients.
+
+
+
+
+ Sign and encrypt the message to the sender and all of the recipients using
+ the specified cryptography context and the specified digest algorithm.
+
+
+ If either of the Resent-Sender or Resent-From headers are set, then the message
+ will be signed using the Resent-Sender (or first mailbox in the Resent-From)
+ address as the signer address, otherwise the Sender or From address will be
+ used instead.
+ Likewise, if either of the Resent-Sender or Resent-From headers are set, then the
+ message will be encrypted to all of the addresses specified in the Resent headers
+ (Resent-Sender, Resent-From, Resent-To, Resent-Cc, and Resent-Bcc),
+ otherwise the message will be encrypted to all of the addresses specified in
+ the standard address headers (Sender, From, To, Cc, and Bcc).
+
+ The cryptography context.
+ The digest algorithm.
+
+ is null.
+
+
+ An unknown type of cryptography context was used.
+
+
+ The was out of range.
+
+
+ The has not been set.
+ -or-
+ The sender has been specified.
+ -or-
+ No recipients have been specified.
+
+
+ The is not supported.
+
+
+ A certificate could not be found for the signer or one or more of the recipients.
+
+
+ The private key could not be found for the sender.
+
+
+ The public key could not be found for one or more of the recipients.
+
+
+
+
+ Sign and encrypt the message to the sender and all of the recipients using
+ the specified cryptography context and the SHA-1 digest algorithm.
+
+
+ If either of the Resent-Sender or Resent-From headers are set, then the message
+ will be signed using the Resent-Sender (or first mailbox in the Resent-From)
+ address as the signer address, otherwise the Sender or From address will be
+ used instead.
+ Likewise, if either of the Resent-Sender or Resent-From headers are set, then the
+ message will be encrypted to all of the addresses specified in the Resent headers
+ (Resent-Sender, Resent-From, Resent-To, Resent-Cc, and Resent-Bcc),
+ otherwise the message will be encrypted to all of the addresses specified in
+ the standard address headers (Sender, From, To, Cc, and Bcc).
+
+ The cryptography context.
+
+ is null.
+
+
+ An unknown type of cryptography context was used.
+
+
+ The has not been set.
+ -or-
+ The sender has been specified.
+ -or-
+ No recipients have been specified.
+
+
+ A certificate could not be found for the signer or one or more of the recipients.
+
+
+ The private key could not be found for the sender.
+
+
+ The public key could not be found for one or more of the recipients.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ specified .
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save mmeory usage, but also improve
+ performance.
+
+ The parsed message.
+ The parser options.
+ The stream.
+ true if the stream is persistent; otherwise false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ specified .
+
+ The parsed message.
+ The parser options.
+ The stream.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ default .
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save mmeory usage, but also improve
+ performance.
+
+ The parsed message.
+ The stream.
+ true if the stream is persistent; otherwise false.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified stream.
+
+
+ Loads a from the given stream, using the
+ default .
+
+ The parsed message.
+ The stream.
+ A cancellation token.
+
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified file.
+
+
+ Loads a from the file at the given path, using the
+ specified .
+
+ The parsed message.
+ The parser options.
+ The name of the file to load.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Load a from the specified file.
+
+
+ Loads a from the file at the given path, using the
+ default .
+
+ The parsed message.
+ The name of the file to load.
+ A cancellation token.
+
+ is null.
+
+
+ is a zero-length string, contains only white space, or
+ contains one or more invalid characters as defined by
+ .
+
+
+ is an invalid file path.
+
+
+ The specified file path could not be found.
+
+
+ The user does not have access to read the specified file.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Creates a new from a .
+
+
+ Creates a new from a .
+
+ The equivalent .
+ The message.
+
+ is null.
+
+
+
+
+ Explicit cast to convert a to a
+ .
+
+
+ Allows creation of messages using Microsoft's System.Net.Mail APIs.
+
+ The equivalent .
+ The message.
+
+
+
+ A MIME message and entity parser.
+
+
+ A MIME parser is used to parse and
+ objects from arbitrary streams.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new that will parse the specified stream.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The stream to parse.
+ The format of the stream.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new that will parse the specified stream.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The stream to parse.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new that will parse the specified stream.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The parser options.
+ The stream to parse.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new that will parse the specified stream.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The parser options.
+ The stream to parse.
+ The format of the stream.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Gets a value indicating whether the parser has reached the end of the input stream.
+
+
+ Gets a value indicating whether the parser has reached the end of the input stream.
+
+ true if this parser has reached the end of the input stream;
+ otherwise, false.
+
+
+
+ Gets the current position of the parser within the stream.
+
+
+ Gets the current position of the parser within the stream.
+
+ The stream offset.
+
+
+
+ Gets the most recent mbox marker offset.
+
+
+ Gets the most recent mbox marker offset.
+
+ The mbox marker offset.
+
+
+
+ Gets the most recent mbox marker.
+
+
+ Gets the most recent mbox marker.
+
+ The mbox marker.
+
+
+
+ Sets the stream to parse.
+
+
+ Sets the stream to parse.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The parser options.
+ The stream to parse.
+ The format of the stream.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Sets the stream to parse.
+
+
+ Sets the stream to parse.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The parser options.
+ The stream to parse.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Sets the stream to parse.
+
+
+ Sets the stream to parse.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The stream to parse.
+ The format of the stream.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+
+
+
+
+ Sets the stream to parse.
+
+
+ Sets the stream to parse.
+ If is true and is seekable, then
+ the will not copy the content of s into memory. Instead,
+ it will use a to reference a substream of .
+ This has the potential to not only save memory usage, but also improve
+ performance.
+ It should be noted, however, that disposing will make it impossible
+ for to read the content.
+
+ The stream to parse.
+ true if the stream is persistent; otherwise false.
+
+ is null.
+
+
+
+
+ Parses a list of headers from the stream.
+
+
+ Parses a list of headers from the stream.
+
+ The parsed list of headers.
+ A cancellation token.
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the headers.
+
+
+ An I/O error occurred.
+
+
+
+
+ Parses an entity from the stream.
+
+
+ Parses an entity from the stream.
+
+ The parsed entity.
+ A cancellation token.
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the entity.
+
+
+ An I/O error occurred.
+
+
+
+
+ Parses a message from the stream.
+
+
+ Parses a message from the stream.
+
+ The parsed message.
+ A cancellation token.
+
+ The operation was canceled via the cancellation token.
+
+
+ There was an error parsing the message.
+
+
+ An I/O error occurred.
+
+
+
+
+ Enumerates the messages in the stream.
+
+
+ This is mostly useful when parsing mbox-formatted streams.
+
+ The enumerator.
+
+
+
+ Enumerates the messages in the stream.
+
+
+ This is mostly useful when parsing mbox-formatted streams.
+
+ The enumerator.
+
+
+
+ A leaf-node MIME part that contains content such as the message body text or an attachment.
+
+
+ A leaf-node MIME part that contains content such as the message body text or an attachment.
+
+
+
+
+ Initializes a new instance of the class
+ based on the .
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class
+ with the specified media type and subtype.
+
+
+ Creates a new with the specified media type and subtype.
+
+ The media type.
+ The media subtype.
+ An array of initialization parameters: headers and part content.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ contains more than one or
+ .
+ -or-
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class
+ with the specified media type and subtype.
+
+
+ Creates a new with the specified media type and subtype.
+
+ The media type.
+ The media subtype.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Initializes a new instance of the class
+ with the specified content type.
+
+
+ Creates a new with the specified Content-Type value.
+
+ The content type.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class
+ with the specified content type.
+
+
+ Creates a new with the specified Content-Type value.
+
+ The content type.
+
+ is null.
+
+
+ could not be parsed.
+
+
+
+
+ Initializes a new instance of the class
+ with the default Content-Type of application/octet-stream.
+
+
+ Creates a new with a Content-Type of application/octet-stream.
+
+
+
+
+ Gets or sets the duration of the content if available.
+
+
+ The Content-Duration header specifies duration of timed media,
+ such as audio or video, in seconds.
+
+ The duration of the content.
+
+ is negative.
+
+
+
+
+ Gets or sets the md5sum of the content.
+
+
+ The Content-MD5 header specifies the base64-encoded MD5 checksum of the content
+ in its canonical format.
+ For more information, see http://www.ietf.org/rfc/rfc1864.txt
+
+ The md5sum of the content.
+
+
+
+ Gets or sets the content transfer encoding.
+
+
+ The Content-Transfer-Encoding header specifies an auxiliary encoding
+ that was applied to the content in order to allow it to pass through
+ mail transport mechanisms (such as SMTP) which may have limitations
+ in the byte ranges that it accepts. For example, many SMTP servers
+ do not accept data outside of the 7-bit ASCII range and so sending
+ binary attachments or even non-English text is not possible without
+ applying an encoding such as base64 or quoted-printable.
+
+ The content transfer encoding.
+
+
+
+ Gets or sets the name of the file.
+
+
+ First checks for the "filename" parameter on the Content-Disposition header. If
+ that does not exist, then the "name" parameter on the Content-Type header is used.
+ When setting the filename, both the "filename" parameter on the Content-Disposition
+ header and the "name" parameter on the Content-Type header are set.
+
+ The name of the file.
+
+
+
+ Gets or sets the MIME content.
+
+
+ Gets or sets the MIME content.
+
+ The MIME content.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Calculates the most efficient content encoding given the specified constraint.
+
+
+ If no is set, will be returned.
+
+ The most efficient content encoding.
+ The encoding constraint.
+ A cancellation token.
+
+ is not a valid value.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Calculates the most efficient content encoding given the specified constraint.
+
+
+ If no is set, will be returned.
+
+ The most efficient content encoding.
+ The encoding constraint.
+ The maximum allowable length for a line (not counting the CRLF). Must be between 72 and 998 (inclusive).
+ A cancellation token.
+
+ is not between 72 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Computes the MD5 checksum of the content.
+
+
+ Computes the MD5 checksum of the MIME content in its canonical
+ format and then base64-encodes the result.
+
+ The md5sum of the content.
+
+ The is null.
+
+
+
+
+ Verifies the Content-Md5 value against an independently computed md5sum.
+
+
+ Computes the MD5 checksum of the MIME content and compares it with the
+ value in the Content-MD5 header, returning true if and only if
+ the values match.
+
+ true, if content MD5 checksum was verified, false otherwise.
+
+
+
+ Prepare the MIME entity for transport using the specified encoding constraints.
+
+
+ Prepares the MIME entity for transport using the specified encoding constraints.
+
+ The encoding constraint.
+ The maximum number of octets allowed per line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes the MIME part to the output stream.
+
+ The formatting options.
+ The output stream.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Called when the headers change in some way.
+
+
+ Updates the , ,
+ and properties if the corresponding headers have changed.
+
+ The type of change.
+ The header being added, changed or removed.
+
+
+
+ A mapping of file name extensions to the corresponding MIME-type.
+
+
+ A mapping of file name extensions to the corresponding MIME-type.
+
+
+
+
+ Gets the MIME-type of the file.
+
+
+ Gets the MIME-type of the file based on the file extension.
+
+ The MIME-type.
+ The file name.
+
+ is null.
+
+
+
+
+ Represents a visitor for MIME trees.
+
+
+ This class is designed to be inherited to create more specialized classes whose
+ functionality requires traversing, examining or copying a MIME tree.
+
+
+
+
+
+
+
+ Dispatches the entity to one of the more specialized visit methods in this class.
+
+
+ Dispatches the entity to one of the more specialized visit methods in this class.
+
+ The MIME entity.
+
+
+
+ Dispatches the message to one of the more specialized visit methods in this class.
+
+
+ Dispatches the message to one of the more specialized visit methods in this class.
+
+ The MIME message.
+
+
+
+ Visit the application/pgp-encrypted MIME entity.
+
+
+ Visits the application/pgp-encrypted MIME entity.
+
+
+ The application/pgp-encrypted MIME entity.
+
+
+
+ Visit the application/pgp-signature MIME entity.
+
+
+ Visits the application/pgp-signature MIME entity.
+
+
+ The application/pgp-signature MIME entity.
+
+
+
+ Visit the application/pkcs7-mime MIME entity.
+
+
+ Visits the application/pkcs7-mime MIME entity.
+
+ The application/pkcs7-mime MIME entity.
+
+
+
+ Visit the application/pkcs7-signature MIME entity.
+
+
+ Visits the application/pkcs7-signature MIME entity.
+
+
+ The application/pkcs7-signature MIME entity.
+
+
+
+ Visit the message/disposition-notification MIME entity.
+
+
+ Visits the message/disposition-notification MIME entity.
+
+ The message/disposition-notification MIME entity.
+
+
+
+ Visit the message/delivery-status MIME entity.
+
+
+ Visits the message/delivery-status MIME entity.
+
+ The message/delivery-status MIME entity.
+
+
+
+ Visit the message contained within a message/rfc822 or message/news MIME entity.
+
+
+ Visits the message contained within a message/rfc822 or message/news MIME entity.
+
+ The message/rfc822 or message/news MIME entity.
+
+
+
+ Visit the message/rfc822 or message/news MIME entity.
+
+
+ Visits the message/rfc822 or message/news MIME entity.
+
+
+
+
+ The message/rfc822 or message/news MIME entity.
+
+
+
+ Visit the message/partial MIME entity.
+
+
+ Visits the message/partial MIME entity.
+
+ The message/partial MIME entity.
+
+
+
+ Visit the abstract MIME entity.
+
+
+ Visits the abstract MIME entity.
+
+ The MIME entity.
+
+
+
+ Visit the body of the message.
+
+
+ Visits the body of the message.
+
+ The message.
+
+
+
+ Visit the MIME message.
+
+
+ Visits the MIME message.
+
+ The MIME message.
+
+
+
+ Visit the abstract MIME part entity.
+
+
+ Visits the MIME part entity.
+
+
+
+
+ The MIME part entity.
+
+
+
+ Visit the children of a .
+
+
+ Visits the children of a .
+
+ Multipart.
+
+
+
+ Visit the abstract multipart MIME entity.
+
+
+ Visits the abstract multipart MIME entity.
+
+ The multipart MIME entity.
+
+
+
+ Visit the multipart/alternative MIME entity.
+
+
+ Visits the multipart/alternative MIME entity.
+
+
+
+
+ The multipart/alternative MIME entity.
+
+
+
+ Visit the multipart/encrypted MIME entity.
+
+
+ Visits the multipart/encrypted MIME entity.
+
+ The multipart/encrypted MIME entity.
+
+
+
+ Visit the multipart/related MIME entity.
+
+
+ Visits the multipart/related MIME entity.
+
+
+
+
+ The multipart/related MIME entity.
+
+
+
+ Visit the multipart/report MIME entity.
+
+
+ Visits the multipart/report MIME entity.
+
+
+
+
+ The multipart/report MIME entity.
+
+
+
+ Visit the multipart/signed MIME entity.
+
+
+ Visits the multipart/signed MIME entity.
+
+ The multipart/signed MIME entity.
+
+
+
+ Visit the text-based MIME part entity.
+
+
+ Visits the text-based MIME part entity.
+
+
+
+
+ The text-based MIME part entity.
+
+
+
+ Visit the Microsoft TNEF MIME part entity.
+
+
+ Visits the Microsoft TNEF MIME part entity.
+
+
+
+
+ The Microsoft TNEF MIME part entity.
+
+
+
+ A multipart MIME entity which may contain a collection of MIME entities.
+
+
+ All multipart MIME entities will have a Content-Type with a media type of "multipart".
+ The most common multipart MIME entity used in email is the "multipart/mixed" entity.
+ Four (4) initial subtypes were defined in the original MIME specifications: mixed, alternative,
+ digest, and parallel.
+ The "multipart/mixed" type is a sort of general-purpose container. When used in email, the
+ first entity is typically the "body" of the message while additional entities are most often
+ file attachments.
+ Speaking of message "bodies", the "multipart/alternative" type is used to offer a list of
+ alternative formats for the main body of the message (usually they will be "text/plain" and
+ "text/html"). These alternatives are in order of increasing faithfulness to the original document
+ (in other words, the last entity will be in a format that, when rendered, will most closely match
+ what the sending client's WYSISYG editor produced).
+ The "multipart/digest" type will typically contain a digest of MIME messages and is most
+ commonly used by mailing-list software.
+ The "multipart/parallel" type contains entities that are all meant to be shown (or heard)
+ in parallel.
+ Another commonly used type is the "multipart/related" type which contains, as one might expect,
+ inter-related MIME parts which typically reference each other via URIs based on the Content-Id and/or
+ Content-Location headers.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified subtype.
+
+ The multipart media sub-type.
+ An array of initialization parameters: headers and MIME entities.
+
+ is null.
+ -or-
+ is null.
+
+
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with the specified subtype.
+
+ The multipart media sub-type.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new with a ContentType of multipart/mixed.
+
+
+
+
+ Gets or sets the boundary.
+
+
+ Gets or sets the boundary parameter on the Content-Type header.
+
+ The boundary.
+
+ is null.
+
+
+
+
+ Gets or sets the preamble.
+
+
+ A multipart preamble appears before the first child entity of the
+ multipart and is typically used only in the top-level multipart
+ of the message to specify that the message is in MIME format and
+ therefore requires a MIME compliant email application to render
+ it correctly.
+
+ The preamble.
+
+
+
+ Gets or sets the epilogue.
+
+
+ A multipart epiloque is the text that appears after the closing boundary
+ of the multipart and is typically either empty or a single new line
+ character sequence.
+
+ The epilogue.
+
+
+
+ Gets or sets whether the end boundary should be written.
+
+
+ Gets or sets whether the end boundary should be written.
+
+ true if the end boundary should be written; otherwise, false.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Prepare the MIME entity for transport using the specified encoding constraints.
+
+
+ Prepares the MIME entity for transport using the specified encoding constraints.
+
+ The encoding constraint.
+ The maximum number of octets allowed per line (not counting the CRLF). Must be between 60 and 998 (inclusive).
+
+ is not between 60 and 998 (inclusive).
+ -or-
+ is not a valid value.
+
+
+
+
+ Writes the to the specified output stream.
+
+
+ Writes the multipart MIME entity and its subparts to the output stream.
+
+ The formatting options.
+ The output stream.
+ true if only the content should be written; otherwise, false.
+ A cancellation token.
+
+ is null.
+ -or-
+ is null.
+
+
+ The operation was canceled via the cancellation token.
+
+
+ An I/O error occurred.
+
+
+
+
+ Gets the number of parts in the multipart.
+
+
+ Indicates the number of parts in the multipart.
+
+ The number of parts in the multipart.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Adds the specified part.
+
+
+ Adds the specified part to the multipart.
+
+ The part to add.
+
+ is null.
+
+
+
+
+ Clears the multipart.
+
+
+ Removes all of the parts within the multipart.
+
+
+
+
+ Checks if the contains the specified part.
+
+
+ Determines whether or not the multipart contains the specified part.
+
+ true if the specified part exists;
+ otherwise false.
+ The part to check for.
+
+ is null.
+
+
+
+
+ Copies all of the entities in the to the specified array.
+
+
+ Copies all of the entities within the into the array,
+ starting at the specified array index.
+
+ The array to copy the headers to.
+ The index into the array.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified part.
+
+
+ Removes the specified part, if it exists within the multipart.
+
+ true if the part was removed; otherwise false.
+ The part to remove.
+
+ is null.
+
+
+
+
+ Gets the index of the specified part.
+
+
+ Finds the index of the specified part, if it exists.
+
+ The index of the specified part if found; otherwise -1.
+ The part.
+
+ is null.
+
+
+
+
+ Inserts the part at the specified index.
+
+
+ Inserts the part into the multipart at the specified index.
+
+ The index.
+ The part.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Removes the part at the specified index.
+
+
+ Removes the part at the specified index.
+
+ The index.
+
+ is out of range.
+
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the at the specified index.
+
+ The entity at the specified index.
+ The index.
+
+ is null.
+
+
+ is out of range.
+
+
+
+
+ Gets the enumerator for the children of the .
+
+
+ Gets the enumerator for the children of the .
+
+ The enumerator.
+
+
+
+ Gets the enumerator for the children of the .
+
+
+ Gets the enumerator for the children of the .
+
+ The enumerator.
+
+
+
+ A multipart/alternative MIME entity.
+
+
+ A multipart/alternative MIME entity contains, as one might expect, is used to offer a list of
+ alternative formats for the main body of the message (usually they will be "text/plain" and
+ "text/html"). These alternatives are in order of increasing faithfulness to the original document
+ (in other words, the last entity will be in a format that, when rendered, will most closely match
+ what the sending client's WYSISYG editor produced).
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new part.
+
+ An array of initialization parameters: headers and MIME entities.
+
+ is null.
+
+
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new part.
+
+
+
+
+ Get the text of the text/plain alternative.
+
+
+ Gets the text of the text/plain alternative, if it exists.
+
+ The text if a text/plain alternative exists; otherwise, null.
+
+
+
+ Get the HTML-formatted text of the text/html alternative.
+
+
+ Gets the HTML-formatted text of the text/html alternative, if it exists.
+
+ The HTML if a text/html alternative exists; otherwise, null.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Get the text body in the specified format.
+
+
+ Gets the text body in the specified format, if it exists.
+
+ The text body in the desired format if it exists; otherwise, null.
+ The desired text format.
+
+
+
+ A multipart/related MIME entity.
+
+
+ A multipart/related MIME entity contains, as one might expect, inter-related MIME parts which
+ typically reference each other via URIs based on the Content-Id and/or Content-Location headers.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new part.
+
+ An array of initialization parameters: headers and MIME entities.
+
+ is null.
+
+
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new part.
+
+
+
+
+ Gets or sets the root document of the multipart/related part and the appropriate Content-Type parameters.
+
+
+ Gets or sets the root document that references the other MIME parts within the multipart/related.
+ When getting the root document, the "start" parameter of the Content-Type header is used to
+ determine which of the parts is the root. If the "start" parameter does not exist or does not reference
+ any of the child parts, then the first child is assumed to be the root.
+ When setting the root document MIME part, the Content-Type header of the multipart/related part is also
+ updated with a appropriate "start" and "type" parameters.
+
+ The root MIME part.
+
+ is null.
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Checks if the contains a part matching the specified URI.
+
+
+ Determines whether or not the multipart/related entity contains a part matching the specified URI.
+
+ true if the specified part exists; otherwise false.
+ The URI of the MIME part.
+
+ is null.
+
+
+
+
+ Gets the index of the part matching the specified URI.
+
+
+ Finds the index of the part matching the specified URI, if it exists.
+ If the URI scheme is "cid", then matching is performed based on the Content-Id header
+ values, otherwise the Content-Location headers are used. If the provided URI is absolute and a child
+ part's Content-Location is relative, then then the child part's Content-Location URI will be combined
+ with the value of its Content-Base header, if available, otherwise it will be combined with the
+ multipart/related part's Content-Base header in order to produce an absolute URI that can be
+ compared with the provided absolute URI.
+
+ The index of the part matching the specified URI if found; otherwise -1.
+ The URI of the MIME part.
+
+ is null.
+
+
+
+
+ Opens a stream for reading the decoded content of the MIME part specified by the provided URI.
+
+
+ Opens a stream for reading the decoded content of the MIME part specified by the provided URI.
+
+ A stream for reading the decoded content of the MIME part specified by the provided URI.
+ The URI.
+ The mime-type of the content.
+ The charset of the content (if the content is text-based)
+
+ is null.
+
+
+ The MIME part for the specified URI could not be found.
+
+
+
+
+ Opens a stream for reading the decoded content of the MIME part specified by the provided URI.
+
+
+ Opens a stream for reading the decoded content of the MIME part specified by the provided URI.
+
+ A stream for reading the decoded content of the MIME part specified by the provided URI.
+ The URI.
+
+ is null.
+
+
+ The MIME part for the specified URI could not be found.
+
+
+
+
+ A multipart/report MIME entity.
+
+
+ A multipart/related MIME entity is a general container part for electronic mail
+ reports of any kind.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new part.
+
+ The type of the report.
+ An array of initialization parameters: headers and MIME entities.
+
+ is null.
+ -or-
+ is null.
+
+
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new part.
+
+
+ is null.
+
+
+
+
+ Gets or sets the type of the report.
+
+
+ Gets or sets the type of the report.
+ The report type should be the subtype of the second
+ of the multipart/report.
+
+ The type of the report.
+
+ is null.
+
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ A header parameter as found in the Content-Type and Content-Disposition headers.
+
+
+ Content-Type and Content-Disposition headers often have parameters that specify
+ further information about how to interpret the content.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new parameter with the specified name and value.
+
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+
+
+ contains illegal characters.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new parameter with the specified name and value.
+
+ The character encoding.
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ contains illegal characters.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new parameter with the specified name and value.
+
+ The character encoding.
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ contains illegal characters.
+
+
+ is not supported.
+
+
+
+
+ Gets the parameter name.
+
+
+ Gets the parameter name.
+
+ The parameter name.
+
+
+
+ Gets or sets the parameter value character encoding.
+
+
+ Gets or sets the parameter value character encoding.
+
+ The character encoding.
+
+
+
+ Gets or sets the parameter encoding method to use.
+
+
+ Gets or sets the parameter encoding method to use.
+ The MIME specifications specify that the proper method for encoding Content-Type
+ and Content-Disposition parameter values is the method described in
+ rfc2231. However, it is common for
+ some older email clients to improperly encode using the method described in
+ rfc2047 instead.
+ If set to , the encoding
+ method used will default to the value set on the .
+
+ The encoding method.
+
+ is not a valid value.
+
+
+
+
+ Gets or sets the parameter value.
+
+
+ Gets or sets the parameter value.
+
+ The parameter value.
+
+ is null.
+
+
+
+
+ Returns a string representation of the .
+
+
+ Formats the parameter name and value in the form name="value".
+
+ A string representation of the .
+
+
+
+ The method to use for encoding Content-Type and Content-Disposition parameter values.
+
+
+ The MIME specifications specify that the proper method for encoding Content-Type and
+ Content-Disposition parameter values is the method described in
+ rfc2231. However, it is common for
+ some older email clients to improperly encode using the method described in
+ rfc2047 instead.
+
+
+
+
+ Use the default encoding method set on the .
+
+
+
+
+ Use the encoding method described in rfc2231.
+
+
+
+
+ Use the encoding method described in rfc2047 (for compatibility with older,
+ non-rfc-compliant email clients).
+
+
+
+
+ A list of parameters, as found in the Content-Type and Content-Disposition headers.
+
+
+ Parameters are used by both and .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new parameter list.
+
+
+
+
+ Adds a parameter with the specified name and value.
+
+
+ Adds a new parameter to the list with the specified name and value.
+
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Adds a parameter with the specified name and value.
+
+
+ Adds a new parameter to the list with the specified name and value.
+
+ The character encoding.
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ contains illegal characters.
+
+
+
+
+ Adds a parameter with the specified name and value.
+
+
+ Adds a new parameter to the list with the specified name and value.
+
+ The character encoding.
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+ -or-
+ is null.
+
+
+ cannot be empty.
+ -or-
+ contains illegal characters.
+
+
+ is not supported.
+
+
+
+
+ Checks if the contains a parameter with the specified name.
+
+
+ Determines whether or not the parameter list contains a parameter with the specified name.
+
+ true if the requested parameter exists;
+ otherwise false.
+ The parameter name.
+
+ is null.
+
+
+
+
+ Gets the index of the requested parameter, if it exists.
+
+
+ Finds the index of the parameter with the specified name, if it exists.
+
+ The index of the requested parameter; otherwise -1.
+ The parameter name.
+
+ is null.
+
+
+
+
+ Inserts a parameter with the specified name and value at the given index.
+
+
+ Inserts a new parameter with the given name and value at the specified index.
+
+ The index to insert the parameter.
+ The parameter name.
+ The parameter value.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+ is out of range.
+
+
+
+
+ Removes the specified parameter.
+
+
+ Removes the parameter with the specified name from the list, if it exists.
+
+ true if the specified parameter was removed;
+ otherwise false.
+ The parameter name.
+
+ is null.
+
+
+
+
+ Gets or sets the value of a parameter with the specified name.
+
+
+ Gets or sets the value of a parameter with the specified name.
+
+ The value of the specified parameter if it exists; otherwise null.
+ The parameter name.
+
+ is null.
+ -or-
+ is null.
+
+
+ The contains illegal characters.
+
+
+
+
+ Gets the parameter with the specified name.
+
+
+ Gets the parameter with the specified name.
+
+ true if the parameter exists; otherwise, false.
+ The parameter name.
+ The parameter.
+
+ is null.
+
+
+
+
+ Gets the value of the parameter with the specified name.
+
+
+ Gets the value of the parameter with the specified name.
+
+ true if the parameter exists; otherwise, false.
+ The parameter name.
+ The parameter value.
+
+ is null.
+
+
+
+
+ Gets the number of parameters in the .
+
+
+ Indicates the number of parameters in the list.
+
+ The number of parameters.
+
+
+
+ Gets a value indicating whether this instance is read only.
+
+
+ A is never read-only.
+
+ true if this instance is read only; otherwise, false.
+
+
+
+ Adds the specified parameter.
+
+
+ Adds the specified parameter to the end of the list.
+
+ The parameter to add.
+
+ The is null.
+
+
+ A parameter with the same name as
+ already exists.
+
+
+
+
+ Clears the parameter list.
+
+
+ Removes all of the parameters from the list.
+
+
+
+
+ Checks if the contains the specified parameter.
+
+
+ Determines whether or not the parameter list contains the specified parameter.
+
+ true if the specified parameter is contained;
+ otherwise false.
+ The parameter.
+
+ The is null.
+
+
+
+
+ Copies all of the contained parameters to the specified array.
+
+
+ Copies all of the parameters within the into the array,
+ starting at the specified array index.
+
+ The array to copy the parameters to.
+ The index into the array.
+
+
+
+ Removes the specified parameter.
+
+
+ Removes the specified parameter from the list.
+
+ true if the specified parameter was removed;
+ otherwise false.
+ The parameter.
+
+ The is null.
+
+
+
+
+ Gets the index of the requested parameter, if it exists.
+
+
+ Finds the index of the specified parameter, if it exists.
+
+ The index of the requested parameter; otherwise -1.
+ The parameter.
+
+ The is null.
+
+
+
+
+ Inserts the specified parameter at the given index.
+
+
+ Inserts the parameter at the specified index in the list.
+
+ The index to insert the parameter.
+ The parameter.
+
+ The is null.
+
+
+ The is out of range.
+
+
+ A parameter with the same name as
+ already exists.
+
+
+
+
+ Removes the parameter at the specified index.
+
+
+ Removes the parameter at the specified index.
+
+ The index.
+
+ The is out of range.
+
+
+
+
+ Gets or sets the at the specified index.
+
+
+ Gets or sets the at the specified index.
+
+ The parameter at the specified index.
+ The index.
+
+ The is null.
+
+
+ The is out of range.
+
+
+ A parameter with the same name as
+ already exists.
+
+
+
+
+ Gets an enumerator for the list of parameters.
+
+
+ Gets an enumerator for the list of parameters.
+
+ The enumerator.
+
+
+
+ Gets an enumerator for the list of parameters.
+
+
+ Gets an enumerator for the list of parameters.
+
+ The enumerator.
+
+
+
+ Returns a string representation of the parameters in the .
+
+
+ If there are multiple parameters in the list, they will be separated by a semicolon.
+
+ A string representing the .
+
+
+
+ A Parse exception as thrown by the various Parse methods in MimeKit.
+
+
+ A can be thrown by any of the Parse() methods
+ in MimeKit. Each exception instance will have a
+ which marks the byte offset of the token that failed to parse as well
+ as a which marks the byte offset where the error
+ occurred.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The serialization info.
+ The stream context.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The error message.
+ The byte offset of the token.
+ The byte offset of the error.
+ The inner exception.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new .
+
+ The error message.
+ The byte offset of the token.
+ The byte offset of the error.
+
+
+
+ When overridden in a derived class, sets the
+ with information about the exception.
+
+
+ Sets the
+ with information about the exception.
+
+ The serialization info.
+ The streaming context.
+
+ is null.
+
+
+
+
+ Gets the byte index of the token that was malformed.
+
+
+ The token index is the byte offset at which the token started.
+
+ The byte index of the token.
+
+
+
+ Gets the index of the byte that caused the error.
+
+
+ The error index is the byte offset at which the parser encountered an error.
+
+ The index of the byte that caused error.
+
+
+
+ Parser options as used by as well as various Parse and TryParse methods in MimeKit.
+
+
+ allows you to change and/or override default parsing options used by methods such
+ as and others.
+
+
+
+
+ The default parser options.
+
+
+ If a is not supplied to or other Parse and TryParse
+ methods throughout MimeKit, will be used.
+
+
+
+
+ Gets or sets the compliance mode that should be used when parsing rfc822 addresses.
+
+
+ In general, you'll probably want this value to be
+ (the default) as it allows maximum interoperability with existing (broken) mail clients
+ and other mail software such as sloppily written perl scripts (aka spambots).
+ Even in mode, the address
+ parser is fairly liberal in what it accepts. Setting it to
+ just makes it try harder to deal with garbage input.
+
+ The RFC compliance mode.
+
+
+
+ Gets or sets the compliance mode that should be used when parsing Content-Type and Content-Disposition parameters.
+
+
+ In general, you'll probably want this value to be
+ (the default) as it allows maximum interoperability with existing (broken) mail clients
+ and other mail software such as sloppily written perl scripts (aka spambots).
+ Even in mode, the parameter
+ parser is fairly liberal in what it accepts. Setting it to
+ just makes it try harder to deal with garbage input.
+
+ The RFC compliance mode.
+
+
+
+ Gets or sets the compliance mode that should be used when decoding rfc2047 encoded words.
+
+
+ In general, you'll probably want this value to be
+ (the default) as it allows maximum interoperability with existing (broken) mail clients
+ and other mail software such as sloppily written perl scripts (aka spambots).
+
+ The RFC compliance mode.
+
+
+
+ Gets or sets a value indicating whether the Content-Length value should be
+ respected when parsing mbox streams.
+
+
+ For more details about why this may be useful, you can find more information
+ at
+ http://www.jwz.org/doc/content-length.html.
+
+ true if the Content-Length value should be respected;
+ otherwise, false.
+
+
+
+ Gets or sets the charset encoding to use as a fallback for 8bit headers.
+
+
+ and
+
+ use this charset encoding as a fallback when decoding 8bit text into unicode. The first
+ charset encoding attempted is UTF-8, followed by this charset encoding, before finally
+ falling back to iso-8859-1.
+
+ The charset encoding.
+
+
+
+ Initializes a new instance of the class.
+
+
+ By default, new instances of enable rfc2047 work-arounds
+ (which are needed for maximum interoperability with mail software used in the wild)
+ and do not respect the Content-Length header value.
+
+
+
+
+ Clones an instance of .
+
+
+ Clones a set of options, allowing you to change a specific option
+ without requiring you to change the original.
+
+ An identical copy of the current instance.
+
+
+
+ Registers the subclass for the specified mime-type.
+
+ The MIME type.
+ A custom subclass of .
+
+ Your custom class should not subclass
+ directly, but rather it should subclass
+ , ,
+ , or one of their derivatives.
+
+
+ is null.
+ -or-
+ is null.
+
+
+ is not a subclass of ,
+ , or .
+ -or-
+ does not have a constructor that takes
+ only a argument.
+
+
+
+
+ An RFC compliance mode.
+
+
+ An RFC compliance mode.
+
+
+
+
+ Attempt to be much more liberal accepting broken and/or invalid formatting.
+
+
+
+
+ Do not attempt to be overly liberal in accepting broken and/or invalid formatting.
+
+
+
+
+ A Textual MIME part.
+
+
+ Unless overridden, all textual parts parsed by the ,
+ such as text/plain or text/html, will be represented by a .
+ For more information about text media types, see section 4.1 of
+ rfc2046.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ This constructor is used by .
+
+ Information used by the constructor.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the
+ class with the specified text subtype.
+
+
+ Creates a new with the specified subtype.
+
+ The media subtype.
+ An array of initialization parameters: headers, charset encoding and text.
+
+ is null.
+ -or-
+ is null.
+
+
+ contains more than one .
+ -or-
+ contains more than one .
+ -or-
+ contains one or more arguments of an unknown type.
+
+
+
+
+ Initializes a new instance of the
+ class with the specified text subtype.
+
+
+ Creates a new with the specified subtype.
+
+ The media subtype.
+
+ is null.
+
+
+
+
+ Initializes a new instance of the
+ class with a Content-Type of text/plain.
+
+
+ Creates a default with a mime-type of text/plain.
+
+
+
+
+ Gets whether or not this text part contains enriched text.
+
+
+ Checks whether or not the text part's Content-Type is text/enriched or its
+ predecessor, text/richtext (not to be confused with text/rtf).
+
+ true if the text is enriched; otherwise, false.
+
+
+
+ Gets whether or not this text part contains flowed text.
+
+
+ Checks whether or not the text part's Content-Type is text/plain and
+ has a format parameter with a value of flowed.
+
+ true if the text is flowed; otherwise, false.
+
+
+
+ Gets whether or not this text part contains HTML.
+
+
+ Checks whether or not the text part's Content-Type is text/html.
+
+ true if the text is html; otherwise, false.
+
+
+
+ Gets whether or not this text part contains plain text.
+
+
+ Checks whether or not the text part's Content-Type is text/plain.
+
+ true if the text is html; otherwise, false.
+
+
+
+ Gets whether or not this text part contains RTF.
+
+
+ Checks whether or not the text part's Content-Type is text/rtf.
+
+ true if the text is RTF; otherwise, false.
+
+
+
+ Gets the decoded text content.
+
+
+ If the charset parameter on the
+ is set, it will be used in order to convert the raw content into unicode.
+ If that fails or if the charset parameter is not set, iso-8859-1 will be
+ used instead.
+ For more control, use
+ or .
+
+ The text.
+
+
+
+ Dispatches to the specific visit method for this MIME entity.
+
+
+ This default implementation for nodes
+ calls . Override this
+ method to call into a more specific method on a derived visitor class
+ of the class. However, it should still
+ support unknown visitors by calling
+ .
+
+ The visitor.
+
+ is null.
+
+
+
+
+ Determines whether or not the text is in the specified format.
+
+
+ Determines whether or not the text is in the specified format.
+
+ true if the text is in the specified format; otherwise, false.
+ The text format.
+
+
+
+ Gets the decoded text content using the provided charset encoding to
+ override the charset specified in the Content-Type parameters.
+
+
+ Uses the provided charset encoding to convert the raw text content
+ into a unicode string, overriding any charset specified in the
+ Content-Type header.
+
+ The decoded text.
+ The charset encoding to use.
+
+ is null.
+
+
+
+
+ Gets the decoded text content using the provided charset to override
+ the charset specified in the Content-Type parameters.
+
+
+ Uses the provided charset encoding to convert the raw text content
+ into a unicode string, overriding any charset specified in the
+ Content-Type header.
+
+ The decoded text.
+ The charset encoding to use.
+
+ is null.
+
+
+ The is not supported.
+
+
+
+
+ Sets the text content and the charset parameter in the Content-Type header.
+
+
+ This method is similar to setting the property,
+ but allows specifying a charset encoding to use. Also updates the
+ property.
+
+ The charset encoding.
+ The text content.
+
+ is null.
+ -or-
+ is null.
+
+
+
+
+ Sets the text content and the charset parameter in the Content-Type header.
+
+
+ This method is similar to setting the property,
+ but allows specifying a charset encoding to use. Also updates the
+ property.
+
+ The charset encoding.
+ The text content.
+
+ is null.
+ -or-
+ is null.
+
+
+ The is not supported.
+
+
+
+
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 Preview/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 Preview/ExchangeDkimSigner.dll
index e6e8ed6b..8ddc231e 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 Preview/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2019 Preview/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 Preview/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 Preview/ExchangeDkimSigner.pdb
index 74ca1216..db7ee1bd 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 Preview/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2019 Preview/ExchangeDkimSigner.pdb differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 RTM/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 RTM/ExchangeDkimSigner.dll
index 7d9eb357..43869341 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 RTM/ExchangeDkimSigner.dll and b/Src/Exchange.DkimSigner/bin/Exchange 2019 RTM/ExchangeDkimSigner.dll differ
diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 RTM/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 RTM/ExchangeDkimSigner.pdb
index 1bde6f84..ee9c73cd 100644
Binary files a/Src/Exchange.DkimSigner/bin/Exchange 2019 RTM/ExchangeDkimSigner.pdb and b/Src/Exchange.DkimSigner/bin/Exchange 2019 RTM/ExchangeDkimSigner.pdb differ
diff --git a/coverity.proj b/coverity.proj
index 076bf80b..4e740d41 100644
--- a/coverity.proj
+++ b/coverity.proj
@@ -54,6 +54,7 @@
+
@@ -64,5 +65,6 @@
+
diff --git a/install.ps1 b/install.ps1
index ab2aca9d..a8075940 100644
--- a/install.ps1
+++ b/install.ps1
@@ -51,6 +51,7 @@ write-host "*** Exchange DkimSigner Install Script ***" -f "blue"
# Exchange 2016 CU17 (15.1.2044.4)
# Exchange 2016 CU18 (15.1.2106.2)
# Exchange 2016 CU19 (15.1.2176.2)
+# Exchange 2016 CU19 (15.1.2242.4)
# Exchange 2019 Preview (15.2.196.0)
# Exchange 2019 RTM (15.2.221.12)
# Exchange 2019 CU1 (15.2.330.5)
@@ -61,6 +62,7 @@ write-host "*** Exchange DkimSigner Install Script ***" -f "blue"
# Exchange 2019 CU6 (15.2.659.4)
# Exchange 2019 CU7 (15.2.721.2)
# Exchange 2019 CU8 (15.2.792.3)
+# Exchange 2019 CU8 (15.2.858.5)
write-host "Detecting Exchange version ... " -f "cyan"
$hostname = hostname
@@ -170,6 +172,8 @@ if (($exchserver.admindisplayversion).major -eq 8 -and ($exchserver.admindisplay
$EXVER="Exchange 2016 CU18"
} elseif (($exchserver.admindisplayversion).major -eq 15 -and ($exchserver.admindisplayversion).minor -eq 1 -and ($exchserver.admindisplayversion).build -eq 2176) {
$EXVER="Exchange 2016 CU19"
+} elseif (($exchserver.admindisplayversion).major -eq 15 -and ($exchserver.admindisplayversion).minor -eq 1 -and ($exchserver.admindisplayversion).build -eq 2242) {
+ $EXVER="Exchange 2016 CU20"
} elseif (($exchserver.admindisplayversion).major -eq 15 -and ($exchserver.admindisplayversion).minor -eq 2 -and ($exchserver.admindisplayversion).build -eq 196) {
$EXVER="Exchange 2019 Preview"
} elseif (($exchserver.admindisplayversion).major -eq 15 -and ($exchserver.admindisplayversion).minor -eq 2 -and ($exchserver.admindisplayversion).build -eq 221) {
@@ -190,6 +194,8 @@ if (($exchserver.admindisplayversion).major -eq 8 -and ($exchserver.admindisplay
$EXVER="Exchange 2019 CU7"
} elseif (($exchserver.admindisplayversion).major -eq 15 -and ($exchserver.admindisplayversion).minor -eq 2 -and ($exchserver.admindisplayversion).build -eq 792) {
$EXVER="Exchange 2019 CU8"
+} elseif (($exchserver.admindisplayversion).major -eq 15 -and ($exchserver.admindisplayversion).minor -eq 2 -and ($exchserver.admindisplayversion).build -eq 858) {
+ $EXVER="Exchange 2019 CU9"
} else {
throw "The exchange version is not yet supported: " + $exchserver.admindisplayversion
}