From 06508da98165efd779c7c85dae4247ccbf038826 Mon Sep 17 00:00:00 2001 From: "Jonathan W. Thomson" Date: Tue, 24 Mar 2020 20:58:22 +0000 Subject: [PATCH] v3.2.4 - Add support for Exchange 2016 CU16 and Exchange 2019 CU5 --- DkimSigner.sln | 8 + .../Microsoft.Exchange.Data.Common.dll | Bin 0 -> 1687120 bytes .../Microsoft.Exchange.Data.Transport.dll | Bin 0 -> 601472 bytes .../microsoft.exchange.data.common.xml | 9082 ++++ .../microsoft.exchange.data.transport.xml | 1792 + .../Microsoft.Exchange.Data.Common.dll | Bin 0 -> 1686392 bytes .../Microsoft.Exchange.Data.Transport.dll | Bin 0 -> 601464 bytes .../microsoft.exchange.data.common.xml | 9082 ++++ .../microsoft.exchange.data.transport.xml | 1792 + Src/Configuration.DkimSigner/Constants.cs | 4 +- .../Properties/AssemblyInfo.cs | 4 +- .../bin/Release/Configuration.DkimSigner.exe | Bin 821760 -> 821760 bytes .../bin/Release/Configuration.DkimSigner.pdb | Bin 378368 -> 378368 bytes .../Exchange.DkimSigner.csproj | 34 +- .../Properties/AssemblyInfo.cs | 4 +- .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2007 SP3/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2007 SP3/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2010 SP1/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2010 SP1/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2010 SP2/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2010 SP2/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2010 SP3/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2010 SP3/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../bin/Exchange 2010/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../bin/Exchange 2010/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2013 CU1/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2013 CU1/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2013 CU2/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2013 CU2/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2013 CU3/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2013 CU3/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 44544 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../bin/Exchange 2013/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../bin/Exchange 2013/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2016 CU1/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU1/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2016 CU10/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU10/ExchangeDkimSigner.pdb | Bin 44544 -> 52736 bytes .../Exchange 2016 CU11/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU11/ExchangeDkimSigner.pdb | Bin 44544 -> 52736 bytes .../Exchange 2016 CU12/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU12/ExchangeDkimSigner.pdb | Bin 44544 -> 52736 bytes .../Exchange 2016 CU13/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU13/ExchangeDkimSigner.pdb | Bin 44544 -> 52736 bytes .../Exchange 2016 CU14/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU14/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2016 CU15/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU15/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../bin/Exchange 2016 CU16/BouncyCastle.dll | Bin 0 -> 2049024 bytes .../bin/Exchange 2016 CU16/BouncyCastle.xml | 24206 ++++++++++ .../Exchange 2016 CU16/ExchangeDkimSigner.dll | Bin 0 -> 21504 bytes .../ExchangeDkimSigner.dll.config | 6 + .../Exchange 2016 CU16/ExchangeDkimSigner.pdb | Bin 0 -> 52736 bytes .../bin/Exchange 2016 CU16/MimeKit.dll | Bin 0 -> 800768 bytes .../bin/Exchange 2016 CU16/MimeKit.xml | 38398 ++++++++++++++++ .../Exchange 2016 CU2/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU2/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2016 CU3/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU3/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2016 CU4/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU4/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2016 CU5/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU5/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2016 CU6/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU6/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2016 CU7/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU7/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2016 CU8/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU8/ExchangeDkimSigner.pdb | Bin 46592 -> 52736 bytes .../Exchange 2016 CU9/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 CU9/ExchangeDkimSigner.pdb | Bin 46592 -> 52736 bytes .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2016 RTM/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2016 RTM/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2019 CU1/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2019 CU1/ExchangeDkimSigner.pdb | Bin 44544 -> 52736 bytes .../Exchange 2019 CU2/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2019 CU2/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2019 CU3/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2019 CU3/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../Exchange 2019 CU4/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2019 CU4/ExchangeDkimSigner.pdb | Bin 52736 -> 52736 bytes .../bin/Exchange 2019 CU5/BouncyCastle.dll | Bin 0 -> 2049024 bytes .../bin/Exchange 2019 CU5/BouncyCastle.xml | 24206 ++++++++++ .../Exchange 2019 CU5/ExchangeDkimSigner.dll | Bin 0 -> 21504 bytes .../ExchangeDkimSigner.dll.config | 6 + .../Exchange 2019 CU5/ExchangeDkimSigner.pdb | Bin 0 -> 52736 bytes .../bin/Exchange 2019 CU5/MimeKit.dll | Bin 0 -> 800768 bytes .../bin/Exchange 2019 CU5/MimeKit.xml | 38398 ++++++++++++++++ .../ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../ExchangeDkimSigner.pdb | Bin 44544 -> 52736 bytes .../Exchange 2019 RTM/ExchangeDkimSigner.dll | Bin 21504 -> 21504 bytes .../Exchange 2019 RTM/ExchangeDkimSigner.pdb | Bin 44544 -> 52736 bytes coverity.proj | 113 +- install.ps1 | 10 +- 137 files changed, 147080 insertions(+), 65 deletions(-) create mode 100644 Lib/Exchange 2016 CU16/Microsoft.Exchange.Data.Common.dll create mode 100644 Lib/Exchange 2016 CU16/Microsoft.Exchange.Data.Transport.dll create mode 100644 Lib/Exchange 2016 CU16/microsoft.exchange.data.common.xml create mode 100644 Lib/Exchange 2016 CU16/microsoft.exchange.data.transport.xml create mode 100644 Lib/Exchange 2019 CU5/Microsoft.Exchange.Data.Common.dll create mode 100644 Lib/Exchange 2019 CU5/Microsoft.Exchange.Data.Transport.dll create mode 100644 Lib/Exchange 2019 CU5/microsoft.exchange.data.common.xml create mode 100644 Lib/Exchange 2019 CU5/microsoft.exchange.data.transport.xml create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/BouncyCastle.dll create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/BouncyCastle.xml create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.dll create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.dll.config create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.pdb create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/MimeKit.dll create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/MimeKit.xml create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/BouncyCastle.dll create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/BouncyCastle.xml create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.dll create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.dll.config create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.pdb create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/MimeKit.dll create mode 100644 Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/MimeKit.xml diff --git a/DkimSigner.sln b/DkimSigner.sln index 5351064a..66bb295b 100644 --- a/DkimSigner.sln +++ b/DkimSigner.sln @@ -50,6 +50,7 @@ Global Ex2016 CU13|Any CPU = Ex2016 CU13|Any CPU Ex2016 CU14|Any CPU = Ex2016 CU14|Any CPU Ex2016 CU15|Any CPU = Ex2016 CU15|Any CPU + Ex2016 CU15|Any CPU = Ex2016 CU16|Any CPU Ex2016 CU2|Any CPU = Ex2016 CU2|Any CPU Ex2016 CU3|Any CPU = Ex2016 CU3|Any CPU Ex2016 CU4|Any CPU = Ex2016 CU4|Any CPU @@ -64,6 +65,7 @@ Global Ex2019 CU2|Any CPU = Ex2019 CU2|Any CPU Ex2019 CU3|Any CPU = Ex2019 CU3|Any CPU Ex2019 CU4|Any CPU = Ex2019 CU4|Any CPU + Ex2019 CU4|Any CPU = Ex2019 CU5|Any CPU Ex2019 Preview|Any CPU = Ex2019 Preview|Any CPU Ex2019 RTM|Any CPU = Ex2019 RTM|Any CPU Release|Any CPU = Release|Any CPU @@ -151,6 +153,8 @@ Global {3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2016 CU14|Any CPU.Build.0 = Ex2016 CU14|Any CPU {3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2016 CU15|Any CPU.ActiveCfg = Ex2016 CU15|Any CPU {3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2016 CU15|Any CPU.Build.0 = Ex2016 CU15|Any CPU + {3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2016 CU16|Any CPU.ActiveCfg = Ex2016 CU16|Any CPU + {3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2016 CU16|Any CPU.Build.0 = Ex2016 CU16|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 CU3|Any CPU.ActiveCfg = Ex2016 CU3|Any CPU @@ -179,6 +183,8 @@ Global {3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2019 CU3|Any CPU.Build.0 = Ex2019 CU3|Any CPU {3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2019 CU4|Any CPU.ActiveCfg = Ex2019 CU4|Any CPU {3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2019 CU4|Any CPU.Build.0 = Ex2019 CU4|Any CPU + {3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2019 CU5|Any CPU.ActiveCfg = Ex2019 CU5|Any CPU + {3AF0EAB4-6135-4908-A659-5E3C974E4718}.Ex2019 CU5|Any CPU.Build.0 = Ex2019 CU5|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 @@ -226,6 +232,7 @@ Global {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU13|Any CPU.ActiveCfg = Release|Any CPU {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU14|Any CPU.ActiveCfg = Release|Any CPU {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU15|Any CPU.ActiveCfg = Release|Any CPU + {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU16|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 CU3|Any CPU.ActiveCfg = Release|Any CPU {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2016 CU4|Any CPU.ActiveCfg = Release|Any CPU @@ -240,6 +247,7 @@ Global {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2019 CU2|Any CPU.ActiveCfg = Release|Any CPU {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2019 CU3|Any CPU.ActiveCfg = Release|Any CPU {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2019 CU4|Any CPU.ActiveCfg = Release|Any CPU + {8AA10740-EC1C-43D9-9BB2-9DF3F82A214F}.Ex2019 CU5|Any CPU.ActiveCfg = Release|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 CU16/Microsoft.Exchange.Data.Common.dll b/Lib/Exchange 2016 CU16/Microsoft.Exchange.Data.Common.dll new file mode 100644 index 0000000000000000000000000000000000000000..542477a4e696ca1f9c29b55e5e2de5d9d3e2f521 GIT binary patch literal 1687120 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μ88WHHimNndK4SX`2`)Ev(1Y( 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

xJR`khqz*DW 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

  • -@lJYWNNqJeW%a_oe?KC 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

    6cfvnsjr^2C;)8Vkl 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�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 Bd~N^$ literal 0 HcmV?d00001 diff --git a/Lib/Exchange 2016 CU16/Microsoft.Exchange.Data.Transport.dll b/Lib/Exchange 2016 CU16/Microsoft.Exchange.Data.Transport.dll new file mode 100644 index 0000000000000000000000000000000000000000..50678a71c6422689ca1a427c7828ae83a683eae1 GIT binary patch literal 601472 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

    Wb@uGzE%*&D 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 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 CU16/microsoft.exchange.data.transport.xml b/Lib/Exchange 2016 CU16/microsoft.exchange.data.transport.xml new file mode 100644 index 00000000..d75ee16a --- /dev/null +++ b/Lib/Exchange 2016 CU16/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 CU5/Microsoft.Exchange.Data.Common.dll b/Lib/Exchange 2019 CU5/Microsoft.Exchange.Data.Common.dll new file mode 100644 index 0000000000000000000000000000000000000000..52aa6cafad8a06a3284479c8a8c6c9572e175762 GIT binary patch literal 1686392 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

    mUT-tu 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%0DPv-Y)q@ROyVY{7g@E**2lD-hq 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ųyY4VB5iNxsSDg)p=LIStaiZq5cev@= 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 olcK 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 pXZaRDIVWvS}9n`#Am<25Yc?# z(D>{(@E)Jt#OwL7fmMz9tjOo9P!xYCC5*+Eu5NU-`_wxOGj4QGE20}jpCp)~dqDRW zhZNB(L{SloKn!@^av%l`Z+Xy*4Y~k&$P?2igcj2eqL|dG43J29LI+8u4JnHWWDH=4 zK)c6ZB-LR!mk4wgCzZl`k?QiOy-8(txciXk_T(%f)nmvRCeZ6SFD13eld~_WoaY9M z9W8nZyB~>yA!md@pXako%1_&hqI9ZMNeviYYXpW2U>Sj;0gMtT8Ne8Uy$oQSz}^Oc zq7W_agLPRK*Z<5P_-z98935!(B~cnOBx36{VBy5K^OFFo%*FGvurxFzz`YMyl>9B2T~B5;uB`vgU4-|I;otTjB5#A?Im1_G0w&yy6TeV$C}5QF&?0*89cQ;O2e zICmT^t}&Q55;)9bK2=eg`7~088_cH@IKlwVAh6Z|HW4_|ORh6X9pwo>OHo?**`(Ha z8FUV*qdm@Z6{R`PBXx`s$g>IH8}%xO&R3LXzJSzmo&pz=I^OVl5rJoUUN2UZ_Ie4a z6Ab1{39L7O%Ltrk05b$O7{KKOPV$0(4ylt3=UD=$c#+;rYRaRoAT{k#SCZQ3DSDNn zw4%=?b*druY67Pjz%>L;_k3TgDDAsR>I{SVIs%&vphe(JFA{U4&hn`1Nu90B=@t^_ zcq%`S)VW@u&sUTV^aZ5O^W0vjDDCzlQqT6>ZcvnVdoii=J-3%AO1r(3)CHc~%M_*E zUQX&l&+SG z@smde_AX*=z;wa;Z_*ZMuk5{>fF1Vq9%9kJ(|bwB0{VTV9Ye_b3B&`250Fk63?C$r z1YoH4Az~?m>B9ulft0&RX9D^oq}#(nK1!^^5b`ksod)o60$pKWpCFbEW1l3}ZFu|? zfu1nar-}8FN!!rR_<+u)&k|S!4xQllkj@44=Sb%%LH9a8PoNMme1UWyXd|hTFN&G6b+7heL!=3i$Ey| z=RVRLyyF8#b@spSC(uSfr@#XQECM=q-}V75^E(7=gX6nCpgF!rAZl=Y-v>0u4+z8z zjvxAf=J*i-ha9@s{67TZ0CZmdm~xN^9$11fc_=vZhB}}Dg7{k9s~Flf!@H!uSqWo=--ge1@t4N^8x)^ z(uIKj9qB&MUfw=Rpx*!eS*?$pR8pi%jY~L{UA7X#$^t0)4 z(wNEevTZx*zkxPnKSAv80S{IvqNRU?dD@8mGmKfp{uRb-V*d_fQDT^FGQ*4!!?cr$ zIm9sMm=p?)77AhbUdK5q!XaM(7Sy=hu%XV8J5~htSgX$H3L+xfX0UyvDg9H{C9E*KGa|{s}H8_espgBqe#te?Vd_Z&TO<>&M*vAJn z#}Wc{gJakSG{;f``-4O0#lEBuFnqW^pndE|V7b9D;sctaOkjng4CfaVw@u*%>V_W{jOColmHqn_?h>_EfU0Y0F8Ehm7Fu$aD95W}Zf{2Xui zfcCYL0KVDco5@uKCJiqWKA^oENZ=5I;~*c<90wD?XI}hZSNnkGm?VI2viKZ__<-g( zl)zyI#~L5d9ETCWCr*4BIFG0S&2a>Q$f#dP){<@m?NxvyeL(v-ihyNstn&fQaWnzj z;5fzyG{><7q6WutKA<^{ClCXNF1*ho?HE2z@B!^(J%KnmbPwS~0to}yKp+{&Jc)G5 zka@BXXql%FNQ1*DW>ds6VQiXMdmwou=?+8ksXm}3pGKfFEah}!y%UE z_KPsqB=*ZNb{(;Y!&r;hufo_IF@CF2C)o9*+X8wEX)B0`1^13f#+ybk0H5z#9k*7{DzAA~*|SMC*;j+JJefv&{nxrZ*9@!XDpD z%%(>j_qX_fj{B_yq6WupKA<_?N+1Rf9m%(mjvGF1_W|wW4gv{-SBC!~-f@*laMA`}HFO!Z_h*te81QGzW>R%RmCc*2nJZ32;1ftT<2fcElT0&UPY9ftX|yAJ7~zAJ9#m;{%!_?g6EtE^qxb;bZ;=j4erG zgGN{>AJCH01Qr_{86VIb?F5Dljt(Et9GwJ;21l0wvQpV&j+;JegaDjjsYLg9D@Xg4UWY=pgD#JEHyZaKA<^D z^MSp5Kx@A@fqf}Md)dbaG{+Jj&>X`)pgEQja1A~7^#Se0C9t2tv7ZlUj*Z^{s2Usx_<-hEPM~IRtndNN z(IBwQ;8^Jcnq!p*7LO?h9hY&c_ z01hRvhJa4UH9nw2IgG$z2FKw(pgE2paJa#-)(14lkpzw~IF9lG&9RQaT7%IR1dcRh9Pa~K#-Mc`O)=)T=F>EjF^8+}0gIF-Qh2FGbWpgB$_@GOJl3?I-On+Tj>aGdD_n&T`2 z>&c;KD$XWwB7l;W^%{nAh;1MiG#2OjSWtk^BX$z_bocVvq)!g}JKx6we-{ut1$^Z=6X}N)PJ6@iq& zvDF7O$EyjX4UU@$WWoWxhFE(Tdo8h!F!nlPoy3AV`CmR3)QHy;>k9L|!N&r=TZm=D zVZ4!8H!v^K+k8Mr=}iRq%|(yn%|4(x-a?=a97dPwR$>+~o%6SmwgdXDq@w}-Hqx=M zjN6GhVeAfKabTV{Z}$PM%{vGr430Z}Ky$p4K$0A~iM@+JDjd+eh^2w)2>dtcj3M^j zKA^?Ehd{d__Pqr71wAd|eWcq!8|n0ZVphQO0n&Cre~@%Epg%-97SJCi?F97Qq~oBC zFg`*o5%7GJ^n(HYG15N?=#P_rJfJ^8`i}wqNzz*;{dj$fv^DM1pC)aC_ByGb5#WL# z!9Po&3<+K?-s1y0F+WFO#Nhb64`_}r5ZKS)_@WPJjxP~-g|Q<4WgpNSUjcyYRqWQi zc(J0bZ}HLFx{r@s>;8~yPPs;vYhJlx(>uL#^Sf~4NzbGy3un*lT;5%W9V*!1&i(t_ zBI+;r7UKihU%vSe>@2_5p1Bo|YT7u12Gt&g9Nazn#1q%I{>ax@>k&S3t>57hb!(7a zv2$G()c=pLaur>UYqb8NXxvtz=m8vuv#ib7=i{{c`0joP0jgu-d7&?$rrd{r7`EK< z&%clK50HhkqCAtY-DG@Jq*Mqk1_S(W#Q6{Jf9E^@;r&m1=Rd0{stDth zC8~_|}G-Q{0H$&&X%O9-OTZw|16hjsM5w#NBmad z!;IL{1(0#YNf3`@4vw5`<+ZEQk#XX!gC5hr!hZf8CYegSnMH}PRjT!hhWO@$hF$C* zL+Fo_cRskC;9ET%G$(Vkzn*sSnIT7C2+(AK*}*r?H|+?v5&Xcsz!^>{`YI<pF6(!zb+s4TnYi(AvrVJ)d0!huCrE%W_3Z zle}|0&gA|Q$4!g~8NOB`JXF{NjUZAC;*4+*&3=G9CUdQiOBn7Z_^()ta72|A!$@AG z0&9*sM_EFBT!wRGp^W0k3Rd#7YGOX3_yWafG@4u1HTyU~_hc&dHX4?gxZs0qUGgzD zci+GzDj&zwc-+UWCW`<+Jk>ANn-}^^p{U_T2EG*PNGW&7k2lW2odn&m+tR5n#)o5E z9O`jgY=3lcl^H$Y8l->XQJ%yXLa|#Fr-86l(-BJ`|I#?68h5eB(~06}z7@m4e0&B6 zpM_~!NCd0NLbc3}RdG~30C+hhrB)&CVt7^GMqjT?SHw#zQCNKDm1%5?XA0G=h&N%b&gS3cOij z7^`i_i*x0kO^kXtONAkPWt3-f5S|aC(k}0qIxjrtP(GXrnFfz1|6EX*PRRL)EJq zjb3G}ds~Yb>t1EjwXNiRXiP}-7P8i$D#wFXanjw(FUP7F=yHtGflba%>FT!}ymxKa zjFyZ2(N2qo+bVX7=*qFM19t+=*Vmww-bG2ys}hm=0oH&}{q?eC6_fJbVhdn3`M-p- zt&y=VtAt0yP5G)d*$h;Vvx<8w@rN-WC4Z%b=_+ZDVsJz6yL-aD(Ts<`+RB-QBl6;{Ro zBBW8u*YKfwN-5MbR>4KzLz@n(Db0q>W&;*Th!_df8^1x>-li@TX+5FBX6bLSVM1k< zvTik5vRhF?eaaZQH-l;9!H^wrO=?*Nv7nuDv0+}@2G7c3qRSZsn(o$4J;Cw#FluZhWamr69K`TMxMJ-FGb|s^7jy~ zlvCYt(2cgAAZYWjMZj4M)h4rEU+D+d^#-6j5O}(C}%2gSd=T zN-`6LdNqE_QZHf5?-8-Qt@;L?RTp9f!mPAg?q!l*>VB1=bAjtQt;G_@GVXh%&O^A9 zSuywRL{U}{WyaYPK;^L9n;_hM1^!vhZeW!jc;$;Kr@0p2t!9ts#23$r?>ZNE5unv% zv?W*hf^e8ib$n{ZPs&<2i_39qKq5wUnJATGEcdlcgxzO=`#kWiYS~CcBLE|>AT!@$ z_sP=5XjiIB&bbFdWQ%=3OQctK;X`E)dvPn#mw|OFsIs~XFD}ldI5;azbC;iFT~zOx z{zU)j)BUHnCveMAqJ&GHB4eYdzX{aef>(ca>#_5=CX!Q1gVLU`7N%Vs*l{XeI4kx% z92WL<|GW|&Fv#Rbt!j=0hH675SwtBQ_>1lJQ}-YyD$i@@ zJ!#dOS?F4+BHQ`W?_Q6d-fjz8ze+9TXQPy@ma4)c?U<0Ws`68+&60A5SpfH-Jx<&q zZGG9+--O%=wJ&P?MUz!bPQ1{!hl@D|@Jv}!myYuJ3c)8zy%eThtm1A>WgMzUJVl$v zjy}5Q%7!9ftI5(RhKesRR4fs`l?6vJC9y(T5hI#w(Tai+8>za3oCS1N zy^1k3N;$49NR`|CaJ4y7`J&U^%u-A&1T|!yU(0}s?>qW;DxS~M?{^xw=k7f**TY*NChnGJapGfms*mB~LW!$+p~RfJP-5bx zbip7fa^DAG8stuzk^5d3yuL4ZeQ)q;Fnl*aVHZ3J7YDBkqZb7Xxbtv82W-5)Hed)| zd*yzYqr5cr`YF3iQ|xbz9D?7m_%S_O_%YT{Tz==_iFs3bXF7TK{O4=o#x(tmJc|>b z#CUM)w2Ta;SPB*smy^t`0(Z~-50UQ+mQp1CW9Qy@0cdfF%kinE1zwU zeYFh+h3l6OH^{+oYWCL5)La}+&B@)T=DvGWNH0Pwrf1l9k(?=&au=n_HACUPaH^;3 zU}F-34QYsT{tnuRV0ht`cs~tkxgU|cc;?r^BX=J?%-%@N++`i?j%;5b!WT>PX#t54eB3P#X2)7Ox=326nIA9wpd5 z)Q*3FhCv|x%wXz!iDd9gc9p@jX?H=+?-tVi$rt85O4_+!p$E5+;)~H~b6-kzSukI= zYrUh9FG24|7t$NIRfUXkF`Vk|3?x_5Zm-dLaLESKsU=?N{tDhnsupo9SHh~dy7e;YHHbGx;LIQ z`|3+{$&`+H-YBMdTs0>%5=+Zz_ar~;XK`cCQ6i9YEGkVx&|-WM#R+@Ta_~ z71q2}`US4&Q|oIY!JSjG)$*w<2`VjQdby0b8ntjJlg&;3mn%}yruE|8vv>SfIo+^` zgzmZS)Z|i)hZ(87i~CNT%HDX9eobGvKco6Fjc=3HeI+>gxnxe2RK}H1HAQd93_d^7 zhR?OB38d|9yb#*Dj+)4Yv*l6GhpcBd2jQ@5A6DGG5kW>1T&ziOu_l3U(eV?tW!KKe zZmteGxK(<3Iu)9;%1h+SY3~;K==islMpbkIs7*ByD`pO|u-vVTbtQ!vXX&<;2Scp_ zR({COuY$9iruu2o$Z2TzWt|KcHg9j!3#aa=WiA~^ zxxnPQx!|VCMR^n}Z7dbW^4iOpW8vjBUBK%}0YBi=N)tNxB)Ea|9X2TO|ZmZkg#k7&S^} zIu}}GRB`so3MU7IRVKFdfM1y!v3Zz+V8^mTk$h3}_w&{*cN8hCTBLMLbBCTKOK)^mnm%3*Xd%$MYJ)1{wWnb0~*{B8k*W_N+~Ai(W!ZK zdLEsbN4L+TJLb`yQ(HGb6vUj7(oyFchM#b|N_MPo?wIWFHGS_Y*|CD>`3{mD7kxP+ z1F-LhBUS$(eO?)=IQuXI_*d(6+%JGD?_&6wN|zlOIiw%#TgvipMO>`Z>)sm1Ua9nh z5xK9Pm&5QYO8bmN`XH-~VJrvoM+rm5yG|wPxES;7u~1KD??9yQ0?6cj)N2?F{&ZQ1 znMI|FkDmlxD0I2x>SWu zaS<8TMb?I8%`xSadbZe+gJ^u6Qf7-489mJ@MYps?M)z`7{>UcEDes9z@=Aw^f3Z3I zjL=EY)AG%P3o%IYeom>2eEgEPk~zUoW;SjVFEIo+x)ggdB6eirx55(V>qGKN*NHbU zfHQ>KA^lR&PN|!(rwbQVo>)(r4dIG!aU!Eb3QITDuJHJ=yl#-EXWa5S5i>?!2 zrEE)lB_grN1a(FfBaV*87-;@Z5S)T1UPmwAQZzP5jIMD?oy76I3V6-(^-J>F2G{As z<4DRkgXVW+j)yOPCY;Zg;>R9HLutcJ2os+G?UcAVVFL5Rc;!x&$#cNzEtz$*5jx(h zlZ_+k3Ak;xa5-#pqda zbJt_zYlQMrd>WtTyR^AjmzSq}2w`jx8X!m)(bqdo@~yp4?BvU%sC;atl{T`?MdEaexyDBrJ?Ro#DKLSf|bRut~W!GpCaY9OTgR@mua|oRHVuZ$S zA*QNZ<0igq;m_y$BBg;|dY8n|TQ{VZ%7%~JvW-X*)L(a*ktCdHgIKa*C2j!$s($l- zZW%i~6o5{ypQaQb-87kJ`x3J2&$JJFU=jEcU2PHgX(nYVCT;*KAJIj9^DROX?%q#Z zgfql9t&Fk=#|a&>2&^qmNi4#DBml7poQB6;#Zp69xBrR+)E1#3Tw)PWvLg*zCkQ~T z+`%Hql8&+n9}zCG2+Y?8=7-=*EW%cK1*t6p_P9p)yG?Mh2shG;;^WRQ-y+Nji&%us z@)}r#qe1hB4Oo$t`srbfBLL7M!VFBvt5}3lg~B3CuuL~f_~(`KRT$~9IH{aOqr+`L ztF}WglnAxaV$~lMB{gi-&q08#=9PlR0|a!PS;dYxJPPa3m{*@^_{TV!NTB@WJfGm3 zUyI#OF?4W?5UB%KDW3j?g^lb=81C$Js>>0K)~&Q)OMFpLFeZ*b<=mUZu$mv5l`84l17jD*1(!S=%9$x?0*kG zbiaX1qqim~;tv6Bq{Jyy#7`2bQp8V@S1IEEf*K8eUjzk#MVz!Q;`@tCDdH>f+PGVs zER@jE6IBa03XP@FMmowRH{0a$s8doUJO&<2Oho>HCwq$CPZjFgrK*jq9fjPRI|^4Psx3rn zwZFlTt+``7xN)V>yvtMA8s`bU0Z0E8eUi`>&mE2HdA(&I;Mb5vYX#A{VklJ+CT>urTy&0EZU$)~xpuK9|{m?9FS8lO7_?&a9rMxTwJ z+6bJdl=G>cGrke3f@-(Ks{~a(3wh&nY=Ckep%cD5Y0b@fSh;S^UGEc1tvO6&hGK|K zSaZ*thw1+Em8dw{cE}W++U%h>mNdEhRqbr?M(NzU=k=p^VNBkR;pyciN?O;qkDE_4T%wn#)&zva=81MgFXG`>9yuwuxcbdc-6`{sq1^71xVoJ<46r=WfDc}ME?ro6UI9*L8*gg+0hT5Uq6V99nLE4(Y4VpH`lP$4T_?kXu3gd%bcGI@ z>LsAPpI5ttMQWEczN%9hYN~$$b#!m^hw>`5>t4JzzAUsf)!ZVaYnLkDQoHUX*KOh? zP4!ycR4>v^^-IKwwW~H)#)L8(>DpDQQq?XoYt$?_`P+bBdA)9)`&IK?J506BwF4Di z8xL0`R-A797N|(DS+Xr&4Lyd_G9eOgu|_bDSe&Z`yoE~xCMsAOLN&)$XAtmd_yvX- zk%7^;e3Mt!!@ade#$J!o(4m7ZchJR?$Dn!)sRssdMDv@`8mCff0tl-ZE*4}{?l4>) ztZ?QkfgWnz3*Pqqq=1w`H8<5BS-T-p*(ajrrrrxf_g5*C zYSF8H5j=7d$@5<%lJ9KNfIk7;M4(`nRfh7DTu3xcY<2x^J;tC;vrI}Epl-^s}*rQ`YO zw66`mOzL2TQqpVL)$o2r+#@|j;|>--6S^V3pA^E)QbVOh}?vY*uQciNZ z2Xic@vP(tTbU2|?I-yh4G8Jf<(pq|g_gqV^#l+;>U!2$UHxLiaD^aTCBA+Hi-)DS|Zm_*UgtVrVU!YW)I?X z$4^1*&eDLN5A@T3gr5eA*aMB3zVXO^pfheX49dZh9m)aw1jX%}3a3h9Hr~nH2-&&D z>j>#lc+#JQD5x3i-ItP$#`#nPgm06Vad1;+_Lb)hzIQ1xO3eL+Q(bYH9o*V~wkGpa z3YdCe8@@B2jyvO@#T2|O9_z!WEX0M4HEaNptkjlq^;+zG;I|{~$T^6@-%MM+PUl^U z3(7Vlh+hgn2fuQnfRz&HY2{IgscA0$ zUcg7Z`QESae!iEsK!(tm5++bkjzecYC7t3C4k)o?jnD+1RMRQaF#UyE?ntD}d#IB_yQKa?XQQmNtyB%efT^fA$w}A6~ zc7A&NQMG|>fz5KV&&fgU@Qur9`(a?dbVze=834fYj=e!-s zVQ-gH{K);#9vI~&v)Jgu?r`b`-BYy+R$XwTj^2x4%gF%Rew@QpbETC7u!P5O4P&I+ zFl9>AYMybJeHoVYKF5!X2DQbW+RC*$6Ogs)9l%EzZ^mmF@%#I{I=7Vzh##dYYC9Rq z9#4DwdxdeCZUp1OP(77k=>w~`*+F2?vV*{&We0&l`#T8G^*2(MI|+=WB`In9Gc$_* z;&;sSiZyVMj8an8r79ZTD{Ec7|ci z>o{=x`yZYy#4JeUT+~V~$MDB@^GB?) z37`^)&(C8>kHK-&!U&(e(c$*$V|Z82(=ASBSWvUYfwkzt7wEwU^x$K@9_TM|D31pR zxOi|}tXLNcuM$fZSJi)mf0G#0MI>;Fofat)CdK6yt)>ZbV*@&HZ<^fav_Lyce>WyoJ$V(qvEmF?q$M! z)#3TW}ua;=RUC)7no zY4X?eYyD> zCi{7}#?le@*gzWl;#TA+C63z%J_8nSY6eI4M6V|=7B@Wo0o}Zj_sn7YU`p*o+`(3d8p$22e>qf@ImkIRIP_Ww%_U?#Q^+F!y(hJ?Oj|6>Z z@kFN-W{Rz?)g`m{AZZN<;pYDsjzTZ4R93Oaa7#X{4~=)clG-&JVfOan@r+N zli+D3pN$8KePXjo@CdT+!ZXD_ag|9t*CehsiEB*aT9as+#B)d-tWp>q(-|J<;y8&Z z4mvl}GP$ut8z^$UNwEC+Dqd<5myoF87BgJ<_=xu&%c*x6FRnnN#yj*Zu0y45Z zxB?PWS-b*r2@CictZ-IGv{fOy-P&J0mQ&}Md&r0zeDL`|XQqSan~0Wy8f}D=%{zn?YMw`JC+Yx$157vU-54s9c>-NN4|A}xbnU$x7;J+KsvZ1>irPB z4^FlCu$t6U>4%Z)Fd1^KRpP>kVD1R_$NULNWX0S+6B|yRTUAt$z)M!6IG$wqOeZg<^go(KZsz8s${jB zEBMZTz?qUQNlv@DlJEQnoGIFpWVM@2O_ii}lPTGfzz-`Pyx$*OiBlp zt6XC>`Bd>y8707QbB(|(f>SN^PR8Np(FU&G6+R(2|D$WI2qihlQjy#%C91rSS+Fsk z$-*JpYy1w>Ih@>L;m1QNW3MVCy{a7as-n@WNjLRFeg;L+PXrCG*t$aIFZn=m+ng385ov5G+(wQ zH&U#Wxg8cIyLNnU%C0U7>L~7yaC__qq>VjuBK}LFN#9zM!I7xh zIuX_5rVD4z2Ip|9`a@L(^ca-eyRp}b=V@6_Y-uQ}U93VHh_q4MI6~Gu&lQDj>_<7yKi~q1CY6zrlZJoBJ?>{sXd3 z+F9;=<)2p<#K!TUsF=8D>tNPUyS17R%RLyDA?8O?M2m2oTXdN1XXFr@eBX_v}5#3`rckA@GWWDhx;+)C68XarBdfG@CT`L zIH^8SqTHu=(YZ0SaF?o7CL@MB!mlMA5t6i)RKH40=*KpQdn2)lD~kfaS`)1e=(lRz zJpihfW9|ut#?0eNuVz8*+dwzf#ga($*Us@`GpVv&#k+1b>9soOMR7;P$|zi`84;ym zxnBwD$GFFgD+?|P-Z6}d)ntqiWrbriu|OWG%05Ob~d0HH8@=W>$teD5Ub+mHlH z@vGr?Fn(Crk|y9}Jh_9MzvcKLdh*VtJrAG%d^X&0lC*X$j*-@`Y`jm%$=XJqAw6B4 zA+4R!cmrS*r(>ZJcSJ4x9Mbswr{`}zjzgkKP)?^Nwh3^w9#ej6B*Wx>++ zeX-@e%S8{tQI66SS$1B9XoeIO$y?>`-b{5gEZ zJ(}wWflCd=L|9JTJ&-<>{tx<5-Fd*;OvcQ3OWnl)MgBY)ss@gR>PwJyRm?fCf>iol z3;;X}CVmFTp^rqm7jKEm2NAK=!uka|BN!XimRZs#qS#P6EhJN}SPDvJ8ds{=BCkAQgv=YgZB_7b z2}r=+i>qVoi`)uA#?2pwYLc|lHdqnv8|2?^b&-pQ0^zA3(96w0)3pwREYz22iYB1C zx6aQlZEQTXF~U~qgw2{yA_B~x)0O(W*T2|{Yj^|UgS9Ik^Zk#rjUNTw|ir>5NdozBG zx8t8>-|=3IXWceP9+|zJgD2JPvhRRNX>%>&V8YB*+XX&_-g293Yp4G*iSLn!YL_3F z1o|#*ZcMx2>WVhkAu;6QrNz-f;eRoSO-eD-PF^*61|JI_9T#`+eJiKd&v;q#3HjodcvTc?vHt(HZPs3 zq%ZdEjKXm$Kz%HORo}8V|CU{xtLFLjn!?RVx^hg!!o)FuFwk_Qud%}@oeSC=rNaZu zGCQ{XGit+|{IS%|>!Rwz;gT@l(Bhhpke#yKPDa2pNDS*F6_ghi?rNIdldxdtx?pG} zJ)$BN)p}9T>U%**f2b7>BRu!9^Z0nSrB0o9VOz$PJ11+Q1kPP~eW;Lafezf?$^(A< zGt%~%9H$O0^NNKoN$69n4p)=iE{qp(vep}^85uWJ&tSG4GwcU2R!hx1EqYG-s|Xt% z8rAT~L_NGNg1eN%hgFm#m~H31Q8MR)eEz=_Zw`VgxG#pIKkjNLJ(hNH&%GCK>D+SZ zjYC3=k2(w|wxoj?iRiqPR0GQ~0gE@t*Uc^#LTs5@vZBf;8?;zlgBIg#&|-HDTCA-> zi@`N$v8@Iz#?+w25F4~u(^;(_nsb>$s@qZQ(2KfhW|zS%2JBEjGBGzhk3no6=L)!| z_z78KV`}9mUcmA#<*iV=R=o^xBq2j|HIg`8!Tso$$|R7?2Gp?z$tepC@i}tGMMhRr zCIp03<0FyVS4S6?^BEO>X-cL=gcKG|7#spImP}e>KZ%-t<^<9-z6}vqU0ercLQN-O z-;XS|>cY8e4wQDb`Xc50e#BemSaWI(O3h+_p6%TQYDznI(aaY> zmiJPU^n{-?^8tX+hASY@MixTE^Sl{B*?9y*eNRZ5PkfP5WD%l*xg(h?m(>*PiQ=rg z7mBe~p{Dp%z=}zSo>QwXYB6o(OFLxZPP0eNM{zwV8bJfE(nHyvd4tKLwNa5t3FNqp zL7C$+gCL}2g?3UES6$Vf;-?_g7+SSx!Q>Tf?7^5{mT|t+^~zzY?kfSc_MqFvH3FVJP`2K5um9FkHUBu%5)RdQfbcj-%VAxTmeOk`aJ6mF2o~$h4K`X$ zJuOhi0+LLeA%jj-I(f5GYJybNmCH(6Qgt5nc@) zwIHn{s9owfw1AF0W~X(;PG3VuP)f(41$5ND0v(4;9pTl`Q47*Kf--gV$NLMV#8RbO z5XzHJ36>{6jD=#d@BA>Hd`uVyrV>?|#fD#_R_J24-~2$prE3Ediu-_#1S83$*C|F) zl8p158xRWZAI=&aq3jcOK8}{Q(Kw3TiqE_VjfQ*+&O^`x!V=#RfVa2d6pBlO zrGfhU(at^H@@Y3s`7wUOSdCk__f^z%lo}Yg2&o=eUVI6(M0@yyXvJrRC8oy8PV7V$ zgWN+|WL2`#k=HZ#ETk(orIs(YN?SncjO4xtbObGFZvslY@6VJUX1A-_{%0hBYTyzx^F4obKT@=)nm3s$W2|_VG<|}rmQtY;{Vk4o%@dFGh>Hq!2 zK_akk@HIU7r`wHny5+@$AlB+uFtf2=hUsKu7etUi{#A2K18l74Lq{2uvVoLfG+!DA z7c&PGAF42L7{au;>B2E=1L1ZM34VevYVQTu4*us~r)xAvd2bz9ga@4FQ{ zH*MX9cDc(+6s9tX`1mKGe4y+?#hQjD7B8I2GQDbw7ZI!Sj83mnoR-(yt; zEJEq#E2M(zpiis8gX->Uzx_%#Jy@XnVP0QpmJv+OasM&)LbCWW%~-%u2=S(nQe+F3 zztZkeL1$R=6gH;HQ3wAKPx4ON<9}2)ren7b#pL4X#nMF`+=$CY9NfXEhIjInL3DRz z#aq5I2rc~OZ@GevU(#WoSu$?W_peZ(V#H+yJc~J+#S==_mMOZn?+ET7fnm=jp}i#dYnc_74B5GfA0%Bl_&)0?nzzuIPoB8eGLW9 zc10TZh!d}689hVYK*1{-<>r^aNkF`uV&Z6AspP=m?18Y? z?2)j<=pG4MyC=em{q?hU6G!=a#2zK_s@7T-$V>tyUp8Te)obtiJG-rL8UbFwXy30uV(5)g*-1tZfA)+{Ip9SiSNK%8RQsdak z*h!5m#rMoS--&L9QJi*?OM7VRPu(M7ZH(^PJuxueQlK=dTnaSGy_)C@71I<2V?*Gs z%&C;pi4WkMqakc3vF^)29*RA?eNUm-(_2Wte#*PpYO?>hQ+ZFVFCq6QN>S5wj$woX zAJT!d*ZMRE{td64!(fYP-(nb{z>7L?_LZOJ!0(+Oxb(*t&e7r_Ph)l#4}FI65~B#+ zTI?h*@wpb1qGuo@@%htm$n!I@cpgK326FL*^Fx+gG}^P`nx`}C4ts{O4hI3l2{^wR z7N7eJW!)R+hrC19UHuGY9d4Tp$NB%SfKPcy`2V&FxDzuv_jLDGif8V@u=H_EG3>U{ zE}pdqlDJoP_ma-8@4xH5#Jrxk?vd;y&CaPGuxn}f+UY_a97CM!5$M1qh{ZWLz0xa_ zVEXdl(T!?uXLN5z=C~%7%jA%JDC6BSK_l1va()++UYz0?&8rEbiJQb(W_`H(0?wTF z!LbARx<_qRPm+z+^*1tl)#OiYTG109!88qcIF&PTASR#GoZ7?~UIELD4T6#xod;#c zMW$)~qI}7{^6^7uZUn%dloeNxk$ z-08wauGi)=4Q|6!8pZG6zN@Be?6b^SrsJp#pfi%T||Ebo_MY&v8X4x zs3*0E*Ltc^IyT*?6(f>z(bizC<_){C15G({I6cQ(8(qw8ITZ*_6iYoR{L*E+&=dFO z53t)vdEj({Nb5;j*|<8#kWH#nAK8?q)B2eZ9EqYvDcxR26ZeKnzpsvk9yK7sLdl^l zLObQed_H%|tl~#I+>OE9rdEpq=mJ$mM0&8HM(NA0i|K$(t;&H4m=0apj!GiiS&3%5 zaC@5y3>QK~Tzu`q+5DYe)U|9!e(HjrY&M(UREgui5S{s{Y!~j>y`ZQ2|1kF^V3HM8 zzIgV%nfK;a%dI7|_FFV`bIGl`Dh0Es4R+zxDMiuj*hr1_&c{8sftjqiJ;L;uIhWyLqJM8=N9r1U|chtX8zGMEY zp*2Pbf#P{~P6Se4|D} z+&(|69Q}SyIR^Z-$}#8{lq2WQDM#MlsvJZ9ymAct7bwSwf30$i`Zp-Yn17RUjQjhP zW5R#Ca=8B8bnLzptQiY9^I-`a@;@oxVgC{Nj`)wuchvs{zq{W-ZgvH6jE#z$z49IQ zC*?ch7vwwYA1&W8f2(}Q{T=e1@Gq7xxOtUwr2UsGN5;QNIkNs6>Dc{FReP7fa>crb z9)xjMWf16H0DF%?*cWjYnBIL?=!F(?diT3SFBDBPKl&`?<80dv4acO6PpVjJ5bF6kwO8P1?^2T$NT6mwxL_opD)+J(o9e=@(oR zmnLCl7wuA*Vf4l7aZp<_ES|zsr<>sbIZ`Bs<0+D8cn;wJIY!A577@j2qR2V^3fft3 zQF`dN_JQ_k~0V!h8la ziS}CB8k@?QlkzgahY(P|2e`}Z4{&D*sb$9SOk4d#X0)lA^nXau1T4|776~_WajETG zW{7-9^Bdaob9+{cD}_Sp#)!(WTun)dGHx1X*@ou>GWu=*cP!}XpemDuor7$#*Y

  • -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 MDOUjoI`V6BVDbu2DRRgXoZbpXZz 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� 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œ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 + + + 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 CU5/microsoft.exchange.data.transport.xml b/Lib/Exchange 2019 CU5/microsoft.exchange.data.transport.xml new file mode 100644 index 00000000..d75ee16a --- /dev/null +++ b/Lib/Exchange 2019 CU5/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 49bbe7a4..477898c0 100644 --- a/Src/Configuration.DkimSigner/Constants.cs +++ b/Src/Configuration.DkimSigner/Constants.cs @@ -72,12 +72,14 @@ public static string DkimSignerPath {"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.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.529.5", "Exchange 2019 CU4"} + {"15.2.529.5", "Exchange 2019 CU4"}, + {"15.2.595.3", "Exchange 2019 CU5"} }; } } diff --git a/Src/Configuration.DkimSigner/Properties/AssemblyInfo.cs b/Src/Configuration.DkimSigner/Properties/AssemblyInfo.cs index 46f63a3f..9cbb011f 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.2.3")] -[assembly: AssemblyFileVersion("3.2.3")] +[assembly: AssemblyVersion("3.2.4")] +[assembly: AssemblyFileVersion("3.2.4")] diff --git a/Src/Configuration.DkimSigner/bin/Release/Configuration.DkimSigner.exe b/Src/Configuration.DkimSigner/bin/Release/Configuration.DkimSigner.exe index 10a6818a600c4aef1bc6b04777fc9ac31c16cd6f..02b5ab673c501806dfda013f201799fb62e4947f 100644 GIT binary patch delta 10220 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 b3%zR(&UTI>{B5>#D;GX4w*KHE{Ui8)&nyN= delta 10117 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 HnE?L>BaG?Z diff --git a/Src/Configuration.DkimSigner/bin/Release/Configuration.DkimSigner.pdb b/Src/Configuration.DkimSigner/bin/Release/Configuration.DkimSigner.pdb index b94534125757213dc8ab07d0b6601c7a1a134afa..58c1efa0537fa3ce5cd411666e5ef5d0e1dac18e 100644 GIT binary patch delta 11022 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 Up}0AYvLwo1mg%+6_{Qyj03>(Uw*UYD delta 11019 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 L%nsXUeH-{crii_g diff --git a/Src/Exchange.DkimSigner/Exchange.DkimSigner.csproj b/Src/Exchange.DkimSigner/Exchange.DkimSigner.csproj index 06af387d..7c1a22b9 100644 --- a/Src/Exchange.DkimSigner/Exchange.DkimSigner.csproj +++ b/Src/Exchange.DkimSigner/Exchange.DkimSigner.csproj @@ -32,12 +32,14 @@ v4.7.1 v4.7.2 v4.7.2 + v4.7.2 v4.7.1 v4.7.1 v4.7.1 v4.7.2 v4.7.2 v4.7.2 + v4.7.2 v4.0 512 @@ -492,6 +494,15 @@ prompt MinimumRecommendedRules.ruleset + + bin\Exchange 2016 CU16\ + TRACE;EX_2016_CU16 + true + pdbonly + AnyCPU + prompt + MinimumRecommendedRules.ruleset + bin\Exchange 2019 Preview\ TRACE;EX_2019_Preview @@ -546,6 +557,15 @@ prompt MinimumRecommendedRules.ruleset + + bin\Exchange 2019 CU5\ + TRACE;EX_2019_CU5 + true + pdbonly + AnyCPU + prompt + MinimumRecommendedRules.ruleset + ..\..\packages\MimeKit.1.2.21\lib\net40\BouncyCastle.dll @@ -858,6 +878,12 @@ ..\..\Lib\Exchange 2016 CU15\Microsoft.Exchange.Data.Transport.dll + + ..\..\Lib\Exchange 2016 CU16\Microsoft.Exchange.Data.Common.dll + + + ..\..\Lib\Exchange 2016 CU16\Microsoft.Exchange.Data.Transport.dll + ..\..\Lib\Exchange 2019 Preview\Microsoft.Exchange.Data.Common.dll @@ -894,6 +920,12 @@ ..\..\Lib\Exchange 2019 CU4\Microsoft.Exchange.Data.Transport.dll + + ..\..\Lib\Exchange 2019 CU5\Microsoft.Exchange.Data.Common.dll + + + ..\..\Lib\Exchange 2019 CU5\Microsoft.Exchange.Data.Transport.dll + ..\..\packages\MimeKit.1.2.21\lib\net40\MimeKit.dll True @@ -968,4 +1000,4 @@ - \ No newline at end of file + diff --git a/Src/Exchange.DkimSigner/Properties/AssemblyInfo.cs b/Src/Exchange.DkimSigner/Properties/AssemblyInfo.cs index 1b08d2de..fe120fc8 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.2.3")] +[assembly: AssemblyVersion("3.2.4")] [assembly: CLSCompliant(false)] [assembly: NeutralResourcesLanguage("en-US")] -[assembly: AssemblyFileVersion("3.2.3")] +[assembly: AssemblyFileVersion("3.2.4")] 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 a2e54648873866bb4802e6de1e515bdda4fdda92..4e23e755f0a670ab913523c5b899764339327647 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PVoBA;ZgE9Mmd%S5ITZ!GoBt>7ojloN|Hi8);%3j%-@M0Z9xJ2C z=4cN_Mv&Uc@t%?buS|Z6{8PN^)RNm5sP|1+b909$8#5;h0}}%?0|Nug=IK5M8G(8t S{ni7i$(#YkK#py|VP*g$E+~os delta 117 zcmZoz!Pu~ZaY6@kw=3_)ZgE9M=FN*0ITZz}mAg*FoVV~<@xc0z$i{`@oA)@)V`Vhn z9PPo#2vR#a-cwRQ?rGSHr^j<08|Pa8So7~m$mR}DHfBy{1||k(1_lP^&C`7jG6MBP S`mG02lQ{#7fgIa_!^{BWNGQbs 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 033aa55138f1848e786120cc8718f2e4c72acbbf..2983af38dad77ae81aa2945bf82f161a0758a886 100644 GIT binary patch delta 132 zcmZpe!`v{3c>@cVgknim93uk*!z+{DBL5WcI<@5X1?qhh*4!+^r6Z?M{B@^^)3Zjk zOL}!43Y{HY(yS~G5=vF)1ZvePT+Es(ztM39<0dT*5q1&Q{9|%V*CzAZ1+qBZVvpRM OVz;0gkKwzX2m=5{FEBR% delta 132 zcmZpe!`v{3c>@cVM7Jw%93uk*gWS`w6;F@nIyTO={;}rYlaS3aTsm?J-k-l!u_TN38JN-J5*gprYd^B$*ptc)g` zqdgcIL24(*drAuMn6bR~(P4MqdS_A}n|@Qk<_=FbW=<9cCI)5(1_qYR(|ryy0`)}t Rtp`$*IRlJ=9NU1y%m8@zBDw$o delta 117 zcmZoz!Pu~ZaY6@kmn-kaZgE9M=FN*0ITZyq9lf-WuSLp#>mS}SIhPe|oA)@)V`Vhn z9PPo#2vR#a-cwS5!Svr$_YG^DnmYDedV27D?dA?oHfBy{1||k(1_lP^&C`7jG6MBP S`mG02lQ{#7fgIa_!^{Ai&nLP7 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2007 SP3/ExchangeDkimSigner.pdb index cd9968d1bd515225b40260290add6b2369c60b29..eb412363f2156431c431f65f90d87823258cefc6 100644 GIT binary patch delta 132 zcmZpe!`v{3c>@cVgknim93uk*1CJTYdmkNk=dE`p^|9$U1#Fh#(vedr{<_n|=~<)N zCA~Tih0cyHX;zj838kuY0<~%tE@n-Y-{?4lag!E@2)mB1=P@~^Ym@oy0$H4Hu}5xB Nv0G4$$M9WGgaJ&XEO`I` delta 132 zcmZpe!`v{3c>@cVM3*aX93uk|nEspUzG011Q^%f5PY<52-7LeUBd6f~`CA3sZo#b$ z1p&$qpE@eaG%5e5Jd%s7nz diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP1/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP1/ExchangeDkimSigner.dll index b7c2ce2ddbfcdd61df5a2bb3b3fa2b8621c43add..f13e0ad485f7447f09867e53d2bc59afc18a1cb1 100755 GIT binary patch delta 137 zcmZoz!Pu~ZaY6^PVoBA;ZdFA_mdzU#`4t8Foh8J5c3C=2aM`lS>aJPj<_k{qSQ$+= z=X)?R>HyWoF#rJ*5X&$!Fm$8?u_psVP_RpILO_)m=d2kXYf=tYU3;5%dGj34PfVOF hK()+3)hwH*`y6BhniJ`_9!O2*3@`?AYy%E60|1UgDZ&5% delta 137 zcmZoz!Pu~ZaY6@krz`KqZdFA_=FJ-w`4t78onG|(zGIqq%iPlNeLA^6H(zj?$I58D zIp2ekQ3t3tjsXamfLMl+fuSQEh&>q?f`VOw{j{$xx*2EYu_tEFi)@z7qMPS@cVgknim93uk*Lqb5680V}R9&1t#R$Y6WcX_i6myVo5@zK^YDKV!2 delta 132 zcmZpe!`v{3c>@cVM5iln93uk*gP-=*MK|NjJod!wd6CVsS#+}umyVo*_vddFY`X=w zHWUOXJACS>ytmot=*|hY6WZ7rZ=ZYiy>+AG48~1b93t$q{`I`!I(T(5zg-|pY{{2T Pn^Wu-RO2yx*Arm?!Z7qYhAQ90L$A0kI4t14BnT5PLE(1O>YUe{L>)lcbpFvvR|&Cmr{miEp0c`H6{> h8K{;SsG526bf1HaKyxDf)&r@@oB_r_j%~nUW&mvrEPVg~ diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP2/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP2/ExchangeDkimSigner.pdb index edd9291c4605659dff5f39ea0e222f7d046c445e..3ddb012a0d8166ac083458e8901b7dc9a2991c0c 100644 GIT binary patch delta 132 zcmZpe!`v{3c>@cVghEMG93uk*!!}2C`EFTbr#4HwW5?|3~GRu1)5*3uJM+#U8mi O#cn}09>aG%5e5MBmoK9L delta 132 zcmZpe!`v{3c>@cVM5iln93uk*!{_GGH%W?#J}WoedeU+4nfPWIE*&`q@6X>V*metU zZ72v(cKFm$d2h4P(VY`)C$zCM-ahy2d+SEW8H}5>I7HYLs{`L~9lSc3-!70Pw&csF P%_(*Zs__`U>xnP`WVkuS diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP3/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP3/ExchangeDkimSigner.dll index e1959a766ca1942de14a6c0f0ce6961bb5782558..a18a73eb0601bda264f456412eb8c7ec8e24d81d 100755 GIT binary patch delta 137 zcmZoz!Pu~ZaY6^PLP^!eZdFA_mdzU#`4t5gCwC}!3;uVRcF1zm!WG}%ZNA_%kCoA6 zbG`>7qYhAQ90L$A0kI4t14BnT5PLE(1O>YUr))WBwqaAU>y&dUmu@G{uG&1u^Ai&% h3s5aHP&Lcu={^S;f#yW|tp`$*IRlJ=9NU1y%mB#uEe-$x delta 137 zcmZoz!Pu~ZaY6@khb!;KZdFA_=FJ-w`4t6>w{5h1#{SH6bIz=JQENTlZ@%C(kCoAQ zbG`>7qYhAQ90L$A0kI4t14BnT5PLE(1O>YUCoFjKURZCN+j^fBLP}Yu7H*#7`H6{> h8K{;SsG526bf1HaKyxDf)&r@@oB_r_j%~nUW&lJ6D;@v< diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010 SP3/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2010 SP3/ExchangeDkimSigner.pdb index 6634ff8b2e411f415d88853d95c1c7554af31361..864f5f54ea7ddaffc46474ad8533a543c13cff2c 100644 GIT binary patch delta 132 zcmZpe!`v{3c>@cVghEMG93uk*L&}zeW*asoyG}W$a_M&B?5fQ&Tsm?J#b0-tI6Z4r zyQEj=q0rgUCC$q6AfZ%sPM}t;!o{qq@*5pzFmBS~5Ml4hxpq{J>Dpv|yFeDFTkMgW OQ|uO0<1u{K6JY@U5;MpE delta 132 zcmZpe!`v{3c>@cVM29PH93uk*L&Ab5?}hcYxvlqEA*7UbYT;%XE*&`q@6X>V*metU zZ72v(cKFm$d2h4P(VY`)C$zCM-ahy2d+SEW8H}5>I7Ha@EuZk3>)_SN{C0sXu_a$V PZBDUUP>sj%T~CAo$_qC@ diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2010/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2010/ExchangeDkimSigner.dll index 5255f116807ec6f7e112e9200e1a9fb6a724f95f..4b1a817ff81bf4086f1fa47bb406b6e38fad1c17 100755 GIT binary patch delta 137 zcmZoz!Pu~ZaY6^PLP^!eZdFA_mdzU#`4t6n7T>=3`Qz$gy!nFDJXS`N z&G{aTj5zzIf^tpVqpWA5}C288*-H{KUk` h0#wTkRL!z^y3avIpgEC#>w(l{&H!T|$2QHyWoF#rJ*5X&$!Fm$8?u_psVP_RqzizC}(DxR(Io_YIz=+PN!yEo7A{KUk` h3{=YuRL#73y3avIpgEC#>w(l{&H!T|$2Q@cVghEMG93uk*!-oYS`QoWpd|K;fepJyAWY{djr6Z?M{B@^^)3Zjk zOL}!43Y{HY(yS~G5=vF)1ZvePT+Es(ztM39<0dT*5%#-xS00sPx;B~LE|A6P7JKC8 O6uSl0cnsh5L>K@|g)oZ% delta 132 zcmZpe!`v{3c>@cVM7t|*93uk*!;2%^V=A7l@Sb`5e(2E|YP&bfaOub?cz^y@!M0m) zYePYRvcsp2%6prQj_#abJE4u8@%FiA-&;32&S2c6#UaA(rV{#^>)_SN{C0sXu_a$V PZBDUUP>sj%T~CAon`}CK diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU1/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU1/ExchangeDkimSigner.dll index fe19120204c46bb700502845c3866a428aea86fd..1b8530e7a6f6f95892859bc93644f8dc03cc623e 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^Pd`Z>D?(+(aESsYhB^3qM8N>v%yk_xP88NruX8RtY%`Hy-tc)g` zMLawhL24(*drAs8ns)l1nY_)l`^RDHV~z&XHg|ZkF>|soFflMQFfg!ep6+vy5vV89 SZ#|Hj%o$(|HsCNb0D=c9DgXcg diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU1/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU1/ExchangeDkimSigner.pdb index d4c0faaf9e2b65fc10ae0a97a747bbc9fb65cd84..ba2bf2d8f3503350fb7b5cc8b0fc37749ff7e9d9 100644 GIT binary patch delta 806 zcmZ`%T}YE*6h7bf?Wb>>v*wyZH`mCLwZevuT8Zr^DJ)jjMGKO3VMGuG&MtyPu_!AH z_fmARSalN^RQg#nqA0@TU zTV-ai?~Lc|v8xsR;p@_X->8>k79#O2*rYZGoJLJet(eXQL|@3s$A#g5Iv+~P`jnX{ zZ|)6ygX7DH;tIwtvEw+8Ar>?dwQGpp!*@g4B;rj*qO7qu>=QTd%a%qR(X31~hiFoK zt#{~dqsF9~wtbh<5u?GDD<5%dCWJLor+t&?7xBm;w+XYW(5dW8wKR37XWvnrxr(Qn z%wj$ga*(iE@?PmqB-@El$6 zInClji{y}1eArwp4&=__k=5zkT^+LG{L{9yB0K;0ty)#rvyUi2L}|32QOwEeA?NFsyydVSDi;hDWWiz zR}xPVHM)bZmaeh zNCwsDDG9vnm35b<#+T&mOK$SHG+#yz@&mqsfB~vo(R6&emk90S!gmkb#%|PFo7g3gtv+ON=P=3Pee%r}uEPoo-N&LkhA$LDNx06m^rd zAj}-v5){^`%{Rss_hSuXKSaio$S#Sooxm4b#*QOD?(+(aESsYhB^3pN4Dt_b6m@l9&gr0eHb4B-<`$=ZRz{P} zA|4)$Ahna@JtYNB`tN_&9QDm>_U*eZUyJ9MZ0_)6W9DRGU}9iqU|?X`Jl*FYBT!GI S-+CZ5nKQr`$gvGL%nSg+cqnB6 delta 117 zcmZoz!Pu~ZaY6@kt1Iuu?(+(a%$uVXB^3p_`NFbRSj=~w@W(!8gRorS<`$=ZRz~B^ zA|4)$Ahna@JtYMgd76IN8+`Uz>#06vrs|`;n>#$&m^qmlm>8HD7#Ns0Pxm><2-Fkl Sw;o7M<_s_fa%=+*GXnq@XC*@b diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU2/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU2/ExchangeDkimSigner.pdb index 2a81e7229449a7907dc9699b8aeb0bf1c8b396a8..3669a427514c71d92f114a5e41cf4838c0eb7667 100644 GIT binary patch delta 806 zcmZ`%T}YE*6n?+$+xGQsbJkpQ*yb8pvR2esqef!;HYBrHSr<)6)`d|)6gayG5@kj| zgyCL-pv9`2z@XBvm=XO+f$btFM96LZ30_GN;krraIo80N4ji7BbDnd~bKdvu%V_&D z+6SUsTc14BDKN&~#GZdkb(D8qFO&x6yE6fGmF#o7yXPMVl-d5Z?>F}DbYHx1sZJ+; zPV_Wn_Ib~`-yOeNKN7wsjQS+K7&SA-e+1jrPQOFa1h()}&d-NK4mvK3`_*zNA?lMR z#)_t)uqQaVjIo%Eu}ka(&UwUwM#g$IjD3LbfwXDF+a<=b(oopTZ{8QpZ92wgMaJe3 zP4Mr{cHM2%7**qrpF&!Z47p?FS1!#Iwr?;;=M_jrL;%3$UD7Sj3l#Ha3krp!A zjx1?XSL^e_XvdnpLXFxmoH8}%wT%771>S(S=ph?8iAy~RKY-k+zm=>2Y{U~};C4Jm z3O=V#OFq-D|Zzi-v8I-h+KsbFFJmL|@!T{HH7 z!#qG*WjWjcZ-EdC&<24v;1t?d0h=I}IMonq1;!CK18Hqg*%i| z^Yl~_YDhPCuQn31c)F6UB`1pP2oZtC=zwg`|Pix|7 z%>z+xN^}^b0%J^2M!x%8V)F64=ag@z%^mARWFG_BV&BxQNKFuuIL0eFJ;|)+|!JzGV4}XJ;y{TrZ84e zQUUw+7Y4>UWr+S2{iyTUJ6prp8)RE8I51X71*}q+p0SKR6|nGkK1KTpt0-UcS+%!7 zGN?v>S>Tm`taI&L`6%aJaZ}K%`7(5b9}f0~4N%>R-s=`zLh(+r`y^_*MtXF10$2_5 zROL1$kKZRQc_nVA%;$q1?h5s6AZt}x-{99}qLFo?wbk-7A&*et??dKxnwT~V|L8=~ zv)aHoRhOd%G!${823`qyY#A)8l+$~i38K&|5GA9Y+sDmzxDaZl^O-B(^)J@X7 zFnM%KL|CIb?w(hCPc@AF5E)A&J0!+-0bgnvJB94V*}(6ctO#`C@oyk4_!uL|&ozuM zwRiF7dp7c(>;=KCma^koer0Ab6%of|vH5?0QcSfyc`JfnnY~@p>%Zw(wEmHK2>G?B z?MND?9;rh%z*-}4KP;JmuOVLt^nyf_J&TX?LangVl1xof4ok;C6 c(4y{;bHZ3&-x!A2ZtP~!gpeYv+VYFqUpFbV_5c6? diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013 CU3/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013 CU3/ExchangeDkimSigner.dll index 879ac3b370a0a466acaa016254054d60d2403939..20b1ca04ef02019348f763ad545d50e6ea6390c3 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PTuIf&?(+(aESsYhB^3o4KmNYszbVgQ*Qw=?d#VKOH@7(Tvoe}& z7V+?41gV`I?w+Qdq-%>dW;8AFU@p*xcdC#>~mWz{J4Jz`($=dAiR*MxdTZ Szx6kYgKgm>B>{pD6PH delta 117 zcmZoz!Pu~ZaY6@kt1Iuu?(+(a%$uVXB^3o~uQID0eh}r*=Wt_Ircq(m<`$=ZRz~B^ zA|4)$Ahna@JtYN#bv@n|Mo#nC7__;4i|54R%^jX>%$&>&ObpBn3=GVhr~4da1nP!Ah7dN3l00;dl_rdafc zFx-dG!(!D-V32=qF(ZnS0@*`R3?ZFm2|^%*MD~) zMn5FVmG0Dq7J)Gqeb;fxY4bJqe;ce>*v)6Ob#lPtY5V!KR-NnK^kG})KF{@QH>wQc zOtQT?bJ%~;^Zrc#`r*iJVI&|K#h8ULz7T5GT7phVSG$8x=Yo77?4;w;SWsIGCq-jQ zVXUb1MZBTHD#qe6#;&llIOh=ynHlTUG4>ID5Yi?QZ9ftd;F>B_%KZLX@nfOrQwOcpAt!kbAZDN?m)e~+rX8X{o>T8WK^`Q62X`HEw zrkWMLsD|Ans6?skJ^6?zB$Oy|nR}zB_~U3`E9ooI)Jao#XD7 zFfWi+Sq(SA8z96Av_qgBIDz(Mz&eN}PC3NdfC z^FRcRRlkCSXr5$!P^2I%e-so2O;{g7P*I>p3Bl@lsX+w2@bbLpoaemH^PYQ$)B54G z{+6uPB|5Azi7^&w>HK^sda*Mb7H4noNF5d{)#iqVor~WFmHSl_!~NZBeGBJ?ib9*d zJK`BRW0Yo}y#Joa`Y%c2%_c<-SQ+EldwpU^D;Xt?7jqgPbJwFPO=)7uy;oM^7RCye zl;73z%*hv6zn zW?}U$O1$J(jmP4TKB$u~xGmt(e;M4(cLjPwW~i=5?-lP_rP=Gr$N|)Jjr8bjKd>C+ zsm!fQ?z>4`@=Dw;mCpp+yfxUfima7sy#rqth(^|l)>grf2HjGDzYW^kX=2(e{G$^? z&vFCnMCBwkprMExGxJi=?aW|VrX1PYlpqSd0#P#J#5Qhs(G3c6NI@1TXgZ3xMXXU~ zr13rLx}{~J@y02O_pzR_A2MTUWQW4oCg5`eV+WBDob~^{$!38~c>K%AT6~O?$WJ=P z=i9^l>6X>JCwE%XL@_sJ;1?bYq`Ku%Rj&WvpA;9)hp%PuOH`XCI)5(1_tKM(|ryy0`)}t Rtp`$*IRlJ=9NU1y%mBEQBkTYG 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 20d92d597c3b24353ffa141539f2985a6664b455..fd9ecbea2e352b269d9cc287873fc1e1a474d3ee 100644 GIT binary patch delta 806 zcmZ`%ZD^8F6uz&%>f5W%l{1x1bJA*x-h5kVBp6$Fiq6@3uK zyafF)to{@Ws`(bKqEVw@7zD)_w7I?p`?ZLO)*lBwXC>@U2M*8WoadbLoO^FiR@;-+ zJ``n#J9VaAV2o`$T`D@t<=E4@^qc*;{5Q2u_Io^?zn(NHGrg}tsF@tyU&J9cfwVEDR__e**)YG#c82)3#10jH#C+Q_F00X`6N(s6zypw5MoqCRC} ztYqpBdxK+37>mmoyU32?TtqBrWUO1m*a!G7NSi>sO=2u3^@n}@<^$2(s$*&!G*WE^qQ8jM;DP$DMFkFB4m0L5;ElRWYZDNqel|ybLW;dc!?br3f6KdyR74QLgjP;PO99O4!3sV%F|6PGT7xH+{q%B@~1B_pY1q=k&O zBTJdodVNvIA6&Uxs8JgR`b;fFEn{U|;0<_8581#mTiUBjP5DwrR+rAe?{$F%+5 zFfWi+SqeA6V-R8i+91#d97p>qU^B!Lry63dzy#uEAgv858$x~=|NVN6>na#Eh>+p9 i(3YlM0d2XuL4F}*MkQM-hHgUi8JZE2?NnW()4D%{@v|5J delta 792 zcmZ`%ZAep57(REqyW6h&Xl-svt!yO*8Q8E1PwZ3H%dJgK2P)r&r3aRo#9(xDVCCXSS#dAi zPx(?8v_k3e`|o2@!K=b_t4AWBv_yN6p{bc2E%Qji4-nvNoFP&P@6 z!t~)SQDKeJeEYn?|47Z)50SA9vQuJgC-9kuu@lH1oDKfI$x6T$JpOg09UtQy^0SKZ zWluMMvU?-%&5a6frJS48@XHT}(ou0-790QfC&d-#+$$0M>ikVrU*JablH-reJ;<*` z?LyKp7NizwgSC3#URW{%UqIdj^np(tGwfP{eb_ewX>f_JE^Koqabm-Y0ww#2PNa4T cXjgW~d11VutB*iz7j|=KLP!x&oP{OLFG(A-^Z)<= 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 cca09703e95786df25d76bf5541da9e5bef1ef45..5c9146430f77ced96a1da72f0d6489a8c250139a 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PTuIf&?(+(aESsYhB^3qU{f+uBv*o4luIE7l+g&T3ZEkVuXJs_m zEaKt82vR#a-cwS*mN)gG{Lgj%%Rc^pXZfk-*5(dRHfBy11||k(1_lO}&C`7jG6MBP S`mG02lQ{#7fgIa_!^{A{6Dvvp delta 117 zcmZoz!Pu~ZaY6@kvn%h$?(+(a%$uVXB^3oWZORuBN&Mit^p&8Oh)bvJ<`$=ZRz~B^ zA|4)$Ahna@JtYNRTi#iIao$Vco(?894<74?%^jX>%$&>&ObpBn3=GVhr~4da1nPtYc>6gazx5=EmQ z!f-D^7n4;N1qPOW#f&IQ3S<{SAwqLjCU_-&%xN8`QM-Gzn&|oYh)%N{yU3j)@{oBnQO|HwAu2kv7 zkBRo0%zn>#*P9d9tA|22gki6w7o#S|_`JVGZS~nDP2Dy=mGkj|fSrzuqds*ZkP!7L zg|VX27jpZ@S1=ZnF?N}q#5s?c-^f^phOu|>y^vNwyhUOxEA@pu{N{bp)U0D{R%C1r z(FFg}VAI`3jZro3{3fKslA(WB&r7Fff}6uZ?d$jukA;sojhJ1FPF0__2$Oev4;;st zs%WZF;S1q_lLVD0mAyv?i9$k&5|g<*a*RKWcsG&05-nUX#EC|_iAK33uw+F(9kIx? zH)V?o_e2A`6X;oLV0u*cf*Q~&M4{aB23f>Q+%r2iTp%u8263}$SCm`aR7yrt$w&(s zZAX?;)V2D&FnoC3KA}Rb8R%9T@><4z;R5^Nje5uij^k2K!4D#L`fnwh1lHmSGH@H7 zqZ>Y_S$b%m7%}tr_2v9ft_P2-PUY_DkmVPjwx?y${=aY4raGQ|5UF5s^p+;hvdJ0S zzhQ15t+EnsfHy*j8EAz-D{uns%YZ?MB~CfST7YrHO+Z>3R5pVAD*ofuM#nWUDi9&V kaj7j$y9(NBb*ubbNRLU@W(?hq=o2&}B-^7p#%6SX0NOsYRR910 delta 792 zcmZ`%ZAep57(REqyW6gJE}L#jt!yP08Q8@nS7Topu^0{Q#|#|xBj}GILqhuzD>H;- zIM1J;vFewQ5a~tM2L%%Z^G8up&=%`Mh)NLDK7?TPywo6qUU+%lbIx<#=XuY)iL^eE z*54N8+QD{9Okj*Hw!I#In)wtS8P-XMlzmZcquf+qe|YsRTBeC~E5L z-BHizC8JPy{Nel1r2mRA)nt;yfQ2zWd9OzsP)kNZ<;ASZC){FmLd9A^q`)@-Z>p(uaGSj;J{cu<#$LOCdM+Rl;6(ZdKJTGtYUoG>o8mg z$*fs?s{$|iW#f*oOCROj3vLZ~^h^Cm`H?_($PCr(=)K{6vrrgMcAi2_*GP}fP6Eq8 zp321rHN@X|Bp@# zJW<& zFH9ZV77^BI4L1iB?;|~9KSajT$aaabJ;3J%#!e$Uan}3$CMy6N@%UGfc6^Kr$VDCF z%dH*!N!w-~&0Z8#t(cuK@R0|7sfaixi*^6|lj555;TsYB(##EAm+xA`g5!_O9muao z?LyKpRY)VU8rEun2Vuzyd7SYg)&?83eUNP|m!ZFZ+KiIZxqC{VJW=tOFl dfp%@ToD;_8Of?~h?Zs{uO$aGMnsaW!@Cy*&wYLBO 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 1c0c9f23ae76e25f6a0516e2fdc9d95b899d99ba..0c3563300ff48113f20e3f9ddfe9affb1e0b8f24 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PTuIf&?(+(aESsYhB^3o$ChS{az-#Z@b~Say37Nyvn_HavSs6_> zi+Ff2g49lq_mmVk>Gpd2w)ho(eRH-eRNwDm+}z>G#>~mWz{J4Jz`($=dAiR*MxdTZ Szx6kYgKgm>B@o(&|FhV&@#qIG+v^9?H@7(TvoacQ z7V+?41gV`I?v_0WRs_FzO115A>(3{(>U8I-_v_lX`7U0#RAmxB zX>HZnJ%O{ncgLEO*E$z z#)?XB)E^#M#8^Vc*adbR=K^A3D`V{j#y-GzLfRPOO%h`{sW%$nH|~qJMiXPxB4aa% zYW!Qh%XAAhR^7VwhmcVvOZOG+mDe!J?P{IzZL*&y)Pr6tX4jxo)tB|c`0e!Gqc~F) zO|>d~R*iT`P>E8RK75ZTB$Ox#nfqf$_`_ImE$J)K)G)>1EQVX)4G>}nIw8;r97X#wU>(E~ryOD(z$D@}Agv858$^By|Mhx}=Q0=-h>+np i-N5lkkE)&*&-;0 z^ZW@~t9}UypD<=CMy%i`>U+0>wHlAG)653YV2lx8i{vHtK@-^!JtlH!_s zFya}xtQCq+-hYoz`mYO9%{oa87#ZV}GkwaCtE?4Vyp(bAad#c6a?Yi!xsQud)WBH5 zkn}ruKGQSSAw%@9=tG^y-gy;cuaK=(;J{cR>9yqvq~FHhcnzA5SVj1<*RHt@ zl3p?TRs~-6%i7$;xes#o1vdvg>d%8m_~AfrNDtNR=)Li6i%=X(be%#?*GP}fP68`I zo+{kh#EE;vC9lNokokPT&0B)qo5@;*);sWZg=l1*XsuQJY|t$f_+rr7MibL!;UAp{ zdR7`3r%hREKtmBXqUYtH+mXhyLOHXqDNYo61)`*t3;Vg%NjE6SAq82Wpy?>02Bkro z7p9JG3k&O%#=FA??_)J%KSah-$aaab-N5G>#!e%j2QJ`c$(TUWq d0&U7JIV+6jbu}S~?ZIvaO$aGMiX*?I`2}cmw+R3M 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 3787cfaf99517cd36fcf87e89a2e58e8527a15c1..c063434ea67b1b48ef2336ab8870bb1467fc7249 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PY)RF|?(+(aESsYhB^3oO3m@uR(lpbpbHVKsPju*1t`-Nt-@^A1+=n>#$&m^qmlm>8HD7#Ns0Pxm><2-Fkl Sw;o7M<_s_fa%=+*GXnt9sV5Qu 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 a9a95d0bf8aa26ccab47e1f3c8f1a0dac50ad84b..b4b390a8867696a0dd24c35218e8144d778117ed 100644 GIT binary patch delta 806 zcmZ`%QAkr^6#nma@3!vloH=a{+nOUw)`}W7YP4*3OA3pX`Ot!7Js1&0fwPAoQ7p;` z!~Fz3ELIT&29;i8lPF3GY!87UMsAiR_#{L`_L9(dtbs2bID9|neCM3+{Quvb)_14% zPei%enY_>@FvcqS?gwW5p}jd#svRx7ozT|GKDWE$=V*gE-?QQUmacv7zN^=2Byl#; zS(iTSz384eeRJJV_?9s2Ga1CFg)#m;(4w{Z9VT7Fc0QB!^TD8lj!R>HZ84Y-4M~Nu zqB0Qn1SVH87Lze{g`L4Uk66IWSeK5mkMM(#HjQ|TiLs1nAnfIL9*dS{iLrT+u?0jE z{9B`4x`!IGX5RBdNU0`c>xbR1UAif5RYUrB@gW{lkGss6U5`#RU$+W{2mMD*;Y?LD z)vWMEHRvKiB}#SwiAO{sp+t$v+!Hy;Mq_0F%r;Tx&?-cs+{y+S#7o@syEa}XE?ow3Gg?oS+dNcCMpDU03mI)k zmQ=J_LtYp@w*HV%snrekDvfzPW502Mx8Y3&$Oca0QqRI$kvsRdk`;jUc!D(Cj_2rw zFX)yZnkRBr{%L19KbpOSN7iPt4<%&zmFJx)S#oLl8@xa)`A7~~SQ9`hKUTP3QFT6bOIp;a=^StNYSW*{D z>h6h3<58KJrZy*IvV7m9b{y(dxAHPWNA6TnK4 zrwX?*etep^Jkc@sLu4$849bk{0X~-)JB94U+0gHstO#tyFnW4`?m1D>?Ogam9kS3zcx3V2#b@7*z~_YDXKXhy%xbQ&)=@<_ugz-w*Qfth5QE8 zP9zOehtwnMVXXmp0G2GkmyoXky1^%o1$M2#e(alpG`P&y7j`=0IH|{q0ww#2PNa4f cXw!BpIbkwyXb3@UFLtwNLP!zP9QkGG7uQ3y5C8xG 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 a56b4486ec78142f42d43c174e5b218a71aec6c1..46888e896c557c53b3478d23fdc3eae2306b46cf 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PY)RF|?(+(aESsYhB^3n(n|gf=y9@j_sl4M*jZ<5^xy7lUmCoT%^jX>%$zI?ObpBn3=Axrr~4da1nP^9AFflMQFfcH0p6+vy5vV89 SZ#|Hj%o$(|A>N6Ip;a&Jm-DiuB^T* ztM3=(N>}PstH2nWPtTve-E3>R`@P?n-5Y$at&jsAPy5fuHR^Qtns*yIcX%#dxKw2j zKP5YS*=GM4&)XwcR}Mt334;O2D8?*|@o%9Ptu^SBbTym#WIo9I!cIEQ4F|Q^a8fj; z6vm25Z^RoKUBXyg#@I!64Cex3Av0s0I>z3^cS71Y;w=(mIjJ||=QkdRmPP|((;{Ot zh$i{hI)~vFYRsB>`wtZX-g^4>oyAR_` zRW#MC@L4tNCP5`iWzWI;L?NL>iObv@J;WbI1M5j&iKdR55=0~2M5A0Auw+I4Ick$> zZ^{-G?vI5VlIU4#V0l#bk{Zw|M4{Z`206q_+>_hZo+B<@261y*cZ}P-R7yrt$w&(s zZAX?;v{lA}Ft~s9E}=s6^`(`%f}XM8xWMc1dLv{5M{%jg;d_uf@wbvq0ITr?S-1nw zk%rIc79N@>hpha=)^ffte-@9dP3G?zkmcu}c4TDH`M+<~uDPCl6scft_@*wwa&1$N zf5W^$T4gER1h0n>E6@&scHkJ=mjP=bmN?}QYXc?_w*YBvP}vaj%lNO?>s(jBs6d1a k$Az{u?J{V~wN3I1Au}S`8!>bXqEFC_kgQ2_jZ7K-08RO@c>n+a delta 792 zcmZ`%ZAep57(REqyW6gt%ch%BD_e>|26i#2(b$*k$3hy~4-H%e1^qE(NNo|ZEF&<6 z^ZW@KtLR6O5a~r$Nx=kR`J5e0=BB?PPIr3Ml7!prlXbDr})&wK7oq_v5( z_O2+`4+qT=fiZUQ*=TU#R?L5+v+2v}nfMWPz1-T^xOe4SOq!{gP7H=OdzUZ9OR6$= zf6P60K`#`ay#GEj>ANgUwHhSRZ)S{7J{VBrN?9)`yp&b=gsTBnc~((ZU57*|YGSNl zO8K1Io*NnKk|Fw644}?q?~I1A*U0uNaA2&E^4XFOLcprMExG4gW2<;Y-Jp`6&=GC~x31)^lsvz^@Pq#G3Ekb*2w&~y}0le$To z7p4w0g@rY0^X+pc&tolPKSajT$e_g74&VzNW5F6!8$QM`@{@+~ zrH*d?bk|1Sn>{ZmYAHLR@D=2%fo|}LV}V^Oun+rYAPp|@)w!*XBu;9vqCm-hq7$i& d0&VJcIVX(g4Rs-i?Zj>tO$aGMsw2Os`vv+hw)g-5 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 926f1e83aec513fd08c1865eb1128b7a25863389..c644de949b4d3e711240daf963cb0e8900f8a5c3 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PY)RF|?(+(aESsYhB^3p}-deuXQ<%qjPF8YcQuij|%`Hy-tc)g` zMLawhL24(*drAsSw4J!QG4+Y>{L&()U(|soFflMQFfg!ep6+vy5vV89 SZ#|Hj%o$(|#$&m^qmlm>8HD7#Ns0Pxm><2-Fkl Sw;o7M<_s_fa%=+*GXnrmbSC5g 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 03273066e5c9e683ea8b9e94307c45a456e7cc3b..74a792938506249c925cbebf2065a50f45e3d96b 100644 GIT binary patch delta 806 zcmZ`%U1*YF6n;Pb)UQvSD`!rYX3}byi;^WJ$?{W1v4*v}$RM!`BZ4TJb`dltEBYZ8 z`qIyZVRaKMsJ5?g5k)P6;YCo4L7VGuv8zGEXhk&WIV)i|9XLEM=RD_}=e+ORQ_%Jl zv=2nN-kCm?5Ex^*P)^OJzH}5bCzM}Tn-l5^+2?k5eSh4dOlQ};UEjUkec}AY2A%jZ znQ1KS_MUdXIdWy?K=`^a=#%tf)XW(F7U)zHeut!K*~BMHe%>E+&~bj)ug(RNqCRb6 ztYXTAJ%Q0BjKyS(U1UdbE+ZB&GS;nO>>a!V(#8?*lo%^Yxv-btyf2#Db&O4mjLjgL zCuy4$ERs>W@zLSB&!*JgjdbZN%8MG0wN#|L;!Ip8v4b`v@^eBK~T-09nM7-y=Y zsYVl@Q-UrMRHfAS9lS>r5=xYq%sr7q{9(k`O!}%cW!w-a8tEn)Q{~0j)w5$}MhCM7+v9xpnPX;?iXhx2R^L-0GoHGLlM0TF7WS zvb0HEr7sJE`&aK0>eR;mUQ=sX%h+#R;0<`29xYT3ty~rK^TgfJXO?ZL=+>Yny zh0kaf9-1eIEd2eJTE4Gz29K;xmhS41<>#Je^0Mgo-?!>gozFgqR4_k$OA}|s)Rg_- zFb|McSqeA6+aSaOv_YT^IEMB$z!1a|rxs$Zz&PS&Agv858$x~=|M6;_^D-E9h>+p9 i(3YlM0&TgvQGPDuMTYl%l@V1nDnH6GCmmG>{+}pTvnCo zM`NzB^E#pQV*bZy)_X;mXxB@k&%_wdK8~ovN<}9qyqr^b#@URjGNq_1&cmV9z9rZlm@KR$;#2wrQ_} zWKd0>C4pDGvhLLK{m*j#H8=ZQns2d#{D3bMFhF%HdawJ~A(U<<`i`NdYoteKM}gHK zPgQPH;>bPXl2_vP$b81<oK3k`i=BpO*KT4yak>30f6{=skQqKRp<_>WE) zJ*y2&lXZD&KtmBXY~U5Y)1Jn%N;$EoZImeV3Pee(BYU~UK{qJKAq82Wpy?>0Ms<@k zBTO9H5){^`t#{5E-On|Qt%{7LklhkvJAt!W#*QQVa5nh+CMyBk@c37eR(y;z$geew zFLd?tm%BIe{@gi1QOmiEmS284lnjdFve^8;KPjr(pS=^ouT0&j8Sq?dowNOsc?kKn zs2xZerXHz7Ho#gVa33t0fo~vR2Xui?95d`%fCJb!0cmiFuS{>VCveh$6$MK66P-xy d640vdkn_TLLEjjF*e>km(1eg8pxO&_+Fx#zx=sK9 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 1dd088adac8a5944f29d337c1789f06cb2079a3c..a67ba9d7db69941d484d75040294c393034e2c9a 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PY)RF|?(+(aESsYhB^3qQURv4xzx>2ylgAs&s{c+`H@7(Tvoe}& z7V+?41gV`I?~mWz{J4Jz`($=dAiR*MxdTZ Szx6kYgKgm>B?s{VE{< delta 117 zcmZoz!Pu~ZaY6@kqbu*m?(+(a%$uVXB^3pBg*~ckJGIeuTJz!qAuF~PZ*FnwXJs_r zEaKt82vR#a-cwTGXYGEC0>3iHmaa(k{b4(2Z0_)6W9DRLU}9iqU|?Y0Jl*FYBT!GI S-+CZ5nKQr`$gvGL%nSf4swkWQ 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 d464a69aec7cde7e12344d5b8afcfd43f495f6d5..4ebae3eaf5b1240bdb316209c7a56c2fef3896d8 100644 GIT binary patch delta 806 zcmZ`%Ur1A76#wpax83gUoHf@RwzWomgmyU32>oJTBZW~@WU*gNq%dcrjDE9L?hiqqg*SnXaznMvB|VI zWeW=TMMFCh=vi!F87O&94QLgjP;PO9EaFA(iLGnT5SK24xLGX~N4;A)-MsOQSD_ z^ZXGSt9}IukzQnJluQuJ9|c808!SsGC|Clh@WRS#wnK3>w)1wY3CB2~VVpief?mASZIYnJ}pAegL(mb=QWJIMz&Od17rD=-!63+7|R$^ej8u%nsgtrit-h&U3Uv4 zqiXi83B2T&^^T=0ALQIiZV7m_pZkyUBZ2Oa5vq;oz3E-EP`H!qJdK*Jksh6$0+xe3 zmASRallO>AUWwZ-^TmLhHwU}6khL}qU4{)oKZcvaz3bH^!(^14t>NaUn zm^{8CENoC4?p`!`pJ*BTAu^Umwn>cb0lv^Nb_Usrv)J#OtN?W3@oyk)_!t+EpEQiG zw07`k`?m6~?2w?S#q79_Uw_n_3X7w%Sogm_DXuymzY)PN&E3{Sd^a1G?SEt*Kz<`? zCz6J#Lh6y#uvP;+2ul{=E67&@J>V0^0=rgV1p8(n4KDHZ`JIj=PO7n@K*@fh6RBMT c+SJ{0P8eM<)Px|m7rR+BA*2YYj)i62FLqwG8UO$Q 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 7da98dee5a1bbdeb91dcd0b24ea892d4ed537e62..f45f025036cadb70cde67b3de5729e318923ab7a 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^POi9(o?(+(aESsYhB^3qMo)VgIkh9)($;NfoF*6n&+1%pP&&p`B zS;WJG5u|o#$&m^qmlm>8HD7#Ns0Pxm><2-Fkl Sw;o7M<_s_fa%=+*GXnrvR3+2^ 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 0fc60d4e3275f671d1dc365f75ad9331acdbaac5..1e427727d89ad4330f90cac2ebb7cbbf42346aaa 100644 GIT binary patch delta 806 zcmZ`%T}YE*6n?+$+xGQsbJkpQ=++upW38}Zqef!;wxqCFSr;ux)`by46gayG5>2CD z4EGXru~>CeEXwq&X7q0avWuV?LOS~syc$GA29eNntbsQjI6N=sJm;L}yzkqc)^?}0 z_e8n6HhH2=V2oYpdvYp!C!{TidnOeeUe}8lCtl z(OH+?mgmyTFd%oJTBZWUNcW*n9X6NSi>sRbnh74TOFC+MsA|(J?k7GFCz~ z!M`@ybvICBRE?Xz3n@i1JRH3B%B30S7Nt@9CO*Vt%6^v-v%Tn4^QB&xyxG6|5YALZ zQ;jA*tAt!6s7$HuKX8{QB$OyInR_A!`TdB04e2Y>lnFzeXr!BHlxqi;t;jz|tTOFQ z*`kU2qM>aG^ei_pKd5*~4QLgjP;Oy^4B}<(@lC5v6PGT7xEZx4%B>zMB_pY1q=k&O zBTJgp<@&rZyl=%$p-QdG_L`dVTE>3k0eozFgsR4_MsT@z=S_G$aS zVICl@vKVfFH$#X8XoEl-a2)L`fQ=AKoJxqb0^^9AfwVTLYy|lw{O9Y{&P!laAwq`Z jd|R4!5wxZ1I{Af=8k1}-7`g$`$7n`Kwq13OP3!&u`lPWD delta 792 zcmZ`%T}YEr7(U#1W6kGHp97fq4~2EOne}`(YJJdxFB3} z_r^S9=k!wk>4)#5Q~pcRbfZC$17^nf)ct-j>?-Od7cZn;e9~QmsyOQsEAE4`5;HND zGbR1bt2ngvqQjA zkf##2I?;EVxa5_%ohqLXxOsE1dmULT(Rv5JE)k8a6Ro9;p9s389Df(Iw$a42nfpg4 zik_tg=9%&gHK3u08#VG`(CwJOvP3z)tA3Oy^a@0o5F_o}>ZBVK_jFcnBWvJ%#+fV*MI0(=Gea-au%;#gqU3hcqY8AyXGd}Xe|k-$kMRum}NPjn)+ d3qYILre>t^tf49du^re=qX{8JNI0?!x?lQTvqk^_ 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 ff5811675b5c105a2de6596a6d5275a26e5e22d4..ecd2733b2ea7a761fa687377116e65034d9b162d 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^POi9(o?(+(aESsYhB^3q2rkDNLzG#Pk=i&!^@jGIoHn%wSvoe}& z7V+?41gV`I?_RQZ>Lqf7p=Tf=Fa=6a&w0#8#5;}0}}%?0|Nu|=IK5M8G(8t S{ni7i$(#YkK#py|VP*gXHz=6^ 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 540a1bd976f31e18a0a00eb0954ff599e363912d..11905470a4d42b82935788ee2d11f57f4f382fe7 100644 GIT binary patch delta 806 zcmZ`%Ur1A76#wpax83gUoHf@Ry0u28tQ9qE)JSx9V-zMU?V$z9dN3l00%s3FGBN27 zVYsiLht;YV!JyJxOo^h5K=u$6BIIWO1fPV6$X=5A9c$oA2M)iFbAIQX-}$~TozpLP7Ex&~}AvU1Z%6^Zh`^QA1y3n`z-L~Gnp39f6)ELB1 z$)39GLEm}L+mkmojD~LtV}8jfMlFo-Z^3r0GvJhTjXU{VKEOvpPC7162DGJ6QZ%L% z#!AXi*c+T)!&qF#*j084=K^9uGh@9v#@@r*AZ-@$b_oilp|FqNc_><14U8>_j4dLX z1H=t9^m+eAvc(CIH&QwKH z%?e*qLv9jOrc@6edq5NtN|d(oHnVbpgv(;-4cnnf9h^ zN#VX|XkQXN%MC0~Dqd0pT7@W-Tiqasc$s^4PyGOK=`x6$)B2*^=A}|Hl1fHe$Y?vV zl%j1k7KE`Qn+^z7THQ#$(p=Cp_6rwy3m!8@Ax;& z3#3)n!cFiPgjj)g2($xd(7poL1hK@agjgFefw%=oYlF(hkzdDuzTV=x21XSkWH_$0 hrD<0|Td(bqUkI5g$=-^gyAXYfW`tz>HP_U<;SU;>tziHF delta 792 zcmZ`%ZAep57(REqyW6h2E}L#jt!ya<8Q3tX)!0`SOr)Xx(7;hYf(i^7BCa52Wdy}= zowlm10y~FE`iMcPy_AOAo82V*{bh-r~h*L3PgE zA9Igg&9y2F6l`gwM*~drZ17ScUnL$ELdu zl2KK>%K|U?WPLoe`?H*R&CPzdc5(P1Kj7~R8lk!cz1Mwg5%Ra<-N#VVHPWNAqrh^I zr!u!Te&jB3$t!U?Wj^nB@s>c(2C`PB^$mV25{;}At+j%m3b=$E{}8aW(ZsZw`$s2? zp5+G0bY+Gb&``t;8+j?*W@D1cEfo|}LV}@M|uowFZkOr6d>fBa)94FOSQJ`c$(TUV9 d0j=tGIU|f`4K+cC?Zj>xO$aH1sy(})`voA!x1j(4 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 45bc3cf78fc40ad25099bd1bb1ef8c0c4bf97247..89bc51fe30616353122dd1caedf7ed403d2ad03d 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^POi9(o?(+(aESsYhB^3pd8l{iN2gEpSnR79Arl8oJ%`Hy-tc)g` zMLawhL24(*drAt}+D)-@X|MNdzrOjHfdA?K%^jX>%$zI?ObpBn3=Axrr~4da1nPlyoe5x;NTs%MU)KC$}fg+uY*R&&p`L zS;WJG5u|oC#>|ZI@4;3z8E_gk^_%!qA;1ShPCCwy1k|}uO4O%i z#!7O3#2Xx2!dP6w*hO{>=OSW36Jwnk#y-GzLfQo4twzT3#{P(p-?%55TXc-gh>Xo5 zn&RIY9lBenF{!3)KZLAeG&G-2zHn>CxkU+U-y{ZkTsi1AVRjulRe#+eOy2I@djw~y zqNygC&nY1{2`W>ndJo+t3JE1jT;ks7Vg4ZMUq|}NG-bk&AR6f=8s*x6Wh?P7QJX}2 zQ??{?Uo6y|LeFvo^TUeg)PPnY3gs3z$Rl3np4__T9C7I~h?`ftW8CJYQZkZCMq0>d zJF>K_uGANWp#!US3zcf^K#$y5)H3!P7kC}sq=#(a7%ufVd>?Wr{#LR{U>%+y2Y28( zdf>B~g@@*;VGIAb#me^=&f<~Pslpu{vOM#oBP)r{|9z`=)%Em~NCopFH#G^CZ<}`f z8|DSlDof!8coT$JfOZJ91IN+60vLu^;#eWp223Ds2GZJ~vSH+x@n0|3y86JVM1%~- jg|;;9GHA=yjnXqAJ8HDIVCZHl|BbJ9y&A`B|}5ZLF>BT>lnT9#_o7hPrq7)~<~dglm3w z+%tYvFXf-Fd>@_i-;kyo4T>BvGsdSL4T=$0Q7^f8A?@Om?iy6ZIhWXQACr}ciLsn1 z;deH@G&0tuLiDc~M4iRn1r1}1$d)p2U@VvL+m#*zV<|(zZ{zR0Cfx_D!hF?h*WCum zD9pZfi5LB<{!_HDqGn!mOTeT357XohH9PHah)=IR2;je2%BkM$KDdXpYZYjs#2d%9%F>U7l(Fvnx zseyT>JVOm=DB^~Vycl#lQdpKKXZAOY5`|uYC@FFA0Jl2n1_e2!APW>U9Yw?>>XZd( z`smJXX_KhGciH59re*Ah%vciHt}wP2_)5pvX=E?XhJN2>raLg-SUJg*Zl8KiU`Nkw=(#}xjUME->v#(`yZKykl&2j ziKJmFka}b#tW^O!V95e}1Nm~G2YljKVAl%l$G#azgDZSvezzlzlS-^8P_m!sL~3I| bo7kgfq=~GdDg?1M?55F#kRl`;*=5}?4@0%N 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 5d7f7c4c4a8c06753de4a6904fb466446f1dff4b..203f2925f616c1e899739878f31c8e8015f57f7c 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^POi9(o?(+(aESsYhB^3plm^X_~nw9I`oqs99huiP|<`$=ZRz{P} zA|4)$Ahna@JtYM)1bL#8q+Ysq9v4c`b8HUT+~LW_%*n#Q#K6qJz`(M3y3avIpq@y- R^+0MeXMiz~V;gXo82|?yBwGLg delta 117 zcmZoz!Pu~ZaY6@kgDdaG?(+(a%$uVXB^3oMxa|+DITP=?b?LfWAzV>an_HavSs9Ht zi+Ff2g49lq_mmV6`&O4w(6q*FX$Y&qk0*}DHg|ZkF>^9AFflMQFfcH0p6+vy5vV89 SZ#|Hj%o$(|DK&i8!-Y5hQ2 z|3H)~s}pCt1jblTncR77-Pheiuglf?aI!?E-@Gqc+YF2?h>R^F zs`76wPQz`~STxJ7A3{non{o|JFKcwu+@>_^-^9mwOgU0x!R$J8s`}C(%-$J3)Ppls z(Nv4fmy}Qq2`W-5hmYPP3JE1jOyb_iasDvk-%9$5G-bvVCmQJ{8s)lyMJw>n5xYct zQ??*;Uo^B=MbBab>!Xqv)PPnY3guQe$RJ+io@v^Afw*)T#LZ}fQEvBADH%y6BQ0dK z9a%!wHW>55c<06gLWNd4nv`4edd7a^0&l=ujgSqT!lj;qcOZBAZzY=r*5L`#a3`K4 z318H$JTzA)Z2ZH{Qhqpl9*?ZeW$zl0w=zu^6a2oAPfXxs~oKlFj1LKHWfwVTLYy$am{_E8i_f;?|5Fx{H ir7can0@_+_oAg{r<;;#Y4Bdg~6Eq_v+o!p6^M*eN+^XyV delta 792 zcmZ`%T}YEr7=FL)+qdm=(`-7GTA3vV8LVMaqoLcol0#-r`Ko7XN6=A>ug z;h1mil3B?>V?Z2kX)LS$)U?&pOk0Nr=lQ%0KkxO~Rl(!01e%>QDy?v?{vk_%% z34hK0msX-S9io3l1oa~Jh73e+kqt%Qz*r{Xuh2RyL`h4+?-cKwY^Kjxg~e)9h3N)J zR%vfuS47^gn|uD>p+({9_S5Op}H5nw|#Ug+1sO?r&04Y*5k8Nz(TO6 z0=IJXI3#`NAUq?FeF@}*}3?xVJPyOuFXYso>}5ZyI`VIl{8rR8 zNFJsXX-1a8S~;*4mP&wcAYTmhfzO;0*mVGVux|(Q;F{Q6*ykF>Nf}lgDCs9UvDy`& cQy$RM%J`zCJOr^r*iE4cBS%QO7MD%G07O@|f&c&j 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 f0718c7954d63c179ee650b728c3b853c1164084..6ab02e7f5e2e6f889f5637e3ec4efa91200d8cd8 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PbV=35?(+(aESsYhB^3pFQm6cs3SQzqZSmf3rxUK++T7yQ&&p`B zS;WJG5u|oB6Z`2tW0_dwbh;!P4`IjJ`q;5Q$LmPP|(Ga_TN zh^F|LdWYdQYRsB>`!^w@N~UV3>y=kG%B^ah{%x|KC)6WeGiFzzll$`qVf=2-f#Wz+ z6-_lOd`^vcNl=O6>^XX$C?u3937Pw2$M~aIa6RcO(bO?hl4zuxXq0OKmaNF9Vm6uf zrfgB+fp}zR3O!2=ERV}xQUh9rD3n{=AcuH~+rDk>dE(M#5I3iF#ktK-rDPz$!dJ7Vf}v zbi-$L3lGgxgI4}=YdJrZKZi%wCi3?T$np!%+A^}}`ro%|)jZEXiBvE@bW4|Hxt3|i zzhQnLt+Etuf;T{j6=;V*J8%^3%YbzdOPq3uwE>feTY$7SsB94VW&FqMb)KtWR3Jiz k<3d}Sb_KNM+D7?>kQtWjjTpKG(WhueNVZ$^3{M;W07=!ad;kCd delta 792 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 j!&{=1imkMn=b+rPMzOM2SzA)-)X4I(0LNYL_# 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 F{ufcGZm9qO delta 5008 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 Gl;=NnHkwrc 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 4fbd003a1c998e7a25ed79ce8c3fb4c2b2c10a7a..36d4050e8ed2d9114232c8ddc5553f9bed70a53c 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PbV=35?(+(aESsYhB^3qE<+sl5ZQSj$qB?cUkEM4%Z*FnwXJs_m zEaKt82vR#a-cwRw!wROuf0`{Eo0Bp!b1r3tZtn18W9DRGU}9iqU|?X`Jl*FYBT!GI S-+CZ5nKQr`$gvGL%nSgDA}P=S delta 117 zcmZoz!Pu~ZaY6@ky({m=?(+(a%$uVXB^3pPG@Eo{_)hsx*p^9AFflMQFfcH0p6+vy5vV89 SZ#|Hj%o$(|Ce8061a%!r~^f$SnkL`Y|Uf>%OBWH$;u#~OIkfy481&U4Or&ilUI8Etn) zJ19z3&g6v_fiX7tQ1fOXRToYjZ##8*to@L>TJn259lxH{DziQ7$2NEE@?5)m-Ki75 zBs!}z`+XNZAKGuN84BMPhW$pp7&SA-e*~M=mVm>ksoln>a{=BTa?o)xA5iB*2~nSv z87sHM&@#4w3%mnw)I&CK9G7|)eh|5He=FG(um(?%f!pyM zDfpab>7jXI#KJ#qFXxAIm+;8ybncN3S$^e3XIc^+|NB-Qs_W%vkqQ>`_cU>qZJn|I z8|DSlDl6dzcq4>ZfHnxU0VmMD3|J4b#3_eZD=?0@8Axk`%0`f{;J@E(bln7_5)m>S jm)g>_8=$RHw@R;s^r+F+grRkaK1VY`vOTJ6bVm0FbcC;9 delta 792 zcmZ`%T}V@582*ksJKK(%%jP!4R%;~&8Q5V-jmG}6U?MH;LIX!#1l<@iB(#fKKSodt z=XX)iSalIeLZk;-8U+)C^HPHddg0}Hzwdj#_j%s$oOntT zPiY>Ba^v|m-x=C(xI=jl>Mx-b8v+<$GHh<~rXi-%b z=f=I`S9C(*#me`w>A+24rcE!2K@($qdVWwHRVq3`;l+%?r#wxlDhrCb?l~?>F(YGn zV=~~{^~%6lw+zw0Vi0u>d*^Bxdxvz_f&*juWWX-<=ow4vlK~t5;4^Ahv5N9FpIv(g zB!g=5mjzx4$hsps=Zc(t!_7gj=F7-YemFP~Hb8X;dN+S+7Yg?iy{AyqHPWNAlfY__ zrz*EGapECy$t!WYWxf>j@b*yOX0leL4Ge!R5sj=9&0WjShCD)^e+*eVXkyyT|DzK{ z&uRnHY+aTb&``vU8h9n-aip=VQqJse9U}_80#VZHg#+B;q8k+Ckb*2w&~y|rqq zi+Ff2g49lq_mmVk9@4OLmL-q-j6a#o*G^0OZ0_)6W9DRGU}9iqU|?X`Jl*FYBT!GI S-+CZ5nKQr`$gvGL%nSe)jwnn3 delta 117 zcmZoz!Pu~ZaY6@koh$Fg?(+(a%$uVXB^3nn_HavSs9Ht zi+Ff2g49lq_mmXy*37x|x;4aqo4wheYXa+^ZSL@7W9DRLU}9iqU|?Y0Jl*FYBT!GI S-+CZ5nKQr`$gvGL%nSg9%qIW< 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 9476b465dc59842d9aef43bd1dc9d500a3f232b9..d25e7df5ee8fe43e13c061926598001568f9bda1 100644 GIT binary patch delta 806 zcmZ`%T}YE*6n?+$+xGSCo3rMcV{NUGC2K_u8#xl&4_0Wb%!?Kz>%yoY3Y=X8$;AE% z!@UF&iryb>ZJyHV&l*1($%9G;hRo^#G~-uF#qw5g2t zktkO?lIPk5#@L&-)Yz?hW%t0s32pJMqeWdK``qr%Ut@LQ*`5s_wsh}tU%hh8p%cF( zx@s~9yyxBTPu^TR92yWte3D*_ni%6h0a1V{?cm z`1eMeZV)v_)wt`YkPb_RXO{-^E=`e}!wuSZ@nIedA8{EmyB3`s-?j=<_xcVV$C;{V zs!`$d;h>8Il_}MIM;{P{gc2ntb5G>tUxy3`JWF(c0w2;wu zWJyI`r!NR2hu7~Hs??gHUZt_1Wo!W#cpKiNhiu>kF7-6L4Y@OaE7=sV7Eh3Y+wdH{ z@Hx%WL-WL_nSZLU@W|?P?!FFLe))Me_AMKeOO7S%aEqx%Eu8?So+ delta 792 zcmZ`%T}V@582-+7cD5Zir%gAdR<;t04D4W|Mq_TvE+*noFEnt}MbJft3<>Q**3Tj+ zhV#1#8mq2?gh~&(ekhnAEH4U-gf>_|k{1cVG|DJe&r1y==!KW({l4${-sgG0bD~LY zG^xEW%5`Jy=CHsR>)3s2aW&T4HS2Z#SgN|WqHd9!8yY&+zl=zat7oD^p&e~&mq!b# zGXHSgGk!@gxbanz* z4)Rpy*2RzCB`$d-Zl}x_{BGV7=-W!x%Cv#u&uc^@>qKj<;AaDFA;;eZtS*|EHgo^z zgweCyz&ul#p$0S*al=Ml3b-99EX$NLhniwUp;sVENUjD_1iv(QOVi(WqjA~(N9F?b;r f+7+Np-6v;+iL9YE2(bg$O`{1RMNoBQmvz4YC&ajJ 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 3c1eb991e78aed12fc41380f0627e8e3365ca57b..c5a181263b89fd4e03238173554cfa05ce2fe5d3 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PR7usw?(+(aESsYhB^3pBYAxm7Vjtu%?bfr@tGrupZEkVuXJs_m zEaKt82vR#a-cwRQRQC9RYg-;UEL`h9SB2}u-OU}IY|NZ23``8n3=9k`o2UC6WCZGo S^ji<4CUXWD139(#$&m^qmlm>8HD7#Ns0Pxm><2-Fkl Sw;o7M<_s_fa%=+*GXnseP$tp< 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 7367c50cea60881d2003224506eb3edd0cd1c43d..4326e81b116b9893ba98fb4626b30321682f698e 100644 GIT binary patch delta 805 zcmZ`%T}YE*6h7bfZO(6-v*wy+TWe^^T2aHKMxy&Rq_9|77cEHEg%Lp%IJ+nk#iAd= za4$g@lVvx7(T{$HMieGQV;4aogLLah!7CvmvYUjSV-39Nz~Om0=Q-y*=Y8Lvl)fjW ze<~}L>k}8-B_eXT-cIJm=9-5dMF(q?OhMbA_&uJ^pU>;nh2G5{ws-II+_-+T+8}?4 zch#m2`!0LlpSiPfBy?9A^_z@x#7ZQ-H?(Q(fhv=(ewQeW2gGo&ijT`v0c|N5myHPv zQQk5T@-|GD5=9k^U1eu+&LY-eChFD^eS{x`v>C+POhjqZK*%TVJ&~=g2BHO-Xc5u4 z_}1h!+((UBGdKT`l4_|jdTGk7%L$v>sDBq55mEJo+l7bp*uRbC6=~{BNsMVMn`xZu02VDTzJ~1zug%%K zMff7Y{c-dxHn2V`d(91a6Q*!(b%QkGMec>YTdp#f?}E8$tv4dpAE9%wKL7v# delta 791 zcmZ`%T}YEr7(Uto z>U*MGH`-we3yiUCXB(55vD2OW$F;+;%$B3ddby>cp>yTyu=KEcIyxBI4$HzN#Av0szoP>eiLJS^1*;I;w)yjb*R}7%eV{cT&*ehh40UQ`BBz!ihTgO;hm+)En8;?=*5vwp?^4K&P zko1blyCU$i&miqxcrWK(av=igvZt}EP|oaYjuC|(fhcL^{C;k6&CQ!?=ZTuJ?;>L5bjE55}A!>>LXN`%CuEY|<;M~W!+$FD{3%d@vsecqc*i?%;9Gmu}4 z+JU5Ds*ze`4Xo7y55STcxB&Sopc{PRm|@of?8CkZNP|m!b#A*oj*}X!C{VJW=tOE) dfL3LvoD-6HU2PCzyRn-^6GDohV$UyXegR{qw6g#J 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 04bb8f5dda1eb9bebd31bfeb1730bf471e71b449..7493434757220654eebf5978ef8c7345e622505e 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PR7usw?(+(aESsYhB^3pV8igu*j2^p8@_q1uZ^{dc%`Hy-tc)g` zMLawhL24(*drAsy?NGK_YwF^-BTrRimOE4X<_=FbW=<9cCI)5(1_qYR(|ryy0`)}t Rtp`$*IRlJ=9NU1y%m8WvC653A delta 117 zcmZoz!Pu~ZaY6@koh$Fg?(+(a%$uVXB^3o^r1o@JR&Q`=G2gII-otUq<`$=ZRz~B^ zA|4)$Ahna@JtYOAZKYaEjV+w#$j^CH_l9-$<_=FbW=>`XCI)5(1_tKM(|ryy0`)}t Rtp`$*IRlJ=9NU1y%mC}3B!K_` 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 10b3d7d1cf705b3fd712ac76050ee75af97e0143..b689426f223bb71e2ac5fd10ad628a3ca9553180 100644 GIT binary patch delta 806 zcmZ`%T}YE*6n?+$+xGQsbJn)zvaPjR$y!lEM~%exZCGKkvMyYZtP3N8e!$s9kSG>f zgyCL-h{dX#z$nu%*&>P>M6!z@5h0!Z30?^ik=-Qp9BbfB2M*86InO!gIq&;+Wwc!x z?GsV1T9dliDlo=I`!<9h)x{$Dvp(DHy_#NitsL-p+J8Q)Rpz=kjc@DR=egQ1!Hj;W0%<(oQsHsjEr?^82bP}2x(J@H%p9VrGbc_-yIUoO*+QrM8@V3 zP4aII4&8m!7**q*A3|D@3~$F<3U19Lwd zJF=8XU9T?+BgZx#5^Sn(u*cL;)H3!P7kCHWsE2Ie1TOU){3vqg|5mbTU=5xi19#v# zdf@Y#rHAIpyoG<F4iBQ1;0|9z`=)%Eg|NCk_9dzu8xw#_>J z4f6tNm6dP+ jrM5KfI%uoa9r7z7JtoB z(oKs>U9`&_78qkE+*{)3_H_nQ4XNemXK7N~rnELT9$Ei3BF|UP#fCyVy=&J-i<-Ll zV9Y&sRWB5te)t}r@l6P`tp-{2n;GLX4+phTwWJqRUd*U`%2ki5w4iDmu9Ko1F)@}m zC4J64&y9?AD-iuF22tm*7p-9IHL|@D92m)N0xluX-vz84G%;=F|IrDf zXSsoSt}06nXei=_jl2|aInr2`Dd!Ki#EC+$K$Nt0@esE<=>`Qkq#z3vG#y36r0tNG zgxTXwAz_o&eD|`+^F+tk50SAHvP))cKk$Xb*jZ#R&W3*9WCdUg9)A*P!^gOU{8YjC zYDW)$cA$axWv&RSR?JLE{KliBmDY2kK7zxQVIiv5qweaLS{ z?L^Wr)kr0k+=8Iln_HavSs6_> zi+Ff2g49lq_mmU}V3&%Xulvrm+cM^q7Vo^Xn>#$&m^oP(m>8HD7#LVKPxm><2-Fkl Sw;o7M<_s_fa%=+*GXns1l_m%P delta 117 zcmZoz!Pu~ZaY6@koh$Fg?(+(a%$uVXB^3o)>NtA-7YVvfc(O5bGBYqSFf%YPFmImjbC40J UC(>^{kebXHU<~Bg1{`Jv0M&6Pf&c&j 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 05793b1434cf4fc327875c2c52c60b1f5606ef8c..759ba9577f9ff538820e9e1566f0a035ca5ff284 100644 GIT binary patch delta 806 zcmZ`%T}YE*6h7bf?Wb>>v!=~yTWe&=no`3?j>Ptp6c#h4{QLCYHf2Q`!)=Lcs@?Oi0SLzDI=XQ7gcw8Tz>0R@-u6vvN!ug9;I{9Ow zt2({Qd)ocx=+%`&p=;8x�H979#O2(5ANg9Y#(4MlqH3i@~6SkMlXdIu}gH`lOkt zU>*p00%J>vVhYACvST>s5et}zx-~@a;5#900`WE@QN}nB@`{`HWlM{WXhtTQMKmG4 zHraKzQDag~TfR%Fu+i|VE|7C+#)UQ9sC^wD60z_>mkG0L(5dS4dTH`b|L!9=a}`fD znZ;Z<=wd-dN=5&ndrV=WOo=JN6FDp%MtrrbuSg3|7~)K0-AvPEmsJ&5P^KdB}OJ!p%Y`h&? z(yXr1=cVC&t6QZqwR*76+?3Z6{l*1ehd1jX8#snbJr3W4+=;)HGzqN16QtpGJVzgV zR;rma7|-=Td6aSl)u6n-G11W{hk*ROjfl?hiirtepS= delta 792 zcmZ`%T}V@582-+7cD5aNTsGa5TG>ntGO%G%!?8c@Vj&IfLW7OEkh(EsNN7;4pH)zd z&F>~?t)H79A<~1a9||@QmKOy@K^v?esfz+hjS_;@^HPHddg0}Hzwdj#_j%s$oLE{L zOKb0na^vw{B_c4!^4^x@)$YZf^EZbNDS_}8b-mo)+`MPy+qm?wZZLMI zMN`V>*!JAWSf32hzhVS+0edGjjJ-y7)_?&w?amg!j`(!@vckzzE;0Cf*rG>}7E)$Kc6Rop`9}BpIB7YaKbkW4LS^P&Q zf}Yg|%4}_p8qiS0jTm_);Ie11tWu74x5bGYzOd#jDUYk_X?iDQOc3vdYg3Xleu`0CtNdjco*SW%#4KhcTQ eE&{FUb~z_Z77PtRi0#B~7EK5#f~vi+p!)?h%CztR 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 35b42b30d4ee8ea23365e608c267d76b43a1e7c6..eba809a4623cf3b2d8fd1d912ed50d520c712996 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PR7usw?(+(aESsYhB^3o0NKf)U|HD3ySc-YjhT~$fr){cfq{W#^K_qsj6gk+ Se(QnMWX=F%AjdY~Ff#xrG$|JV delta 117 zcmZoz!Pu~ZaY6@ktt;=w?(+(a%$uVXB^3qu9fBUOTHWV9@xS>k#h<+&Hn%wSvoacQ z7V+?41gV`I?9-z8P38%xdY3Y=X8iDFTW zFx*Sf#bVh_U|{NJ%!r~!f$SnEL`Y|Ul2<}RWH%Ffjy3S61Bd73oadbLocDcuGuqya zc2tyWHYP8}1;*IvQn8d8>1>;be;XBtQYLki>~*=iem!jrE%t4Dzq99{>*kGAtxo)$ z=&s8g^;~hiJAY^MSn#ee?v?an#Kai?;cr*tKD(r8+{5Q{K0X|<({Uy5Q2AsvzouN$iJPR$HAhnlo+V`DrTI^{HCc0D@Pe%&R^Jsdc84ri*O zsYZn_hXPI#RHoDnoEaes2_;HY=I-!WJ`wirAbn+8Xx0!T8tEn)>tVxW!GSWF(c0w2;wu zWJyKcqAv*JC$}CEs@1yTexg+wdIy z@FmUaL-WL>nSb0@$xr02;*r()+#?;b{QC3mv@F{H_pQ2A$BR!Q6|CfkG%=R#Sg`#Y z<_6L#>){4?3xt?~RtU5LXVAU^*aWe}sf1VyFow7ZNNa=2CXuh=zuz=CZi7*c2pNv6 iZE4yq&^D;M<(EQwO0u?M=w3vhp&23BVbw9Up!)-nkugD-{wOdM+F*T1{YVJZC?QxqFExmu7hazCob#ObdERqxG^vdy zwGTzPda%_T78qlX6E7AQ<`aiU9@wU42V0ia&2mF+?UA)_{nE3FiD++VyLa{KKtWYz zo(#K(ujqyR%TM2j#(Xz~@dkq=`pt~-v8O%ifKt>83NNG;KI*DLRh(ATb=L_|ikKM7 znc_a@?s+3)Z8AjviXPNi?48#z_6FHh1`dqn;y%07ZeT2Bi2H2(oyVm6j8&MgcP7GTl=N|7(eRo4jQ4l6TLTmXcY2yV;!ea(>2ngvs1uQ zkf##2I(G6tamg!j+hjiHck#wR=N7V7qILIuT_qY>Ct6b(KNoNbIsQIiZKjE7Gxv{9 z7(Gi3%oF7qYCuB~H*Dm^fXk7>vP3z1pnixb^a?~tsTU4%tCMa}kV6WxKta<{L`>>7 zX-*hFz9S@TQ0wkpGI?gTjQtQ9OCnn(#`XbU>lizO?7&&?@0%SK~W3oQ60bjye}RS6S7$IzdtFWI;P%=;1{RwXu7<&>Xz((WF{fM z5w#OZ!&D&k$VynN0v>`T3vdzg3#tl)4DtW 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 3bf695f262acb86b53c95166fd917f146e6fcb0a..6a18e4bb34007484afdfc72c385e65cb619df3ef 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PWJ%S=?(+(aESsYhB^3pd1%J71O1LO^9AFflMQFfcH0p6+vy5vV89 SZ#|Hj%o$(|m{rJ 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 86a27e389675303ab46580b452fed70994c13b6b..47b954e51c2dca71f25418b2caf778343446a410 100644 GIT binary patch delta 806 zcmZ`%Ur1A76#wpax83gUoHf@RwzWo{=dr9bbtbs2bIQ%}&`JHoq=li~{w7x5? ze<;e8&gA(Pfic$m)p4p29f)SneH(mtv(2rok^LS|`_Ct}>TLIhw_7@QdwQ>2tulz8 z5*^j)1HKEMHz#kb9SYwPhW(OJj9M7u--FFsOTa1VYPa+0T!3doPC71*1+;}wLNq27 z#)?XR*c+T!!B|Yj*kyJa=R9ITGh>}P#@@sCLE0qZ%@Si7sXy%FcLqgElYy~Wk+C^M z6MVkGVYr7Hvu57)LrAHT=~dnQs9RUyR<&OLIzGf>>QT2Dvun_)>dRJP>VDtB6F5^9 zO*JcgK@GV{P>E96cWi(tB$OyInR_G0`J;$`GwCbQ)JapEXr!BHlxqc+tjIq{Y%=Xl z*`mUI(a@d*dX^ek9+!<$16qYBlv~~)gLsL1cIU=R#HGt1Zbs{la+{Y*$w(?0X(6NS z$dZb-&X^a5kF4J>RA|-N9;G3#XY4mF@HV{B2-(01T`WrR`_pRDB*Yl4e6)cY3)x}w+b;j{; zm={Q^tc083jSyl5+9A*mETDZEupVNGQx35tD^kk$s3jUc~@|9ZK}bsdZfM96Sl iYD?3ufwo%PCch9;&Bng6A1i6herVvRA3=W%84?;4>%$0& z;XHqW#;RXIf}|H&9~4Xwraub$f;LzmQbB>BMhU^{d8t7Jz3}q9=bY!f&-0#plNoI? zqrEH2jc2;dae*;58Qc0|eyKCaKOJ;;dYndequkcga$xn_u=KEQCOH`099X$LQdX6@ z`(wVbOM0R7cN0IqEz&P!pk{@Pk5V9Rb~}+&3jao5+=rq zrgYG?7b3j^_z5`v5NC$zg>3| zB%^8$tO~pml=aO{{RcV!l3PMP?b7gJekjx*F+z14dT)5&E|hMkdQPCGYoteK$AQ%# zPgQPX>ewW4$t!WYWxf#d^7e3VGg+(B`iH)*5RI%8%~QiqhrL3PzYAMCXkywd{-YB| z&uRnnOl_VT&``vU8+j${b!4%uQcmr4j}nDmfhbw^+&*q~(G3c6NI@1TXgZ37N!=tZ z2-8QlM1^%~>zxZG|Gbv5A0lHJWS7L)F5q(=V<(Y4I2-(Zla+vOJpOg04Ikq?@{5M? z<&GGCy2r_Ta~B0gE$1e5{OY5jbW|Ld#isxLNeR{Q_>BmDW%ib)FL0xE(f&u~9^}`f zb|Gn)I;0+14{Hs;{jg*KzJh!$&<8$oEU;?@_F>-)q`@V=Hn-i8!bv?=6e!tGbRxAY dK%2T#&I{uOLqh~&yRn-?6GDoJ>L@JgegU6svZMe2 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2013/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2013/ExchangeDkimSigner.dll index 6e541fa0580035e3f393d8dfdfd47044a309a9d4..a22ad49cda6c1fa74aafc8d4c29f33f6db979f66 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PWJ%S=?(+(aESsYhB^3pX4Zh3pD{uDS_BgpTfv0oB<`$=ZRz{P} zA|4)$Ahna@JtYOiyeB7!t=i(;H`{Qd^V39+%^jX>%$zI?ObpBn3=Axrr~4da1nP*_yB(H>s$ZisPjy3S61Bd73oadbLocDeEv)cZw z_K7IhI#cI51;&^?#*_B^NF;r`u@L#%)uyhO{T@%x&u2}_!ocQt+xyx)SFc>F(}|yw zz4h6Hz6+kWCvR>jgl`GMen~Gz&5ZHy!49=E;FL5?JNaBO!1Ey|9hWBp>QX2v>Qg4h z%BG>PH#oJ1vAB$}tLzlcCB%Y8#`-jjy@&6Iv>C)ZB*t>mP}s-sJ{HX}9b*e3V~dC; z`L`B_?mlXas&VfRA)`o!^JA~a-I{4`QJS@H5(OStj=7DP-GEMYUv>zy57LKD;7nCC z)o9{NO2|!uDwNuE*CV2kP@=?T?u{JhBN6{L(pRA=Glm4wNH@_a*A1*#nSYL0W!jsv zWfS*BL+wfQtTZq`ts18Wv zrA+EZeMuNTy6J#Wqt@pKO)VuYW502Mci^ph$OcZ~QcuGVBX{O+C7T5{;0dyD2cBaP zzNlGwXr3Ik@DIDI`H|v9JhD1he5gZ~Umokt$fEOq->OG-z4$0n!ScjCO@igR=N zIT>*6nm01mu0r&$=tG^u-dPP}uaV6ra9}K-3^DkHRUa}ed{DD5xi#q3ejYr;JA%DoBUHDe_lEaPQsGXb>o{tj3n5zzO-!5le{`bg zS#DsNtjJOW8j844BQJ$K&NP-~%BlSg!$hH1AWB-CYvnc<-Jl?c6l8&drlW|N#TI2w znmD{IBCQkkcQ2TIPqmEwkQqxM+Z4w30AJ`BJAv%NS^w{wtN?7lr+&D_@X_;1!PI{wH!g#3Ec zE+h?8iPR&jV67T>0G6!4SCFp&dch}-6?SdF9_(9yG`PaoW_LOhIH|&l0ww#2PNa4P cXcxQHtTdW4REHt97rPlWA*2WkXKqpV3t=d>tpET3 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU1/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU1/ExchangeDkimSigner.dll index 9b6631b134fead3508d46dab73f41aeae808473c..70cf0c6e17df132d033f47ce2db852fcf08a4d86 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PWJ%S=?(+(aESsYhB^3pp#^3s}kGsKl;jDukOMLz*Y;JMtXJs_m zEaKt82vR#a-cwRQMCAUKoBZMKtu_(Y{feHi+T7vE#>~mWz{J4Jz`($=dAiR*MxdTZ Szx6kYgKgm>B>IXeciL delta 117 zcmZoz!Pu~ZaY6@kjVtfQ?(+(a%$uVXB^3pj(w!$c{NCr&9@Vq<&ZBE(n_HavSs9Ht zi+Ff2g49lq_mmXae*2Nf^?#hsi&ySF;QnLF-OU}IY|Na@3``8n3=9m+o2UC6WCZGo S^ji<4CUXWD139(j%Pjgh9V#6r&c#`1fF=)*Nt3y6T;LCKuq@kdux}qXBI(ln{+c zg|ULt7xo6nS1}foF?NNW!#R&w(9Bqejd zJF=vrZ7}AA!4n$~3wEtC+pW~)^^E<-1>S|%8zCDwj!SKYA4Bf^-%2(Otiltd;SM}U zH+(_2{LnlxY~>$zm-43E6+E&wlj}Di%dfs@PsyV5f8VN2bG@7usbFdJzAnx(Epv{4 z!@NLRWi{LcuZIvTunYprfD>q60<48t;*>(H4H!q<0;IJ;Wy8p?;lEyQaoqyLjtCi! j%WY}eP0-eAJLFeFYD_9?z|dWYK1VY`vIClHY|iipA62iK delta 792 zcmZ`%ZAep57(UnC-EG&+Wz$Wmm94}e1G|{iXzVL17SeG2(7;hYg8mpXBs3z{hY=LR zdHw{ARrDiDi1a4QV$lR)`JPQ?ep>wQb-hfAt5 zJ3Ze?7_czLC+_#F!-{4Q6kf_GeB9lLN}EyCviqPY#mtNq z%t^m%^D`4;T{1-fihk62?47J)>@~8z8XOoaB>fJl+sIhjnDpEEJFi*)39Bey^g8rc zK{BZp-?G3pzidz<*$;B=1-Aw~x-Ucf`MyA3$OP4m=)G#bO(@<-M2?`QYoteKhk=zK zPZe%M;?Qm4l2_t($$T#0=54{AHDs+q>l^&KL^QHawDxL#Jm?k*{C&{YK@-zv;UAqS zdR7`(rfPE3fQBM&)Wo%*+nL6)LOHghWrQg73Pee(r*?9ii*8VmLkhA$LDNyh%<4L6 zPMAEfAuOy=n{S;ldmrl<`yn!xLUu}wZ3RBpGj>+VL??BR^L$ zzSz;tpKf2vdopJQMJ;8<_55OXFc}udWU=voe^N|!K71>JugzSm>h)b|UU2-8xd-`` zs9i`JrWR>H*1=jma2G6DfiEFn1N4AT94qYFfW6qa0BLZEmuELQ6F8~EiUKA3iB6<; d0ccmZ$T?vwZ>$eNY#VknXhKL4Ql0q){V%W?yD0zw diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU10/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU10/ExchangeDkimSigner.dll index 629c4c5a6f8a51955f6f556b6e5c31932d4ba25d..aa4f6bad9fe2fdb0e5746150a6dda102a4d46e9d 100644 GIT binary patch delta 3928 zcmZ{n3v?9K8OOhS@9gX&yOW*WkOv8{8$z<=oe)bfV?z_Mg)xpg|Os-rx0)x zDX8^P;%F3~JUo>gpc*4Sk4k{jgQAtzR^cdz)LPF`EZS-jPl^5CyF(PUb54Hy{lEL& z?|$>m%*{;4PS&xLZN5WGYg@ax>+THpX;;re_K?L`j$=t9QHHgxI^SBva@ZGECyRxT zEF*PPft(!lei6|-zaV09H|?~-d}B<|ENJ*lF4|IIMKmJ)M1`m28lqMDm;x<3DbEoN z5qTnEiD7bhByZQS7H?hWw4(Sh(*Nk6Ra$QE4%TLs7^(0a^45;~$#c@WN-m#XENBTXpGQ7l zk=b%Zv!&lnt2i!xxv#--9|jYwUT+feJnzc}KlJ5H2qQ3_Ai5rAZcA$dp2g^D*#BoC zq9B%f&aSA&K*7i~+}dOKV7+1tH!hrLy=N5SH1x!F@V3MbHoH&w$1#ZU=0wbBGgq;! zzK_jEMC?m+ZG7NsaG_7yd%b5tzyBQQOW=Z0o#MxdPT17}QzX+wSCTO4QEv*Uc{0Gs zT3G1%^^_#)I`SwRoB^KqJScME`8(wz!zH{B{DPH&MJy>Mld^1ZJCnn2C@yE?VQ2D5 z;ICN~=;D%zu;+%*RN9oGZl%hbWe1HVB=LDA`F%5_NLYLF{%2rFBYez#b;k^wVu1h4)X$ZY)EYuLHf*AvyHpNF#2jpZN??jv27A{kvrHeQt2Y4{8OA{M5)xJ2CpB9m6wgVSAWD2v)`HQ&Xc*4yd@_oreE zZM4-9_i3nmZS|h#YmrUew)&UnTc{^&m6h@^le3meX?J{#PU~eF{vq|9N&A>B>Q#e`pYzY5Ep!GC3HN0^2OxlTr`0D z%w_OA<=$3G<2(JecoRA4Tti{rfP%x^AE>p8GE!pFf6l*!j*)!! z$MTm0yTD)J{7d*g(F+cWId~}dm}_VPmt_v9$N_rW>4*KL?-j)CLgWDb!{?`Jd%9H&R@*NvIe6Zywg1evwEotk!gVjTEkbM9a(CDe3hY0WjM^*v>RC#B3H9A6`4h! zC*F<7g@Jaql&6?@S1dtN*~<@Iy=(&e#`yyHUBc_EpT32sgq?vsh3%$8;6l%zLCyaO z>*AH}&)F89Vg4JQGYQ|Yc`DC5c0c#iJT@3`@NImAE697WH>ZJn0-5|y#61dpGN!d}9Ua?Nby1N>6&a(;~8C~pAv zxYj^D>^^NZ=C;vlp09e4WOt&$Xy?s*2mOYhMTTxL-T4@2LUmO9Gq8&vWih$HS#CO? z<)(NR+iwYfkMfv{CekO|MU&|iSf%V)u*cFX^q5vi3A7pv(yd^+@{Fe6!p@_E;5a%3 zUP5QVY2;PD;*vX}5n_|D>fFcvpA6A^AxKy!2JVLQkyi(8ZRxjI%iI2W!4{Nb}_Q*s$RQVewoUWC zI~(74>#0Yo9-aKRdj@7yZjx0`ySV;})*D({>u-*(T-vs5>B_>kWznYA=*s%a==H0c zZdlpYT0irqwyM?F)mw9_j|KKEliB0PacPIT!pZDNUvtfDW*M_O+!~ga{nPp$oYl`z l+oH=}6{S>crOi1F<(@l^mGxE3eUtH1<$dP-)2yr5`9Gj6@5cZD delta 3816 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 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU10/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU10/ExchangeDkimSigner.pdb index d7b75e5a08263540b74aca778940cb51f51ef49d..3c246c955f1e4f33bb560b02d66efa3298c4cfd9 100644 GIT binary patch delta 9257 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 G&i)VH5pk{n delta 5008 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 GJpTdDvzh7u diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU11/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU11/ExchangeDkimSigner.dll index b617d2ab40b31fc7003b0c17c6872f3f80016936..b7204b327dd621c43cda1bd48e225ac24e334b26 100644 GIT binary patch delta 3928 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 W@nAl4!Rw6gtr!e0y1;rTI{ytn6WJ#K diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU11/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU11/ExchangeDkimSigner.pdb index cebe2eebec17342ddc0bf78442612b8a69c5a942..644e27f39592ef333035328fa9003f1cd1e57676 100644 GIT binary patch delta 9257 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 delta 5008 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 Hobvn!GrOE! diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU12/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU12/ExchangeDkimSigner.dll index 7950b83af412d3cb7da78f6238388e2585ad3343..085950077cfa8991760b5ae05c1e626f3e9e088c 100644 GIT binary patch delta 3928 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 V!F!ip3G1KW{11Qz*L(l~ diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU12/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU12/ExchangeDkimSigner.pdb index b79a5e5fdbba89e35458dfc46dbde2c9f3c6fc12..c7063cd279df0b33a8b2efe312d4b29ede48bcc9 100644 GIT binary patch delta 9257 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 G!TuL2m2si~ delta 5008 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 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU13/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU13/ExchangeDkimSigner.dll index 6030e9409567470a245c7eb6b57780daab2d3a5f..d7f5bd9998c732462f44fc84d7e0db1cab799495 100644 GIT binary patch delta 3928 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 UdDX&K7=NH**j)Sp>!0HM4>AqaoB#j- diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU13/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU13/ExchangeDkimSigner.pdb index 97ec9e06f9f7487bcdcba8603fba47c748dd56d7..3a585051a5d8886dc20c4b2aa712e0d0a756d7d9 100644 GIT binary patch delta 9257 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 GdHw^6vX{UB diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU14/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU14/ExchangeDkimSigner.dll index c24adf4f26967ef603192062e7e6dd8e1f4faeb6..9df9a54ec13a2934ebb332d987b1e23e601a7563 100644 GIT binary patch delta 137 zcmZoz!Pu~ZaY6^PL`l`g?(+(aESsYhB^3p}c+M7{YFTo0Cp{uTYn*-#o$d9}_1t gP%Sf1HS^}_J_i|r=0y6f2U3$c1B`(j+knH&0HZZ2b^rhX diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU14/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU14/ExchangeDkimSigner.pdb index fe868f42a2669cd3713ba028f09655f607806dee..835a38af276912972d6407287f5db66bd023f3d0 100644 GIT binary patch delta 765 zcmZ`%ZAepL6h3#m+pgE?Etl!Attl8fBs7-jLUeZ$gD}d4%_vz>5kX&+FoeXQphATC z5(F)41l5nQ^djqnECtCTg8DI*V$CFfW)b}fl%9hO{L=%6=e*~hkLNw_?Ms;Z66Pne zT3ULcr%NKDw?pNg&Ol@;ljGp7a@i{ZZK(vlC_Q z@jyj=CXXnrV(c26g8u&kD}9Q zWcbWPw_rKkM;Fb|T9%|iU9lCM$-H)((n8al53hJ_AKIk~Y z_vT<0d<>ieYtJ<(7%QCM27D*ZK~H_EN=q|pNp4>rHYu2!(aJFt+Ir~#bDUeCcg@a^ns3C)7Nc!eRD6EAWF_QOPC ze#c?)rE#5zq%Px)jk(mYMfAUnIsf-RbsMhnuQI1DPu?@-(W}aZ5*{H&rX1BJ5KxT6 zP7Kz-X$&a@KZU3wa1(evxJZ1TYIemTaRW{axMZ>sajyY%*=W?M=?Qrw1RG$8uI OvC431kKvkLu>1q~GOEY` delta 738 zcmZ`%T}V@L6hHs%?(4Rj-d4G33r(bi1#7HYi#7LAL5560kT7Y2(Mz!h5v8C(7C{t~ z^H7l0q8=p3(%YC~2@cjbz1fR#g^aybWRWkmItLs0(t#i6{LlHFPyXpqV|vv1SdyJ* z4=OzZ0DQH5A94?_M=tcfS{dB#KCf+&J@xgi-+vC8XVhFem1t~PzC5IBzT$Kyl(}RP z3-3xR7bhY&#H7b+mJTTZ_-#*z*5h+og%9<-A0Gx?WR(kk?N{)GWE!vo=$H&Qy5HLX z+GT3GMoyFcmV5!c8+MGuy_kI@HMg1oN)o^qD?l$Lb&$>y&Jfve1h`4KzYajr)RwOT z%MsbKf6@C%o}0(2XhuWxl_%Ii&$^FZ;k=d{KSefA z#*}s$+hRd{67w7hP*#O@y#L2C(|Ay(ajcJYMRZ!R!Zqv;G%%OfX0C3>axA!$*QijG z-1<4D@On()*xGVg9EsQ2dEtr|6H%}BG~VTC;2aj7n1x4T;U!rH_|g-JF)?{;tULUM z4)vQ3d7E(946v8; z@XE6x*Z)3GzviA@l!#d_+%q&)-)UN^`PX2I8gC$b8-X`a2^PX;oGsSaLKJ0>ilt)M rm7(D_(u;*m5JcoUSG5Dr3j+VVux&a@H3HGLH@7(TvoacQ z7V!vR)B&oEV*mmsAeLcdV5mt4VowH!pkSBaf^Ub@9TsG{uG(~d^?PIej?EK1|1ohg h1JyDERWom%?sJe4XilWxdLT8KGr$yvd-u>akwXI|R>(Y3wVwFQhMB=xv%jj-!Dkg8Em`i)bL*2>l@`Ts;tM|y(n4KtR zPxvc+(*;Cf6=T=nB>eY?>4il7CZf-dL>> zNwfEd!^h!sISbP4Voy+)!lFLtP+2tx!>Wh}^$Hf6uM5oB4ssn|fK&8Bv4Xmsm=8L7 z`Q9ANf&0LDu=ad|q9?_#xdGpabNSoa+!W&Z-0G$F=bX!1;oOvBjCLGzRB|nYbuw5C zgD=B~*^O=1x6=5b2Z!6QNF)FOsn#+?8ApQ45<^Ht{5<%zqd0(w=oP{t#~*rcPT3<64V z*oDCwIEx|0;HMB(0&WGb2bYNNlWnd9ByPZo0hdfRBJMSeE*p({H6x8oDW#oQMiZhh O9IFhM_8P9K1!1U#wU{O zy40fd2mna0yf_ohoojiJfB$f4&#pmrtL&|-YyG}*(LC*#$fT1E(dEH@P4$A}g#JdsaP{N0~$5K2=~_kD5@j6 zB(TyfTSn&O&+_a%R>i_nc}r&%UXFDO1$W1tGBdf2V#n99)7yB09rUdIBCn{lR8V+&K1Jq|3F sBJL~=w~<~fWP%_f*SW49d|4Fu=ap^KQK}In*R*q0lL>9AXKvB-7Y5d{Jpcdz diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/BouncyCastle.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/BouncyCastle.dll new file mode 100644 index 0000000000000000000000000000000000000000..17e4744bba01fc38813632881cc84ecc9142f374 GIT binary patch literal 2049024 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

    5*;c>=$eFKE3_gei6{p(#Bx>1_@K+#j9y@r9 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

    3wZ~p)$sQ6W!5wU_}oHgL!t2N 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­^+B|2qb9$aTdGnk# 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�Th}g+tyGUR?-%5s?HO;)$h{;wf@9>kteum?tG4C;s5htWF*weqI$O~|$1CFMmZ#TkZf_$qeD{+5)?fo|+DPu8xjtw>*t zVzQN#a1IGOYuC8CQ0Pt?4&+rLM@9KY`!>RM(5r1@db#G7S1ySY zg+-X`0(EJ=h>qGOl{#K}8hxz; zth1RdmK`T))!h&3va>SLJG&GV(*)Vpg8i-_c_0DkCYF&5>T>kMR-16kT>UZD1dS6- za+2jn;XyC83V4lRy!NrBlXJ!cQ`Ds z3}5unPP<|~w6k^$CQ=DGl_tXzR{6%^4OZpG_1~b@8U1#p$q;bhoKu8LIu9DD;gy4r zp)w36z^(RQEP$)Mbo;GgIs=5e1NCSsE7EkQzo|K#0jXQy)2@ZUNB5Zi!j3Wcgw$bh zz-55Y15Gbk-pv>^M8O%v3QgLKqEnCJ7P)*QOgEz~)!q&3t$ws+y)|&-daB7w0vjet zc7Ib6?E$n@Xzqw^CHTaZMn7qxKKaZ~tcm-agxZ3);`>oZm`&!_B;AE34*(>LuFR(i8BDlEtcLWneDhJj#hKeFx{$_bXDzKIu#T zA`1KBFKr2UOZaGjY^D4aHOnGzDU*S@B$@5p2Y-DPRqT_$oOq1}UR+9JP2k1_xqFc@R-qFb}Iu@{XNK@D3Ak zHU|jFY?$So5&#}hJ)<>R#;iVNwZ4al;Jd5_M=ezZAUH$FLM#cY+3AcE{M%B5&YoX;~rw9U)|I-aIe6= zst=1D<_uqhYJ#f)vH>h#4Y%`BMB~W`@WdLp%~0@q#9QHy0513u@;9Di^6$5l_|mZ=m&m3A$}KF;ST}d4)5)g zCY@xOG^`VmG;J$NiRWeX{0N#?mR&7`52GABS@pD;D|nP>7QiLD;puE)eq_l>mfDov zz?F`vfV`;hc{cNGq)pf$FFxBb0cDcbb3un%>jQvNi+Yc|+W;ML1d04o-MiQ)#(y{b zP=H})Dvfa#H^cH1SH7I6?dHtQIxho^kaf!ZIvD&lfq3EhXpYd4_w%3SJngj>FGnk0 zArSc+{1SP>K}1?@30JUoNQC`xfN6H;l`P_Pw!z^tgn8*Qnr;-|W|+()9wfXfiVzPX zI#Gmp5HS};hzB%uQ(r)PUV`>GjX_Ke!O>_Aj<@gP`rs+f)w(_ie*@gn%*W8rIWPPP zoILi@X>8mIP9vS^N7*KBK7<5v$Ar6cT)iNV>~zJ4YnZgeqL_�BC_U0+eU|;JK*3 z=)we%%lq6Sw+1FFYoKAH3=~a)3mOn?0#E0_Zs+B_?` zGU4AI`)6O=C7QIZQJnn{qP$=d?5Z0Au#+T>aSau|5&R$KC<9Ni!U9|jKqCwLunLZ% zqA_V=AlagrDI0;n4B1G0K7#VK4F%)Exxa`3#C zo;e$by5YeT=xs)XACuzMa}4g6BID~255(w*JndY^k_2%zJ;V!#3-S+fuScA{`n3o` zoE0ICI&VM>{5|x)k^VM+%Tw45)ALZU6Lof{1!OHT>or>J4eZBjr5Jx3OBGRJzj=io zMuR)oYatP%JK#4wKLd1Hq;D8>n@Z8$I7V9!X~^b#BF`JV6=HBS*SP_XUyD+OI{02j zoKQ7_AMm+Wc@f+#+K+-sn>d7rpiXR!M&aPXynd9QeoH~=nF+pzO3rUa>aKo{tiaOpZdEI`KY3H zJN{VP-T3a;tjsn$Jnf z8EaU|s-Ck3d-T*Q#eD6W4@>05Yd$FM=9v>ccy7kuTk-dH{Jjf*@5A3m@VAPrH~SXQ zrZ)S2`Tdss{z87sOBsK-{BDrntL67^Hg%j#EWP@Q3Qs=eY?nmDEy zNja%ha4xy~v$o}xrDiXer~%hR z49>oj5kfKZcA)(^!0jQR-0Vk@XwLK6tj=mbAc;+kLRmXW{qI5DXUf`_sg?j}@;a48 zaF}_SM!C&k2F>6m!XzAG*0ma;z@h&l00g|{ODpT3Teo`k&&yWsux4I>B(t$0&G;IM zAzVYz5jp0hE)c4LZd&8YRS|>D{?HIECYv=#MjOzK8mlzB0j#zSlNrIIJMUdvp?aiVw}xOaJXUTK`>hlVrI@-|Wu+Xh2k`QZBToU;I&Ggtoc6*i3D*lr4W4`&B!P8!KAUxniGjSA@CH+l z5NZ@>h2@GS9BGxO(pF`Ug$p!nkD;ytf@XOS>g6)eF)yh3d(8Ei{xu(s-HxU+x6Lj&0*?d!dW;HTR3gVsS#}I2 zL3eB%Xg1Z{C$=I}|KtaUWB!H_hUdZYLUcUdDnKLL4X5G7nkF@52QNe#VsI;#9e-r^ z(xSU{2m_buat%D93J*j4_iB2NcW$b>O^(LEM~>LzeTA%1E&~Y8$#b7)gYlkiGa||@ zY*4eg;CE<2z7A8)vxp3~;in`Ii}%#99#_o6>yXozTc)XRr^90qy8fe1$|^v+uU^4( z<1`S2N>g?VV|S?z9AYKs)c?%1UQPm|KS{K3iW$>rTkWK>fRW_wf}80nENQ=ptk^?+ ziH_U(G7-m+XDnSt)0KGi3H!!bluEr)`i8k0SkuwnF`j`*jpv|Qb?mbkV+U&yQW#jK z2`pr}Rw4$-F<28N@{O{JG3kP;84^Bo?w;A6Ztx<*CaUN9HbZ^kM0{tZ4vn0g67uLdqm|6 z{)bY_pHM&7udf5mwt-f5a1nrIjnHLx_CoPdV|PaV=uJJ=hd0O1M$QI_aUDE);hTaT zyc7XtC1_19gYGLMl#S%U`C;{ljnG2!5ge?YvQyvk)0x(GGRA#ocsjv#2;w~8Bn;Bo z9UQ589$XnE9)!bgXOOOhZ>gw9OXp_qWI+|el3~kJ=ns);me|_Rbt*w9Unn>z zoJ=oMKvJOFfjR`^qaBPbwFljnv8D8@OqZpn&gxTMgar-8WfI+Rpk5_#6G3|#*;(P<>gGnBOL!vN9SHgfj1ia6N z`znzUOx1R`9+|=r(0n3;b9FrFknsj{SC$uk6ddjApnY_A(U(D+Pd6|IMfl=C@<)JR zWbklm`5L+YLA&e}bazsn#5mK2#f)JGmjL!CWK6^=_C92DujL2#A|DJw>_Z@b-%Gb{ zCY>qsZ$W)?!k04P$(Y54-JGLU5j zGRA>_VyW=eJl%k?3J>pMa3ELEiyUaYx0$&DYZR^L16p`OmEx6U@MtO#S1a4q-WlMj zdX`rL&mOnh+r;Wf0NCLjXh&9NbIhoW6J-mi)|^a`P&jhKw<8Nao1FH`2)qpeD75=M zE@Z1L5249P_-)W(JL!N-Z$+kZm%^-aCJVrN4cH9+853X*I0(XuLmqW`QdPl9XP8&2 zLN_2U=-Fq+wV+A@uq?Ad^ImYp!GYjGep`z*n7Q+U)xt;b@*Zw>Txy&-++s+Oo)yKDla&owej~rUE`kP2&+j34SrRKb%%~3@Tv^&3c!E62M{|)@n#Xg=V z{|dnlf2@k#X1?I9fNx6JZRXY(DaZ3MX0A=lTFWBoH*B@;1|<-8a~yZICBVY-(8}2- z5N!!42?ryXp0H-r92X#mNu)RUF%z-yBrb9eZxVSV->hA#33j+HE~b8HQAiP^3`WqfyX=Uk%kGjaSK!T)(+3*20MN z;!Ddh2S~i;+KRV~R-?~qow*E5V&eoCx-br$`Vr1n=vYhIxp7)q(}rfJ0mlh4*r*3U zGMfMihFU~0PRHVTFs2g*(O*{TShV3{-Wj*0qBb*xtAv`2u)`za2kBXV1D{rT6tV+r zNT!9Wk>myc&KS_!O`V3dEB`qsF2(Ny`1=X|zHD6jqrXA;>-c*K{y4i((!Cykci`^_ z_&XebC*Tje`xH-L-;6(=IXSS;CP!L#BJf%K_26&SL-?_5H~caO2oB*tuWq&14gVqX zR(r!QME>E}3)$55ccXg|{Y8^|qzi<(qiDeX#|R#xztqhgMKgC4ov#ASS2d3tekCgC zh7THV-@FW8V{A0vU1M9}Lx?cHZungW)Nxv;gQ;uG^3Re*e)p9H1_o~<)N_#ao065k zj@v?CY3#QomcPl^f09`KMzK2p;oA}`zmDRgPPJbVLM`*+TPNX^78mzc_&=ni{LV)c z%Wuet+8r$UFU({dj818=aovjMBdqTTEcu;RTeVlQ7;IgI+ripk>p?ouVf#7?v>w6S z69=A12FCPtK==)2n-`EW6Rir?6k2|;bwAbrK-J?hsn;f2N5j!1t}Pb{=YlO$wwzz` z>IuhPsT}^6;BNqbBlyG1)0$2nHJv$XdOKPhl6j=IOr3}oaC7}H7;_lF!FT9lrqHYP z)2fU0p8D%&MpmAToO-p^6y4vx8#Kn^c;>_m;@9Ahql{-HNf%pl3Dfnk&Nz{%6KxLL z$gLlYMdiPNQZ=~WH|`IN`$KWVN9aVzABp3rmtv0XYh6Q@>jpo<;G9Xd+Ox=`7w1-c z3;eBr_!H@0XF5)f2)uO{84YMswp|OC|Dd-DM5uJymC??AWVDN1=R=UHBzN~Cqus67 zKn{PXAL$;F2*>?OM&REt{(A9O$6MLQwEKRd z&g1I*lup!{LfnxToW{o5^7^+mqkAYl8jp zo2};-eLW5i7CtHKg)Ri)MVtY(J_ZKrHtE&e@ekYE6 zS{7~-m>vEUaIu6)BLH^J&~ZCiIz3J&2bXNkXbij|th=5A8oZkOmNtth>UaP|U{;&? ztu{;B;S&Iy-Cd26H1ctY%;u_R_^mPcx5;?s*&zQNeRL}OdThc`qtwhX(AK1soaSsV z0Q8*v+=+psdrb|$V?p?x3&M9V2)}nh_yY^VACAKiKT<{T6qx}x_1w6EWIez|&s
  • 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

    8~FZf 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

    O=qdK+mp`KxlbYi%er(sEU|Zy;7XI|7o3s@rcD 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

    }0gR@jp)UXrZ=f?4HIyA2)a8s9~sfQi8%RUAY4 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%0DF$2WVz=mjRl;|?SBdV;#6V1%@ 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
    P`;jW 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�HRZ}0D(Zo!CX{t}XK&va)-oNert9-s(pWAF3` zMzjYY$^$SGWj^Eq>Dd*O%TzlDq@ya3QKajE>Cq$uy(`FLrR{qUN^g@iW(fK7=4E4k zoqkin%i7_fwEZql&-NbcpmcBrviEdj4o)WtV*0H}zj#g({wCdESI%W#*grHQ2pODi zsmPm0(>o}H9Fp!-fm}eyq3IMw>6gijHjcuAE(qK2?W$XPi zLXJ!qX2i|)j!Zi-W1`31`o11gEK# z@cBA&y-}5G#XV~C>dt8@d3|0-F0-elT$!scBeO5pPF1;<*sHdLD{`7jUW4n%b!=6x zbnn`{`f{2|UKiAn>rYj=rqz+_ld4?3_o*%6W}K!{!gK1#b!kd5mQzqZozE^oxda2|xJCOI@ zZ>lk8r_(e|e?`u%@`TS%&pF6)m)9VlCSK>K6s5n%+igy3o))<BPRt)xM&E7GyQ%jf!Y6|bw)Sx4k^U6aoE zeLmN9>C&fJL?m2*^mBcBsvwOYPLp?l$E0Uhq_Mw3J|?|d(^${k+QyCP4T{+PQ|p=E znBHEI%X)D)rcVoE7F{hgFH*T~Oh2hWY?_B@>MO1xg9TsNit z6nU9`hsDm?#-;-mnL>ztF==f2Cq;JHLS}Y1r*|o`7a=yy&FKt5%=X90+Se`VgTtA- z8UG^f^bxOH)A5Y77@UE*HC^=#r?F|AW}qNkt{H^fo<3NC*jdRP=^KiiN%OeRDb1bf zpb?f1dFHf=b^ep|I~u7uQ@9^R5?W+jx-lbS3Exw$`_lf5OmD)Swfobxue7t0=}rCV zg<;zEHTS1`OPXN)e;HGH*CGcCWuB*$I@9lHq@x&dKL4ZXwTi&!e=NOA5v*{IPdl7t zB@}rUCpzQPo{Ts;Po|qH0y=+7cT@y)CZ=aFB38FD(V3Xu<3PWNHN(RnRBNDhy=SgCeNYAJZ<1piaZ)?u-mGlWDcbw&k#S%qUCeLUZW^+G8ZjVe=NI zJt1O0cBP`!JdxA5eTQ=M8;nSr`zcpr^DIq+9jFDH`&}XuVz*+!=0_PBMsI@4Xti+j zsh7HPSzZe_pTkItfy|3EkE}=&-9i_8oB!;kS*-asMx4xxHMjqxr9901Vzlt;*gTjK zw@22odAuT!uw!%I%WSSw%^LU0s?p-j6s5nG^1i3hZ6_+};>|~J8u#XK=jPu_E^fIK zDNX0*OBoq%o~BvtZ(gO-yvyhhfM z>#C|;W=w5f?Kw>)ufyxeHMA<%lsa&Du=nmJ7+ zuhDhnx~(eLqBqs%)rHek@)}-8u8~!_W>)1YjkVmRhqS*p(X+WDBh$0}uU=KXU$5p> zIgOL2SMw-FTpMgH*R@r-7P~oL_SSNB;WU-J&Z{HWpQ>^#a7%4oojFYx~^mFv*EYV$gQ(^T^MqK;hV zZoj@hVPy98HLEJu;rG;*a44s#l<=!Ma+U7&CH#Vs*-L1~`MHi}WcImEtIBoceRY(J z)8xukN3PQSzJy;eGJ6Tl1AeZf8JT^q)2ecPTSuyxTn`#oa0&z{#1PE%=7Z`6_N-Kt!>JzAUB zKu%N1Yf>G#rc~wH;IZ1g`f-{{Uia3KYkXC%75`eBS9eZR$?N<&a{Z|)SJUIQd3EMA zmAsCsBiCtFxjwEV*Q}~sdycOy;UG>^Dd9_Xi)Y$JLPiQ*Q*{s&$$Ok$I zfg@~3=kaX*1wYS+C@=Jka(r=#@H>It&9eDAcCh(qM{8-x|Ho$~-kWZZ*zZr!D+e|N z9lyNb5BU&6K7>ezdhz9e-GLA40r?~h&2?;Fky%^qsNUxcA@fY8-cw|oA z*U~GQgK2$@PLi63=^U2L2R)!Y_;xMrg4Wv9z8~CG_zFGR1!TIR(xrE9el2nj<@QXk z8_-Qt%U{an>~z8aq4OQxfw6Kx|33dBJA&R&f5%-V^iU3z%clqVSEjecEZ;-4Ul4ks zk@|_u_jHTYelNmnl^=5W{I8+YW44}pG}tgQBZmr~*71@#mDAC?Y+k-)zLk7u(i^Z= zPL!)i-g$-BDtDKDR-VxOp6%4tJL;oIFGY5?)A2-(%7^eG?SJQ0dFrJD`}ETTuceow z_5k~x{EXD&2igxv7@C#nmn>}gcRpJ}q(?tqZ@BtLqDO=nABS8hbbTD(J1isZ8T^a* zL9SZqit^7b4*pxws+YCDMaD{b5uzOErv(p<#3OCzbWinI(Ff`S@t?X}kiV$@#g8C= zNymi+x3+SI<|O((Y-=AM&@R6X$J41&8;;mra6gW8_>K_$9qbw5x0?z*U#~yUIK5HB z_JNRm)#YvZBD2x~QqF((_q)5d#uxJWVQ7#Z`rn#P(b)Q~6~C&hP3PK$lruCPnk)Iw zef)FwFCz0R?XSRRZgI&UW^_?rwC}dYr_rt6O1;e~9pMZ8(|rxCj~T32dMi!i=M5D7 zZ@8o78)g2|Gv82@>IMCi!~=s6?Hl9#@7P}n%~U!kZsqsmhpm&h2bAj*I(cH#qkp-F zesR#o(Z3-CKHwnv4!Qgga_vdCajg94zl-8W?IiT@{dA3^-xK=e7riC&k9=Oj&VQE> z{I8?iHdgL>@ekB(mN?qG^lOp%+bEHL_vI!0xR-=T_x1iZ9vOTu!jTW*z;%Vr zMs#Dw%5!U9q4RtvsqZ{azq;+Edy`HZTKz7^>C5H>&fj3p8(5j&<-0}cpPTz08nM@i zUJc0013B+JMD#U)`}xQ~-@s81h%fe>(2+RlpXW=i{?M-d^etLXlkT-*J7nGoTOqmw04+{%xfz^cpkzVppNrgyo2|Un*(8Q`Yh|sK41x{fb7l z|0Xl|Jgbid%xkQ_1jp8^;bTdXun75ca@Bkt87GH z4XUqps;5S!)0ELE(u3&L@mpT~X6QE`hE?@{3y+VqJ_S4B{?FM{K0n>1<90^peb{az zGbFV7DVZxiw_(}5spG1&Q~I4>^`jBy`-jMEu%YPlVD4AQ?^l0h>;+qzsBhoDk@X~c=Yhu~T9487pbJOa{BFIekIIAo=+yItzJ%di^DB}M{IGr^ zq2q_R^fOL=l%t4lTg$y7t!&!rrxr+2#Bv(;6pdau-KPI8m z6YN>~#W3p^A-9AsJ>uxM^KoZi=uhz-{j|>q;|IpOuG$_yUqtj;Z`htzkF8x6<)2gi z7S+eRrYC${`v?7^dM}cz2nRjbMNvBRJ4N4-AO0cMADT~+c7NQnt%af4rJK~Je21S! zFO_k6#3P+&Ill|vFUZjay~qGZd+(%v5bVnD*U%1;ZcfW7>mZ@}TW%d1`olbY+WJy% z#Q*q%)lX!A!>@f_{VwbS9Cfeg5#LYWPvY=vkq%+ed=!3QecwaVr@!#Qd<^;%IwkLW z^}Ms*{P3gd;}h!qh5T&wN0ATwBqTp~5mGPdx6JznB{Q_EjhD@#>)8D5<%u6+4=b2#(`{pHjB=js=7 z`TB+3`TDIlU47+r>pS2Fd5|CRdimCy&aYSWXKls1)BP)J-%rvBaU0Imd5NsAgyxpF z1ebMUw;m|-70Rdkis--4K0DnZb`KouoBn$9WAy5jZ9g(^cI(i7IzR5yllgU+%^NV^ z_UQx9hi-l08TJS0>^slb=bj$;KwpR#$%S$u^wR;yx(wn71;@G#LRUU~N4+86?D-Ve zOHn@5mtX&W`jFmruy%+2Uf(|eofYU7j7^7iW9(P@A@;5O(5L$duPf1ujCx)Gp|n4G zn^66RabH=!^cLYOHjE7D%03N^-zxu_O2^;7f&Wx5e(x`&oPK)Xa$X@cqx77@@hv14 z$tUs1yfDeeX}xeSksImqahGnS&i@di{0OJe8{C%OnRKJa^4aqXkuM*Q%$lkPA3y$O zo4#a*e=Ye&tu5ikPZLaZg+9({M5gB_v&UcObyez@p0ep819}gS5V|j4Bl+Rq_#x~^ z_I*ROr^uXhtj$+4qc{xA?7x>y3)@G78LxJ-imoeu`>Dur+6xlyJVU}B-%Ge^HwnKU zEpir>zx$bz4)%laAl>)wvA+Etna&)R%rEGLb*sC*+~^ z3YF7ux0o+L{zV@WJ$%aR8YS}-z2RZyl5-#EFX)b_>IeC5;B_juUXA(4(RxlKACFXD zrEHuMzM&DmQN~xw7aGx{)Fz@w(3;_Ta{G z(J!sHb3I~RoZjbI-j**kYyMNpF^%O2P5BcWkBsb#mNL7+yrK`tPv^UGcwmm!_##lE)s2+hm7-Y#+a6%)qkg&=wv%6>j(`@Y(5;rk`$$@dlboKk3p=s7DtF6qb)*^i=ogkJi`G`=o} zk$GO{T_-C&@P|C$k2t52Jww`zpS6GQ-WTRKKrS>e`NV0lN=~| zD8fN+kq*Ki@`1je?|!a-R}Wiml&^>1>No;A_+CT@{E<#VSN>*gA2^qRQ1a1h@OqwO ziJ8`}=vQ5mYu(p(E+IPZ#g0@3H^!r!z zn?1PSMt>feb$Fe_`3;z_`RUG9d1c%vYrooH9##Lah@bGKUt!|@8U45O&pz&B%TqEv z_OoGG`}+nnRQ(dk}7-%iK1M$?=1)|By) z{7x-oK|a(+t?xb`p{s%k{;T;G(q%bHM&xq&P#;~`?}LBo+Ktp>J0tBXFx}X{pKX;Gw z?Hhk4<@3+C&uuwoUtaQ)bo~J#>K*GvMIp{fNLoI$57BpM&VQcNN&5Ve*9Yh~ zR@AOO$;Bg0S27=KJ^T5$S3js$DC1CI^65gefS&IXJT&`pJTj}QKkcXQG)v^ZX-Bbh zDTh0!hV?G7`^c=u=L1Sw4jP}i91Yp|%5f(P9h?IfdMGcAXL=5^JGWDML0H@CZK^-C zPib%T+Q=zlFNh1jD8r!#2}6T=_2X#I`7kunZe6{|Jqfq}C+UmRT}Jb+kp8t-Jr=Et zU_Vg8&`i2Y%C$}xX@_$fVm`3a`?lAk`d`J$6PZJG-Cv};HQ^3tpjW$^@sIb2_3$Y?&IKI8Nx}UrQN}=_T!)H_lNcTjUUIo zgJbl(x9FRG5lQu5gvz{n*xLOC45l+;_zJ67sesbft)^$^cc^Uq?exU`0V2{o|Fu}Ll2UVewAAF0y-GC z!5294`?ybE_=B!1FWQCZ#ohNfbBx#@&f&m6#CYhBkB4Y_eDA!Sv|Gf#*L$ImQ}DU> zYyVUrC;U>_<7J1~dWf?7z@0y|<)igVUgso#RNFz`&Y>rl4&SfReAAzja{4&FKcV|~ z_SY{hKg8u+5&hy?SHW?90_QM`+IbNUyY~ATDJT6}-;=hyC=bRj7fQXjIM&r9boauF z_|Gf6h%fddv401DAAZ%vCrJ5#A9kXRhuMBaJ|39~x^C{{r!QdZqg434zkZi=kEOwd`0|Tx<{?+Ph0FJ^(^Bj{Nj=kdi2}21>YrqIlI3h_gzEvs~vsR?~vVvPdA=7 zN7;Q_i97%DM4iWer1#;sA^*+l%g^W6EB4>9KaLRn#A5?29rCZ$FGYQ9dk?{cOGxAT zH+qbut(G*_-<s=R)Qc=b3h^0{$)gVf3unn&oDD6E{&w|`Fxa&J72 zl94?iF857vKE?6BQSUEF`Dx!s@2xup?a(#K;`t}MQf)LZL#MLsVb&X^?W7MaTDPu^%a`Qi%I-k_QUA)jyEkG z)FbN6@yo_(9O35J zI)me`eIWnx+^>XY9qnI6KO}aHe&rLsXM=l#k?E`Vo?xGTxH#{VI63_9;9C?P)63R# zsQnhLAE>|eZj<1mZ?a2$mq2hjr!(8{wBOlL>__;9*}kUe$Jyly{N9MGf3cr(c3)1~ zo0D$~l@Ip_@m=QW}c34eSSKQS`6{~~eR6NmlR3UOZ~GLyOpeUu0H08#(A zS0Xt11A0#o-_efp>CjFi?H^0o{S@T?9nV)Iy%${l{ci3z=sd>$R=$$(lq+u0Oa#$7{$3d0;Ohzq5Zy-_E?~*^l(I zk@gQI?QhH4@6>KLwb~=TOFP8<&4xldp40TA-|GGbddInV=nFXN!~YI_3hw$>E4OQ<*HRr^1Zme<$Lk?jPKI^ zs{3!)MUfo&{C@j#apZ?ROMO+_a}n<6hu!D-m(3FcWIiDNH@zpp<87q(qDtmo9e*K* zPuGuw5A3UG90ff|=lq*|95_Pf{}knKoj>x|3bDQu8T32g(>mRj!$o zJ06JpdaaGu$9L}AbCI13f9J2j&RTD;^SYfneHGb*$WhYy^Za)CQ@87)dic4tOTRtk z_4VJ=9(_6Iu6?2%p?rQguiI@kedxK!e&)C1%Jo^)7sjDdwhoc+e~Z5t>G|i6y!BKDX$7kqK?C-zNZ}#gE{Z$bz<*8mrsJDIQ>BCN( z9nS6dpL_c+(z}oUuebYoQ(oV$5ck9Ret@*Q;`KbVZ@*sh?G<`;yxx&IfkfB25R(~CIHFKx*8fDL*!-bc>qDV)*hq>}9Q${N{K3Yte@DMqt>5LnqsZVp-W?M9 zp`J&ecZvDjq$^b;9Vu0bEw6?t=~7&@TESar1 zUD>S1VS`zdLweWK(_cOwnM?KF2=FGo9{_#d_P*%<8{G%F=sl?i)Yt6o9PPr{{Y8gK ze)N0!_ERfeWLnQ3X+4&*@2l&5t2>&lox1Zk`8d7*dAi7h`Ww20*tLYdU6jn?`u@An zp?5`Qo1We;8l&_#l5osR)_&+c$c1f4zl^Tu6Cb&#QZIq=)5&*d_juQ`b-ZLQz1q?% zn?FA-bdgTpUv}qbd^)XvFDt!lm@L z)mzD2($$8wzt@t_*YnzXz83PJACdmX^)s{oUac>rZ@nC4?avyrb6;&s-%jhNF{_`s z%|EZ|7xp##5a&}cPsV%k)%fiDjleAHo!iaYpPr*cJAhpv4!Z|FujB=tT5@B&$M_)Q zR+PQpzkVlc?{wdFS+RS_Sritf_i>EF&{HkD0Y9We`|xoYKU_PO_Tzr11A1vatgd%S zSA_fHOm)1-E{6Y7`bP*XX@v_zwtu{Xg`m z)UU4>+=uY-BDpY57Jc{S24DCyMfuuF7xK1FFEFj+bFO#rLkPXWK8wPnbKJVm*Js^bqu-n%4H1GHeee}C7#Q3}{pQoks=<4rC==(>3 zS#K@zpX7IKg6th_oImfQbfg~K`ly^sE}2L99*Jwek9D!_6Z1LD)5>~|ncnx&^wNLP zyJY-c6us-E_gj2E;%~bBJ>l!Ud zJ$Fw6^?~oT`iZ0YU9swRC+*DdSCGyRU4Qk{=Bvf0!94bY*WcvgPHtbHzQ2L-2K~Gr z7u@}h)ZE73RDa9Ar-OB${Cqq#ztwuf_=oihUydcYf1-Cvw4d_7W8DYy8vpy;#xdUb z*suXmuolKv8YO<=y% zc>>Pc&3--D@yEQeh^~(p(FK2>Uah$F7|ZtWmn@9y4I5nUhuZ@2S&`TqaewO?Oo@AdW* zdHv0|kN>rPZ@zuld0qAW0ko66{m<_|pqKgmhpfLr9|-5$i`9$s*P)mB_9FH&-#+Hs z$Lz)%v=@Z)%3eTc1g}feyDtrP{vDZ)9F|Nco{yJJPo0-<%prcqnf4K@O*t> z9k;sPYUTIqKTo%sUcL3+x}0v@^v92U9Oe1>%)e1yU*FJgt@U}yk8)S*-KXpGgZ{t| z^(Z0zZh)Q#Kt6mgih~}$w_fi~UdZR?11|iqAMEnw(*v(n@BVo*q%Xoj7xq^j$9bTl z@nv4M>z}LN`|p+;c9*xGfB$~ozq>u<+XL*idc88Qm-+4L-))~i*ZyFByUMRe6}7kd zoZrs!e*S;!csAc&XFr}{+-hA< z^VdD*`(M_6=8p?S>+^p5sWmQq%)g`V=0EfOulfGhyzsx!f8#zO{5iZgD0YT>xo&@^ z-t?H){D0eLo8Mk-|6l!1(fo0-zHxD0t*4-UW4!_6%)h%`LJprl;{NxdcOC@H@ls_Gc&zxm@L!}dC?^WgR zKf8Az-bY*=9ZrsU|9`}{;d)^4;cN|0g9mmMrsOMn> z4-CE!W8D4TZtFPxEhn z4%U!s?ydM&mOzkX-0*V_Ef`byeITlE6F^Xu2gi|hmX zMp&QT{qhv)sYtKY`IkOU+A)4dzUY0HdcSYFfu$E1^a}|6-$ideNzxVJetqoIRpf+z z(cVEH;fUR>9~PKe`3Ew+Qr1tbbhOZy-~X=8k9tB_UwswTkHdd1?PQZRL_g58UvIc? zBIBE@|9pG(`+27a)GOLkK3`zgc|_VN`1|@te!P3@=lA6=$`Ah6kPTToLg?Gm?DJQ* zKm6YPp89TT!}6BC)5kHN2*0mAJqw@ec3Xt!%N?1Ow14;O3++#S7dkXIYrFN+;oUhO zNB;AlxAj8f{F*W^oW6myza^KE@}zs)Ff@ou7}C2Wt$mL&9O;FAVCoA)^YK|ix2WH3 zYrTnI8yfshbv_;$smCDuF6r=|oclfRd_Lfy>*&1qoyad?^>@hO^U22}13K`_|Fis2 zj^c6`mFqt(KlIwai>(*vwPa4=xO;D|t#THX_l-TJ{p`i>3(Iihi30Dg$~*wFu9lJA|aDi`mK^Vy4>1#daqCQ`PI9U?>8NUALK&0 z`}UFi!{3r{g%>3}iuE3tEwmmWAM(pQDm2}BJ{uVHhk{4um|jBXsejopG;8l|`A1dh z<$I*xOIbe5)ADo!P3QOtU596U)ejSW1*$g}ju~v_3C$auikyD@h2EmC-|0N@9(^Ac zex&$QG!7kL^OwvY&J#K^9)>3WJusky{1_+w{1Oi{dXhdcut&sOrxPgO&>TNd%tf5#9l(37YF9A+P-fu<wq(pTgFT|Yg(cb{eD4$VO-H`4oZz>d3h6S}7jlX6J@$h^Ou#Y?Ksvet88{B%cg ze^#AN#_3S~^+@vt=FjZMho&p{OOcWKDCv0X_#AqRltaE_94!^f0snBZg+;HpAB}Pj z*q_}B&p^DWAA+7letJJ%f1g40L*rm7dK%6AsD9b6 zp#F@*QZ_D&y#{7)^*6+ygTE7)ZrZP79-EI>_oFB9yVDKkug$_=>MvCPF)|NbZE^ZN zx9_Cf?R6Z$czN)llCN}~ghTcFoc42hKO|KDjppGs{JL8FME+36k?L^*^|$UQDF@mw z>=}B5{Yl)}K~cTu=gonZCp4n>DAW6a{QhxZ5ZCgdxQUs_Olb8 zH$giK4gCFl`wI>HSmZ;w^YO^srTtJIcl2A&hwnkwKh&zf*1wYDl*qQ6M@S>P`Orl?3^u` z#pfe_X=obvuzI5Yf#=U9b2875X}y8#vB8|eVLLN?rsz}r3Hp5w8k_9+gnc`oKGtWY zy@Y0ao^O)>!2So#Kc5i3;#bq}H>urV-iLKK*ooj#wmt{^&>Mt~d@p6+Wju3!*;?0# zyvT>RjDIfOs4c{AnA7!N@t?@Z?{Y~_V->(P^ z{AILbgzy83*4?DvcIyr2HV9vo-?t~MuYo?se~g!CcU$RrGLV0-kH(vCrTjO2FXcyk zah=ad9O(jsboh?-ON7Axs_Sf+r~C6F>BrrC82cCD|A_DSokqlOQ@cU>!&eu($9FlW6d51C zfZK<|i`vnk&+_d^=tf3x>~97J?Md_#ss7w|v?s`kcIC%`3mw!$l&yyXhu&}=4DHWv zr=TymYyW;a=xba_+5_kT7rndu!XN#6V6a}~+ed&W3~dO0kxPb!lv+vS*3HI|)KFBBjSfu{g zPv?h0KM3b^Kdi0(4Ez}QEwAf-((#XpexBOe>dURWh~C}$eCz%r{GZ}^p5%*k-=UhG zzpqrp2ljL!&wm|1*hO3M`qrsxuVVg1No_uGQke**Km&aaQ+^#nS1z@eM(qF%oK z)Yb?6?&btrAGGdrtc0*r8GkXK56yk++3%4VdzGYvo)C(ih3fyoA0mHK*Cj!BS>0!; z*RHUihZ$gLZ@ReWU9^7{9P@?bGx7E1wSX z=l!&K=ikAv0sSJs4)yT^pD%FZ8St(4mGKYbnc#t$)BSIm?}V9uTW|eio^*-YH~JUM zlhD6lT!4KSg{U8_dt$wF#uPGdY6mj^qy5Kr;(wvs|LyzsSntfY6RelGd7r=j;I7Xsl5=J7cfxEv3VspF5B~-H zeLoNLNcdOZjh6ZcorlIq9CT#8(?3sub6q&kP<)P{XuQEb9@?G1-qiZ~O*?bQB$4l@ zS}*bapB`Opzh5$&Y-HO7-B)5T^bmw$_ zDjfR};P1!57vGCQS-*DYg#0+@)LSmB4pb2@x}v1G2g&-Qb4 ze`;AtC*MQ;PW$Kly;Sx6ZO$K=eZBAgx~0rlLj%5`2f6Y4p38Nt^hf9%l*;oy%Ny#t zOO)X#&vgDC7zvTi`SnuHNd0?vZUpC2WS$;o=L?tN^CmR@a#)RHUN8PwXy6aX`~iMQ zV9w+HH5X!k3iE?G4Y6N_bE(bS*m|SiPv!Xw<|VHDXjfBSmvnb*DD}M19TLYr6V^?! zE{uE>Bf3BC zEak^NNuN(!Gd8Plh@|F8vSVy9HajW+)Fg_I5JM0GaCF`Q@yt|yM!g=H%`@NQW z)5E{Qdev+k$#`mEET_5-Jx$oG=!FY#oQ$5GodOR}cwut^Pp5t87r#ni& zfP3e1{>9y6$9b4X^qgBhU1S6=8R=Jw@|BF-`!Cl_cMjiAD4SLEo=6eDJiP`Z`P#XB zdd~sn#5x1?laCkcN8atA`p|v6e7rcH_=}<0W}NERljn+aZGD7B&K;2+2ix(Xr2b-H zX8*lxUe)s%uqWA1iL(6^tY^;td-Xax(qmrY)5+t=@9Z}J-Qlgv=jV6tU0nB$=uN`v z^&Gz)`1bGHIqXR6mCiw}lehakUdrm*r<1oEcYX_YmbZ`U@4j8+<55o0kk+!P=*bV;x)c9%cISamiOrAAXmlr}b;5 zPw$fGJyoU;in;;k0ZUWN2zDmo)JfS(1AVp^noM2Pv5soy9kJA1EGx!+WAJBPfKA%DTG2g2x!g1a(Fe^PQbf@vXDfD*;L*3_g{WAEW-TVH- zmitIMdzHh$3%n-qjNBPzbsO`WS(F?WpgHl@6N{~bFtDD{~Ps%u)5wbEb)pk$@t%K?+NF3)_7X#2( zet@%2w6p%YZgwT-bKeE0^Bjyv<~$Bd+TP0QpEa1p_#9w6v-lruJvN$d`i>L&FZ3g; ze`LQ$W;*}QDfAtvpF-;yYA4XgEbWiPzWn(&;y8bVIOgYw*ZvN_{p8g|e-f{L{{!nh z2;ry8x}E=?59Gi-Xq<;~?-xlvcW>~gE@v(JA0K1uCoqF_K6Ds|^!r|XjyEueeIVbD zoM6K+i_5xAVEl6uIA>jiW4?oPtm5Cf`?%0E#!dfxqr{`kuf2R_sXv7NdoG~k@0TNv zd;FD`zJXbEy48!bN1Q7MU*YHM z*H16+?39e8bM`B7XTP9}5cE-Qyw}q@Ufn)$KfJH%?RDN~ESb{AmF+Y%J=8v1f1kyb zTiRRwdiCY>>jip;Js?EBdDSm~k6*rPZkF~a{N}!%rQX_J&$w6N+Y#<%<9!s_*9g>a z!n=6Y{VePUVZG(6rEio^(m6YpxSKB`j`!-IXIZDgKA3AS*e}cbTh;b_;nmV_ioV?W zfjmzAsFzOYy7O&C_5iy>dy{fFd(XFP@-GKSzu?!KZ)f%D-=~x3hw`@FzE zdTIB*e6r3#<>B`wTnM?Lmwf%eKd7!xq=z1B*$wOj=RYxjF0!Lwth8IK`@yb$oF(NG zeYNhk_jehwE?w6e&p)bFm^y&NGA&1Y$&*#ez zJ<0Egq8C3JLWPY3VRI(jm1EQ&iE@6!78^ZAR?W4`3R zWB!z$)}NoQr0eT`efx3P7uw5Tbzj|YUt(`= zUV?b*{TPj7?58>Z$LEuuPlN`1^K#I;6FTp}d=q?q`$zxg_bZ@RuOH;MKiu=ICI4&e zXVHCB)gSogak{5EPs-!=yEaySbE=;c_Lq4z@;|VsjKf%e{*=$X;+#mN@5xq=-}(A* z<{_E5(~x2{{Op8fij_`I@H*S;{%$Np7Y%eQ?8 zsmHyRmi`{+W@P==@$u=(JQMSBoDXsB7~?nkLBzLVJEZj?wMWz|>gWDNW&9R?Zr)MU zZvA!)I>WSI8OR~VSA^AcajtqVy|?@xhd$n2`~o}zVy zBD~)929)nP-q(-J3b#wW7SS!j>*e=rK40t3pTG|C_TlUm-{qdGTdzbMegx9VxiOk= z@%o=zFIjp~=@*N>`|IjhKiYHy(Ff@Jap2hhKt9lub-u_zPV{p{a)2K4WBp&wNmZ}^ z1IPZ3=EmGcsI7K@65suaX#u-I)0-a@5%kU^S8lgUh$pR^t$}X z+74LCHw_F6%x-gMs{Wn;vxJT^4$$LhE1F7r-~rcU$OPnT4%>sUKU?h9zCMDXV<` zyKRw?_haE#2IjF{rT<-YX$j$%`Saj~)Zg&^3V*#3^Y7WOv%;@N=+5)PpO^DYkty*# zaX(#Te!=HzX&qL-LtfOUKVO18ZN>e5X7tro&!H(gPl$a4=n>^9>%126A$`O?Avf%= zt@`~=&*6f;pC9Ee!tssTG0)uf$^0_$5+ra*m zdtVJW-p_}8^3F$S9z4_PpUzWgyOcQH_vd{-Hy$FtPY?a%>&r=bkPhRupI+jj`PY?} zZ)85?uw>rjux#4#@3SEc?8;cjn$XD(m}A5x0MT zA2ZV5RVnE?!*aGy1wQi5SES#a9KC)cdTwbiA?o2?eMbuQAac5MUgB3_+;;dmOwYYH z<>!;~Rp0;f(+PbiC-jN+NI!j^Z&~~CV)-U=d5hD@I8dEm=JT}9&GW#rd8n)C&6g*i z&YjCfKZ^25IZ-d}T`ZwT^F=@UZ$y|4ev;)vZ|CwJ`!n!%i9hh3_ z7P`llpZ3%Fyi;KE@krnKD#EMn^^cE>KA+L><;_LzV7%}_T>35Y^VnaleGcvkeeV|X z_3C8lMP|okZCEm!^Y}{V5w(3Go%m;wNuCoqfM2kp#Qk}PABSEbFX|if5#W$#jTJx*qfF z-IhO{zu}PR@p+EW;Qlu1Z6<$@jOe?h^@<2Iolez25ZL7e#u+K|hP@`VagX+^1hx-w(s@p)~Wknb7$7HZO_( z-~X4i3yIUcut|bTJTmWGV!xM6U!|KrM;2t|Y<-_IFnRi6M(0$f8$X;@cK`v=iXgD+~ZkpqU9GElo#_;lyB5O?f1~2AHn<% z;~35b4_5s{UnM?Y;`q&LJ&D}ZPWbnz=>1JzPjLLCo@pI|?-#ldb_ls|=k=uOapPdk zcbtZ`^8HKaX~_4BwPc>sR{qnU5`7=6=N{Xdzo=YdccFP)-+5n) z!u5x{uwM|FalNHns5i7Dw0F@n+Gk1iT+Z|iefjc>p6Gp3z4w6f$o$H!k4t_RpQ-a_ z^c%JKOF04~VQ3!xg_NgAF33^q`xRQhnCJNOLdoyWYheEY=RW;7)~Tfbiu7DfNzb`g zuRqBAa{hPN@6TO-SXZlMN437sD>^cdr}o0{HRC)&aVUK8yB}>ozk>b+=ga)~r@AhH z@PAD{%vb*1daSi>)_Ok{m?!jp@S;2)ip=rv(6B=DDcIi~d@ejRkL_s3v53w;*|20j z<9J|deMkR@d-s0)o(*L@9mn_mBQur9vy$2HEZe`A&AU3j{io8Qe7NU!vEEk_J-Bx^ zqzn4@Z4L&$ar4THisht>f7LdcEM?ezBk8e(&d2e{HRA*ct43 zPTTY3lc-sezx{x=*YEY6j<({x_4mX#X{hTcbU)?@D;K@T%;hg<^46OU_k#R$B+@U_zS9e~zjNoEFpjjfp6B*= zN?|7w(muxk@w0LMvaRyKzXsjW+z+~P%KljO{%0*dSRY>dL$Md!1FMzK9|w^h=h2GJ zp~*g(JBKFg!S1|zejm-9Lz8sw9Gb{m)DP7<-|5z`F^(3^LtsC%55cdtpI3C=TE?Zh z&+nH9^^zaY-274O2J0!Yzw^#stFw1D_;$MbvI^t){w4@{H#chINo zkJ9f-9U^k%^+4~e@VNx{{e6B(I2C|w>7`d-!GTg zr(5T!_5G(BXId{;b-S1TzqsAEPN$ZBtNFB5FTS4rIQ*}@bzXyh1@no^6`wD^ZQrzh z#_Rp{+oi8>KVGl?WgVJ+e_7uh!~U+{U*SAS5$@9|YVV-qw>#jl2gtDxpBr=b+}3o5 z@%|L8r)miLkgte7{B)7iz2AcUnp)vEn@GRzuluCzU(@f;@j66kKGJ*r2+?0(q3g!J zyuRN2{@!1Q^5c*Tp-;a^AGOjAs)2%pH{-3RbR zycYfQUlc#>84j^;jeGmfua@?R-~U8Az`5SY^w52N*ahy>0f)Tkzx?{~>l5WbJDbz> z5Xf`p;j(Hzq-9yfi1g2wOo<*?PIE?-hl5E*if#UX&l}4f*d_Zwhstm)>LH{<);Tk5txsYw#-( zqMxaj2lR1HyfdE{4~&Fic3uzfk3nvP$S)!IxOr6`4-EFTrM}&LE6|gD9NbrP>G$Mw zEP+8-#25XxPd^{0b6I?jzhti0{s?ldu%PrG_Z%$qQQULJz42ua5Pt&naF6T-zTXg- zd$s@Ze@9nv_j|Yaom`<$^IScjgM6~i7ns?HbZ=s!^aE$9+@SZl(#zv?uEa~X*#=V1 zc~!s7S6O-JJq`}h4`JP>dOb7oMS*Zdwsypoqb|n zCF7=BfAi%)|Bd^Eck{bcp`H__duBS`w-s-zy#Fq_ipl|b;lKO+E!wf@v$~%^eHZmF zb6Ov$pVsZNt#(|Ue)i`L-1$%Jlg&?W`xBg3nS1@f?qEL%e{ObEWT*ct<(qH!^VaU$ zs?YxwJF3-A;P)Yff9a2p`FOSeh<*ei^q0?9?T>@6$m#n#)#FD|dD@CYPJ~7MpD%yW zc-~eV`T>80^~%xK^0uyDr|Z#j&%?^2c`aJt?!Tr z^bpqDepcE)KaUcBzPerI<){5u&R5d;TREG*$$Z@37xdeko0sP42F8EaL(VA&2Ia&$ z58n5v*IzxF-^-zU27K8r zV|`xg3v#%5mtT*lul2VT`ES_DhLPE7eH)g{Z`QM6*__zbh7IPkrEJ*F%;0-Vjb#)ZZIM`0xm6 zN8ev(%Mloa!11oawDoN{LbC$D+Zvfkdfy-T4K0#?(6#vx`JZDu4otA3=;H!jAFZYb ze3!c{9cr(8C^aeEOgZd7)>>>GJ`8(($e98Q-Dje7suE z=r1O2EP9oD*`fI}-y;pojJ-sESf9W3X0baTU+qT0-`rd5Z4a%NPxh4jEAcy9k(tQv zjF-%1%&%;=fV(7jiYf1iZT@#*>+@E!LM{U9#)h>O$VcU7eR zu%AKaz4Ttupm#-12}3h_NuiJL=zpaD!um1ZU!{Be8%z3ry`;VnU-@OJFU0ZvUF~NO z`Z)68J3@>@e)#e=R{qdD@x7D-@hkavCFz}~PpusE`!t=!F40c#j=b1wWX|Ds92g(p zobgiC_XYS|WpzH_Mfvjl=y&G1A1s^kx?ePV{$)+yP?a8hr5wd{kuEP^F-SmefvfncI(@>Z@-A2xP`PAvE#_dxJK`7DBij~m$P(R-Yw;a zePbM$^>@J$LO-Zi{En56OaE5Ne&@>nF8PY>4D|DKYTFs;9{!}2yKIJVSluptx{|)3 zDn0DSFDLLk9mfaXAx}{|_0tu}jdXc_Wm6fqWmH-sNKd1fjE2jN4+jk@>OcE>eyW4$HnNBH+uY`QSJpM0D4&zQd;Y#k5HSbeVq>CWQ&_WrpqoaexKZ1?-@ z@M95vw4eAjcz+P@u;3hk_;t?T1CIPfp-&gT15xBJg3mC1ConQY*>9zJk@}gv^!?d8 zACdY({MfyuJ`Q0&KQK3|e#L*L_cA!2!?$F*L59~Vk6#YR3Ax}GgAPKR2hY#{U439* z55NC1y^oaRX!YYHqrxKO=hdL;Riz>ZPdOAP4&At$5x?`_g*er9b!A^!~xGMUH$tG7Hh1 z$qydj#@5GWfk0yi10DZAYF*gl0({$9{Q~r4yQ8sr-mv7K&b0 zPDR|Y(?kyRb89pZIifd^&v8ZO2EKn#GBo*bl&__{u(BARguP>Yn@k5-ugB-uw-SUgFa(%j-@JIc;q~kvH2DyM2y$6MRMaYNr z*gx@c_$7BVi#%c%v_8-MhO0Nw$*0GAgrQj`75VE;=gWb7MRKCN=dWYyEi(0%6Z!`I zBEI;J_k)m5LV7oGOR-O+!*|57{_EqLe?#I@zaV-gduF|s%)PuWS2o=qx8I$f{rr+H zG~)L}nP29ogI~1Z=aycS-N&EPbl5+_`n697?<`Bb;9X`{4)hy&f870!ALNza^^44E ze6Qc-hhAS?$=Vg2AKFFg{b`|yB`10`%+KWe{J;_ngewG82SA6{q|v!-XGuL z2Ym3R)PsbfX+BBP4`+K1w4EcQdG5+mKd5J{KOipOXzhh;t$ifd4SbtDf^E1gWu-^#6ww=0Q{8kf<@#t)dDe$)028`P&#ui7y4h( z)7;AidQ#qYTHZ#Lvq{UlfR=Z`y2}f?QtsMvie1sWscc{HXIxzDf!^EYdMv_AIz9!a z$ev;UzQ6w$_WvXEJnxs$ee_SHA3=M^^tx6^G^8d2$4R2j}Y^lz#PHr1n3U}Gg13p%=^&~AVj|-@0Zi>DYG9G8uX)L ze}URdV5FWAhDQ1`>uOSV4kxMcksj7vyw$1U6M0q^sWlt=s|^n-!+ zXMs6J=kNF~^^X13P}4=`+ry<^A-CkK#-*RE#=!^q;TOz4UPPxFFXHRVjks?o7{6gp z`27<<#Cxvtdne?F++p<_=w{_hU_3X#dj=tdfrr(LYTJ(-} z9?->n(O%%2*uu=e9Lja5}E^76~2D_(^YNxXx*CM z6AE-3b>pgxk0otqWo=(>JQ07S(TvpfKa7(Yujh1}t(CvtakhxgoQ|_a^x8Vk)}kZ* zSnctvmcB6_wsqVtk`MIeblk2*x88BP-g1MU=(B$R!k1J006L$ben1ibd^*}U=6S30 zKc!!a)NiG8M(nqi)o*Rk{<)p{rSyCC?3dQ|hvt;7w4(*o-&#=1*FN*NM1O8v#XO`R z|BfQoW8Auh^urCNrHk!v+L>MUmwu<-aU0_={1TB5@0mNl!XMYh={#mx))(nj{d&xw zFfP@b?s}!SPz`#1y8k2YeBiU3_y7O7?)%=|T}`d+-v7#~m6c)DWUmMtVVYth% zv1vIuiaCZMj6zX_VQHLUhcFBs=9ps`=7DunjzVZG29*^H+ zJ$t>c&-MBL`COmtbA7JszAo-(5t6=tUp>Z9J9~`Yk6SA98m>?L&XUse$@t3O_;ytW_LhhDGa{pHkN5r)5G?w9xayXo?I z3g;uL5ADB>IgmS-Yk&Xh&h_P!;~_l0-nTityT50Ay}A3$tK0ef9vH&sbyklVCg=I^ z^Rk{-wZHu&=lg$>;{EaT+%xW@AE5tzCE*^R^>MtHK5YA^|IhP-55wjMx~=n;CuqdHlzF$K^bs>)<>Oa`VmeXLq}|a%nlzX+6(l zc-;=yKeGM2tRwYSpL%`L+x3>Nw^hjfe%&sU_uuMvhdke++n>?*67Za&tZ%FPD!N{A z*YU!)m-XXzQvWUg{%zY2(Q)F&uk&S%ZdW2qr1MW=VuMa_X)iFuCv44b^QJB?s^_`-|MiO)>*wq*B$hC3q9TOox1xt z|N7i8ufw~~5#2S8_v>{NpU-f;PwOJ?_eQziJf@hQb9RsG@Otcd{5z)Swj1t$9tZR} zp#8@KJ^l}-^R{F5%JVX+?Cw6Vrv9Fk^8??n_R2iUXY{_j-e=eP_;uUveFsK@QcsNkL zbllVX{0H){=L22;I*@-I*MDpM>$=f_;@5HhGkK0PZ77dp2MQN{p3?hYeBaA`9x(hq zQ24gq$J6g!YCN&}yEs`-G;;q*=OH?-_x7Blj`Qh3Zb$PMTP}Ux18!m4?`+_5>-~Rz z?$KSZ()4saN&DAh@;x(EU2j$GZQWYO2_0{BzOT<|>VD0SK99-cF}@R1!sQBAeSVX} z>2td7^Pg`~IDC&)?z?il9>eb5eeT*0dS71a|0j8_M(cwW_vPq0QT^T*ezzjyp8C^p z;rBs%s~-)g@fVcwb%nmCN9$Kr+gm5J3@|GC%;2DP`ba>-xaC0e|pS- zRaWtwsN_$NJ9XE1!|Oro@yo}09+&F>6zLDzFQ2%DkB6V+IcDvD56S&{tv6K-7v3NB zxK@9K97qu0k8PW|aP_AtFqT8|Ia-jB0in@?>=^{>y}YrgfnUE$9=>T&qp zi`-tCU+uSAuJCP5Psb$%d5@AfBc*R$z4NPTa<+mAUucYN35N>#&a zKhgBV!~NFtyvD2L)_Aqwg~zY+HQlfI(RkEd(c316B>)`J1a~IOM;xRcfcARre`1W7rdFJqPa(o`c z-*0q`rmOX${Y}fI<=1#v-F19EAL#Q8j?wd*jzc=0X#BeEll$x8?!2wvA#&s8>oy%X z@%)vnv+}s(j?0?g|5TO+I#-hzxH1p zmo@yaJ@2dk@bq+iP}TOkfX??GbA`;q!}HNweA>@cHQyTkK;hJ%hU?A$uN{Z{GDk0ex0s+@%}qm$JP0*&YyaVPoHz|ZNGlEbhvy^Q{&a&BWixbw{<;oc38On zH*o$JTxAvCZzFX~&v-qCbYLR;}74~`f2g;b>Djl98TS@P2_D>&%W>D&bq|5 zJAM}=*8}Qbx7EMaxBl+pzq|X)$&-4f(=*(!-5;?pfB$nju0MWG9`i8iAAfGO<! zc=kOTlTKz?sjE5A3oeYlNRzw7OoF{?P8p8oNCUWtvj zxA1OzYkkk6=jk=S?m9&1Xvv?f>u9^^??k@5u={@ZdR^n?eyHp0s-Au8w;G@NXLZNt z68WA>{2ATT(fO{Mp2lEV->d3*OWRYA)9`Tm{PwS{PfhPB>F2B-d5#{>ZPE2R`o%xEoVu;=gJIp@ zzm`wO@9=!yQDNi5{3(mec_9Ba^nMVuH{IWK4BtO;Ro6QY6wiM7c$3SO716W(G#*_y z(eY^q{SMG=fAtq$PCagUJon1@e&BF?|3ZJy?)ukt>PzLhYt{I;?)9hr)9uIM<=wS| z%e(bI+%Io?hRdzjr;#_YJC_&lVU_EP-pZ-@()v-=bpN;UYQOx~yPUsp9ZSDUb<73y zeKxm$@_g2j-}Py~+<#m1cQuVeZhhTO<#)`>Q*F8!?{4M#;CZ!Uc>n(H?B6k`(Cza$Wp4+89SzY(twY*>R(=&dz{&fEi>Q^3 zDu7`8p7mu*c))9tBlyKR;8$+^@%c#mDkri1TLP3PlW<56AQ#P!RH zcz)?#-)?(f_cgn#YW>91eS7q)M&5tA{LV__@0m|GK6ZE8UHui(^VS}-;K-i&`nA4;mhiiB~bX$Kp= z?3*X(@9FvYcg%Ty?pLZ^a-LN^e;CJq!u9M=uMc$oqU%JX2JwEKfAp4)#ydcs2N?1r zhYK&amUAqf4;{mbbr=~Jbz8?h-RAvxFHhKb7@nWPew^+#qT$;+%ema^0@feCpFs8G z-8ZlKZSFpEwbXNXI4!^Gf$Hx-?NlW7s;cd#@%L8GHFIw z@0fhLZ>RUs-22wrPTDS-KXrfO1#VC6hfm9VO#7Q|A0pRH%jx+P_q?b6{z&2Q{1}~o zy(XTn!+hpPdJZtcJXLSg!TSU0_rCjw|2_Qx=z|a(vk| z&v*Nm*3WF3m*PF)JrwUJI?nbl$87vNx1ahyTz(I!&k<_>2@kLB#_sOA)k$=n>6q=8 z+4{qKaYZ#AO-G-vPC172uiLC{e7eo^RkU9u=euXP-rYHz`&^_xhoJSY>yElkIZM8$ zspI}{ZIAGBhOet>`T4z1?sdooR8JoBCpo`rJgGFF#C7;QTTkwLo-`iy$Ma9TU*l@_ zr{~phf4Z&j$N?NOV>x{LY^!emG@bD9$DGdoH6Gp1?+bL-cQyQ;YTGZ|_ErD7 zUsc_;9X<+Mzte5?$Jc>wyy5ZOMfKt_;qNUD_s9D^``&-7`zz^wIog5FgT2>Fc=(>% zc%K+Ohm7Z*599Hj-?OalKJ(cyuJ`c$;qD!BJ)q^+eCjs8_Z#ybIWNhj#eRg+A@YH#Tckn6mbA9{w@{OY=ss>Y-1?7AJko_>P72k9}I*SY!X&A;}GTWQ?% zn%~jy(tM^*m(5p%@$TXL@qUl&$M?W#zi;3E1J&0>@?Hs6%wRws*gNsOQJFWZMtChSwo{hSwz`%*(rfUAn#1^JQ{Bp_JxDUb82x z-Ss@g%6LZeW0r8{JezAud41EfAj)A zelF~>j^w7J`!~}((QB@kaq7@BIo^WzQSBIC?vn3|^7Wm2{A&Kg(>>627yEa|f6ea+ zG7tTCflVLZ*_8FW@c21D9`pSb>~BB{=QrH_Vd>A|;kmpX^VIho{+YL}`poC6twxx) zmvVd>uDy!4Rn=Ydt>a>1X3uc!uUk1~eO})as_UXxg+1r1@lKTW(bc1R#;f}y>3$;C zpM(E>|CWcWJJutPNcwzuIGO5zWBn^Re$;(!=Br{hnpeS zHR18i>&0E)$ExR7ecyIpx&G36)%rMu<_(Tf4c{Ln_YGM+<{4Udam+Ula=o*<_d_&Z zjYn18*US6MRm1mtzv6gR!}s(3SIoakmGU?!SM>CtOa|@cay?bsxvD;yt=@Jcaw)E$*yt zzf^ybG;eZ@>TSKmqvOdR9LM=!X|M484YGfQ{2n@de{cP>H}~-H zXHmQ!a}g=NCn4$d<{lp2Blqz>mHr&Qzl81+;ynX04)ominz&!M{d#lP_%4=pKHXOR z%cmTEji}b^&2&E*?|CQn?zfJ4pm_nuzyJIx{QH)C9qu#yyoLMSSbZK&^V3^=x<5QW zJb%&tzJEUW`%bt|PS+9oUQ-{ABio6fHCX29;pP0E<|7_+<{?~9F=yI#_LEJt@(L( zD%YPL7h8KNzaB5D8ea1qz8Y{Yc~0{P1@Z z@O=Qf&hVPUWWD5%^t@n%;qNr~&HeKHpyr>$yY;Q{>HhF|=bmiygK;cmHNu=m-wVTg zhAG}Yl1|`Pr?W0>ya>>`jK|zf`FHzc(lVRg{^P9XQ}Z2O9^J3==T&OcVETr#ER>NuzC)!$NADe>hD1NHC-)V_&P{*B zjswlV`qS%jU3UuK*5^9;xe#2}%Dh6u_m;nD^g9`>7t8uKfA=K3e)n%*jZe=@nqR%1 z(fcC&y%gNPlXZPg$7fc{dxj2_KmH!ef%1pv{9d&6=rQ^9T$0zM(fvrDIYQQjd#0oB z)A{wv=LxqS^t_?hH#)EHnU3pU>qno<*XNQB&t)Oa<7zmv-;Ea z3Ga{B(C@)LCQHtb;r_$hliSN9-@|bXe;@Hc?XiEk50sAH*Uy6>6^{(r!zg9Jz zDu0j4W5SOY{Z3VH`?VasjeFtkrR$$vvaYM!>hI=%^Z3d4F}!jejOPhx9u{Hr`y~8* zFT4+gzF&p+gwlSW$(HLMRn4E4Q@6wGQMc8f=I0ukm*M@`v@VbLNz?kf&+xi@gsjWs z{m|r&_xb%s|C*oh{@L4eZJ){Wy*cS15x{rhoz9O!-?NB2K(9wzq(a%ep8%6HRz zrb@@(u=$k!E?Dbj8GR4cV@{`WZ2$2w{J7ElX!!lM!^V4EAIr_{dHtZ_S9Eee(f$)2 zpU&4ml=*PaZLA}2u;G2?@7MIKFI`V!|BmUojd>m2$9LzM;pz5~{IcTrYxG`WugMHc zN6T?6-EY8qcqel?)jd4k@NIscz%lw@zi}kfL@-kU?$haSW8bg#K8gX^s~_uk6YoB!V2^?29o#VK;#*qdH2*NdwB{E8#bqwKHx zdy7O_?_DVC{PX4dZnMm9OT@jma)sBIzF$ti?{hD$llzQG;ClP-`yJEM{nz&+y}sAu zT2=eef%<{^XT|SSj^KXLbK7eisi*Mr>izkq;WnIp2iYgr6Yl-}-u8#b*V}e)?pn_9 z{o(Z)zCV2XDH$hN@x6^+#*NkC z%c1829235+zbDk+Nj@v@W#Zr2ddy~8SH^w6`8GcNeRzcVneKo2&5X0Gdmq!B$m!L| zIMLg4ZNK&TIK5uy?}y<&8=ZH(lAce}$9v?C=k)b=y2;7B{j{u$SNt8>#C)HBCy(c% zDE}HhVqgAy)`w@`dtUf?D91c0@o_!jO|f#n;Q<*Jucmbhui@_@Ip!}?|8GC6Oj3~mlW@}mG`ZlK+kvJ{;0I$|Lgi)C-1#jGnVU3*E!C~w%Zq0wTdCl)> z8^2d6weAt-4-#&otZ(rBX#8$V?)T_>ICcK0$L9&1oK8>m7;SHUzr161AIj+Um`KFa&q9qX;+j{AM$uHS>#ey8tU)aRwc-%G>qqwttN zcGz_G|K4gn9cQ?ou-ESQ8a{vF{?1U&$CT%~=NG@*9A~%jJ8c>FIX$1z@BUqy#r~rQ zu=4s4jt_c|KECrDVE5cgJ}+J+>X+vY24BMQZ+?pXY5zP>IrV*+Pe}juM{)ey<@sY) z9T%K^-&1?-SWf4W<*eHObpECNRG-iM?jrWb*N1pcj-KcCnv-N*MX%rWceOen>7wfc zkC{o&XJLLigyYGk<8Xg>{k|oK_nIY#TmL>&m&4&^ziZnI&oTeWD!%Kv(Q5Dhc0XXl zdCVs??z_+Ha=a1y#e4G$Ha@(EnVui=n3v>zli}N^&b9T7`|2`YzA=T9U03FHXZQWKlZJ6SaJp{1zb#)_ACTum!oSa}`PBNY zq4ME-oKnB%lKOvjd#@YG`F)t?nP7=I*E|C%OgY@j;Z_c}^Wf_|*yq8n zMEFYBm9XoO&RWoAR(Q9VRiG9u_kIdKhy6M93$Vv*^8NsRG&{XNo1ib?1bzL%Kqt!= z*d;tTfpxr_V@K<2Ksr50+G;xp87zPr!X+clM4z137&#L3igfg6!=GB{~_2O3qRwq zZ@i}+6b2@EHU_fbCl~vtc}o4$J-PlFU?!Laj)mKC&;saePgdXKJ>~x6VHZLRp>x5B za4&+M1Wxv3`%eRBgY&_K;9}2Ae--o(&`Y7!(958ggR8*RU@5o;)Pm*UCa}Vj-ESqh z6|4fQ!EN9UPso3#r^J7kC(~c&S?s?X_C20O{(C)D{(4V_f32sk-+j;q=>6aU*p1K! zp$~zFL6c`gzdw0e`#lDI9Qp)kMtwdBp2Gg8p)KGU@GN)^Yyf`-&x030n{{XKy80iCk z5CDC>nUVcLBpBe$@JE3`AQ}WgEQkXMV6eB^KLk3|o9aIpn&PeW4+F!&2yBmp`zYuk zAPtO$|1sEiDC~4_7&shmM}Q3Y9Sg?8Efabq^eFh92t67c1F}I5+;X9L-U9y=qQy*w zPW85!d}uy&8gv?TI&?a87W8Cq4Jh!R0*Z+ib1L?o2KzMV>Cn@mA#cin3%%L?CEm`1 zmUz1kx(Ip^^kV46(52Xajko%sYr*y2k^#%WjbJsn4{lA~O#}V})`Q2u;S3M{JB!Xlx7!2_(F~fbKsNt|j!X5<<@l{40g6%`$ekk-XUrE$q&?9`M zQAa>Cus;Jj&bJs;56VQC9Qe(FJsEx{L-XJ_4|v^)DVU#$OUO#*aGimqr~5P4`DQ)BH=! zJ^l*(^3Ir@uQ@oA8e^9htZhFvpD1=e=xDL+lEK(+_QY;>UN?JIH~WNc_Nm?MGrQRp z-Ruj*j)h**&Azgm{h-)3KMpdkd9D!Kx^D+5t&T~8s()Lq>%l9yCbIT0OpP_{SlG>_ zcn>+;t$iz=Qy&R?BJ7n59djsb8}<=gAK5yX1^0Md10E^v8qXcrzVrjGC+q)cti%0Y z{Jit7G1ahb*f^}m+y(m?pkb}O0N2lr(8s{sK@R!1?tL*&vSHPaT_*Yt*s!*|_I88X zS4utDpK#c;44yTQfSabuS=e8JQFEupm?_sZndl{~m zs>J>rkzEEG*)_XxopLqwZTQ)UYYero#&w8|^L@B?`MCZsK;CYC+A+;=w{~Yb-s=Ke z%lLLT+djT~3H*F?wqri(=KdLMo9A|1$NdAg*7+~6UxfQ1`0j+Qw=KYyWe?)8_G~=w zW!uHtl_%kS6ylzM=K{R=`IOe}2-vplwjGOM+d8rS=fT!GR6n*&?-oBA{~hqJ?W?w} zbG0?>Lc9-s0+#V@T9MLTKfvE7`2I@{+^zlm9z%Jy_DgtvY%J6+lWMy^gKcZWiQ3|P zyz_dQ#Hszq#(&7qjtN8{|FBGQ#D5#ss50T-+V6jEOg8KXVQc=!c8gzaI2pC` z;NRNXC$I13Uv2AO?YZ#(7~;RxLEFK$Wqc0L3(gn2>~Xej|M@`r+-=@$9<)Af z9&DWUy!pQ5;q@-Y`K1S zD%XRxZ;Qq|k)SIPUe8TyVQZdW#JF)RcPd!#h!+7^;WSjSmnAeTCH{L6&ttG> z;^$7_)A8Ak$ve~e*#GuQ?zi7b zK5ZSIDz@!272V>o`LV}Q`~>u+ZthwqHvbR8UE9LOGxI*wC;FQWYtQLZj=_9S%4^el zAMQ3k+J|lYFT+m}_Stw6C$n9UiutYBdfN)yk@~T7C(ZMQ+2|YCeg@;lqjT6EGTLLFggprU z2Q9-h(qh~B>R-gZ8~0gW75nJ{JXf^-+qd$3+qRwdx9buAi`P1)3;x%lY_H(B_(JT6 zot%GLb~}eZ_IU2AGh__0{%t&0z+J;$2ixXfuTyM)+m{yHbuM~6Y@MTy72D3Qth>%> zZMr(Iv$h>qFPqErrNbilxVB++K5YHibHVNKa|hzGbsm2r@&?xLxe; zPe%WQpAhB@Lr!6P7Jl&+6cc&4u|94Bkp^}-FVpD=lLV~4|q7Aksb~g zCHsROjxRxUuo+e5!*Yg-@zUL{@nV#oJ3p}l) zg`Ss5i#)H97JJ?z4SBenC6Z35q*E^GREql|abGO%RUWSYYS9|cMv8B#=Y7&zDaUfp z$F#k|^BL(X57+M+&oT29;N^O3^m6?+ zdAa`Ad%0eky<9IXUapr7Uapr`FV{<(m+Pfn;^~lhIwhWsUT()tUT%lY-u{$smp6)Z zt2dT(o0scvhnM?Nu8;GT@8f*U^l`ole4MXBALpyc$N4JualS%6&R2<#^HnPGluJC7 z63-$Z=WDT#^Ht^Jd{z56Uo}3?*HRzntJcT)YV&cuwM)Dm5^tx(yHWDDN%FT@^4BH# z+ba3nCi&YT@$QuLBO|z7(?ruFxc_HFaD8M(aD8M&aD8M)a5-`#xE%QroZp$^zd-yK zivOYruD{|4uD?(O*I!8l*I#J_*I#)A*I%W?vq<7uEb&xHy48|yO$689(g?1<+6b<{ z<&vKj5nO+(B9f@R*F+plS{IQ@S|2eQI>59?98TLEl5VG@yHUb#lKgKL_b$oLR`I`0 zbcgKUDf@Rxe)mXz_liH`=lb;dxjqAauAfLh*H4t6>nG^v`bqF}{S5YV{iOK0y;A*r z{H6K%cue>6@t5J}<1y3E$6=PA>!nn}l}orv3AaeXEtYUq60X|M$8U{4;{XBjw z_w%^1!q4MIgSa>PCsKWO`X`ZY6WuHBDSdccjO}-G}S5rVrO=2jypg+0|z%^@lxu zPNRIA0H3#J_T_$4(3ks7M_G`-|NBUn z_J0f-Fb(}Vp2q$hPg8#`@B02+-sb+?zgzlq|K1?}Tg88y_-_~g9pb-}{P#0^`*$Fn z{#c5#8Zc>*oKCuEMkM#2%t&s}l1M&|OC$OCFORhK-QTQ;e3#-`75On~9mUt*)QdKV zHi|Zht|twcj!3C5Nq1u;mvd7jmvb|v6EIzoT;8pbT;6Sw+;1Zf;&x9th~4uK;&RM9 zh~p_Z$i_3ktT^aPDrazjb?1hw#Jxn^OGV2EUPj@nWPh!=FCWPLzE0fNi+eL^0KdlOdg~l`6~gy7n+IM;+BI+m z#kXxB*Yi%&{$|g>J81vjf%nn=KoswfBJFPyq8_IGgQJ>hf12#i5X};Qxlw;6fB8{1 zJ(NrK7s>um)L&_TNz_}kzg+e&lKoXtn`nP^)E3&mRNR+GeMRmoqB#F`60Sk^H${C< z``1gnEwaB=_P3LJf721Qm*U+d`@2MUMcMv`>FuD1kk!B-d))X;#-M)K_LgeI5HPNZ0OQT1T z)<&n1E{`5Vx*|HAbXD}>q-&xxNb91t%>3DR$UB_ zoAoh#9&Cu=^I&5PkE=~F_I!ZrnwXO)TyxB6q%ARLkZy=6C2ftVAZ?2|pR_&ZLeh?y zD$>rF%SboITt&Jm<~q{NG0RE2VpfuFjk%3IUq(&fQ&(iOplq^p9z zCtVY~n6xffOYv!8hnp*Tku2D9lAMsfqo8)EE0RX&}}+-?mF+Y=AT>_8`(=Y&2;?Y&_}U*ukVJvBOAHV@Hvu#U4tU z9-Bd$5ql(QX6(_VS+SEzvt#o~b7N8{w3qiGfC6p&LK^YTR@r-w}><|ZV72t+#g7@FTX>r_rq@lP!l9t3Zk(S0iMp_>C6lrDLbEJ#nT1gkjy-Zpa_Zn$++*_nIaT`gO z#=TEk8}~8k^0?1PSHx{2T^08Y>6*BIlGerTCasU#OWF|Ul-PD@jPsK=#q}p$9~VX1 z92ZO45|>1}A?{$(*0@yCwz$!x?Qw^bcEpV*?TpJJ-58fcx+!i7>E^f@q+M|Zq+8=o zAl(*sGU<-E(@A&6m5}a=Dl18)<(0tE4mI z-y|)Fe}}X%eiLa?{70n4@t=~0;=d#dHlagE93t|x+vb9Y1?ISd<1D# zd_U6a_<^J~@j=q1@rk6h@k2?M$B!Ug5uZl7DxT*XYvOsnQ5SFL8xf{Hp64kI@jOpy zjJNZk2-76n>t(w+{xHN7VOrwtyfMOTh(Ch1TjR%)w#D;&u|0k~ZFj^UN!l5I6ls^F zvz6ivm~E1u9h9F4vs1$Fis$*}o_L;b?v0;F;Z4FZ(16KK;CWG10?%uz6LR3*&(tJL zAzhkq9Qo@=u=AmQW@kbXx$jDt2aPa+L@sA!B9}8twu7>rkjUj6oXGW(BKuQmKdwU) zxgOIKxgIkTdESHr<%z3ES0p|`x+?Ka(lv?ON$V1WXIcOCi8-VViKjsWrb)`bUdrDr4+lyjq$bCZ;Fvy`(dk>{IR6M4S5E%8c9e`n&g&=kOX7YSNaA*kOyYKrO5%18CM~0Q5|VBt9h`JCX-d*c($u6|Nz;-dslTTuasSRp z;{KVL#Qif%(#uZbewr)k=1aOWCEWr^w@~~SiNE3`K8`|3d>kzj|BJB zN;$SkId(`ncFOiH+1?}N+AHNU$+lb(#+S_P8A#^#j7;Wsk4olt4<_4o5152xuBXAt zTu&*&pfYLfZ- zYH9Ln^v{5)O}58Fz${O`le9jW`$vP6yHU!$G1-oj0kcWUyIK5oiNCE>FBta++j@&I z>j!iFHV@|dZ5eFqH(+)S=K9<AXPA0W*h`XFiU&?eISp^uWz9QrtE!O$m33x~Fl77cxl zw0P+Aq@kfNl9mi@BP|{J3TgS!*GMaezCpTZXea67q3=K=OxMBo{1q^TDSW+Gl=2?j z1Ex6TL())67ime#=cJ`6Uy+uld`nuHvWv7?!na8H4HCXp!naBIb_w4h;X5U~8OG`R zhH?6VVVr*CFit;e7^fc`#_1;vu7stI7dz3W& zFgxz_H5rFB({|=z&p-pF=rFGLrQ*L<{4W>(E5!dQ@!u@|+r)pn`0o(^o#KC^_}@kT z119QlZnxaSxqZq-o5j83aPB{y;+}8>`!5ysW$<=>hJ?@Hc3dRx4P)88U3AY__8%O_ z^^!2oZud2V$8r6njC-ESpFNKIN$xoAC;8*JpUfP`@fD2Yeo{E@C9W^g;&JV?9U|>- zO2)lG+pETLzSfN6EZ4>u)(GJm0(T(D7ljvq~ z?~?7U9pa_UaV^&B<+a|$0E z{}pM%cs{NNkLUA5@px{BkoYedZ`&bYs>QuyJg>JDWpce2i&lxQ%H;F@noK^w*Jbi~ zygrl9#|^T-F_X_{O_`kT`b<8*H_QGOao-@}TQm85-zMp#9?9wF9?9cZ$&sAzw*X zC7OMd%!`hSr1TdZ#rdl{O2+x4xIZ@>#m7P8QMMfhnAEI6@ISz$iB@Ih({^>%g%r<@ zEPj3_a5QWCFYK>oN5de%mqklV)YJzwB)Gmz&N0^0T?T zGqbt93$l6sSD4NHqbQsEWpOt5gHSe?vm{&kO*ZGFLE>+e_?smD^%8%x#NQ(EZ;<#~ zCH^*vzg^<*koY^Zc|6;g&HZmvHqS3NXY+irE1Tz&TeG?UZp-HN$Q{|d9=S7{*CTgj zOFK$FO%B(CFNf=ad|tucqek^<`QPUtgx@*z3!H z$;jdL&deNM@65{K_0H@ZUhmA!;q}h^9A597nZxUy1vw8y;eoKRMEWB)^T4 zUX!@5m-4iW|Bf79f9uS7l;TUD#O2MH#O2ML#OC+OD8o`zH2A(akOR<*F)VTu7`RlPlJ@FQOeUK%NjoRM1RY>DPW~%xZJ>wYl7{m*;YSUXjb~vnrR{XH72GdtENq zdwnjC*A2Nm&Nk-qxVI;lkF(S~PA@Hw(@W3ea%SXlIWzM({j5BWFFVhc7x#DO`Tv6t2I(6t0KtDfYR@erDH{&#Bz)Q~yD_ZED{&w*7ZaO@rb(Y#O(3(KN2_ z;%Qvpp=n$nCDXXxOQ&&tluzUOsGP>_uxJ_|&x@yVy);UEO%mUFiLY7WYne8K(%mHf zHjBS)vb{sLcS^Wj5^j&=W3S}HOy_*~rt`QGm@fTdI+r7BI+r7Rx-G{5vv_&|rQ0x_ z>!)!#*H_bYuD|uuxj!{aJT23?+#4jGR*AQ5I-f5$P3L;sEbd+857#3z7En5=GdP{J z8Jte~3{EFw2B(ubgY%m;gVV{L!THUd!THahVbd94x@O%#@vS+~NP&JIQ_Pv7Fu>@xNF6o8vgV?>HNNfGM86j&#-RcG9}p-;lP>j=sb0@0dNF zbm#0M(#ScNkQUClhcq}F88KF?thyL<#?RS_1iL+>vzLkE^q5xuHUw~T)*ve zxqdt5a(tb0IsV)t>ks3?$;FhuDdzNj#k@aI%>GlvJyqP(#67*3^OaG|@fV4|V(}Le ze!m2f<5Y2o$EQ$;$ET7Ik58o`9-qoXJU&&1czjwE;_+#5 zh{va@5RXqwL);FvA#R7|A#R5ilHMxG_Zlf*os_#?>Y*XT$5Ug7*Uy?lzoYh8AL8ri z=Fno=ZVB-`dqarl-L0YBXg@r!6uN}_Pv~;ej?mSlouOLNjiDP!H-+r=IPQyvZlUe2 z(CwsKLv^IvLTgEPgdQNRn#b)`J&)U~W*)cK(s|rowez^Wme1q%S}~8?t9t&!6uxFY zKOenxKG$FEe2#DVe2#C$eD=R;K0mLqWnlK66Ef4=OWDfhc}ywS z)2dQFF4mOtaZy*w?OI>T$3;Ua9~X_Kd|Wh@@_BoGDWA8SOL-pJQp)G=4W&FEYAxmC zrLFW?YNz(n7f3s$UN%a-Y?6A}EcMbQ^|Dp!Wt-H?4yl)&QZKutUiL`6?3H>kWn3@5 zGOm}%GH&;%GH&-^8Mk{v8Mpi3GH&;jGH&gGH!=# zNiSE@%P-@0m|4c{P*BG0P*}$8P*le4P+Z3C5Gvz#C@JH1C@tf5C@Ktz0;5ppB3FmP84nBw5H{~4LzWDmcxdZ6FMfSOTeUf|b z9J*gJxSZQDrJUO@wVaEcvY}=ikj#mveus zDd*?smP$OeXSg3Fy=!S#_*@e!qyS;5bDWmRy!XIF54$gSYxJHLXj2WN`^f(kB2VFe$* zMHSr7iYvI^gv4J-1-DOW1^27+3O=qYE4Uvml6V$ZaC=r&aC=otd^M8Kr4`(+wNj4d zQmz#h{QTsq3hp;+B;7hmr(WW1kaQX=xF0u3y{?yV&El^`^1ngy-74j7tKfESm-_9H z`tFo;HcI(6QGN9{+bTXqz4kXdD!wM&S+R@ix$`_eUN)Y`^QBGa{RDTcH!QHnFRp(V z@OV(afX9QumHhj$luEA0G}%sTbw_cU1CofEz30XnRv7_s`9ePFE%Or){!-hwR@e`*+Fyy_Lxn z-YiTZ4J_pCNZAf997*m83%NcAFXVJm7V`0zCi~N6e}?SOl>ONYx&3k%a{J|rzk-GK zelM=;Wq%RvKit?pg5Q`9b&R!Rz!I^OVXqQ<1nj%TJ{0y-VvmRYf!N2u?h<<{?0yGx zoX5c)CH9Hk{GSecs<`9UoGB7}K{r1a!ahUXFBSI+{8032*iVeX`!mEYgP(QyowRk| zFxoLMiTx4m(E)b<82(?1#OpZV=O?&(4|46P-Rzg5UH6yp8+03IAA~K5XWORrSpwUM zaIZ;X`!2ZGi~Sz#)^2vm!LA>Z!nXC3(#@_P=K9GU?)oX|X5)o?lpmW`?#OO_y4j=0 zuzTF0j+rHP7VPcm>^={6-^19x9d`aWW0s+ew!hR&V0TXne(Ma|*1v7v+$`5F>1Nk- zv+KLr4X`!Nl8J8Enr`;gX`I#xsKd{WW&0x7ThTEz>{Mhx+w1CT*Y;lS+S_5t^B9=0dLuDOrxLd3uBeztEyd0*;gPyLgd)-2dI{_XJppxE{uB%>d7-AAuy z`)2F@nCt%F83mSDc8M5?1jj~tKHm3KkfSYtOduS z#F_F8yVt>gZa2F`>^8Vx4O`oy@3ZXxapb>bgBz!LzFR(DVD~NXW8P!C|1iWa_6*pw zK4AAghdHJ~?4w|(e9Z2Z@RRz9+pkKy*$v(7t=;Xq(CUHieGInL7%|CJt;2W7u9 z&B42kT>Hgt_Lgq8<8}QE>t^S5v(M~iuf^~8HU1a7*;~5Vj^Fh&tec(J%|5f6ePuVh zqA!QFeJn51jpxj6_Lbf2wcYF&yV+a1+0H?3Jj1%#dEM;R!`aVY(Jlt>JF;aY`$*TW zKZfle;iqH{+Y^SP&bP5$k2=pg81H*Q*cMy=VsC<-i+3Mc_fz4&M(m4Vw~Bo;Y=d_< zSwGgU5&Jpor<;A|@7d2@#JQ!4?IAdKICxoz4LcR~FtICP=ZU=VJc{91LUEj@4$#dOnLT;S(-RzWku6u4bduy3*-9$_Q_IB9yE7=aFqCecqwjF0`RAlr|@J>@C3f3W_a zb^X+AbnUM9*&aR;b@Bn*r@+qr(Dl>0*>yJ`x$ZTex%JSxmEEgs*e_iFtzz5wTYq-_ zbonBvEv$R)2)5V2E*TxMul~DW+xGga4V&e9fyIDqhZ}{!6>rsR7qLKdPG@ zbnS+G*Y-_w?Y84xyWwQlwr`-uh~~!|;h>j7F#$JtM*zKT?J{T#wl9YUp;tf?pf%9J zP&lTqL>Fb?E_xu6)#1DAvA z!7ZR3G=o;~3ivzd0$+dtnmGz21Dv|dkzg{I1%c9b0knhnz+T`%Ek%M1 zFb&KGr-QS>0`LcL1-J$@01W5m5%2`S5N=w*UqJ`JFpl>)8uK;yC-?!_?spi#aA{@$ z3`gdAa3^R5uY$M0d*DOxIrtiU4=}XY2c!*#34>w4B!d)?2j+qjuozqiZU$??li(Hb zI@k*S0lo+ExGo(IMuQ{3ksuGu28+ODpcbqGb--TJJ`SD(?}D#@gPzn6#DF1S1V{&2 zAP>w2CxQyF7~BjV08fL@K@=W(%LLQFaiAPjgB!pq@HluDya?U{d%=``=vQDqCZ0coCWR#kAdgFE8u&u7ertbhz3JJ zA*cYq1AhS5fE&RbpaDD&+CUKRlRFrU0!M)}!2<9#*adz9QCPc}4vq&WfiiFrSO#td zcY(E_5j+Z>1}}hLKm>;30bnRd1(_fhEC3gPtHEvH0q{8Z8+adV0bhb|!N0&L4CU#d z5^Mq=gYUqPU=Y?*lEFxDD3}QHK`}TJl!NoZ9pGMYKX@9ng4e-j&^Hcs2a>@sa0HkL zCWC2U4){H|6kG>x0&Bp%;32R9w1Stx>);dcCD;Rg27R#3GYA|Cjs}I`0&p3)2Rsa# z!3OX$cpvNpyMYIzdL)Pj!$2B10_1=xU^X}joBcD;ANw5LD3f=+R!EWG5LONg!m;mO2 zv%v4bP2f(j4m=1R1y6!kz&qf5unl|(k>Fa;b7iogP}1Y8QP2akZs zm|ENqI>8=r*um)YAQv19E(Q;Rm%%2m4P2Rmv_aA^)Df5ljsqcZHmCqAz?0x(@D=zT z#16+e0n)(Hpa`4|{s5MO)t~{q0^S9mf`5TuK>rcO91czdr-6mw60jPq1CN4Nz{lX= zROAU<3mUimfRn-5;CyfyXahUI$T8^C;4H8dtOoakr@%+x z3$Ppf0{S0{u@IzyaUd5=2g|`~a4%>BuYt|rYcMb!bpytMiC{W75tM=p!8PC(a65Pa zJO^F_o#1`21$+tq1I%HV+<{1t1X92uAOlPUxgZ~$1QvjcK`pou+z!@(X3z@W0Plbg z!582gunYVMe1{_qFbbRlE(TYCYrryaKX?c{0XBd(@D}(2d<%X6o+B_`f~z2W{XD@Gj^A+rbYYA_MgYlEFxj0geIrU=BD3RDspt5%3rA2KXEJ5bOp6 z#-h!@aF78ef?42na3)v)E(F(u72tMI2iAc`upT@GUI2dudx38p`Xq<~abPeQ4JLqG zFcX{z=7S2b7+e8v0=I#CK@)feyaql1Ux4qyUf>&#_`x8M3XTDJAOy|=3&2I71}p=s zK?8UMw1QW`CeQ`G0^fljfiDyBg5e+s%m-!QYH$yD8gznBzz*OXi9Qb!!3b~!$OKct ziJ%mm4;F*Vz;)nuP!Afx6W}l4O|TJs0J^{zU)>th0r&!Z3!;y~_ySVF7?2HSgJQ4%ECH8-E5UVO1-K2|10DeD!E4}suoe6h>;Vzk z#vB9^Kq@#66oV3Q4p;~-12=$`;12LdupT@OUI$&^U!Z>u&i7yfm;`2mIp7p<4!8hZ z0%CK*Ch?Q&0h}2DM-ns0WXN zC&5PWA?O0%f**k|A9Vr}!8ni&W`nc9B5)O01=fN;f~Ucs!JFVcumyYx{sWGhhOrQw z1WLh0U>R5i)`CBQm%&@$UGO3J3j7QbrsJ9gj0Ra?637R~f|Efxr~`ijPk>hND)<}N z26h9_42(x03JeEh!9*|_OarsQ$>1zd34RZ%z$4%#@E+I#c7Pv1#7rC;U=SD#(m@u; z1=B$xI2qJ{>%dBI4|ou~3f=}EgU`VZ(0>-@k6;wY1=B$hCos87Z?k&!Avj*6oL7m4EzrK0o)4i1CM~`!7Jb`@ILq_ z_z`$#V-5fg28V(PAO}nbCxZ|;7c2sofm*Nz)Pp~PSHWB0@8C1=E!Yj5IjDOO4~Bzu zFaczPd~iHC4U~X$!1-V?xC~qkt_Qb*JHWl50lWn^f$zZ&z&Re*LEs<|0}{aqa45(G zM}tYA5S$6l1($%8;C65~SO*>kkAbJbOW;-TF8C092DX8nU=J8nh~owf17pBgkOPhb zCxiK*0#tz-unepQjo?|(4&DV@!1v%s;5h-u4@dy1U@Vvjrh?84O+olU=#Ql>;QX!w+Q_Q z#DGMQ0!D))z>y#aOarsQNnjo*0}H_tPy=egU0@w}7(4-90I!30z$VZIwt;WK9^g3% z$0~>hDd2E00px&V!CX)b=7TbD0k{%e4_1OZz*_Jicmg~JUIlN1_rVsh9qa_VfjJpt z3pfhofK$PZU>*1~cp1C{-Upw8ZD23xa|*(NDWC|P2Wr6zuogTAwg7)I=A+;Ua3m-O z=YUFZA-Eje0_@jC@C9rWVf=Wm=^*?Kz+Vy;-3Q|vXCq9!8HI)SL$JJZ1Y9#rGQJFx zV#b+axNk7r9Aidekjp_~CYjUCWK&{t@ukYC`2Jv`<3Qga|c4*gRfmafNxtinFZ!?Q)!+u3(W>|zIhSfacaYJ zH7_H^4y^OPX)ZB;L(CtU%grZK1Ix*A?7b|pJuyRZvJU*G(VaZW-nrQoZF1Y zx!puKcbY!VS`%>YH~pOlOr*2k9OOJ<1~^ZdfzICVZXkaLD-o^!5ezEj~j!@0n7rgNd^ET`J@ zf7rY8=qQT6fArm5)w5)onQWwoBomUEER&hZ%p@QnU}TAifQW#A?7M(~7$EG6ECJa> z2#bIa0U<0RLWBqrk$o2d5djeakxh2l<-WVyp87uCc{pFs_4mE^x##&Kuk$&*R##V7 zRd-isI`LzKF8ny5D?e4}#?KPo;O7Y4`68hwzesqKUn%tB*9pD(&xJnxmqK6uE8%T^ zw~)sl68iCnh5q~rVE}(h7|8!54Cc=X!}trraQ>n&g1;n;6vhyb zFo9$X?~;nbL{dqZLY@)cBUOa=Ni|_QsV>YQIl?SbOPEJ$3m=kPVIg@zC?a)*kI0L{ zB2rISOkNU}kov;Mq=B%MG!&MRmxW@|NLWr@5mt~_g_WdOuwQ}~{|DI6!ggda$6;RNX;{7BvsPLsaEPvmXkXObtJBmIP5Nq^xY86aFD z1BKtnAmJJrCR``Og3X3$-5}JUrNVRc3n7PY6rQJ>gqpNWs71dNYSYa^9r~4!OScFO=+{DHx>b0M zZWCJ3qe5$XT4+Om657%;LOc4i(1BhTI?@|LXL?iULT?FO>20AK{axrm?+ShBJ>hN2 zk$%)j`qNM{fQFHL8cqgM6B$I!WC*p8p)`UFr;%hNjVABV7&3;IBjcz<##1YKmzF0J zX&jkEuWHwDDAJ8;1kEW9ksgo?E8Kj81 z$Vb#o7E=%Tm}Zh?)Juw~k1VHtvVvxlm9!%HgjOP}X=Sp8RwZlcv!sMpBkO5(Qc7!( zjr2LPiRO?p`aIc8YmzOr7WtaiCR=G8vW@1F?eqn*gVrTG>5F6+tw(m#m&hJkpX{X# z$UfST?58i21GEu2NM9k}(8lBteU*Gmn~=k_DLF!$k)!lA@*QnXj?ot6d)ks5r>~O} zv=uo?JCakhGx>>jBWLNG*Y5`BwYrg`KF9Yk)>!Q>VlO778j$U{1sJf;)K zA9Nz&#mPhz3yDFTNkYY0Butz`!o?3rgt(AIiA5w)Tt+I0D@c;Kk|c|(NSgQwaf+W3 zx44FQ#m|UeTuUm6>quqsb5cdzK&pzRq`J6?)DX9jn&Q`_j<}7yC~hb9#T}%HxRW#& zcav7)9@0VlhIAAUlP=;h(p5Z7-Vo1`?&5jUOZ=7e7B7>&;x*DwyiNv+x5!ZOHW?w_ zA>+lnWP*5)OcWoGLh&J)B|at}iciQ#qJb_JjdY0^LO&Km=~6L_E)yeYu^2^{i_vtY zSdM-o#$ljI0{v7>rfbC%x=u``8^koaN%YY&@macAtVOqpwdr;-m+lZ>pu5DnbhlWK z?hzZ%ePSbeKx{z|ik;}UVrP0p>`K2AyU}Cf8}y{uot_eV(9>d1`jhx3{aNfq&x^h3 zFJd2hQGAPD68q8{;@kA5m`87m{pcMrpWYP*();2d`bZp1AB#ii6LBczb;Bstjilka zQPiv(O)a`{G(uNECEWyCUiU6d&`qK?-DH}in?minsnnsHMpJd~Q>Sh^_2_0$uda}0 z>1NX^x;gY&-3PRqZZ6HyeMoES7SP(dg)~?95v{9RMC<96(3f-{(+0Yww2^KZeN9(P zJL*=^&bm)&SKT_=UH3W7)2*ldbsOjaT`A4i;rDQLU(&(4ujokK*K~|-D=pA%qwnf= z&`G+Tbh2(QeNVTK7V7rX*}4OCj_x2`r2B>z>kiQsy6@;p-4FB=-ATGy_aj}SJ5AT> zexfD1GqhCqGu@~=OTW~eqg!<6>DRhn=vLjYbi3{%-Ko1ocj+$EJ-RFOfbKVXP^ZFFAmfk7m>NCW;dYAa3 z-YwSCd&K(sY_XxfqS#1ZS!}GYDmK+WD>m0x7hCF|6If4EP_3g#^`VQg(eMfPjzLWTozO%Sk-$h)i z?F#$cvwGJ{9ZpqJgy%q{-7Twp41N)PwPjBXZ0h+^ZHTZCH*_%Z~D>VP5l`0 zu70d|Uq4QKs4oy7>&J^v^bsUb49;lzL;(JP<+O)K&)z5C{{NVi8Tz1#pex6 z#oC5tVy>ZBtZP^<)-$XU>l;21Up9Oywlu62TN~DiZ44!1d&B2qXTuj_H^WA;yJ3^q z+ptA^%dk!CYuGLhFzgYB81{-o4g17lh9lxg!!dD`;d^n6;gncl_)(l-Fz6;3jJhd? zNZoseDBUzev~IegoNlI}yl%E3PWOQ!UN_H>pj%)_*DW-Bs4FtyZs;xinxvJ-?bV?N zxL;MGs;%*Bhf36J5bp1k=mrKOl~W>l4Rtv-ZPg<@gHq-uuE)44CF->h<5rdEOexQ$ zDp5ZS{BbE!@=k5bk8wZc{ma~7`{*|n_hrg*n*&j>{ocN)ZMkT>7CpgnR8!WiI9Q9O z9l*O5Wt#j8W@^Ot%l4KVq8-s-L@y|71lxzJ0e;6>nalDe1*5Rk+=#oc%^iLcBg2&C z*xuM0!E!CwQL>yY#$c?*%J$fngGD2s7r5riau<;I>T$duh=T2xrRw5Fo@=eFtJ}|W z9h7KAAR4ub=ejA=-Yh5lSvDpcwLHBR*hkV2xSLj%lS_npE}a;et(LInnESRecMpb! zsms;grKOamrE3y?7h74bdSKlrE437qwidX2W$rgP)5DagBtuI}_BCyL?ZYv0TA4e$ zP%GKp1JUnTL(Qx7jd*&aEVm{Q?WiXFdA!p%X>+pz>;C+?Htk|9?VOik?7F&@cGY?O zpI-TT>oG`+{^>OaeWzW?!S;5sy|&+r4TL|_^7It^)7uM{s;8&mpIPI?Rjod_6r+_o zD{3ya{7w6V$2b=G%$%&Oo!_r!^4v6KT5r^Avy@0)SG}gsR>CiGE7K}Jrn?B~ zE7O*D($XRyo0_UBfocDA3W9AfSiS^1j$rFPJ$L0JU-_4F#Bws&e%U^rerEpuy1~|% z^sUyKwz;B3)gNoo+N0W)%-V`afmUrK>PfZi?mL2a6UtF0yswqI$Ok;PMw!Oio?RG> ztG3;%JM!FmWp4Yi`0Y|9DjABW`buOxi*K=%s7fHJ|D{%T?>85?gUVdbb*#qYri#_s2R_0(0%a~sX~&jYyTy*^hw=CZMp;g7In_3brFnZ*Enj+H*4j|(8SScd zRpz-1%DUhGs9n=++8unAqaOJ$$MCFQSxzkDxm!vkw;K1As7IidZ?{=H-oamMktYyU z+M-R9M|i6#{Ufk$?u%MVV*)M2sT$g}mpf^xuTn=lTP_UpR@=OWf&8nF<x1=zRtKiBGRgMQ=ZaQ3 zf4Q%1k8Pz#{AgG_#a;3tThLjnvLycSLIG4A$FR7dT2= zpq0)o86{-;PL~7W=(cgM9y)R!6+rMVnh`FW#jnsb|ZrLz%3tOba$Q z*j9qA8*I6n*s7YUo;?Jvp0W>nAO(|p;9aLO?UmkIG_pwRo6Xp(MZd|VQz?`3FOaLX z9@`$<$HHD(tIMXb<Ab;m=@i(YEfa579EI~T68;bMX@cj^U>j!R$ji(FsO9stA}uOAs6`h7(V;-}Fc2LGME3$w z>Jgr6rR<|S&aYZ?P5esBjhSf6)M+eY+hfz@zMgt!UYW{cbg*1+^hVwO*J<&o+T6{D zFv>tJIas5+68$lW=iXAHn~2o?2Ah_?Tsy1BkOyjM3N>MLh_bFc9$AgXqLip}zeXuh zqgv5g4ad$UD`Bi`uyVl4#?wngu&w+j_VLf8^nbU4(FcJV?w>9P{}XeUm3x-@U{}E3 zuh)X*GpqSo?U*0vX+6EZ4^|`nC-(6_JBL^qXLhUX$jkTeBCSG$Ft{z--QX>3}sr4 zFSIq-R=NhZd=^{&Kv}M&g7%g|e(tzXnO6Ff_Dmsvl@_&MsYROuDPUrZIW`Um(nNJ&8ts+~7BZTyScQOa+o)a9DL zB>eeiise1agJ2OmO18$e*4mNJ;k5LHEaSOPm9$jK(#q8VyrchI&E4tR^TZzawX|I7 zrJdCk**v#NS?;D)E1d`N=21;Et)jhK?2)FGA*r5r9PBykV4NfM$WF`tHe6ed&0Q2Irwaph z?9-2p)wW%~(&`+xy?-}{M7(uV&;C%?Y#O_!**tzPjr z(Bj-srm<+`4sDD`-x=C<$*xe=2RS%Vo6DXk&7Z7YN97FycURf6{6t;7&gCcSYLtuj zTWSi}8uGQTPCF2IFIj?GMV-dlWI3ge18G(xmQt2JmS#CEBu;K?pPm-BU-o7|-irDh zoz+e3tw)4j;Ec+aU$vu$qP&4&=SWWJU*~>5T+0JFrRtXD<;==fSj3Kq9S6&+V8|5ua-Kwf3Mcck%9gT+a8O43DvIYU{@o%-ky|bS5#KC zc7-;wX^}thj&ytA9VuIb)v+lD`9I&FvblX7S`Q@$?}Y0qNAxCCTfe7A?8u*9>VnPv ze`^{`^V6eX>0@g=eJ)#$MZwk>8)#FWzFe?%gH2;wVNtN<{@rP8D^HJtZI7+N=E~y- z)N;kR#z-jR=h0S~H&K8Y#6! zu({Lmte}}Pmn~Nq*vfZ7wi0aa$-q|RQCzK*?QPqNG4DzwKN(Z+kJ$Yddom{1!0Oxu zHf;=~JWV~0rh(^IYo1e#`QzmNIb0Z|p1D^S@nP z1+JH}mAK_R{zsmCN1*Sh-4!hzsIAcsk=kn50};XV9Ch6A$W1(#udF+%rZ%$heqgMm zJnDX!GPnBc+EE7E2b){8O6#wQ!|-1jly%<^oTI~m+&CUM3-VaR3CeP8+~LM2+TEgj zn(!F`^ZL$?E4e)`!DHUgHVKt8MQE2)x4Osn+^JLjwo4c5Z4J43bx zyT|cjgt+O`Pku71 zrkNd)Tnng2G&S(`#r)T_^EU0cw#H7}v3#zi`CN*?ZBin3lq}a+ZUoD}+kw1K#uf0j zvK6*Bwhy*tdAVK6a*s@SUZ+GXPg!}EueT%0T=o=cdYT8+-; zvhngGpVR6bc0_OB3oZ2;Ol^qPN_j@sev~#%PVT0XNH_@qbcjkNyu|323ct<}_Dpe|P1Mz+T3-?V8*0$X8u!0Llw(~>b-UA<=H z7Dqh}xy4Z<`8k{#$)3yX6w(f38OJC9J+BuS+eW`i>Hu{|EIB6EissHbvi|%_v;1ZSn<|0Z_q5+6p zN+fUDuSD~zYh&K$eWmSJK3nRT_s`HXQd@DBmTmjBQnEV_wXM<{mg^yPxodcDz}Bd& z>_h&pQjNx6!^nPR+K?Ms)a`+`M#`@kS;SwsF_SB>OvebsM_KEJrja8;O@t#wiwk*)olJh{FmXxcVj|_Z$tLD{wNvqLU#%dA!W;rJ? zw-U;!dc2b#YTp$tJ*u6{_XE*;`8+pKNsIjD_%tPwzZX}_r2GxJS~g-aoJU;aFd9CB|5*$J-b^Q1$wdOP$&_vNKq> zSj&Uy1}$IY@5|J(!OA4d`>zVMP@cy)Y^Mapijg4n6bzW^?BziTpx>+R3)NiQlnXzR;*0(qvWXdMkwA; zs^#S>dTHu%V-{-d;OA!H&uMKJ;s5F>>&pEhwVb-}##2p81p4SD%G_mv_mayIsjXyh zMCuiPvW38HRF<2D9*UX*_SVCLc2zCy?FzJ#-D`z*1)L3hRn{}`J|6!*?awvXb87bX zfxVFk_8vn1j#RCIfqMMEe&hM))#&EA zoyr>WSDflr4g|jJWF;}!KICsz)qSvaKBfzSC5<%%WG<;{P5hbC=@!IQ^I9 zUahWOAKxWueV@~a)N;QCZL+$(Ox&fOSJr(A*T-cg+SOWHj@75~-JP0JmM`Zpjz`@J zD{CJHuB~gh6IS;YtR81~l4~9D)wH?>YX_^; z(a!m`z|*qff#rggq1j9DpD&f|1uL<&@sv(&Ls=f23e;hZp3!PER(rGFh**R)&0s}_^QYDU%#7G=gMEpCMj#M_ULGtc2@r- zuLAv8mREIAE2}9jMINLnTakN=>XzjmqZ+YqZdpp%cfu{uD^=6SMzXPbh_%=U&ftGr zEBPm1gKDdBv%l6dJwg9PZKqkZ57RtKs^q6k*-8}OL0k7-{Lcn;zpSN`TOqY&3f2nc z1ZvC$=m9KJ(sCB(TwP;2wx>ovjnGoH0J*ECN>_pZvj@6)jCS5w`o2XUNnLkprnW9C ziN=cBlV15asw&4J=cJkkkFc&9)y37wN`zX2>|CzZ7Im@T9A#Zri%!MZtz2aq>phsz z-&Om{ECp=ZWu!%|eb}^Nfu3p+dJk%z9>K_|KU)_}Q)@W6r?1w<*HN>o&y1EK^=eA< z@OHDll9u6!8Y|J47!TK6iH>2vZIq}Qj;NCo<^7k^u5K?1y@Kw_+?-0<8W#f*OEWt* z7KPo{uB{*NenCz1jKH)TfoY?!@?0NfA6M6DYa9(6WrLO4k=syj^jDVaf-7Z+5`Fr! zmP2C@jZ&tKMjNG`g$02~?q8`n$*u)fud%x<_I8*p$KF{#eGNAD$QKxe^lP%#w~))4 zdIsgPq1JG69if(IRujrSj{@a5w!h1B@|bG;Z)BVqwf?(=T41^|Ef@9u93^69mu6|0AS!xgnaS%dW>*k=xZJ%DSykBGhLnhtcO! zBl!t|dPJe9*VJk3C@fM4oFSa>V?{w5z)I@qb$erifyk> zlGa*v$@9$%BAlD`$rRr8#3fNp$JF;FWo5rGbfu6@WJZ)5u zGT2*HC&CC zlr`9LY;Ofyw5NIU8xFNjwBepkZTFMVlfJI3+a4{kdi}EW$!}19SLS|#Hw}-JsB>#A z3fAwGpZ}@HD_<$V?n~XaQwRVg{t*1_7N6FsO20Kc* z_7QAy&BczqxKulGc5G~WY%bdydt=Pb?$MuGcP)-z|<0?VNz zXn)n~H(1Y{r6pKO<#)#h<=FmyznwiZmybwo&)J>pi|A>Ylr5*^X#MPpC=t=hGXRAo8V(y_bk zoK5(hTV<{xaOc35n~l0ty(_<;BXC*Da&l{>ZqG3mW6+do%aXOyc^u2BZPW=w>J!&$ zxJyub4+Vkk*}v0T-AUJZ?m1;EuE2BZ8i7`vrSuydhk8W0fmThv%dexX%UTUq69#)T zCASqXDQm39wV<|YtUVg&(|YD@1JBW?1@^WtUuz+X15qZ*kXn~C!?O`JG6y0NeQ)*H z7S2QtDf@i^|Bb1+63xI{GWAN9+gi0}DIc#IP4H^@a&NS@oILtO-3QBY`DuW99C8b$ z))DLs-v3-X%E=?O?FCDVyx%rTs#u;5PtfkmZi`y2+yG~5jnb1@j!5k-oeWH4{kp&Z zBj(fEnzZ|CZs($%Gi%#Cuo;XxTU8ipO zCi+O~y~}u%Y&AN8|6-&@Q_-_jBe^81BRS+Vt**N+Q@bjXQP-=>1)DbY!oS`oSf7TCb~uX>74uOJ zv|q(A;&(9wE`-y=FwO|0@GBVteitJgIyf^-!S7_C?!X+}fpal19lx3(;CHsIupxdi zL*QC)39u!X2-|Q;ur0PBaP6?Rz_rJEXs03D z&Q*rfxT^4dt{R+<-{8O(i1-B#f%|}~3FqQhI0UW;zri7J%ecC*n5zeu8b8 zt3rW$mhXnR8Wgzde0Rh(AZiM}C*m9^aL@C-5Z8nPSBvk1xHc5HSNOh&8$*G6mCr-m z1PWYJzCYq-5VZlHkGM5N9`b__w}r?!0(RW3qvSy6L|Sv;a!M#7yMkrlc2y&=I0}x0tId=zX0)j z5a*XKLi|3&`Q;ZOo&g1}5Wio-b2Fj9&El6Lo(%B3exL)Z>y2|F=& zHpJeA-S7ipFQ&|e0=H1u4~v9@aH((zE)x#JV&N!UEgZv=pF)9KBOHgH2`4aREfl!* z!YQ~xI1P^rXW$RQS$IM?4}TOcz|+D-EdLY4=p5lPydYeKzY5pjW#Ig}d;sa39_i9>V*A{6Cu?Kz!vwp1@?n^SFu$fleaA45Ei#VuaZw6b>fga0)TQ zIV1wkB~fr5iGlM;Ec}pIVG%xH!v7}4<3{8INrcNt68x0d;X0B6OGq00oH*fn;({B9 z2bK~q{DSy-p4$iot_+{D3EY>Y65LEG!>>tIxRq3cyGaeWpX9&;q$WH_YQt|xE<8l) z!f#1Ec$n13HjhB$Flh)+kVfz%X$()1Ch$kn44x*<;V+~myhK{T%cKpwLfXM=qyxN8 zI$>)!Aaa;=f%i!__<(eW4@pl*XfG(zK2S&dLOsoc2HGDQX+AX5K`??2fsu3=jG`l8 zG#v%Y(a|uLj)f8}fNnYg`sqZNMJL0GbSkVwr@?3FbXb)Z!e{9$*pSYFuh6-$Eu9bB z(FL$QErK2BBA7>)z`#l~0J;L^(^YUFT@44(HE=Lp3y07WIFzo3BWNicNjD-l zMnPOtv<&fRC~)u5&4{N#loPrI7SXM61>Fuy=}!0s-3>R=y>JuV56kF5_$56A6UD>W zLIsGjDjr3g4ACBm#}GRp+9UBe;#7$CNIZc!9ik+Qrx0gAFn^bE(KoErNOH@C%mR}!RtB?6!l(c(EDMi zJ{!jCE5QVPWtgb13X}BJV5+_b%+lw;D*Bo*S6>^})91nl`nvFCeLeV!zCL_i-w?La zH-fG8jbVFz6WBrD40hBvhXeI3;ShZ*_^!SUd{5sFexdIGYZ*Jiy2dW>MPoNu&)6Nl zWb6s+8+*Z*jeTGvV_*1+F%LF2_J^+;^I=otAo!Yb2yAW~2KyREz|qE0aEx&@9BUj4 z#~BM?fpG#HZ=47x7$?K|#;Nc_<21OyI32Du7QzzaELdus1HUlNg`14?VVQ9O{L)wi zHyanhuZ&CJ*T$uAtFajFH?DvOjH}>5<7)VmaSc3UTnm3TmOw6KJ>)}5p%AhWiXmlC z7qS_a3)uo=L$*RGWIMEm?1be*c0)(VUYHuPAEt#Igy|uNpflt!%m_IOT_MMyJLEX@ zhMa)DkWRk%Oo8p`AWh+_%4f%qGU zmMG*F;)@XFFys#6%Mj%-I0Lla=@&_viK zGzqp1wZlH4De$e(G}t%P3EvHM!HJj~$C^@1OS^?@Z}ec|U} zd9XCBKl~yrAN~+F2%ZQV0#AkwgLlG4z~940!TVvO;e)WTFebbJmJ6Q%W5XxHtnkS& zJA5j9CVU#K96lYs8eRySgwKLa!{@->;d5c1@cHoV@C7h0ya-MSUj(OyFM;ocFNMp( zi(zs23b-^C*eCGXW9*U(_Sc;_CsPi2&w51G@1^>5Ytf@X*vd@OvhoY=>(Kar=Znz8kRSm zfpMm@Fy3??CYdh4WYb0Xoar*mFL)g~z z7`8J#ft^e|6}ZkO0=t+**wv(m-AqRKhA9;GGKIt5CNmshihzSnQE-SU1`ajF!eJ&W z9Bzt(BTNZ!q$v@OH6_7uCOiDdlmZu-(%{D?CtPZB!Ou+|xZdQ28%%y!YRZORm@2`o zrpj=esVdxMss?wPYQR0F9Jtq16YewBhWkyq@LN+|c-T}Ao-oyiCru6EPo_rjjHxmF z+0+D{H8q3hOwHkWQ%iWs)CyiUwSl)x?ci-w2YAoa3Enq#fe%dG;6qb)_{h`~J~s7& zg1HYQ=Dsk|oChnI`$M}qA3Dr~V77S(tY{tvE15^YXUwBuW%Fp5V;&2iHy6M<<_R#@ zJQ2QNo($`nr@|M_(_lUGbojEl5H>Q;g3ZlyU<>nH*xEcFwlOb&ZOuinop}*#Z(agB zn3uw?=3>~*yaJ9kuYzODt6_n84IFP?3ul>2;B51HILBNHKQM2EbIoONv3WCGX5Ipe z&0FDe^LDtxyc4c8?}n?)d*LVM{cx@MAY5lY1UH!v!!q+xxW#-7er-Mux0+ADZRS&O zyZJQSVLk)*n$N<0=JW7Z^96X(d=XwTUxruBSK%Y`HTc+k1O8#Y1)rGjK+bX(8ZGx> zh~*(PSsp{P;(=W)Uf9jzhkY#B z@GVOv*w0cK_P11p11!~GzNH2nXvu+tEH&Y9OKmv9k_+cr>cV-JdT@cIK3r&N2v=Jg z!A~uX;TlU5_?e{{Tx)3#H(6T3GD|DC#nJ|TZD|L$S~|dOmQHZHr3>6)=?3>&y2E{z zp74mJ7d&d|1CLw!!XGSo@Pws5JZZ^?r!0fukCq|utYsKHXBh$ch*4087!AdUu}~LL z0AnI1z;Y22VQj=?C`C+#)`)2^Ibu4rM-;-eh*>Z_Vh(gh%!L^d^PwwZ0dz+cL4U*| zm=&=EJ{z$VR*NWxIT0)1^AW3H&4|^oR>T@uJ7O)Y6Hx+RidYZpN0h=Q5gTFCh%(qL zVl#X@VhhZR*a`yW!G^y>MB?ez+~-Alx2t2=0tH4EIGGg(o78!3z<` z;q8bM&=`3NMn|58sgY-(Kk_WB7I_{%7kL5Jj=Tt)MP7!lM_z@kBd@_ukvCwM$XoD@ z$UCri!O#Ltm(QzP-Sm)v`iBAkPt6hkSBG{X6jp>RcH zIQ%Kn49`SHz@Hq&$k2i%LOE zqS9b^loKXLxu8AD1Jk0sFg?l-Uy90x9il41PEnO%=cuZ%OH?)3HL3=DBPs{>h^mP# z_k?JhqH4n-QMqtbR9*N^R6RI4sy-};Y6!7I z`@^2m`Iz!1M4m?vf{UVuz{SzS;IiluusC`Y{3LobTpc|Yei~f>*F;Z%pG8lEYojN_ zZ=$DSYlk4NwdiT^eDrkqOLQT;5Iqb28a)SIjGhZGMbC$qqZhy{(M9lT^dk6M^b&Y2 zdMUgaT?~JZUIFh$uY!-GS3?@J28uCjp)RHb>SNZ!@R(9)irEOwF=fyavl&LjY=Mz6 zTVc7F?JzcGCrpXi4XecLg|%Y#!`d+iVZ)e1@a34puyxE)*e2!}Y#VbN_KG|Z;6LS%cj=2oS#9W1AW3It*F*lG`1rT>$F}L89m^-jA z<}Um)=04mS^APTic?^%oJb`KDc>FJ$>~i>7ST3g=ZlSs7%jseBaz@yqTqtZ=E*$nM zXNIH7$^ZLiUb!f^zg!GFTrL(KDQAU8%f-R-a{oE_dPmjX#_8Vrwh zLQ|{@nqxiC7VCwHv3^(~HXGVwD?vwWWj%fs1EOriR)uS0tHJfLHQ6R1s8kHUlUBfE(kggXS`9BtYv6ThExaX_ z!28mA_&_R!52cNevz9^8x*3LAx4mitA zJq#VzqcFvK45nI-!!+v&=(V1Le(Pyi!+HijXFUsZtmk1(>jhZLdJ*PYFT)qCS7BZ2 zHCWGj1HNRv1?yYyz?ZFeVI%8(_=@!*Y-)WBTUejKmR9^|HGb8N!1h)VcCqSVH>(kL zw}!$V)^PZy)eL)CBVb=^6nxtn0|!`RVZPN02U_FcAZr2~Y)ynitVwXZ)ea|EQ{Y5v z8k}Tx!YNi4eBbJUv#egY*y@MNtl97rYbE%ZwKCjhtqQkWtHB-C8gQpI2kx@gG|0bF zR1@(*Yi)SQnhOtG>%t$b_24OMeR$5=5dLay1TR_}!<*J7P*=Vg)R%7#qszC1>E&C& zn&sQTTIJip7t42m&C7R!Z^Y^f<5Avz@BkS z;hS;Auvgp)EYlm}xZ+m9A#tnW(6}{lSln7TJgx-GjDR@axb^VcxKbDszY(Uym%+^V z%~-|@aZeP#1-=x&6&A*Chcn}M!nyIg;ez0pT{4A z>*J5Z4e=*nY5Xa;G5$2%6n_Sm#h-mP630#)I8_{+r5Ll9c$E@7v33_-i!3e)e2!$6C z!r`w8W_TkZ0^UrBf`TmuhS_3al+6mQwm4|FB|wKQ5xQ+j@EMyOR<@&=GdEqFVALBVj+p-Z)wpD^tY?a}MwyJP}ts4B;Rs$}z<-kvEHQ@$ZZTOWf z7jCiDg$Hf*;5WAV@JCxic-qzo{$^_oZ`qo_-)+s{BU^JApV$&6B({R7iEW@Ku^r4z z>;P*gc7k;hyTIm&-C&Ev?yys0PuMxJ7koRh56nyK3x_A>!4Zl5;mpK*I6rX^T$nfn z79|dYOA<%Gj}u41)rq6w7l~ux_lX7YT;c>6U11_js4yA2D@=toDole7DolsXD-^=M z6=uOv73RRX73RXvD$IvpR9FD_RVacdDlCG(RagR_R9Fi2NyX5dv;xK_t%CNX)i5(@ z4a`Ye3!hIafsK;Z!){5Xa9q+xSddf(CnRl#)04Kq8A)4VVbXS3oU{{`Chdk_B<+Qp zlJ>(LNeAK1q(g95(qVWo=_vdz=@`!VF^Kb$bR6DJIst!AItA}0ord?4&cLwbvoJjQ zJd~0zz=Y(B(3X4|CMI8n6_T&P=aO&0oa9?DH~9{HKlv`4o_rq`CO^a;*Cs!P>yn?q zl4L#v|LZlGz_Mf!ewnO?o0E-je{v{1kQ@#VCY#~4n{36D zdl31Y90xgj0_5$9P_QRKgWV28>?yE%-ahhH$RE5&Y2J7#7)^ zz>nzi!QKIGw0DAK_Ac;CdpEe*-W_hW_k`Q*z2Gi; zAGp`v7ap|d!EfyS;URlIJZc{Vf3gpOXY9k^&-M}UtbG)`Y#$A;*vG=F_5yg*J^|jc zPlUJali~07sqhc`H2B0m9deFBC^}|AonsEvJLW=zV?H!G7Qhfk5e#)Kf?Prn*1!smwJ^z10zHoPFw;>Ay^f90?>^KFNJ5IwD zjx(^#aTb2*I1j&aT!6}92G2Ndz_X59@SNigJny&*Z#eG5n~sO@ zmg6z}!|?<@aqywY$rJ)<3SPExx)eRsrx>9jB@`M{!eLa38K$O0z-LpUV6~JO_*zOV zY@T9;EmGoO%ajE8dP*W}m68Nor`TbeloZ%DB@MPqal$DnE;u#C0~e%t;ldO@EK13S zt5Yh$Pg5$x&r+(wbt%>0(UcnSSV|83KBXo+o>Cj~sku-{tqbd<)`Rs^>%&H=4Plei zMzDEmW7s>j2^^5x4CbdcheK0a!eObc;JDN_aAs;dxG1#)T$0)eew^9`?oRCnzfbKB zkEiy8CsKRClc{~+h19+7OtSHVigN8xhKLO(C9;q>V!S z8bk`yMk8(kk&|g-5x)+RlW7HrTSKHaZ328ZZ6aKlHW?PBO@*t{roqy*>2P0KAv~Nm z3tmr~18=0wg(2zlVe9k-uuXaqY@5CaPETI~3)7dvIqAi4Zu$yXl)efsOJ5C()7QY| z>1*MN^b)u-eLY;0UJBQzZ-g7t%ix#ko8i~#Tj198t#D`hcDO5jC)}OB8-AO<7amLB z55G@82#=>9f=QSARya5xOx1h~=2PQi2!W8Fy=yE=UZs%j@cRqpHP99%mR&f$o z)hWVfoqG7Z(+F!iLt!mvIIQh7!#d6gnCpy!FF0dhU1uzO(P@PpoN=(DGXeH=Cc**E zBskJ(hohY-aEvnzj&nL;fzt)YJ3VlM(+j6M{qQ|!Hk|LQ1V40Eh6|ik;Sy&x_?fc? zTzp;=CTDF}=FEkAops@1XFYhtSsz|PV;HQOF##y3V>1@PaT!ZsLB>)zKBE{;%vb^6 z%UA`cWvqtpXRLwKGuFZx86~hVV?CUiQ3_{eY=pBj%HW)g&G3VaEpTqeR=6-@J1olB z3BSnL4L4@&g(ouh!;={Y;i-&6kar!1g6k+Gu49n8jziIP0_t3+px$*F8eC_f(RCJv zxX!}}*992qx(Jh8mtm&sD)hUqVI*i4MBVGU0o%K7!LF`5u$${He8Y7gc6U95JzS4r zPuCNe=itag7S428 z;XGFyobO72AG#9ZXRai;)@6t5Tq&@`l?Fd|Im7Yo3q&2_a=~pb58UqZ!aXiO{Kl0H z54kGAZ(Wt)VOLdn#8nL*b=831xpLq!S55f6t2R9D%7s6=>cZ2mdhjP#eR#&z5dQ3H z1kbt}!(UxZ;6+z6c+=G!Qg=%zx?90CcN^$&w}YAP4)7UwCs^6t1wQBQ26NoqVXnI; ze8Jrd)^+!RFS`4}hVDH0vb#Tg)twKUxCg|_eS`&y9{o1 zZ-(34Ti_n|R=C%_9qx1Qg!|pQ;bHe)c*MOQ9(5mtKe!LU6Yj(Cr28m5~bRUPO z-6!BV_bGVZeH#AaJ_9ef&%$5b=ix>71$fDQ5&q`B46nJb!h7y(@PYdVeB{0bpSbTp z(Q_B-JolmA^AH+5kD=M~1X?^iz7>k{5E$(dVT?x)6Ff#}^Mpc&Cmg1D%+TYBfSH~s zSjiIut9fE!b&nO+_Qb(Do&=cdNrW$Wl3-nr9X9f$z*jtJu(`(xTX3xW#?u&n=4k>qdYZvap60O3(-MB^X$8Obw1Hba?cg>~2e{kQ3GVT9fqOmO z;9*a9c*N5a9`*Es-+B7Llb*itlqV1VXO_WFGdIKanOk64=2rM+=61L>b0^%Exf>qM+zWrm+z(G=9)v$<9)f2x55tR@ zN8z>1WAJ+Bad;>51pGbo6ug^x8gkw<(BM4_jo$Mx#Crioc`w59-peq~dlkleufYWG z4e0RRf+^lRFx7h(y1n%Rb-hMd-x~@W zc*9{suNl7Vjew23QScRS3~cO;g|B+8u!%PgHuWaJKHfz5mNyCZ_1fXv-V~VcO@jly zPB_f#g2TNYIKu0NBfWk&%9{<}@m7Kb-pX*iwumzR@HT@Rz0KifZ%eq-+Y0XTwt?Sx+rh)$ z4)CnE6Fleb0?&K9!C$=H;RSC`_^Y=Uyy)!%uXy{yyWTu_&)Xl~_vXU~-a+u8cL;ps z9R?qJN5DV4qu>+oXh?ixVYIIR#`q?{a=wYs>YEJ9`=-JQzG*PYHyt{Bh0y7n1v7ke zpvyNGX8PtsuWtdYZzt^K+YR%4dtpD{e%Rl45DxGi zg89C~aH#Jn9OgR)hx?Ah5xx^}tnU;Y=Q|Axd}rWz-&r`#cOJg)y8x&AF2WhU%dpUQ z70&ftgY$eh;77h&aFOp0T;{tAi+%UuYTrZnsqZoT-1h{o_wg27xjq6n`$YJaPY<{F zjBuwf6z=kc!vj7uJm`yn-}|EAabFDl!50h9`mFGrFAkpfCBVzRM0mxQ1aJB5@U|}n z-tncu-+fMa*XM%wd>;7N=Y@K|9~%7G(B!WK&Hl>J;;#xL{MBHjzXpu*=fG%xO<3Mv z8^-x_VFiC(nB=bqJ^uPI)87z!{f(f{-xyZ(H-VM>&EPZs=CHcIC9L6Z1#9}-z*_!x zu(rPgZ0PRKM(fw_lIx#^Wj_mL9oAn z2pr%a2J`(R;AsCSIL1F3j`fd)h5iCK(?0=z;GYQR`X|GW{8Ql~|1`MVKOL^{7sB=a zS#X1Y4lMQ0gEcv$nvHtgSFKYdZ|f+6gULyJ1AuUKp9RA3CxQ z!j!B-(3y1@W@H_OuB>Cwopl^~vQEJ4tW&UJ)@j%{>kJ&4brufGIuD0uU4SF9F2a#n zmn|5J4$-5_x(b(NU4zA0H{kNDTX03z9W1jFqOH%m3pZ!ohug9q!W~(UF?T0KK4d+C zd$afmlfcg!a><_a7cCn9G0C33$v5ptZX}+ot*;bWv5{~^C9jdvYm(*K-_0#yAT&a^klL< za8+0dSew8^cA_xB=pccm&>)<~fy@&^z4LGjKEBG22eto}Rq-}XNE?GJW?b0LYkQ(%}aVgRy zm?}*gVB^xHNds+Mx-h1(v>kbj0~V-ZCo`e8djGau!iKAVB?;X z7Q-BA8+=~c_O6YqDeZ%`q7lT&Qm3(^%>S9%0rlpf8rarGoR z%f`JVMZ@}1^lTeO9ynk_sUmz?sskHIW8f>&n0Yp?vGfSODpj9vZ%*i0G< zUz5hb=F&>oLfQmdO6TC~(rwsEq95A0)>1{-MymLc4PzSm!FE!=MK-Rzv?1XWZ%Iv8*f2uk%1RqXNZf{b5?y7(2#ILeACJ{-+yJQ}%$NGXfznVoNV*LNOY{>P zH$)l(hf15^Flp0gHg34IX|0VLA#GY`!{~~WaFld%gN=Jfa+lh;(UQB&#*L8{!?Dsf zI8HhO3#21o+PLx3ksUT}f^=k$jeA!L+iT+{O3`qVGy_hSX6&l;^>8On>l#ale(m6Owx(#Pbw@=x)Ia2hGHtqw-0q07N-)-DH z$??F(&6k?O52emFGIRGJ6BkXFKt(k8e`+6T*|lkiI^OiIM)lQ3%{MxVsP zEmC}3BKNga5pI>%!EMqJxLrC2cSv>O6EQ-iGu$PeguA6HaF28)A(7iFJ%anBp|(VB zzcdCOkmkXI(mME!v<)7Twk0QG6w48KSUQrL$Q_ZQ(-JYFWd{6C+V_7^_U2KtEPp~* z&U^1(aK&ZRD=rU2P!^w+nUz_UGBc8EcfH%)Rky18F3-`Tx+=T7ez%tXRaM{R0g8y? zf;%|k#y_CPqknRae{wuWkLx))ZfpY#!vF*GV_4l_1V7)1Tx)xeJ{^@2--wKijEwlk zH@;i&`+J`K7{9;w*^mA5&yC;r?1z8F=f>}U_QQ?OjX&`0hnt@pKlW_S?;m{jJNW%W z&wi5MKm2U!eQx~tv){t+A9?n>`2C4zzv~A-Mm_UjF734bm@uHf?5hVh$ziU@z~)QZ3V z9Qbej&x)k+-#&4S|L(~<(z{GKO2YW!Zp?|br7SWW%z@B0H-hy55VQIN^_A`SlanasAOJf93mr65Fdk_TbO*|BLW{6aF8<|4aBwguhJqS;GHE_$!3J zN-&=O#3$cJ_=NB&;WNS$!c)S}A^hB@f9aFI?&)9to2(9^r2x{H=t)?dh9O|8~On6aEgu-}&@cfBJVlO+S71^gEya-A`Aa{`{xk{q*l4 z{Jl?q&8L6g(_i=L-%t3Q@C%;)hEIRt)8F~&Kk)R&KmA37fAHx~eEN%@{?Si=3E>|i z{KHQ_`|OuK{r=B>+0$SA*)M4%2M9k%_#whSPWV*>pAZm2LPUt4{wJR$Pyf@;&Yu40XXk_t;Y-4E!Uf@y za7E}6dW08*K4Cx@60V>A{?A?#UJ+gs-VnYb{1b#9Cj66xe~K_7{A$9Oa6_07ri7Gm zOSmK46J~_(5Z)5zgau(qSP>ow-zBUG8^V_GNO<@3=RbM>^cOz)@btfY^6}|^{p9PX z|IL$ML-@6XUq|?-3I7b?*AxC(!fzn_bA;bW_~!}#0^v6i{zbySMEI8p{|ezZ6aH1g zzef1i3I7J+-z5B7gnygxTL{0E@b3_Qgz)bYejDN6BmDb>|A6ox68@v7@zbCFzF*`T z#*bAQiI!d$1An3j}N2X~ujCeU&e|*@^R?9d%TWz*>vj!|cZ8vBnZO0Ey zJ8;@byB)EkFtC20Sp8Uig9@6z}kuJC6xuhre zkIT1Qqv6Hi9oO}EI{UzNG#YHj+u6ilug4!d%h`7L@gW_|zD|G8w5YVxi!URa*wuI| zm*d6Bj0eMh>|c%s{>8v2?KnXghE3aSH|<8V5k+RxYK1}5a{?=gnywc%qh>@w`B+9A zM?n}kR_L}|d0i)QlE||fUflLAYHGDz-=d-uZ6LEZ;wKzg%~R#vleuK}ZqmX1*c|mk zYg9`%B`MG_2qijAH~iWyi}y>KZOdnX_)+4tE$h&`Mg(w%K-CO}A+Uji7Bc z121f}1KV{&&$WD;g2#sfnJu&Fd(FgdH=MZPguWX#8j0sqU)y64_(2?4PDH^=LL+KX zXS3N(;>21Im|uFbeoRlo4y&_VbJoK70t+x`8AWk zZtzT_6(&iG4iA|*UfXPVX3I0fD6pg_Y$@t8q9{1%4|}7l>x+xg`K2F@2Isyx%E5j- zFs=3|ysYPio?|<%Yc?XsY1>}Q4P38bwt_fnHJa@>a2lp%23`ZMTH*&m+ickZ1Ghy( zd@u1Ww-q%)ItA1cxNggD7zxqvf^f&Q>d=W5InEP2t0mG$?1B zoiPj>#+MD_f|1W4Y#4W!(V$^GCkzNtCme!7UNwyL!*)HMY>C~a+tF*vc8C73)4dus zMwNs~B1vtl3acgTYEHA7aHDl&P1e8y{F)Ov4P!b|Z9S#$Cg6BZmdTN}QOv&&UW`%pfcDn-pw$z6Bm{QONS6 zmf!Y5tI;xpMvE1s)h3=e3<=Y?B(RE@<&%xG?qDcQF!bck76|ji^kd2!iSGnv*apv9 z?N+1JW^kHbXv)xvf|lh4QP6fg3Np9aeiXVaV?nza#g+{c2+i1OSf&;Ept;C$d2XmqdNJ0T_SS0#=KSX)x?#TH||x9l34hs>w3k_8T7fplLF1XrRRd zjj$P5t{b~;=1C)JM098b@&u*YW*h`8)n=Op(GmiyhG{ecGj1_;Vy2bVblQ>3K-=}3 z;3_Zy-H^C(%cc!}ocLaYe76+`e%x@qpc#OdS|%8$?Y06_5S)Ch2%;h4b2X?dNnF~} z@_m^{e&_|R-3ppXLcsxn<%X};Btht>)5l5bnubMv?Z`{4M%#%J5A0>KBrr?OQ1D^Y zX6iQmmT7<^qomQa!*-kb-SWc_nxYlBej^APu1y6zE~cQH*j^A?o^MizA3L_kV#D}j z>hryLWs5v1=r#O?)3hv>q6VlR1mHDeuNB7JzG$8+}HcZak&`rb#&)!zSTsiGfFmMGeNw3KfDH{nE?$m1WkDD06b*biQjH}Y!58k20hylEi9R|%=ftlP~D-^0N2Ou zmX|nzm$V#E3pYRzG{cx06Hxb=sa8iWy>+c^=X;P2DDONDpX)oggyZ?-aX#Lrm!>h9 z&miB440@&!KetN zm@Xcq&wzKPFD9Gb+u4T~;ou{CpAWz$ugrpQq3N<0GtSawy5<(5LdiT|uHMhn>0Qdu zTHPkAHSo6wU~fS3CB;)ou)8aB*pHP7wq#`jD!fcMBsznx2U$=B*Agvqm{3DsA{=Y!ofEZAf+iB@xdA)KK+A)KjTX&Nun^#)D`pMgrUDYaTBa8ZQ8 zK_4ClALO+#IKTcVOc!G%tt&cwU354xd2z=wGnkIaOPaR8LTk9Zf!&}B%9qgv<;!Ro zM65;ZW}PEbP*a}cNo*tER>f4crmb`3>*?IBj;UNXhw=6Da_t<(*UMn0m&0_7d*zGj z`W|#lV4yumbuPsh^~(CBux+Db$w z1aGZ&KYB*+^;b*Q9l@D-?B?S(4PlM}%+_9iyIsq2YZ}uHKam17KqKIpeTlPlrTy(?dgU(m6Dm*;z$8pjboU7FHn4Q3L6&*Z}+3m^={qFTu zG*D4hwZIPJWc~CC9u`1}bR|`wT}k8^SK=kkl~ldXRBg1u-Uapk`T8B`Y^v1onh%|D-a0rt9(Tc656?y-#86oN5!9 z3E`3e31z$>3?v+20OjCA3?TB@^I1l?p75)8d_;ID8R*35qt5ajh*1)63DXo(Wj_7x zia3*NyqucuRucXc<{j5@c4f=FhPeVHh)2WK=(@9%#6>j`Y|hfHhWDAv*E3b5vw1n5 z&+^o(^=zAFIpKXed7H(X(72`zPuYfH#ctVw5^uNt*!FyOoPGj#j!kEiJ|T>ko7w1t zHzIoCJDU!#LCM!J1&z>-<7TUoghA}Zkp-g{eplRbL%(eXFsu{TgDFZuRrhOeL{vDG z>{nshwp7A)ELSJ4I)kB(Rlcz*cDy~*5rtOJw%KBbk>mLhjDWal+ZH^7&~HSc&&Jq< zV`v#*n!sTf4HG?#;RwW*<+R$coI}fkAz;HP^x4OkO>Be3q`j(%Dp6^eN;6(YQYaiR z()oNgmiQ2s>{=pzx{-@;StZ54-||{^(qJbmEf{%2^p*ew`nJ>kgbjbQw7Eb8?4B* z83{IgACt|06V5Fk&$uMeac0Yj5H*-EVq>$_N}>qPr*AjB#DwPnI|1$r1;b{OzKr4B zH|(el>(Vu0^0V!O@$0l10`P8N@xY^7-p$hvOAj)K)v^~nj}qo3VUqP3Q6b3B_TKb- z57MEhW%H!(;8Jd$EEe)Llkk#9_LxF!X1HAuf0Sk$W3i1PkIhppzF!~>|Htp4{WyM#e=G2cRNBe`f=DrKGo~K;2-z0ltN1AKA-HeapYK0fqT@44@dtP%xBwvsSMm4sDI*wsX{ns7)IU0P6g zqomUtm~EHLyy3m^ny<%4-BdD*c1X!0(URK|^&=P_2KIBw9$otIcrLoHNL0yBNrvU_ zLOx0@b;CC#unS<3$#(%nC(KkrZ70Ad&UONs; zbx+33GQJ}fKt&4#sT!+fm6&Gi6~uJ?Z7fYpa~s4ob#mj&%$<%#h5DHx{yN);7J~Vh!mu})(aOlI|T;>c4xB<2rQUw2irAhYy@jTnkGNO zpQo55X?`>zBPlYt2(4wa{MtkbkUacA*Kjdmr!^fo&>jLd2LTAOIomU#Bm&3W`y-=&~1bGriMS}^(=337lKL8TodBDX@MVsQB!`lc1y zb{p2XeS)O14a9?S)3f;?ff*oHbM2_b>(a9!tiCp%hiluXpxKBM7FUn2*m7GfAG*PU zNr-GCVxP$}>Uyz9!Izi4aP)jY%tad5Zdf)P_ry$){Ir?~SsOllcfMxWYPBQ2b6}%; zjWiHLW^Y?4r>e5 zh8U73q_y0IK+19v=OP-6Ac|}xA>C@k!@Ud`DrJX6?!o|O`!o0x&#qw z5D0L1z7P$JW~z&MJ~U4p5n(Lv5+~<;R#~8J&118TD+Wc66brD;0!)e^3$LATWSB+K zcsqV+8?SBS4PU!l%_<3V#PdYHSb^0N4BhfpsLL|pkT|h!*~0dc)va<%Ezy$u6MkyT z6r=Hmw;`|;*~WxxI;{;+@zg3#<7q0!{@qitAC$hsB; zbOd^G6U(-oW{`NmT+c%$2WDeu(P%2Hfrdnr=y4)la^s|J+RSPQOU6H=lHurB2%ZuM zNxNygPSbBD6a}1<^1HA)8 z1|br8Q)uDHMj@cx7IlPXOu+#GJb0>^V6JAdJ;@WOpMXR298VaxSptONpr?Nv0}+^aZilDhg1Z{pG=Q6h>;XaU3!=&Tcs7F!oYg|>@Ggk~P^ zY|xMavPC(if#5f41}#(vKvgDcPoOPi7>?y6C>uz@Tss9023)CXlI=dbZTbz~a~{um z5P1ezm=YP&L!!C%3A!NQJ2(fP#%7iIR08DRx?NvCJkC zSQLpEWGVAV&vLSfDb6EJ@m^H~j zwJeV88xH| zW)AUU)DT}3n`p(D1p?DY@2YcveoyE*xpnpMkqf#6Xe+{15Dg?n5ur}x!=wRiHXA@A zQCVu8`b6-eD*}Jb(o`w|p??`)Ty*@AZ0tlmP8gw;!d3NwZz@~S75Jv2rB=bIl3Fa5 zsS%ti$O~0<22K_I)&&ds`Kj9UgDd?h+@x>Ol_!c-dhtZ5vICD4s`cHGGCSRNq*SfP zj+7}n>qvgBHA-`DXPi|uK6bNf&)>}~9=w~e_ho9I@eKXIofaG&=?BVIzR{^_rRDPG z`!nr8o!_oxbpGwieXGaTzREYfNYT@$3Vy3X(k&6v?r-cCUiRCT8!uPOZ?14}P~^k) z(Dyhns}B^beBmRN)keXQGSaZ}!yYO0Es7MM{YVwHFMgy>>$?vk$p%gEQVB(THet1eO@UjM$(VuT3fr0H3du-Vnuy%Y3BKR;} z^u6Kwwb?8AX#F{6h^naTA|7>NVL(7yUbECl-P467)9;5+Z9y#akgoHuP~ZwW!#yaX z=^T8c6x`AKK=Xvcv#lyzg-T%!hCkt=go@Qh!d?&FjE@epXj?Z?-11!4=PghygCGkd z2wpTa$?;-%9|6jg4HuDwFj-vmTVa$)!4RnzJ5P4B9{So2j18#dX3L2Kp;S>kheu;$ zqktTwiF$vN+C8?Y@MJ8waS4p2hNz^&r=kv@%_?aMnhiA2k*(OV{IjD)Wfi6jYM^Z5 z%rNjQct;e30yoZSg>XmsW{kI<5Zj6uQVgJ+7t%D|K>n7DkV?WFRT7vgl*R07f<1Ye z<5UxFHPMoUX2qX(&dy1lB?XsWk;J7*2{Yq{CKJ{Z25UVR^0b*NhftttY#1GNRt7I` zbv0KviwcXPX*@1B-knU$6n(!^C6}|;yFZQERc<%FWHIS-Y zyfN*DlTrEM{g{8N(Ob@oUE^I*b0vRZA2%pWxkO3PHA4?Wy8Iz8&l<`uDC?+c{Vb>WpEtH2*_jfR$Xu!;4 z6g4CC@`ZVbs5=^6Si3FX9EVK>3XhXIDXJX zqzMNyj46RFQUjIVmL*EPfyZ>g00l;|V_2vw`f!$8Hq*^<+g99)5EP>Q?MH9{VrA74 zQ?T6apu1+X+i?sZZiP;?^51B}F)~9sn;;s> zvK+;)d)@v}uiao1>~lt!kvMP3hc>MbO@^fL+Ws+u-r`7FoYr+1pD_p}s*PXATjqZ1YJK+kE21HlMf>ImtEC zlQ6Mukc49XsDx{yZ6QVuF{VaHSzJHF#0aY>K$sW6jI}{L+;yDULnbCw@CEIb--J=h zf)*o3Vs1yMLSsDzvloSFtJ!o7CLR(7VI;M%YJq#e#k62lI;_iRYK!b82q<{`ag2Z? z9E4pYE*q0&PJA^d9D8lC*tQ1So=BY%9AVyJ zX9;g8?oZ`1wrpTQ*Dm;+1p7U zDO=f+ovOChtEUR8=NFxKs^r1(cA%Btsxm25?6XciRd?pMDk|^%tqOjtLbU;Ns)Yw< z#DRXP4V_aJ>Q}Ce2^nVxDpa5D+ZC&fnj@9f2F#H%>Vd`QJyNJTOpX-!rYdTK<47IS zmdfWoQtI23DMrJII%;U)z^AB=fuq%EdQTB#N6Hi(lQaCPIJ{`*Zstx`>}J>cU^nv{ zDy@vJ+KA0~MS1ho!1!w@TN#e0s;!O5Qw7!Yi_SY$vN}3XmHSqe)yC6$A2g!Easez*;TC{J?jv8C~Y%_&~WT%lSmH%1}5`sx}Ial&KGZBZaEp{z#GH zv!BQ>zR{5~wU2$I%(tnd_{2x*ID~U{z5_+d4|}MZlEo-f`8n31ZBR2ZoOC>g1eDj2Df$Qh{;FBz$l zsxVR|nX7F}ykx3MO0@{D8AKoSrZrGjRGzh33lQCIxroLAm*YDhG7~hoT#Ug@Ttb9S zD?$G)u~Df)gWGE)5qclEjKEe_Dsx(FUa?DUMCg%)u?ufA#Fm`h7En~HVQAtVBZ|K$uqkY(z;E*EKI&|E2xxe8 z9&9Mo{9T-d7-%S=Jr{T=?qQ2-;m06u#11-?*c4-XU?SJXNIu{NMPDgIIi8Iy+DsVu z!i1BCpwwn_13TsrMlAy~r1LHG4&er)Tj}9V1Ae*#(-^-2r~_iMk4h?vMexXBF`zz= zhYvLWu(~%rnAE~fZ)42gFmVAP0(U>4AbOuThk%of#!}0{5E(^1S2Q`j#I?`{L|did zVhw<6RxI}|gz`@s|rVj08NHLyx(SZE)b!knl3(Wk`ULxQp;{uvtW7OIy~NJk3$%xvY1 z*Op<5gBN-gK5Nnpd>^i+?VHi_R_g5i-?R?rJm~JhkAb#)JJIW18VK zVo}P4v4Ts8W)p@7e8~I`BI26^CA4PC@FV#87Ut=&VCir;zKMgf3=Dsq7rEl40UmQm zK^LYi+*(XiqE?9JS{R}9>tnisy^84Apr+&U*=ZU9UsFva3>aQm@I7N#R{?Bk3~S)( zMDSoxPDQ}rP?*5n6rEZ$H?ilyDxEhLs}zugiNhFp)hOh64Yy@5YnTG2Ft>38f=4Xz zQxh|k@w(x|j5WhV`nqMH)@z|2hH-uaUNe1w*9#A(Z-Nv9?NXS(c(viNM#K}6fTyEm z6{DKkf+xlFGZD3f=>4K%+JqBLK_+4wBY)vE;Y9=2D6Np*LKK6R5UoSsSH4n<{-m44 zOGuj}Qx-!R%zCiix2V$M`vhpg*=-7jR>X9|jR2Ssy=cBO+K7%Xlgn4gLfmlp?UsSN z8ylBG7KU|j%5eqeA&5y_^azPMruaeORVm1j!Kj}piW47Z54{@UhY0;)kVXq1B8e5a zC^@z8aYVF%ag!(qHv)WmcrH#o#CH$hJ!ys^u3i$KZ;r<>9EjnvsEsZ(`oYMh7)kV< zup@Cq20r0SwhUPHXeXm23_hkNzsUd$Q2>nKy+`c;O+ehJpptAbpB>bjaSB5JiZd-7 z{($&k%)3efnUeLN1d{X1EXf_z(ZwviXK=JAjv?<4mnxOTg$C@ z#!7Jf5F@t0-%E(Tw0vP612Du9PL#Ba^A?DyrFh=Vtr9C$66UCqu&N2WnrK!NPBr0H z6D<-oY}5i9(Fj5*`;ciqo(eykrqwys0MM$UE8rkA7MLLT%0UydW3_z8Xl*$w-DUqtjvwB)dIuvmx@IvuUB{2I@hHhkJG?IX8G!kj8OXoI+E6E+9 zQ{2JWv#m_xGQdm$pm|h@qdw^d>bP9MokpYIL!J+1FV2Au{Ki? z6fdLzYNHfHRUV9k9F6IN3SFy#!yo(=fe7$3*1{GKM|a?jQ{P_nVhhH8o=}96N+<(J z9UE_Pj&@=ck(o;th*l&EqzcIb@j|jdyopgjj59Xq4A2ddf|w@b+JqSzKr+b+;rm$a zNeh+QGhX>rYenlhiz}sPi61B8$OJ1!&@6Tnlz{-8br*|;D8UgU`k+xWP7q19S!jz5 zLYvk#!DfQ)aNUL#gfgZG@U)fqNHbVaoRDVVwuLnc1dpFRgglXnS2ZudHG_w1Db!6J zap8nV7Zyt1-NOT%%qW!Bk&dv+<3LU%wxFmMsMSS?iY%4UiUo?vfWjt{)_NY~b(^8U zC}F|i<0G=fnuLN_YT!i@Rcawo@M=ekpzi2Vbha_5;4QHgfkHPD#4oIIRtvu|Sc$-s z#=HeF3#2{nCp~Otadks04MtfDBoC3n`{5icjxp;@u=R;pX8go)SwArop`gWT9J>|+ zT`&dIBovWoCLr&{&lgI~iOo7JZDd5oNM)#?4W;b(c#wqXr921*L2(nf8Ml>%#`Q1( z$$%7kZ7~nn&K~9;i4MRchkQU~`?XPs2AnRk$2?#=RLQRG_v=}*MVGq^e%*fdkt|_G z9OROmXckE3ShMO`d(GO4Crqj!Gd%v1qZ*Li{ zDC~-dj;r*24+o7{n`!tZ-WyR25zS+P_wLuIJgYmPA*r$R zTc={DCN~dgY~`^-$1ZH_fDLLcOtLg#K)!`h+c=3BeAP4w~}VzM+-j36^96F>Oo} z1qF7;_+9kT01EKe+CZ7XLw^BNFm@WCAc#fF#e5?O(R6UcQz&~!956EXD45{x5tXdA zmoe2bXp{5{e$&>++h=;<&H1(U!vf zAUay~gJ(nZV0MPD3utR7M3AfU+zV+=#Amrh*+vZbvG@V;i`@Z+L1^Znh7x1T0UDZj#%5+5JqiO+Bn&UHh}D~oMiWnPg=a|L5Q<4fr4X$ z$JQ!}VJgUO(la2zP%y#d&WvCKu(4uWg`}G;IC6FI9qfyj)WkE+j}6S%o_2iU6_%LU z9K#NiW>+2bdP;GEUnV2Z7t<`y_yMdI9_Q%~89$KS*TKydo{Mm6CC2j+j*w>a%?}w^ zH!+InDR?F9DN%o8=*mV39sw&>;Lu?$)ACu_;2NR)gCkb3zl~2)K8JWqi-RWCh3Exh zUkZ!CXi|(F4)T4t9R3V39& zbZk@-@bk#TK_?0?g;<-g^+7etLk|g~FrFiZ3s8aVQf#~qL!UKSrG2z9m_Lk6OT0a> zcf&jtM~kXjtW?;yqDF{CkPijR4|)tPn81d$0Luu)tQI>}I*&<$ZDl0uvFo-&-{|8H zXUf)HScUwG(*iDo1=e_6yEorSC)?b80PxKmXlIj^>}=#)ib3`KBOvye!fC)?F5?^j z4-hR3Q?X8hc)|9IkHGARe1nYzZtz&h(T)Sd;k;@QR+b13jvoPS;bF*_^1VBDFbMYS8bAg3%6rT6wX9Wa#eOs{z7K zu6|Nb(3OhvCl#G=sE~fz$s+k^E9ldMjroQu%4v6~6(?_&%wnb-x?8`)$s+O&Ckvd+ z%zLsX+S~1g+DJOo%<3RIl&`*NIq44-*%J&NYDCeQ#TZl@ipt2yFhhOJ?-u$t)f^LO z@1UWg-%hoteDkBF^6yZL#N9UQk-%?tUK}b^T|}g#cgy5YDmvj%A^o(IMfT>-?t|1v z|As2+b7!}PlQ&CdZD{Y_t>58fk-fRITgS<}^PVimz@eVpn>)LY*quAO`KlYs5p?(& z74&?lK+%yx^6adnl@)0Kzk4UQ{6Kq|MWuT=wRb*{Tk3!u$}Hb?FE{UTHA~otD7PB5 z7VD4BZ$3?qma5K^gN5>k74Lbllz!mpGPS94w3f1~4;HCnwu1#uw?T4?(R}cJ{U)c& z)F#ZqT29}e_h~U@4%Sf{KSxTGW9VQ3d6~+jI9TS}l&H)O8E!k+zv%MayrUVlSKGa- ziV6}6J7axbqOm9?zm1^1xE0I22c46a&UZBW&6j@MQB zw#6O!;%W>!XP0a~udmd`6Ti@^XT(cd&IMKR3|#2*WCeINoh=a=uyP%)Dc)anANoDs) zO4xIh_Y31fJZ|C0C6p7ARtVi*PwuOE`0l9XOlqn6;T%QDBNg!U{BGaa;y@gL^0!XE zq}#`bt5qLQo$yV!8K6wQT8|$dAH=nopGyYwM9nv&Pp{10`G$#9N(3#9B!M4>w;YkJ zIq*9!Kgi#@E!zQQ7z?Mol&H{-roPQK{;K#vNlY?%|06#bIV}v=` zL`g>k>>M{?V(N&LE8;{A^cWIESQZ5_2Sev4ggqj5XDAjqK72B?DPrQN8XyXWmB6Fn zQQ{30X$K4r#PE2SLhnY7i$GR@iV$)da+?&yf((I+C=*5e32~S zy+=*~F}l6@s(02yN8n_=l7H6yhC-4Lo(YVH$L-)Aw^NscfVrVOp7+fWaFL3uIUnF3 zF;FZp+N$Qe+;tO_tRkM5ou#us#jAPsDPGN~A%<#3<(BNN1$6|O2T*BpZ8~Rwd^!hA zVKr-I3I|9_^SK=u%k%>fnZvvlep5x*Y{MJ0F#lyh#W4rRpeqD>3{zrwqX;BJ0}eQ@ zb(yzvgjE2u685W&k38-{PlEA`v>5kGp#f7i!1YiQ2^?N>g!c!Zj^k_4k3nezwtt8k z0TMp!HsvHJIq-=Cc^L6X7~oMd2VjVzD}+7_Hpwjt!b$bz%r10`_`ooEVbWS5hMFeE zTku&?k#ZdPqXx2S)P9hvB&cErOTqEoI!!s`%b4EF??ET@Uj!jX?TE)bX&Kya zaeRbM3p1Lx3y=w*1%PEe-yqa;9kGu1z|%}TgcfxlIJr)%5LabpwhhX4DpY2^d(rG< zS-#Ilin0^3Ozu`}W@MywXugeL@!IGdobjph869;R4^Z!TGunJ4q!YnFquDea%j1|r z>Wmec6`_IBCroMt%%V3YHqh-Ra&H*-u&5CzppD6TAxc?vm4Tx%bO+%72QGbu$ARQevwZ#1LO-#{XT+7#MLA`~)lGZ(fgh%75){BW=wvlx*dR?iaBT{1bPzyIQ%+9MJg60tgKCd8P2sYmCepZg3 z^*l5d)zURQUd^afquN}h!7@OOv_s{fkYS002R~z?r-Gyu>ZvJTkpsp=BxGaJYKI(T zW<~}s&lrK|&5B$WLPLa-h@TuV4K6lOc?3nGXAyA*kx*mcKm=I@B=ysp`=PKpD9`*6T*?Ad{Gz6s>Xa<&jjw$kRtlmVK z5yRgW$WA0SLbRazK}DS&KVA7jsujr?S2oUQ(;^n+T}4wW0>z?rh~}cGu`o-6$gsfb z=o5xY+6L)@l$H5}$_{HE?rSj%hU5YfimOFD65?7wyneGFAWw!6;afmhisdm9WF&=rvVmDN%gq9QM2b>e? z@TiF1q}^z&B8qHKF&{!y!;vzgSIdk?JrxxioUca4SEGP4tww_$M3^C%va-oZI_OuO zYf!egDM8(CKN@}Mhuxs#UyTq4cajc8hi`gpC;btdBn|iqf7choxG&WYyZYh}DI+H} zjLgwX|DwYNN@bUD>j>OF0yjq?$ExnvatLY{WxpD6V(dlbw&(F1B$OB7wFat}xuSn) z-Fh<~r4Mo{&YII=r}vCHwHJ(x>1J~z=N5`E{rc`cIb$& zfQXc|pK>Zj1Oj2TF-Sy5y9StVo&I6yQ<1oOG!H@5XYOs$)<6xk}`&tC5ha zBGiXYOKD0XK#<@b?CowLo*_HLte!E7C6)SoAtpo=FEDPcrE#CFjzf{Wk#3wsx0^9; zNM@6dm3qo{(V(oZJ(%=KXR~=s*Vj}-x0Q)m0ahLNsKm}$sX>{-Be}?0DyB*;Q`pZtv5zmTSuy!Q`&?AX1KnZZX?R-(TAHS=z#lxn(u;pGh9o7{L-bVd#-yC;WaeUvAqmb`0n z7&q;L@-EAZJmwL(KN#PsR?9D&Hn|9xAxMmYqa!p94FDZysOm_R-j30&(}`sEK}RZ$ z>OI~tNa(ce#LnGPstv@Iw1($qY{;G$~LECUKnIoZl&DnZha=jmHA z->P4R2J!6W^!_wUUykK9YoK!E?&k1-N77`F5H&&QOP#G|c@|gmJBt_2^bI;QgVE3|HqkdTSi}(u zPmyM3Q6Ut8WXEafchA!CcEej2AgQcKs8?XvP*jxgJ%4+#nvCZfQcQB4+~|vbk!&Jo zIeL!h#9LLHR2+^U#y7M1Y%A4IstL)x8ZYpc??0l92}4GTEcYPjX5}if7eZ+a^wH<> zl_E0aav2ZLyEMMfu}-f?J%2EG1zDk{Qk2os<~W8(0>u^w9EOR(3|{F`XU5g5Sa0Aa8`UQiwbYiIORldyvng7=JnXuW2b}%ohC+C!V+O?*v=Zu6@wYnu~Ea~BXSNih6=c_f^{gW z;PCJ8LIg374WYs5sCZ1qKnvw84sG%<4MVXV$8{LuK;g6NJBHUj9c#$w$S#lixC@sOVeAiJZmOWJ2=4$}#EBHi$8Pq{Q zDxnGI3;zC>P7Ky^kY z(h1}KkS$BdcA(NlRcN+ZFs{1NQ4#nGPij7BO>U_HgF`^PJ*$#>50xbVQHe4M&mgiF z$fCjZ;7tx?pE?TO@F3Z->R7Emdj0N~aX4fjYy{VdoS7&5m63nZLnTWk&-CTRKpepF z-0-;uWDl1+*ixgzB{8vPkPWuTx+MLoa}_Z_R2=t|A-gx;z2Em~pyU?{k9@O|Ef&j3 z;ou#y-$jWV`#R(<*lA;;4euZ05VV8A%&>|L4nxDT6vT~rCPtd5a*7Ql#(yxe#ApQ@ zFI2kC#0cc54X~w@!V{%fH1Z5IwHr(}{QI%_W=l*#Ht%@9gTYG8;Cs}4IgTZy6uPfS zCz?o+V0binG|XOfZj}+W=<#~kDZ{SgsVK!VOM@6Z%UJ*hD*?8&SeSq?u^glgF`^Y8 zt`_Ul?Jlo#j!7er2&?}hzdPaAlT%x`Sucn<3ZZ^?t|ke4n$!K zV}&jH*m9N&k|jBv8QwsUV2ae{%rkfttWfZZ!3!{L#myncgxJVndJfA2riFq2xg36g zVmORMBxIOhl0-EZ?RhxG7zUyCiy}E}99VX+YZLU++k7ARxp1_-Kx~09q{JN@+Q1ke zqLG=VVN#=kj%g4AAqyryrk*IX zv-HC3M*EyaET&>v3|M-=daO_F5O<)gyeRr(p$b2rTNxxs1Pxf)ZE!gX+AelitO=+9 z(`Br&v>0O^5Hq}f3WB8JYA~MYYP9}YOVIyiiJ*lrrCG8Oc(LLo#&nf)3@;MwNb-}M zv^hxJO+Y+}vAi4-DX5R6BKauckQ}_pg@0CE8L$9MI%h`Lk9(r4f>xvn!niz3OeSyC zxvFK2PUIohJ8|R5Tt4TCTTkXPCQsaYJQpvG$L~X-?|7y-wb;p3=V|BNRh$7`2XORr z1ps=m5c=#wMg`l}vWS-!8soGui9n9Lui>GZna(N>_nbPbn=J+(mKZLF3ONwZ??p)ejxHv)UeOICq1IWYs7 z(N;>_boNC#$}~%iu)bi2*MTrmmvR(zIKe_mSanmsth|=QYlGrT8CKEbV)1ccJ+JsA zHu{4RXEDhkf_Rka^x)VMQH)qkbr|f!ve;Ln?sGjxpv~m8K_i3;?5o%y9;z#nHg#2O zTeM+b=p@=PqF$D%&`3;9M;mb+Q47b8KgzLp&yB_N-G)Cmu8<)=S0Ceb>3-8bebC9TBxrrEurVtH_Tp7`F-J?vyVLbloywktvb-Ndw+Be^h!~TU5O3gXNQR1W7ayo-2 zyOo5T`uDhA!%2`-W-fTnW>x0=HK1YGW2Rs54d8qab;GIe0{-mR>BVlR=*CqPmUfit z!%NkA(PxsLFSLf0(sY)2G^3_(CF-Kpy9$-7-Hd~cQBvAtjj3kV8dJ^KYfLq>)|fn_ zCO^i#R3Sf>c#$ck^UOT127p?c`}Cg(DulWp6m+PD zf05{1^{(;zeBK$7)4d*6QVdy$__HgF%MpJ_m#CCp6E6MERn}SlND5r{L|ilSuW~SV z7m0rSvda!irfmUJHA?EL8$XY`SKwdJzijJRT?P~dz`XUZFQn~Ns1i+8L6vQ9FYXVz zpn%RmJq{yLe|X)GGf7m|hA1A&o`^?i&@}tf@Qr5y(!mrO5;8(k& z@k*BdE5mM&`5&@Tu+?%t>I+V4^I!SFS+&sY**bu&$!4g$kDHL5B7{{Pf@4?&KAf(a%>_G)|dCo@vS6M*)CnB zcST%U`%t+9t6g=FZBGVkub{uO5B1`}H_BkyH_B4A&yvBi50RHQF$)xQ)sHjCPOAE8 zvJyL==0!%7zfhy-g)!9;jENWN3%XYwQvbq`cYjfNcj7C^yUX!I0evC8P`Nwrg%{Eb zFATx4SJ#(8+&6r9QEx80*TSs2g27@8pp`kGq8Vc%HvjbPK4HAA}_6aq{O=?6kp zDeRo(2o;`12XTlu_{MXyg25r%2P{!a3GzUO+~HXVGPncpY=<*&h;%puYuy7GJcAAH zkqpN@kio-2-iI^b2p!CjH%H4e?;S-bs5kGy@;aC?#8txK47}|h%#gl1m@!0O`EUlE zcsPSjJe)x%9?rl++QAIz-NP9$2M%XIWFF3dIy;yl-{WA0>UQfux2xVgoIzh5&Y(*U zXYl5G8DZfoWB2Kab-4%X?LvmHVqf!IMu-; zaFIo1?X+|b9QQ6Kz8>1i$Q$_jIIVd zOQ1m1PFo_oi=e>vRzU$4J8enOUA)8S3=Gwih&*|qXyHM80X5hqCA$u6khrRgSb0cN z_EF(bz0l|tTyA}vj+Jk%GFVdcd_GAT&w+x%6;v}%a+hEOL-%B_i%2C;sHom%oOds~ z5GOIKgQC4knS}a;K!XkRA?yB2iS{0|s6xkBo&-FX&y0gOmW(WQ#W>{nHyL{>SGVA+ zf!`HZSYz3nsexD~rL3ex8dw=+kWx%(y78hLK1VtyYrTwPp|Q#g z*-`K148^!~4=Q|wJ)rDUrDIXWlS680;eak1bwZql8uTq2%si!7J$=Cam`{H-;2Sfv zE}0>W#8MWkceFD3`MPQ!EZ3=dZM?9qjVYmfT@LeWBYB+9&$i^6FDdadx=&rXRTyh8jlTcNxHx-dJbz^j;Mta)@a1^2x|xlaY)VDPX8KB=v=2m~ zM04+68TYeSAe~nRwl}ZvDfHS1__D^8{N&?Ba07^<0Le(Hz|dZ1?Ko4NK3J zlD#c+Yea<+ZNfc8;oGVaDkv_hFK<&Z&R zJb&PqBNO-e2Z~jFx%zrGpHpIXw~$*G{2n$D>5P}-UDxFJ+u4j+ROGkRbJH-m%s^>_ zDbq^goGDmFojh9JCuO7uhjJhKXZV0@Rn0>CvwIuNR+L=NbpG}LEM4k6Es#+-WvVK})1A6L zF7J`5raA%7pVPCD5?~{ta)+yMA?jgydc>#6<3qNvgY9_nkd>9CT40+BY`c@zRdL#6 z%+7bds@^K9UUevsJ_xLrO806i#jWZcdUp>y5Gvk*ObQ9Dx+Qxu-1gZ7JdkzH-2)C< zvk_9l>Hwxy9l+BIMZ$WH*0{_nn(1dy0@s8W>GE!SPcP}lhz2xIRtf6wEXH>_0fR1! zW%4$xWtm-Xb*>sFHyf=GxhZZR?tr#CX`WEKMJx2Fhbvc!D%MXIt9QCeMuY;%=aCoP!FZdsCEQg-O@>4eI#`&UA;X3w6@Eu7@tJCeP^w z@XaGcrgqe(OXbV$UWTf551L8I1}Wyz>%ClF=19)w@C~`pO_?_zsxCa7qwS&hZrJR; z-3GN!)v0LCPFD*RmC2?eGku}a2#(UFuyYl>k8|aC@v!|^2cM5Otb$6}_du>54+k>j zQHxaD8-s-qu@I0P1L6zw+Kas*A3lZE-hpKBfuX9*` z{9d$Z^W<>-xX}rj6(BE_@$h&(OHT@BqO$no37hhogp& zn}0_QNV5?&;-m9i4U`uQSn41rZsan&mtQOz_*F7dqr+FOkSD>76g7t98|ad+Z?{}; zZdmg<`~yB#Jh@@5UO#}hvy{q#GgQgRQu-dNUCDuzlvI>%R9+nJwEZdDQ)$d}%_?4tG ztC5IWO|-|>{W_2jiY@3DAtQLT_#*nw4O##MH8k>Tm}EhVpYJKQeCo zIlBbr)>5s|=K|i=Qo-YFK2`9A`t9U*%Jt>qVUni>4N82GM<84k;9OxnoCbDUo4p|5!Lq1Z0y#&Bm&_*?q(3nMHP|p13iua}*DugZ4bhK7|3!*7r zU<77ZDnRk2M{=@|@$goD_bBsx`1&^tuxWm@5U3$k0F5*xULp-i@qvU;mfZq07&62P z@Dlg(`!J^ld#`T>hO)UFo?fkhTFGDnmpOuPrl~DYQK#=pq-?IB76qWWSv+fQmQp>Z zCQ1E9!94kmSv-HwJO?v#Rbr502TiR0=7O_IpnmgRn7nx%reDxv-5IWNUY;JxwRdyN zGokch#ilhHE0jK((1J3TS5^lXAIq=aEoD#Ly`Nvbn;tuPcb+dkWYGY7?@ta4K!x7e zOnecOJD)8AXyx=+IcR|6Lpa00QU;WgVwN`*Y!#{rJAhczeC|At^VXMlX(bojrtjLz z$tly_JFxlODy&nfg;U$9c7*LHXkxUH$G#&3>AFIoNo(NuOjt+{fIRq9kMc*{hg%!I;%SeZ_RDa0>$9vXoNCcQcWTt|eD zp<`oJV)Jo9GP8}G8j>wNB%R0o`2Zm*hI3+6I90<#Z+^w7a4L&kHL1p@vK}t&2K7yB zwRQ~(Rg3q54}16X5N^lp@Oq;jD#};YG(>!s)7gmLzo8cXTV7@#SXL(e zC=*g`&#C;olWIzGW&cD*0EW{s`9=T=^KIg)mi)CclSS3(`b7&!@olnucx_@Ewf`a_ zZ>;Q@HJq*hI1>1hJ**-88!oR`ywQ|d1?rNBYUFq+IN0d2;ZTvAkJ}V}3!ulP?DeEi z*`_MUXk1B*rHp|6dx_D6i`D9_PK@S7RAOUQA~RrT@1&CI=~^9hc)yk^u9xa^u_FFu z4;GMejc)eFALn(DwGXm$5T{w_;t$!CuRk?b@^d@;kWNQ8v~@CtIKgOi_F}SmF&S(~ zv;J`=!Ia2qsxFd-1zaYgJf*eM@)S2pGMGbo(rV<^hS4F`kHnBvzrNq((5GH)B|$$`{23TjjSvl@6OY<&ikk^W92ff>-jm zAQz!nguqy5`7)t&N$DfeeVc4GUp8Kjk!Q%OAAuhzD|HCVS?PAK=hZ3>fQ1{qQ&N8@ zX|QIFRcp{MRfkLC>kz3SQhMfi6F{?^+!Z6ee3zq{T08x~UAj>$M(Wm0wX)7;53EZw zi8CIsn3Bt4T-?V{J(0_-KX#+8dGiQADuOCghtE)PPgLmYjXGUMoK&2uBh7m2kx`F4 zjQzWegGD0eyFrm~w2$^xGP>1}5yVICH2`)agrSrhP1f^G5ohS-2^o?gliS&Pp@!G| zR?z|ZEX@*Ph;KHetRAwwD8$PnVi&%`_+wUzDKOjeygWTz1uRbfdOiNgEEMuWCUq9! zB#a&prsu}u9gA6Vy`EJ8@q!oP;EYNc-RB65rYV!3o3z7+-ugBtnSot{V>SIuV)J(P zfWQZ(^N%+o4&+vm17Ws4;v{AlFb3uXKIJ;3&YC;}6Mt zd?#*D^wceK*pFq~nn&DSq{9qQkZj7-HvoKc@e0K4`m5@%nJ;$hGW+4!eOltfOwZi06tsHws_e7wS+=+O zDYA~2slmsE79eLc2v0;9mEDQQjj|BvVIQbpMq`9W)qZ+j;Rl@(|4Segov6M!I?WCwLl=ltPaJqboNcba-$a)B zvVG4oMp7Yj*+PK!6hKjw2uQWrV5zJ~<$V5IwUL_PQ1q47w@l2YST2vSJNsc@Ecr1(7k5CpuQrSHIJTj*N>NHllmre9GYx*ZY&5lnGw zAllu*M*(oVj@+rGT)CA4ECeWgAYx;}TY}`5v|g%aoLVXNfKpNz4(jB^yD0jTU^1qXSpA(?|T^^$CPGbw#p_b!alR4a2c8@*%B zLV0}H#*b`0A+A^QgYgWAgs>rO37p`0_Q+LUhqxMAb3wO7bdQIrghz?^-a|Yz5!L@P zfiXpq(8eZZQrU%6l41=~CY41;nN)ThWm4Hfu1%CcG(dK2Wvb5O zAHL5Dv4TJ7;_{xjtdn!SH6SyntifbERTKb!3zrB@YzWg##aG|DfLkJ?OzK2rt`o2) zb%Y&pc#j|({30q>I*xZ=AgYUv`^Veu=tgASil>qBG0t%5ToHoSMjT*ss8Pk-dYqggECTN=#&Vj)B4KG}anS_OB@6G0`Idwp&$5_3Ic2|}si~>s`I~G{uz#n# zE>tfIb@m*#OtrK~&uV~iwe&)_yTs7f!gzx+o$=lUe;B$=c1!Fmb%uHV3eC$t zLubhnbO6lqasYa^;wj?hL~m=PvlwKUDpM~itI*g6rzJejr?7)2l9C5!)VFb~sc?h2 zCTwL!t{m#CqSU8*M6nSSNEFv5Z&ftoR#Wxtb{nA+t)RkJ*$h`Ip3G+tDx#RvyqQX5 zwW>IE1RwL5I^0_r^6AD>wyO_CXrMYT4g5Wu*^)MUSaV4T3?*QL2Af$%O|Dpgaq zUM@>zt;$l;L9fG=JY0PwSisA)0zjv&l6tdSvI3xFmO4YlTo;^*3OG9+oys|RI<;V@ zm_N3cDcmS*RU|UklOSdIXHXAChB|%wz1+;B3TU)CaBeqt6k3-jlVogVly)ZL)#aM# zhM)>4Sw`an^jDf`9c06!v+T{slT?3uIf1*oOlvS@TVDk#GyMG`IRt)!s!+aqNAYF` z478NT<>^=VER!1rWLY7rBh2vdeg)%PYwl<9i3XuR`|w=^GuMI?D5B{t741x4Y_CCr z0?tjhBN$i{SitZN*6$=kzPsYetKQeK#fYt_x~Y)(2r5B30P_<9SCBmsy1&?AblCRi zz#^{kz9x+eAb0IR#?yD|)(|ASU4QJ}vMWSrBacw6>$ zdPQ(@XUTgG;DPCnb0zw0#zJ4@jlnE4j&Kqv=rdLLH*CQR<*jp1kr!T|}{jvwL%9a+XYMnH&9V);zs-L3S*+cbI~# zVO7gwrgT`Rps>vh*_a_dJh(`EDulqBAv9xZeAE}o6p|PYt`Ka75X5<0gcUO2=uTl1 zsQexpDx6>;MQKMNiV)_%q8C+;Om$%avOude$PLwg6;++HUa!_Fl@>9|ZxqQ08)n5> zI4$-YGW*~FXRjbjJv-`osv@f0n8)3#l+3=QNcGZ1QHF7mwM>B?>PamOP&w!5L~d{J z#;j6^+bbzegKM7Sl{7=fZzU;1lI4tyk*rkP`z#@dQb!l#4?4oE(`+6=o{+~Cf;ofB zo1rikgAm3`)L>M-c-y*+IF?dLm^H^)!58YGOZkuGI7e{ zmowPvqPvjhDo0z1t9^`8@?sI9FDpRQj#LVQZmDBvf$4~B=dp3Pf}&GJctw-}l&`fM zBphty0h296nWm!la+FEKUbYsx&-2oo>=6upR@2c`Jx>~_x2&ErB(38TGg3zX-{YH})1Yd>h* zAX*IheVQgemP;cAOQJE(=1RWNeJv#q6&6UfM7C({g0*U(jBZvUv6d<8eMb#toM0Q`E)UA9qULy^?%YiH?d6YpUM&x-?a6lg4X>$(F9-zOJdYe3_?9LiE ze-mYUR?86rk1a}mKll|sfga8~y&?<6W06^|o|V#YTr)eb;S4pLZC+FM_+#1N+>Ihd ziyOecJCL2mh=?2!TK<5YTs@HU%>3oc&sfigyTy7T9g%(idiEnn6Kb8vTrM^;zv~>?q_V+Lr82gdq9r@aDong0R%U>K6~-@E zhM98}qKol_dqKMSq|BaLhh>kg18LsQt-4rm^LD4c9mt}Zt?wDEAF4pA-hq_*aDtht zW%HaEJ#}@SlAaRPA_KHh_MvyIUzwT(+o0WQGc>)QvDqt%Q4}1T$(B}EpQ;zIqF?iN z?qM<`&nezuzev`a{fxJjFQ;2J0tB;DquA_>-8yWo#-Y4E%bI4h2qRP5>p-5C(CwB} z4yh?CB!bidE)!&|!vdw@)D#S;=7fyq!@%U-qOfdOP%mF9f5I zBwr|HRwLq}{S>wXns)^T7qJ@RpG^g#m=kP4$})@2vP^^+JS`s|N`U^9Wm>78z$h#s zSudA>?0uN4iU-H)p2wv3l&6K<<-r7x5*dZ2qW<(dY;JTBILJBzJxeJ#%eIACBhmFF zi-_Wl&~cblsSJf)vS_Bdl}X>WsRqOPTFW^y;N;~LzUNN%`+2`OfU; zbvo;Roxszbj^rwj(qA)1hA2Bq92P;D5SqI16@Uzn?W|CPsvt%=C$j1^`re&8b+N6e zRxQJzvpIiUX!UUQxYyV^RIy{}K?WpL~yFEL=78xI_VeR9tmmXHMKqAA(} z?0ov?_php+_7-{0S~jYor`=<9b#?V!!=*5}V0?duX)Z6VHs7}8v&2lOC@3O>ufc_M zhEddN<{z45yO>edTRa<|UmX1Q=8CuOB-z=ZDi?0{h5M$ns}zzFQgw5Vb~Hf0kGGz{ zV*>R3M~|ovEdT1Bk1h`vhFgmj{PP+ur_Rd?Nt!!!ZiT?&sYAMkhLh6C-PJf}=+#eW zrHa)hCS?J?dRVQmci1=@gYCj{?NFF)DY%qp6>6Kp3P0mSfmhTl8qF5H(=(Fk<}F6l zN=8?c`T4lMb>L``AXoNc^Qn2OyK}Y=+k#)N3(ThP?Tmw#l?P=*kBgeEBl8-e^H;1h z(-!-w<6LDypW&`pcx*lZIq(Tk$6=>`rZWa03xfr8zfO$i>YwnE5w3S0^u(ocE#4#xhUCXD|Lze?&R4fVB z+z+#u*qyBva4sY2kq+`u9*w&l2utw=3)A!g`0LGt7b!H!jkM!6Kz--sX$%qVPogf$|LG~}m=0hKdXwm4YC)SjuVSQS}F*n5e7f{@Z5NA4=2?upP1 ztJt;}8IBGKV=h+S;BsLp;M-XZqfKPnWr36=*|-@|N>rnCKxDvr;sZ_+{F*OmQyjzz z)qhL(tw>87_Y3!)wqAMJGek8qdz#(7aaJ{g^t4=i3=C*4*Xb*>b)&07jBMVE3}R5J zj4~bHrWgz^^U};q?wg>h{=6$%AdcMWu@UgKQ}TuM%LlvSm|u+~frq*E@K{%y52Ua+q#(OCvu zT+-pT?ioZ0_fg5#dufEZWrv!|BNzS#cW>7}5)oh9D&|qw&6d{-M`GG}haDu-s?#`s zVF+`CXTkm4C}H}>I7Tz>#E;Yr7SA5?Swz4n*8jR)9cR;}du~o$Fek$2r>0 zE>y|~F3L>SsEsj(yjqD8dk%wnC1kvF@*SV*kaDPR~QknpRn%j6z+Ib7-_gzWd^1>3IdTVV+@z(w8rtPl6gu#v=$bY?p~uy zSG5?6!H5h%zsQ*|+~3Zyd2kBjy~1?APFs?hJWY83dijq}Y~(UQ1<8qhWF0l}(>^jO474cdes z5&%8V8<^p^~J?fod?qd`@N-I5qL%EK7B=Yx|T5Qlw&JRL(;YA zI*6p&mg0;0E|Tz}$S(O3O&h1Tkrm=%OToN?dnR?5NR_)0DjWtm^FM!ob4XRDt0U}X z#hJw&oIrP?sRuAn)gjilJDK4M_u(3okr4}!e!kme{^iEut%3@~WXKGKbjbVj^I0dF zYRDlwNE1oB#*eJQZlz}sSsrbdXft5VwnkD!^sR}VK(rA?`jh(&-T3h3>56-6q0iEFXA$;v@qWzBgp~ID|IqBr68ahG zG&t;9y}`&L8bwUR2DDCvrxPN!$xuwi#;zU^Jp!9ouIz9kB^>F0 zhQ+yyur6$}Q+BH=0UCp!xNS7n26}{&Eg;cZcAeZmm-Mii&8qC-6bU<6?0Ffm(|qT| zf>VWi>1P~3VsUI?@F#IQGpK)bW5isrI9Y7i8RHri*={;-kUdCiERb}Lm`N1=Y8yc37?!0LU zoZw~E2)6E=`YCdU>>Fe<%pbuu(uj-rEbBGHl!tAWkW{eWGMZUJR5%8+$0TDsB<9&9 zAykPGS!8j`Wf$jiqMthFEfZilZRegt{93VdlvEDB*+X%gaZ5Q8p0|+3MbpG}MgwOF zP=zzw&R0g3ZmnQ;pl=JDI*Fa;XUtor(yMA6OoKr>Jwq^`Z~(oT1Jti?I*kwZc0K)x zf10@H0 zxrW62I=N?M(9X=l=!R{<_yVI^VIHn!TO1TO^Q(R2AP*fKVRxx*`FyveyXUCLVd*xQ zO(*JuDC;X~c9Ou)%QIx4aNbYV>2{p`pH z_p_h&%O`9dLRdBzkXJjk#j-<&?1T4-YlV%K(qmWM`P4q{#pZ7&NG$_aw^0M!cMrUT0JECe8XCSzmR|?tT$P7%1 zONY-ycM!SGfsjgyCfdnY8b7|JVNq5>u{Nfoms)$ayn-|8N}BSm5b|qW2R~o z=GSq%cWm1%A?^qTcoV-iYN?PM;FOhL-e^>LPBaZ?LDOENYJ?%PP;9y`sPg-=QDcl3 zg}NS4n40A6p#)hLP>b~w7rGhQg(#(bF7l>El%=LD&H!e*3KO5D%iTRvoY;C);gE~Yfww3nD9Q}7_&gf(qc(0H&Ml1iB8=^=oq71BB#5M|QE%IcWW0=N# z76FVRgX-S?9X}*WYp|~m`diL|W=O5R=37v{Q2JGeWy;!}*@UbEw3wR>MBdnrudYQ! zS#gAA-_x9vL9U9S7@qx2DbMf3eAwOmrn@5NcUz&`@za;Zv?6eEuENmNV^doZPOz4} zmvM|{&WdinR4bfxTa2xCMPS2SVVhDOG&AV1#M^iQzvk;n|7M55HeUwbt}3Vq9IhLt zs{+h!<|$)zTq6{@W^vWRlcN)?-chT*Dkh0rI*AOs{xqX`xP?HTja4-1=1_Q?ba|aY zRX{dWNLb5FrqHhQiSC+Z3L~h&(;b02K!!EYGJ@Q(onNg_Wukj>1Da-7Y3w4E` zH#miazVaHy57NVpc62~~!s#$J7Dn@fV0AX^iuFuOu0iQLy*A@kC=#}jI)+k@#Qto| zKujUH(M;=GV1%4_9*`TFPU@SVv;ICPD-1}G!^f!JFuc*<_q#pvN^uCyE;7m|z)B^6 ziZ_c}V?XL*bq;vCa+p~-fgD2^8?9^(rVAT7<}?B|Ul7eAd}O$MGQRTdk@)sH1Yfsh zqRh$DbIh%}<|1T)gwUixrovQgCQ*w+z164-S09&PPW>J)-JSB9VZRLnxpX)-WRjN&57RhJ)&zlJwQs_FtQTu$O9f*g1` zV&jPB)J@%V@!vViJ|X62=PtMq`&E_%$WzkM25gHhJFd<@&wo_2A)FSYvqTWnyxhvq z2bO(_uJ-^Wy~rzK^#A<%na=o;cIfOTQ@&l}#;%Pe4Q{5P3CG{cH52t>vBZDD{Fdac z>BlQOxx$juf3<@`Pr;ac^Icdg?+>aUOgNj=#0E^qH~<%~2e@ z^Vx-Er;No02gw*cQ(W>bp-BHs%JD+sdwP_U+4aNitxhLPD0dLzmdJp4XKo>Dz)&#AuacJM!nH=KJuelO#xLfj$`qsU@ehN# z!cUdPXl1js8!~kF!X~Q1I{tWJ(*k!bs|X19{fm|XgXb&z!RG{9Lj&D==!i{b#|23vg>+)DI<1NrL&{)2-nwyX8QuRYxC&?gS}@O{I3Tlrz7Um5#8wX8ZZv`$s&&h-Nz6g1X7*|xO{LK=G+kw+ z)S^BK_0>ic0zx6 zkNZI`ZFF}|Ru}1!sKLTV%@ZM&+n4R!qoG`L0OixTyANXMQXL~19eFvT$f_&Hmh%9# zg~@8J5-qtNbP8gpJ3-9>Sb}Yuasr186{eijmd?9Di&C(8rc101C9DV3+>z6FfECJt z?1IPqSUSzKi2y<*;5tiEt3zbsfDQ#UO2T8-iZtwPVupIeT5jwMUQ)f@6PiX*fN zwTI+Osm{&YTTaSelP_GA`D;N{<_eVqw;JUWYLri?Q9hwYapYE^`l1>&w{p2u`oNlt z9ZrSndn?pF@G!@T%#1SMk!UGfBx=i#0k8M;MSO@3tTF3)86^!{{-X2qx8m% z%nGK?!y{SkIqXFoDQF z7-KluOhN)oXH==cIJ|Q(-4@IQGrxA8a>S>V)y6Td=yK#uFK*yg!mEje$G4LGVnX)v z2P5MzX~K1)x|*8a_3ZlvX1iA12H5jA22m&fo=A=b_mAc3r+ zK|$lUK;%k=Gjr*TU}Z5>M%(%rMxD58j%h<bxv6NY5c+aYivK}%LmQ`sjANp_D~XLgNE8z z&>DN2)>z#A7>A|APh$*IWwAptc*1LOT>4aM6xai!1~C9bUk6lKW*uQ<{}uyPr(SA9 z3Fr0S(kg6ipJ;*Sm~xXVasEvgUUS+9_Ef<1apNDxDGxj03En8Cf-rgBP?ZHKKEw3h zgwlZ%s8GI-O%&g~CXC`FP$Mh4St7yhQSKwhfknZw`2u>;x)FMD8oqz@t^Z{dmAHIBRVkmHUmBsv2&B><8p86fHrPOz2USl0WT=&jzykx5b??^(laTrEhSFlmB7bHCHD_@*fb_D1dc6 z!Y@T=SlOzOgX_MwV%YQ&L*NShp8x7%QY%fkQ+tE1I6)Yd`01Sok%*}P5-|0vJ*--T zikESd?SmL8(!Y#;9`Fvs=qHb(lBNC}>yM;;{a))2*Hk9@<*73L{Gd}BFMc%n318~Z ze5Jp;f`(%o|xPeHbrphGW<);E%V#6ytIXaU z{1T{TR!~pw^{Y2kW(OIyvU_s8ds)g(rgemZT5=Y_0$XMUwZi`T<~LGW@?S^cY}=Wd z7y7Z2aW@w147Uru7JzZCUp+*|xK5yKg?_uhgFY_F5*@|RCqkORq=3a-UdpUZc#z6| zS&s##-X3VyBn2+r6@w+PrN@!PrMRZz5`ZdKKkE7U-lPbcr?D0=9cj8jDS9@xX+r0# zkbGRjVDfas(6g0dt7ldEEs@GuHc6b5QN$o?f5?!z9EC0Z&$Z3PPW%n81;H_{@cr!j!}ID;{>cA zX9oW6;g%M9ssw!c!1#2z;qc8)&YA8Ln%zH$_dgr{42tx2vblXh-7w!E+23lNYVS#D zH8j2%vWYJY4TBkp$qzrRtjqZ$bU?Qwgc4PN9+K3nX?dw~D45IXDGBf6TE;{f^Z(D^ zUmbj1QG5D>jqg`Jf)<_FFE}>8iNuY6139zFL&*q9qH3vO+mg(NEo9%LfLgYV*$6zQY3RPfaX7xcD;&gVPuO5TojYx6BV-9vr@z;>g^t zpi^y!xGr}X?ytWcyqW%z2$~yzO~~c-B!Q~9h=YxdRKE$;vMr@|!p}@V^DRoEZBkVE zz*4Dh9(If4esCa)=o^XOenoM!Fi= zt-ZeO>U;@8=QhoArszvD@?|{Z+EHXjhh^f!7$j33T2y_(A9#xx8lqlQ37JO=_6P{5 zIEJM6@75c(w`aP-y_`H>_%=Hc%4(D- z#rP^wp4>N`6-<{qIqc`)jV#^OXIx0Z?HPXemwr1%-qm&2%Yvz#U-WXD;?STOX4T6u z8XXT{^{AFYhGRBU9Gd^~jm&X{oP}wwV9ofNUf=u@Ot&A+DAPStv0YatV52v6i0nG zxPEYBLqx|3EHc43#ke))K$oXoQf)D;-L*)N%$A~|RNoq>)FpOH&=-5FTk1m7ZSjh1 zXI&_eszSujFX`qx;6dV&jV1YZ##O$6aT9?|#I~k0Ati<6xY5b(g(1lFrTvVYN)uc~ z=hTr*<2r)n?owE!h?%gLsj8p1%S{kz$bw8CmK%RmgwGxybrI%0!!R7PWZJ20lBFnE z&NA(U=owMT+$lyw3QO@!i?p+ecxEU*qmpY%Q3@7~1}A2NcXeQ6T3u*peZe+_z=pdD z=Inb-)0nGqJd4*TbyTC*Ybs;RU1zBZQ*&<%qAJZCf1K7s;reLyBVyq1Di{ zO{UD*Epij&XM~{6I!|Hw30ESTC0NhWq{j&ogeNY$>sL#K`IiCKbGY3F4wb~1{lKq> z02G^D_B+K+IUA9WI#Z%6jBPD+TIp{QU)tM7SOV)+#GNDdVHQM^z5xUAwvxC*^(EnZ zzZg71!qP;*l|Q?{#(BTMzps$~xI|@ZnAxPbY|3UG`xK1a^!MUn$?E~AMeI*^b;tC& z2lo{;jt*tWdkm= z1%VR`8TdLT7Xl8=tQ0;jIIG2qe{{=>AFMF~@!K;C5XE9Z3wa>KzlaAx9)1i^4!0M0 zxet`iGE*X41jnD0-n5?Hp%3Z`GMh{@54a9$sO#DCIC}T|SH^lB_8T5^}Tvi^!Gm87V z#x#Fjl<404kIA=Zwx=-u-M9{|_}&tl#Vo-4^kRCZFy64E%cz}sSy08UWGbUo@|58| z*BFRi&`C5W>a0MvGFnU+WAQ%06eN03qHIze-NH-~pC{?IH9lDw1!KM$sssF-$r-be z=r=tIS->AJjBQ`Db(kA=na1u&H+Sx++0+MIp zy~`oBres=zcesk3Kr=fS?c`WqE){rY+&nEvg>60-M)|W*WtsLxJ5B;dXW-2$>kfJo z%E)dPWp4_km$I&GDt)&eU_Ouo@#by1nsrFa5HAKePqzke(7niz|uW)6ke0Ka;|NxR)>t!LJ|5RL)L zpTbx9xqQTNjb9)xu6hSG>Bx`agX;(JfshU+uW^-0Mg~F0=0IxDjL#o~fwDRviW!hT zj+r|!Y>7{&(!LhFAmmq&`y9sP!iAUE1jB%(bB#Axs01Xwg75%~99Sd*2jIw)*<(}0 zr{b<|;_dhpk~!@$!Q!W^WYcY9TAw2U(~x-F^rRbS65o(vg{8e4JT-1gV(Le2ISikj zVWupkUu=mpg7 zS}W*@(79=A=c9+~IU38tx6lRk;B)(=PxtfD(*6K+thl2;mPAf-c&rqkHaT`hQS0KO zWi2k3t~30{*3;(8$KL|>r<@YS-*8IUG{WUK+=yehSx2qS46_7RMz@L7K((&Il z?dSI+uE2LYeiiTXX*Rweam&U5dY}V4qf4rrqzC}Q*&OQ@2Ni`no~d$iEsC7bWkd<{ z(rV((3n+Voo1cZVLeGdP3l6AvGdwv&VwB?LOIw^q|9ZfpL$Z^j9NUE7M90&q{bx44 zOw%Jd(PL<=83U-7E{Qv03ztnpIKfZPY+cG!WOV!C=;DK^b4RyabaUvvhTOzqq!R}i zRt~rUSt3eGbC|is0pAU&eoRyDME60*eQifMx^{pXbsz?Xgk>k(W$4>VmF`qe+*4~J zequs&g0#mDQI8Lsh=(d?>mZ+386rDPa+QuJe2H}$4Wsqek+B=Cjm{8;oWlI0oxdYg zinK9~;Gd%)47GyHYJ^}^o{W1uny*w2YY8^BDl3LlcqfX>Xn0t`FhHWpNCZC-aeNY| zz`>T(7N8d90Bys6{U_@lncEepiQd&b?v>Yl}B%O761&_tvkgpqD`cK-N_ zjLz9sZ1JGU+HaWg46+Vr5W8J8o(58{fM`I77|V&~X8i9sX(J517iQQ-=n9D0xNaSy z^&qY~gF{dL6N#x*k)VYu(Q=&XWO6q7v1i;9Z$$w65|p+;3Z=7>Q%_bT+JB(3CF z#Ms_Mv7{jhg701f={(TcceaWSGJRxNb0u}0aaDLm>VA$wGSihe8y7u^Qj>l3?_qrU z*LQ^9esIp%(TeucKm@6igqw45>>(m63 zPA4;-0_#1a%tgn&5y7=`1;gf3CI<%1BOS7a+B-}uxrH6`a>;M@RR z+@777g`*@8wDs-PUxJ*VDpPgsyKZI4w$ zftN96?={AB96IUd>LT9By=EMDlllDP_m$ zKy{K`3v;_#lo)7@^e1tA{oDQuyi9`=vTWMWqfA}MrRqje%^<)qyNcPLXv|no4esxSrKx=$@3u2$)6CNH~ ziLqj&tRAmEk*?I&Or)q==)b$QC^~THkqFeVGXlf67MY^hJ<=wn>?R)PoNQrSLta|4 z=xYyY>6se}zh#v&@sFU5wHY_!ycEXVn{0jXvXkPbJ-3K=V}a@{`eo+SPd@jz1$;5u zB|Ct?Z78I8^7dg#=w6lvxv(TKB+;OCn0&%91 zovP~SU%2LzFwLmhU$OOh!eKullsqX2ocPbO4tadU&n>7sDZ%ypy}TKd(0>4tHzbSHQElgq(+H$#JquN(ZFLgC&Afu^ zlR}C+*BdW^m=Vrwn&*ljU&~NH#aL?Ih^k>iGDQ?*6FRnBn#ZYW*aIkZYKiL1Ut|hb zhth2`?dl?3bvK)TGKKIhVd8c=5y54+K+rY@q({m%O`hrYQ_zmz{%5{9tSSGg5p#P! z2fx!L$q%W)f~+?4UR=>jib2Jjxn_PHOKBcJi}vhmzuf`&PUk3ZCewm zwHlpQAEj#Xop02OS!P?^49Nd!D15AS9virQPJS9qqq@)3d`Ba*lcSRi0!Wk9#9;I{ zcr;Bzqc9w6qXWTB#?%8d^;RKHmmdpNLz_hP1A8jWMs8C3*$BvVipF znVHOJ`2HQl&P%I#M+TlJ+OWaKc&x%G3Z<8`x=+qVBj^B+Ln!zn$V_Vv=}DUiG5Z-z zPk4GX>$o*>JRuXo+&RuL7mfvcrTAobMUbmPl$RV^5qsRh3K*6(+Ld%K-lxpSIKyO| zVKNrnWSl(DUlmS2_dP+Xay=hU-{g5C8U8U_4j1s^u}_x|)MTQW z+0?&z)GjjZ*c5% za#-y&{?Jv3sO70$lL$m5k&KfRp6v-bncYjIFU=5FcA`z+J}mBi*(o6= z=5MXwe0cTwb?qSUAy#&jElY|uN9A%`zH_Ba#T;0i&whe8(HoP4A zEl1xEne3ONNB@zE71@_{>g@QOzX~N1h7>ykkjdF!FCL{2d5g%lMsDY7Nw?(AeuGl* z2B&W}IB7KaZ4X~!3}2)^G_Bib8G1JlPZJ}l>Ijq%%3jJu0|B>Ho{oyoLCYYn;?Tsu4M^jnAEG?#J&^RGaka`%6oAF6vSU0~}F&*d| z!up6_i1JamtP=G5o&}Y>xZfnqW^n-;L^Q4uWedT{8dSgg&C(E*EFJe32>FLu;B;*|V8Ktv)Af4xHe_~U3wf8K#=kQwKQ`1*bO zFu6lm=fjjY_HN95H@hy8l6zp?8&(iYfK>{0Nkw4E?jUmD;6yagce`%9dg9r}6=qeE zC=glpd)FYE%>IMh{?o@E7D$se( z3znqdo3HnRO0kob=ekHzSWM~9a9j`a43i%D3`co|OnZr%u%Fp;EYIyZF4;ZD(yV*5 zn(`gxqd5QM3`71k3r*$nQ$ei&g-*nMWG~M?4g+c*IgO6vzsI*F^-nTvD5wg7J!Wg9 zTiBH4AGltme+Y2O`S=6f?H_`~y7~_x_`HAMVjZx+;^WybIK{WrL${+c)N9L^S?zBz zc1S%`)n4OK-!(}UUE@jv5$$5TYttFfJgotl^aeB&B#_I#F>7r&W#_EPSW`$>SQ91T>XWtYyh50W+d5QjufKX$ z*k+;8P^kwl_=7)Hr@H&GCHYBX>55`SrD`w1iG27kgdG$*Bxe8-Vp3Y_eE z5-vW%tG1$vM0t7?3*`IND$uvpJ)YK9iK0MXk8$x5=5&d^=@S&tXZ#cd&5D#A38ern zfiG+cT>iuqv!x-7<~M0lN?nt#GWKDjy<}KMd>sEQIfucoD-P{J2>fqB9j5e@n0h6B_G6f@>4r{*sUZGgZf`G#>f(bGl$o70A6W9H*dnp1 zmS|K_mB*3UgXMtQT5*pu#akqxse{s-(lk^Ux>+{16~SzJy$|#(k!_t+Euqn+AKQ%$|Vx>v1@ab(Hwa=fJoHANHb6UuGW4&^c3R6Hu*j%uD^ z-akYC$${kx$z@N9@8xz&Mv!$GxcAVb%&Ri%%y7!CqH99?agJjwxtYgsY2Vq?!D(I0pp&0o)uspoL=0Ivg zx0qyO>~*e-5rVd}1i8`33kFoY^*lO5yOm(4b}MXB7-i&f zWQMM66}hXt$rc6Mp1cakfuomCAtd<)DjnM?8pK6K+tlncZW4Xk?T#*4(M{6TN1_p6 zX=eNvQY-;%hjdo{4s%qij{RTvUc0dD zeOHtTN7G0A^vp6&y}4OtrpOu)gAz1fO5p5Efsc@p?>OM3D`h@v9CL;s%8cz-;gqQy zMcD?`M$OyG8w))b$ps4}x^~TlUN-qTrz$-H{BK+aDfy)-tWYGE(5Fz;^2LRGw7q4F zuXfnJeYxQb@V4T~((=bXhIFI$aCk}QGuJ#O81b?$7Gl;46jD|2{lxG%SeR-8n!cmk z7h;vnfTyndjiPTCx>!}>Ob{aEY@tvz9zWXM@?0F{0kMxmA#^xp@0VUm;4X7{NtI&l zBZvH*=lK#LWcsFPZXQ^|*lnyddMJ0{$Qe(;bfG~_s^&4DOEd13rFd%3Gp4GF6s4l+ z{o+*#T&EOufurx7me|r(vl=l6arWW2s3a(qK-5=3*uEi{6kO(>szc^A>2^{fQwJ%O zC?j%k6)X|Wjzm5lN_g)lUs%>}(2o{+M4@d9&CCY4w&nJW6~miwk@zLXESFRksJ|bX z#*X1}GRv>cNzGBj$eQ8uYE4m_P>0N?n6Q=o_2~qE z;b!>IjY~%xad-S+FZJ~S&V0B*+JydevWG|#cn2Q_hR(A+L;9zay~NkUkV^TrUGr^= zafNVJeS`0?uTGE7v(G%17FClB6PQBeb#K0VuoY)FBSMo`D-RK9!&v&=oe`1oP=rzK(> zLjz)B0Mcn4KLbl`Et@aSCgZiLUO$5noTS~oI6dYyl&Mz)(+0!4pvPF;Cpgx;SzaJ3$-?4dcQnD6JltLy ziSPY79h9dqxHK?u<3GfT+1aQJvl_i+lf0GD3yJERRNj-%>+Fmens!%68AW?M&^l&J zb~Q<#MEV52sp5_Ylu&h9%8Em8Nva;t?S9@TRi-JMA$QYDz(3$?t&+%@tq_KYK!tH+7lpGkP@1GJ{Zcq-5=F6@*^$@=}jT#cWr@_*X*7;3mr! z0E@epK>lTxW@3x;Knu(u(y5`ryZB}C#3*+5n6qO#H<-yGfvRUDFXiMDOk%{0w~xhO z-y0<@lj-!s^73?Y%@-T!irXVnrJ|&gY%2IZzTk+%fhDh}TOvifL#1FaM&*tt_Ve{_ zJ-T0KoxUr{?FcK`h1R6BCi=-x6Ral1SZj2(Zx~RkHlun6>9n zATg1}w~#Cpqo*yt6zzG0Ls<%2?6c0mOPUz-M}y}bpSjy3-*`&0O*11qJdCi#BFUh0 zLdn&sCzEwBQ$E{NV&k{XXt7@3^J8)(zk|1oHX~%s8@!a>Oz&ogzq~rUvOwiIqb7ho za8v@=i$+a=ppZ>@)Trc|A2ljTywRgZO%g#N2`hv>WYkZBhm1-R_Ht2^L{L%^maT=) zj~8uZ3c4Bbn&zkRCT{kjftKe65wxcc5D{{`>_j|0w)Ico1-7lTKU?&FGwS_=O}T;! zktqX~yOTMyat_7&HhQH(VK#s9WZ??Ciw%!j&38+FnOfN2^Tz3zTZy{g0fmc!6|%Tx zgU>m$G1-LTA@NlNOi{Iu%TWuG*xYL@?1Fq|E#z!UIv>=3DTHPBihPXlZS|ytIri4i z_wI?m6H0$Ip8{+b{6*qqcf`Tx-EoVvL{Z#)1V24@XP#E{%7DzO^;8j)7#7O> z8E^J{xKA)I@{OJs*s<}x-ky*)QuutLn8Am{$=_9n5#eac@wP*lp>O2R zS&vpe&{b`F!*zaURnXA-2d1gk!pJ#`EA;eeFn4p!xX)$+hu-OW3hu>u$~~F>jhKF& zxr`rb+oAtCAK&9FjnaSFvb}er`hy?&InJ)6MzLomLlb$W!I(aD1!fX@;E zNhE=>BfXkLSbZ<53;bT=DTLqUN2FYQ!1!eo?e3t34@ZM#kdFwh=fZ_!BsKesJqF+> zsA845*-{5v7_;%QUT4~l z-mf0Mj;8>2PBwbW<%!)lEZVn#=MMq$X0s?9DI)3cND%OejnOqWtSl_xAFob0?E=t2 z;MP?rAEsN~?;_%M(cu%o^g#x2$b_Gs4r6D;AFJWd56f#n?(3WI7HHJr0|MDBNR$sl zY^tCpa;HgW_o}y=%<+1I>*Dd|4uAZS7Axv_ceU$LwKbAP%1gv5ARn-WU}`GodGX{J zF9LVg<`qF9kbm%(=igd_@*Vpb)XSdWN=QA;PYC(YDie}waEZq?UvZPx@23)JxazMB zK^|4>=v|FiIqV9RnoF3@-f&mJnow23fVk|3vZy@Z(MGEYC@Tv$aw-H>HMtZ5ITU1) zlU2mf!$kQ+VM5{Rr5~IJnep2vDWndAY*vb3(;l9r+>_Py2}3s5fpEZO zDw&HTg#Jffq}h(XUL5%vN(Xqv^KM~$e!rj5KJc8w+gf!RuQQvMfz0xBjyCiC?B#wk z^Nzjr+@^J=rx|m~x(?D3IGt|@_LO4|&y$Z0cUmWg>}HCe9Qw@lDH+!iuf~^l=pDue z_#(-?v*#GTtFqJDIBqk?UzamZpqalCjr|gmK*A(3NKLAtTOHJyH?lr$a9uVfqUR3n zbZW+7GnbGOJ$JZ7C>pMi9oE~#3MF9?77~L!KJ#Q~9TJh;&N)o_z{ zrNL>t8sE`&89zSUt*(Em2qd77&jBpKgTsuMY&qfFL#3iJ)#A4Jj*d|CRgn!&MK(AU z+2C}9jF+-dy_u?9YrKS_lQf}fyo93bG@<%9U8&})=`vnYp{aIzn`#f0n%qOBCihVJ zvOQG3WDk{+XR0;y!S4r;sZh2JA&*QrKHRLXss2o`5Tua_@3xy7wIu1NneP!Qf`xeX zx`ePi4u3s-N~JKutCzpDgo9t-w1mT#zqN!{Zwi41xB2R@nol)9H8}H6gEQYWIP*(| z+Zd{F8#5KYIiT}bxOM9WryDmo-L}Fv>O=|8O_K<@X%ZnfO(8IBRrQIGt3DBOqOYP> za-xZl6D@>DG!b&5iC`9qhp%5B{2qy#_~xsala3Fn!_1kNIe zKGd`asDAwSdcmQY(p|>ywWA7&2YcxD_XsNvy;O-Ay5SqK^i@?MR@LCTs`J0KdO%E!2c?xKkRD$w8nK`29al>gW z-h!9TT?%FC7IDG1tL6b;UE6a&)$MOYw7C8~xcqG%{JlN#YCT?!an&GK!#MQsQ}Ko0 zCoNIx^l5lAws5(p6BelL%>ve5EWr3MRM({>HVF?w>b^o$61vW0ebuGhfXm>s`+TRA!$)$e>q zi>8XLgMFD?H>fMgk8c|4`!6kyYO9WPF>lbb(pGh-RMq>rXFXSm*^6wSUfQruTu+>( zX@p;tRpH?(KHZyiNUtgE32}5;Q*a|$qj+GfQ7;K6Fg1~GS)<3h20cYdQQ>3mZ{S*q0!&Gqai1U;FrXb* zznn(54M^TY0+dFW%b8^P&XMM8>SeBp-gobt?)QU*-KY$EI}n; zS0g8@!uTs0z>Km^!*Watj(ot73A&7GN)aB7-EInEO0nFsj1Aq zu1MpO9+9aikQdVm=VmSjpv<+MDUB+Ql4`50VzzZwF-Q-kUPX{7C|k4qkUEY|YRt0P zE-F51$qExcTcB6;_p(+gempBq6r58tyMy>lA=P>U6tc_C=puw>vW_F zrn9UHDRpC>cUaa7MP=fkxko8?#Y#wQE#m%Ip&=r;#Yz>Qd~w7o-MFN1aPe2gUtTQ>i)u*PZu50ROGz`n zkCwFMDV#YNQ~2A>CmuBe!cCQa^h64Rxf^qVUyY|&(b)DVUP}3Zwp=88YFq$b?u@{9 z=aGKt);BDMy9BZal|jy^W&@O@__yy#J$4h)0qM!6n|HrPYudzw&m#|HPtk#&)ZG`6Nn7%8$?1j`yIA*v-i>aJe34uKt^4KsYT%G9X-M~s4& zTr!h~N>9?ttoC7cbNv*{@+?8JR)`R`qJ%wBy%nuU8)0_K>TdUAw%^zta}l)Ll922;x5kQbu*x)`8-3+_&D2H?VwpEyDJts zekNZ(x+Rh|d4POE7%ri9MMGJp$_SAA^pM5e|2SVibVJVj`U1f$Qko3XR_!uR246Mu zb%uEahH+S;Wx6)gW-En#9Ih#6U0`Gq5PdTsN~_WYru6fcqM}<#JW0R1r^(!$mUb!x zwwfrQsa6aK7rY8bFWzq6T$o;U#8YGeN$nA!GCIR3S(;Z2-U2}LE^)`H?o7!75UsSP(-VjonDS*2a$Yt~cy~Okby@Zt+-zCFD zrx*#mk8C%puqCS@59R&2-g1kp=c>hKba7N_Gz~mXu;K}JPHi~xt8w#;8oZ_as>w;V z!eLRY1DeU{b}OPTQ2Hx#P7p2=Z^tzM=>=QIP{VRacr~+_^I!!EPx4S;>3zpD_qjzz z)m2341VYAyp%3{e(@U;A8ZNgi|8QaTM$6UzwaA;a#6d^Ir)EkrMK?RguTuX8r zupUu68xt9;xIS1b0&-=A-B)nZ>Bo!ZWNgD4jY=KJm+FcV>tdEy2LYre7!aqXv8<9& zOP4#A>D6S_6C>edrZ=yoi#M_&8s2hk7r|j&`e{lA2>ipky)`{H>sfld3A;KQ-iLk5)L$ zCGCE!uxu|;Z`B&sV7FGdq?xxU+WIw|kE|}-sBY>0-mI+NtA`xRCbT3Vak<`bHk|y4 z4Yes~;Yf#pBwh%%<8Zs&LaeriHPK#&^NP-rPVK^lhKcpK$^E&o{s8!M+`$&1l!Ti8 z{wj}+hQ5cIH}Hs^%raf|@scgSA5{Ijq-CsE&$AA5x%YC;s8)nh#+@UfQbHAde37(S8rsarEiF41#8Hqo!pcY3*^pte)Qorue549V|%yQ=Q! zmN21QZHZY6+LEo$nM;5YzbrCs*koUoPdHjO!dUNcsVPlkS(}i*t?k z62U|Yzr9qGo$^-|j+aJ9fyS18!v~(ume2Ki2(0EXwtE zfw;_M;kN=xaHf&{y0`C4TCJ(8xhtekw*wNP4tt>_Ktb+NH7}L@ zZAmk=Rn{KqJss_VLKb;_A+K-SL_c*UF_OdDsTNMGZbYBj-Av#k}TP$?_o=-1(Y>9~ga@i3Sz!`p6QVrqlA&DpU(Q&sSU$loy1;`F@_q6 zTjJm%V!W7GD%#2WkQ!aCB}^l$uBY-H7gW2UvX@A^_vuTPOY^4^kx?r3DAP8;%6zt4 zN%#bMo@_!R^1Hq}H|P9d%y6q; z^(dq`ouKkpR!n2QAO6ID?Ctmwni^C&B=q-2fB8SKZZOvZs=?;9v~3Q;mM0!>Grgwr1>J?ECN*z>5?ll`nA8uLVufjttK$d9?Bm21Zf0@`(arS_9dEn2 zbBcE#BZIF1G^P!0-I$*L_|%QC{MQxdz#g24!xCRQTtGGyClRS>GIdD*KDyua*SX-!q;$VJ2;Wy841gRmc&c4eWvLT6Rzwrfa47kUz6D?4Yjej! z{ld8Gq_G~bRj)EK3XOJ$Mn8^!{6J`i+XO3Sjc)9$D6?o-M5^^lpZZ08%sF(r+pYOh zV7kG#$g3$Sv7m>z z0dXV{9ypl#eQnA3gI;m9z;V2Y&6piCj?y&2(B;%omSOg5;#?}8zrbczoj6)G`HA%c zF#~~5mYpI>x8G7`eFCH29{2>% z9!X_*lZq~n=@$>o7ui^k&M6$fUKNRU)QPn|7SJ~5XWw)+0GtZsc4s_>3kXPV-y{7IV;pZ6$Ok&wKg*z=}n;gzzP@ z;L@WM?CZ_s&6`)h7J>xlg2@K%LxZAVC^$=dK?qBA6r5GLAm)>&ph@y66y=-uxP>e` z)`H1jLcu8etHa-3ssqX|L7!pT=9a;cv+hZZ7bUFOaBeFChh7zTRw0ebqJ$~OGKD5x z%T9Y7HJ?t^w-qjlvT%K?TyU3)3myh`g^-mK6{#{r%}0cVoj2Kqbn)kATQEvk5VXMs zQKKe#s3M=NdDLxJf@Pmqg;cDH3(X~)f@@IW$G8w~nOv(0MS5ddSgRJzC@V?16@60X zpE`K;90?K^^MB1`G)fGs-LTZ`)j#k)T>Ig{2?7uvoHZ3{H!yiL0{H|%A zsdIy)AbC(`Dz#U^ZlK^@Y~j)9F_I}88jG!ta$?r7T3-f%c^Iee6snYY<+c>(i%KY>9AHN)4ppI3|+6_Xf)l|v;g}TFQ zCMzLS%don_?HrlshcnR(t!jdqVn+}EB07Y3ue6Oo6GE{qIn}RisXb|*-V(ukT*7S6O)y14 z1h?Z+%Pbw0=)9EO9cx3wE(qn1SOa;1U7GFHUzFA%t&rvm(@w?Mb#3l`zAyz@nK}o3 z#Z??ldNfUg(^}}e8%sH79K`Yg$Sgr-V(?d_;p!>PV{j{E5~D7zuZC z-mvHN__*Tmh0kzUG4@3u+s`w3WykiTpVEE?4?*n-eyeVs8lmYK)%i9XGw(hPO;Pdt z$!u2IS6jF~Md3`+se@7eQ}e&zcS33wyBprjk;1U1DwV;}yn3!V&D+C4*S9YXE&j7~ zGobh7Jc0fU_u*L%AF}VjA05fQlYU03_6t?Mv5hdvi*07r&#OSE-A#q5Dwwt_%5{Tr z6w$V*)L|7#MQ$k%Em~WNSg)-jhpchJ16R`5ht7}@jH;o{6=kN8^@Xp`x%nhb1^Un3 z&2M%Y26ng@llt83UC?;O=enmL`4W>3e6QB`W9`9hyC z8J3%F!u0S?H64*QijJbp!C^+hvkEDt;VGum&k>!^IWi7HsmD^nnw=F%BkZ-D&&)MG zTNT*frAm}}aBzLxy*k8+h1HAeHxtGhc1FcIOB$yH`+l%gy@%+vhZ7|LrD*bgkznbC zaD|ajmEUw)iQrB(5;ocVypVZ#!X=w{`n-H{)J6W@$c}{k=m<^a0F|97M~|3tO7=cm z$zzFqKLIoOi#1G+m%~iga&wx)7i9kEL^+DI)Lf!*_DXWKp9iqK;NSLqVe3swKIj6$-nWaQuLD zwyY_iIiarcRTX`_Wp&)Ls$HR?lD3G)S#Se;c!k*W$T!IEH&69V622$AN!W?syM;IG`_$Np=wEP$LdJLJYM(7k{=bk zG+!OMN2N0(d%J8%lE}OnwzDRJTWmXPN{E~;uem7rH%C7^Q3(#3dt!KuR1x5N`vorm>3zR-ZIRC%EaQ?S5%G<*UZUe zrnQ`tIO*3!)*ops*+J57e$kAcY-p00;c%x(25(Yb>h#iK&(`6A3>;e}8RuKX=K`37 zVIlOL1)DH3q%A5G(>rpBWwWv1c$s%Viv0&YDqv(xF5-pwMCpQKv&Bc|O*VF#>AqqyIO_z_n;2qDhBmzH7m|jV!Paj+IntDUX@- z0<5>GM0Wvf;)XKqwU$4wAg^Tlq)+ir)a>avBT`?|={CCab?sY_Ch`E06(0kf{YW&9 zSOPSm({Cm7!phmCkUEEJG<9apqXpuB!5#WKJvV+D|A-eFhw45 z(UP8x3Bz_?^XWBy(9XiMkDr-U2I+veB2ms5K6!PqjrHCjv7Gb+sL}I2K+8ry0L_ln z^N&HOY@T;WmRb7}S^gupe8)cq>;5T+lE#U<{pf$ky?T0Ty!%a!5jWR(2)rp^-BLXk zw)T_z9_?Z_Ui3(H;z=*WDG_~t>zj)$g$t%tRAl=KWAuA- zV>6MfCWbi$VPu?qKys3DmJ-v-P?UL}_Sg%v8&|W!7be zz8rZ7k+%DCb2MEdWm?~tkTf73k5|<=#yZuNP(E#tho{M5)oDd?Gi6#Y|$p(f%n1?@>5Dr~}MB*NE-rVXo=m5iR6KT2-PyB+&Wy6;Bc-kzX{H~*jv zB6-``ajwYCgdm-K=n>MRWVBWU+4mTk<>!VBDeYv~5V%`5q+DG47#P|$jA0QVr@TRV zMTS?m*w<26)vzANveb2snI5e|BiCYfv(6*<+dYgSNm~h_HjcK-^)}&j!vwN6r3ZiL zo>(C;#SAweW!U;^LKvRYbB`WWjVtZViMUi=w{f1}C33CXzu3ldn5)#iZ3blIi~(&q zplr;KWtEzC#F4O;f4`YkTt-UsJ*2%o9@1oe_Uo(P|Fwr@7V&%N434v5LRqywWS!wJ zeMtRd-tD2{vv(L2o#BwE%eF)6@pgGLq?+P>NIv6b`61O+u*@2JSj)|jC|%o-s-vhO zmHq6H=!1QIGjO|#$rQ&4!w6^oCgPCsdABDtuhR`fewjZFiS$uz{-r-Qc}V@1Nohcn zQltsAsbgr|adx9vbt(gz4tSbC6RA~|CvFPaLC7e3&!`Lyxlhryuq7}K%o8d-hr5YN zlys8SBb$xWY+FLb{GSgVkfPm|+`SAwUnu4u&U+9J81Lafu_nbqn$#T?S%*{=ieIz} z!~C?q^@-Os&YPP|>J_n$&N(74cXHpH(;p{=siAdA@9VQ&G9h-r!u=uDGeby4UO*pyHu5fL#$#Hx(70r+@NcKvI7l5G&oEN4&V7 zg)Y$X<;OJ^lvQTZD{nV_Ds9v!EqW2z*xDYcN{f3Gm^TdRgZJw4)Yj-a(!AGGizKo> zcz^g#w?2y=B}J%*a5R7`T2g@2?zH$`zIjF1%Q5E&`#I(#VK0k*^juCp0-obW?|P2i zcb~8~^D~!Ds5)N3L~cqn>QG>!6cb<;yz%=q6%MZ zM2yG`S24Aj%F1((&HWrkL>0z|NJYphc8{Q%thiMVt*GIxBd_7%s-xiHry~=*=T#}B zbn}c?@mNT0eWJTnRMyIURH|zaIZcOqSUG2(%-c-JdLNm*_matcA3f#1kJpTqe~R4} ztcljLsM|>AcP@ zH@Ib(n9tcF#GJ4uy+-R%(VvToxdl2j#ne4G6iKqW(#->RW8vHAp8ctndO+)0qk2pk z!)nW6Q3|43b6eQVtkDNEhIN+qC!t>8y8a%a-;OO$JE`-NxrF)?gtKX$jZC4DB`J)G zVI!iuVC5)}pv_#DH&Q`$Z1Gb~Cx->BdBFbdq)*5=5=tjG z$hMO(P1E5AI+W0lAKMECxI5sBb>?A8`<9sW;4L-u+bxk3;5F8aDY@C?Y9sv0Yg8S= zEh%t4X1ybt&%FWqt~jR-{o;C|ZSeB{#pl z9>z%+1b)3+bKQa2PPeq>ceNtOepe&X9LibgbLK%(MWQrA-#-fqlIKH$DMV1$a!HR~ z@ZpBPW-@!Zesw4_<ho247R~W$2#de%YGXGLQ_74t_Yyzpf1a5+B=AjmW<;Lz) z=ajI8X;Z6(hz)N>MnUCZDsV}7!k(aO48F)eJDVloq1dPX&fg-X|% z4W2FSNA}$IO{eZv6=<#MY}168%B zxI)06!{dxxj7a+SiiE!X-oe>EiZEr zzYp)EC;##I(<-e+1z$VzWF+QE-d54lsxO|ZaI$_hdv-%6Tnsh9hJ*9}Gv6F?UPT)! z_@Ix=%|xGVJ}3&&Tu~I1j)m_nAFTN-!iGSFF)34**($5zn3nFH9{xJT3`7TJqkkP= zsE0W+3un9altAWov^F}QZ)RG+GU3DcaVEDknZO8eoq0{k@FXP^ln-;|@0O+pF0bsz z#+xji3CAqTDH6e$3AirOBPzc>?Yd7;as-r;rk7x!q#;@dA(qecHIWt=5`8wVgO#{a zj#eL1;`bPS6i^4X*0Kez)1jPR$iuVEgP9>{nX^{fL$x&!e>oQ9X!?JMlbYL17s}z9 zltJX}0*{Ud$1z1*~7gbtQ#oKX%a4E8N<2c?ZH%c z%GNOsL+x^xW2zv_MO`(IIVWw?IiaH$Y<wYzRF7DW79Zgze- zrIXL3F*DL7{`2-otf4!1YZ%j=Cy;U`u}BYbS@h(hBjeLxs69A*$Cpjm0QgAkk=&_e z31UKyJow3+-nJU_#uYQ@dVwBR?uqCv-RSa(Bfs;-gZD)IojeG(YsY#(>t~`YgTszt z{dBZiuYN9hE@3pzkV>gpOtA|{#p+&XFcgNl+is)=$!{n$B+6KaNEM~#2zesn*0=kE z6ax7$EHyqPE|E0XPeZzWb#c6yGN?}Zp`fsCKPW!)9sy%e|DosY55E~+HOU_eVcxiAq$h4Hf^PlFyt12 z(11<+A{81=foxLAnhPzyX17{V2vlLpArHMQ>|1Ji2)1O!sIMWWocGbt0Jvj1?FMWg zXrXQU%<1-Ie08s{J2}0$l0M9_<<;L@oH*ExJ{uWr?& zuV+EfHORb6w~FE0gBOQXY_l;he8iDhVki}@>=8~2MTIUam^#QCO8Qw+Z@B9q<^`rG94oR$`{ZL&lO6&6 zS<^g}u1ybuHAIP0uJ;&CZ9@4cs~mjyXwK1?qhO;m{rR>+E?`~Kv4ilzRe2E=DT$E6 zwKufRC4?J?`jM7Hzq-Ak-?Nh|X}|5X{pz>hqwDd_S4V#GtU$MPpIAxKVU@_UtRJNI z#wfig0%?8aAA2LDNiKV3R3Y*bm#LdZXRmxVDMRKEb_?cBMs%SJ zsf;teWHTw&#TLVy@hm+~5ma~X9D|hcqmUoRe{V$GIu4 zh+aR@5ya||ji6|}pM?g@rjQ)nHbei9y?6V~>q^u77GW5M$1n^*Fbu;mEVW^{6t^ss zG9|0sZiAvInIr39Q7To9;Snf`lG!>?CM8R%LZMaYbUKYrkPL#pn5$e320<_vxftXk z$VFq2%Ut9?%JW;#e)n4Y@R1)S+tt9RSn{{m+UxMHcfIFz*m2P?`oZ)s>?~?XO)O3uL4^4iyYno?~n_6uWJ&MeoSM+FL!d7bP z7;MQbnMh5R&8coyHKjFxH3abDJ`Pff(#_+{F3tFW*qdT27&NAg19YtL-AaD)3nzSwGz=gVCN+4uTwHVgOH z9vE1#vc7flVTK&(rdXtI<+z-0*0ku-UKpc4<3gJ-*(i^7TP`YY-!~z24v{u_AjTIg zH5pQ5GB4O-qm`>D6(|rb`f#j{mvjoOPkO=CRWgC8)vu#-gKIf1-f3w`eu?(#Y=7U$ zz1vAiq;%2&o_e@jgRMAhHzNjj&Bd;58&UVS)_Xa6BkR{^&tya?(L^4dkZ-9h&GVH9 zYmRLvttg^n^Qw81B{5D^wn??aJ#+U#w@wt-O*LW)85KENo^Ecf-a@Ec+jLqtUdzD4 zp#OUPrY!iJ%#S%Fo1gCRCMUCgytd6XuS0c=_Wiis!I+jdZhapOUdqq82|q&3t2eK% z=X@blqf(UkIss4J=}yHQ-0Eh5`TQlsUbglQfu(NlMyE9}Ec^E1gSv~mz4WDZ{3IzU zeRyr-{?cOwDCEMB&X703>hxf<&B_t$T$-%KJMvw4(CC^U>phVcX+kmla<#^F{UTUd z@#Ovo-D{h-IksupU-4>LXF{4%*EY&?e1G!7mJ9^7pfi>ER||^|uIZ{q?FxUQJ%ilA ztIGykt(U)^nb}$xae^>bn=PHZF2mSqwv8;XEn0C~=RDG92K-bl(K_Sq#UM7Pg@#^^ z5Yfw#zi#?$n(#gl2-X?i22#@1HHeA<>Ey4zP>U&_G-7@@R?0WV6@0iY^Fn^xy>0S! zMx}k07>jIuTW{`DYz~kWUXL*MR+hlUq-R8gg$R)*vv;4bFLR0bmgYDIOk4PwDi80_r(_1zk zm+q|GI`tKwLT^HTG@{+y^PkLr8aXT1Hy>Y%L|$u-1Yd+#M^L_)goM;X^R%1=PbBcX z&}vPZEiM?2L{ghgL(Q8U{nJ+Wk%F?V+2Ey{_T3kd`f1BQw~u|gc<%u#C;Vh{NlHCk z-(XXHUQoHbnV-0+MmH2kZu5xyL{{_l@8x?xu5N8;aYY%hqKZd`&oLlOMPihY_i{sI zAySc;x#4fl2{s7Z)-Ypr@_LzqvEC4CmAdE%ai=Fy*7jePAljKcXdt4*T16rjmz z=&Y0%gEp_$@=XI7uGSI29l>yxn7Pr(tiR|)A(@*JnfJDPg+`XOV26A+WhuH9@%E$} z1)AGVCQfm?P^N>P<(UtYE#}pwlGkcuUQT*9c(dFqNoB+Xw`{RkRoY)#)b`o&S9g0w zHRfJUuH4JJD|?=(+j{Av9Ye_qOQ__ug#=H@J@vgNr6gthU7kHUTQ4W-48hvv`QwAU zi?b)@&JJ_u<~|+Eoj*2`JA3StOT!lC=VnK8)!Rs}dK<|-`q^0S-2AbTva@rajpYim zxd9etXO9l@=8g{YW{(Z?<~|$d&7K(Mefr6XP9J%b_1ygYY&V-pnLFCe`%O2Asj{@# zY0T$!yLl^eSta3hA$d1ndp9S%S>Dbnq0{o|xx3x;{Z8`VTwZ)^1 zQ?+7k1=89B`Z7c|ehG3l>xONXLP*=X#5^w~%2>*6>N|lOTbuXtGZ6%NDtT9G&JeA4 z(mGA5@7=7)N0tscwYjEGl?tqrx*I{afkaYl$#FcaFtuEuP=|{-Nc@ z4oBX`V`DN%Da!uN)=l(-M$38j%OjQB@kW5G7_zU*CJ2n5Y#rgewi!N>*(T*N>J()5 z|JpoS)I{0EtQs2Rap`Zr)V*`tx1vtIDyB;3hUM7u&E+Tqf|h!DB8N^H?cCaw_bU3) z=|*nQ@YrNe>G9^qmTYzBU|sdI7F6xZ{TmDS6l`irZQZF-TGXskDlDa^Rk0|nc$&`f zwn<6$Dy6zrs(>jgsIB1!eu(yRl{Ur1H&CrLzaYtBkgqpxu5-~0+d3j%(#dmlqLW4K z9FEPEeq@hUeo{yImz(LD9^I^r6rX*3@FZt&AyOy9A(KuPonXX%y$(*dj2ualDa zRq|q1jBVYE(ni(W%M$x_Qlh;|0@bAg)y1qK+on+1)mwCRl?3K0d09HFPHG5sQbVYd z8bY0vzN(Ups7_|B+d{$h3Ywr?44=PmlSyk$gnQZUy^0a+&nRg)~r(rx9#ZLAMA z=heJesF`h5p38M~owG89<*JQ4x$@+mccx|;CrPBhu@1=7xP(wih|al4O2;9aw_d$k zk(P-ZNfM&Yxo+cKH7S?%o3d4?y}M0Xwm>)7C6obUYl|Wv!LWcX7%c% zKC7u1lgxzei`uuPhurg=@E87@j+@H$mp0=8ugFh#R`or!oJS2mZO`5I1FKlsb$7D8 zXu(N{DsSJZimZMA@Lp5-7IQ0&m3N#s4G**K_KK*{UQT;6M$-oPmJQ{F%O6K22*)uqDc#wul1oq=|u&#wP4X?-x5EC)g_Two zu_e;E)7hp-It9=e9H}|i5=k+9E~&=+#cdf@Qa_4?uPD0Jz>%NeI_JrM^@Bci=!d)h z@eKxk&S+A!J=eXdQN;6OXFc&x{tOcvchuK)whuSYGSA$r&OYRaH5G`>ff+l$(Gu;C zM=zemPHE&tCyT17JfqEX zrjc0R&8>mMcKIjgtajdC%3E0S3yh1rpf4M=&CslO^5}sDn5GCzFU@1@HzeZEM!dyK zUt`SXmZ+t5|NN|5aq=&t$`7k+7JE5?F!d(Hg7W-T?))}mxFm5Q7@V7l2N8=eA!$CH zn;!W4^4Xdf?fPY|(-zIC2iNn4!(^WVdlh`!rHIrTS(jEfw$~SQNMCU_Ei8-6?>N;g zW;r39r2@-&IZZ!u4Oq+duWYNFUfJMIVfH^NdaciO@{m2DeB-vRH}S>Qmp7f(J=j`} zpipz|nPTv|el-V%ko0_!a#bIQP@F@dBIhXnR8lhbn*6LGSAI~P%Ue(K@5VNJ{A0o9 z+D#IT{&s>ud%B^2r*e3e@P1mV9(Be-UyQqP?vl`Oooxtmy>tON#V)O0_XW4>TRD9r zXKDlWxl>2yKCyUCmvUP6T9a2cv?Akw3MwLWo%XXpGD%_ zsq!@66fg|3ze*9X%uGA2Jl?U;krnj*XNU)7gxXE*t&Cnb2HMisd9yUxV(A3tSr`(=-H!g zqbChsS!K%9D)(I{fSRS2-b-O!1liabS#nwLH+8cJ?c`|Wo%Ckj)6^8#%jQW+Nuso5 zYyJofG#Qd2RZ6uQs2cOEDWzjD&C{=CyWf1$ByM^R#Fo84JNoa6DFJ}ay9 zY3pqUB#mfnHo-=@u*OGTMMQPvRlRXIT581TNNJ66BzJ8HO!OE{#+_|>*Gy!_F+Nu7 zz0#AfaPwDb^LOby#JmXPSGpC%x4I?bTCyna@=eZ+J#U}(Ggy`SiB|%=RRnI5I>Qu;S~M5W4H9*6%biV6e7vd9rF+W^@b?sJQ|_ouwtG~o z9EwW}h@RR^!7Me&iQBK_sc>a{`wTt^tLXEzT9i7)UU-%$yBQ+(PJ!iIOdA`EAe4H` znV@GwYq)T2weQXC%0(4qoMy>s%d0l&t%VVxxJEJcojE0{mSe@THGDZ-1Y&?)K6TyRWT?ymt+M zGS_jYH?FmrwxRQT<7QETVQ&p-`_60MS)Fg^ykIW|)D~*S+$qq_gA3X!531(|H@PbN z-P%H6sO_L3;HHD1^qg$yI9~ZX$~omR=biUCoww2Dr@7!NnU2lcBP**jCu!zka*iKu4P|IQkBC;2?5#?+je+u!v(nvPh2l1 z7fVtE_fDs-v(Z1HLUTu!yta6nFwh6F5Pnhz64sT{D*MIFN0E9stNkL@W%|8#oz(TU zHGbGxqGxS**6;n>{11jfe#L*TiRJli{4*Z2*Uy8M5Kq73KWxgDC2(z1 z&vHR^&WEQ}J{FUo*dd%Bz+m1Un4$0!5D>&wNR*GtXa{9^UcC`<7{BuscIoVcO?^U{ z!rCsxYB`UZUWpGatCOHXrb9w!{6f=QWvdGc0bWnbQGisjwLZHCmoqU*X^bB%){9HNl9@8@$m zr@&qT;!OFsxxACL8yWeEQOSkb-rm%u^SWvw=StA@a#XjMqlN3b3Nvt8dsB0L#rNB1 zQEvNuGYVugf-OY3_>zu(wh3OHB+k?3oLra5SCY$GQ;(W!?UMk^Z2^bYUGhewoUvXf z6j{?QoF{EbX$H-1d;dVr*U`s8o+JU-;yPmeK#E*{Krk})^rUuoPi6PDfrAHm zi&jqY%DO31^=^Wwt18|;5QS`Px2dL_!=j6Mxh{9=mAm}t&ozGikjX#yFljka$K@ZU zyALM_5M7&>o;*y~e>C$qU&~0F@v!#2R?v{aAd3d%qL=tJ8Q_0R%8-l?bu0MVM5*uxqWBdtoY z+pLqJkK*3B=5VEUi^yI&eMhaF`s%AE*S9uqL|S1M1#+)R25sHsy&^>U0QxowO=fza z2?{Us%;R+T+GEYkW6nn1*PhbH+NP->$rJ4cd#qV)E;(+~MY7|j=y75)zgmBsaiLs2ZEvml0rcd%3Y^T}c=zL( z?6Pf$Y^k6ii60)^(3ZKJ!=C--`A+rx;7*f?JkevFl1^xn3ZBr&_xgA7rXYKqR?cla zPC1~>!;1cG>5HHSw3$<~>uP$#2;KuQdoV?Ji9ggeHU`FE$g;AuN*2kTi zFH53!qKvGqyjv*iB4_Fv)5ftPs!|Hm#lrU5#zx8F7+fcVGUfHQzZKX(sO1<%W&DXf zXRX-`AskX?TO!ptCl%pXU%gjnHFq!6Ss+wLY?tpn$RF>EA-1t$93fev+2x3r%Q{#% z%x6!icfGhA5JnB`c3J5P@;C>v3w-gub(+wPPvicKQt9&dTBzMguJBYDJ-HUsSD5VJ&EUg`P;N5W22vOzrZG4 zuWc~`RHOI9-G%%2QJoN+;Xk>lha9Q+G4AusS>oILdpG~rc1;df;E zNHkU#%cYEcY4ti!7F}!tE7iKI;&C{wtzTVBmwPM~H4H9*Y-@l0HKqqTAlPQ zQ6wy&>ss5E2AO1+!l+e6aoQD_xTvSK3ZS0*N0h1d>som@3jibUi}iiAs$sU^dG^aC*iXf0SP&bq&N&Y*|2ZxMdX{W#J?pY zGjK_2%s8VZqvgaZD_F5)WlyH66<}3a8P6@}l&XcBN*>pCHGWT$BPnBvReo9Eazob7 zZ&q(%wNkcWtdb#0;atvERi>~~DJGl0DsgIa;C*H1)Q(u5m#Y>ZV0~?iT`*NfjJ?Xb z)m)iZWr^s!DIBUQ=h~yvMK^wwCsrnT8&D!hr>pq85!dRqw0aYIO3Pd@0Mwy-N;O>V3<2Rh}Bj@e|#YsP3v4 zSMEL9TGb~l+tyXGN@ZIrzTHgcx5TzOt!DYs03^GeMY(R~whF33H}iHsqlGmq&>L3; z3%wXBo{E(Bj?SApb#!5iH@fq5@xj&|S*5;bf}Y5Ks0b6khSX7g(i_|5`L5RWOR3Ta z<+k~czYEWk@WGD|!H;#e=bkicC=n8&Xh~Scm-Kd9Oqii6_CCMFBKZYg+m<=0@D?-6 zn+AujM4*C+pJ`LQCB>btE3BDQ%n z@J(XduWwRjoBz-fzsuXJxAm!v)!TQJa8M4fDle1?B|bY`IULQK#-|*T2>%lGr6v)Rt|4Rh|7uaTU6`D!@GC$&@{+~KIF6HNZ&9j=)ry5 zJH93wWi3Tcs))zG+3ipaMX)zp>&4e6we3!y4SM1@1vkTvzxL?|-I(Fybkz8IJ$|_r~ZK>1*$i!w-*i&YnGe7ZqhH0!6!M`-ZG#SxbcE z$++mZQaOBx*cIG9oi~ z*U1qFb*xW<3{hHGwE%}ft+VUbcNa4`Md>M|`uyC;u0)#I*I-LKqJ}dCN~>2Z7Qw_X)^>>`}`x( z8R~4_zqXV=Tjl5Fdx~c1ol;;;-CWT{#0*6ewI|L=C&_t8Cs>5ElayTu&qdg++?NV6M2bZf9?|X}7skcxj0ZBA4?()uJ zqm9^??9~Y3mn<500IK9U&Q#L5%+`kdT8#wBCo$o~&NdOl^$?H5^n=Anw}VlJwaIXXL5j_GKV zmCm?oRjAG z(VpnZO(Pw&BUOmTxbRbRmz50Mth2Rpl<%cv?JjF)r5A~~qG%8EUG`pDd?&Mnc^!y-~eXQRt)mzKyjid`JRg+rj=rlDbeLelPYS2P@ z<+h%lq_lETEo`J8GgRy9$@vG;edW-Hp+BrQ_j3z(RC=u{x1O|E)wD|4kJHSXOKDNq zzK~YZ<#aTCnr4N|^!fQ_ER20oy~^qqB%8v_mj3G=86g-mJ`Uvm1?`uM!l&V(9Obo? ztlkVASUQk#c~AM^M7tt1+BooGyuyPNpk*T2i@1{r8fdm(yweTTGN$N@@R`a51lcbE2b` z_w?skW%lpoKDX4jXZB!GR)Aokas@a43XgZ$KxAe_?ZmEQ4miD1M zMtn=TzyU<}+W8I|WxhO;x)e2mwcpjW0dF1Cc>bseSwkDR3+RJ&Q=HpY6E|c1)JoLLNSfJ2TdIBdql|P*^$XrZU zo*rr$u^T)WbLo%=rmX_cih92#i~;9EK@CMM2$oxUt~ZqXy|7fu2S)1OVH-P_uj`iQ zbf`S@wA9j5P>Q+gU!}CrExB82P2*xDa4UHJRZ1@(QV(hWfhG~^b;G z;MZu^x~ufKA#LVSQWCk`hd(XB>mex*s6}KlQpWnry6#3E5nLTT`1g@&ZV7^CZH19o z@-v<^e_HJ!bv!D=V%g6q12f%GrMD(X^23Xg?_cM7$N(^4S?u{K@-9>7)4v;%Ez>ic zTnp4iH8&K$UkiLIqZ>jb(^Mu0^FkZh#6Xb7b-jx=qSnU}tO4|}z7fUXpQwdL>Ir6K zQXfhL-xs7C4dTXBzSkwrNxZLoOOvXLo%pi zIDS;C2%6}nqXas27{!pL0(RczehwQV#Mm8)Mc~CO8yAr2&^W{}K`};iyRR6l>D{2M zOA=oTf*cioPNv~$nL}xRyv1BRl}n^o&gn_U%&RNuE7ee`*ZnjnGwRbSHJ^^PsiRWj z<=wn$&8c;aG#lNga*h;zFYg#;X(w+^eXHGlUE@_y90IPnbX9F$7Gxd|?f@hGt@^?I zyP$M>bF8H6&re;yUow3Z_?QBMx5mq+BQ++cXy={DReK8T4b&uI5ucMiMny0g}OH``*dl8*0` z=K-AWjnQE#pW62|ti$(Rc!%%1Fjwyn^<`#2*v*&3J<`o7BkksYBFFoLYy7UcJTHlHyP(!eznE&Gz3Q%E#I2dBLF`dJbDn@o4LK~J2 zmubBHgDE}z#}%Qw@0pI7=X5*CS8zA@F2yXL#uw`vdui0<#JiXdSwLtQHf4UcvAqvh zgl=73AY?|2kjdX@CUjZT@T+u4QMFmW3A^g zzoZf`eJA5N*f_npD5Lai{UIt_6ZM1NC>|N{ZCJ=X*X;kHBI6&buZRb%W(LHg4i8^( z-b2G^=mZb?z482uGVzyXK&Ru28JEU1SO+Si8HK7Nq7Y+a#53REs`Q18XFg)(L3QIa zj4**$94**R>BD-?yYw3ZHTOJ$bL%Mm-g?e6co4^w2n7(qE432IC0_n><)&8-q`%^K z7ChOla{S~#raJh{E`4w%e9gb~(mh3?KUB;J=$K)G34{S+rXBmfm1)r~Ig!~y?bKZr z){4{n0yN51e4IvaWydg`jvF*Pb%; z)#>pNEx?a=r8YfguR0L_qjbog^Z_MnB}O^i`P*tSXgZzfmtsWbPN<@;!{}q4MYm@t zhc;q%?&TS+OTbIO4wi#v;0P41mebTS5=-qI?L%-~HNZ%>HRc3Efib7!{W=7YkiF2s zophvE7kojD>7#zVA#`oo3#|AUqr|AUg*gXZf_k24)JRR{5ljuCw$ui4^?ioEW9Aqe z@PeN`wzIS|TsvdJ)GBDc7>8!c+9!5~VTjeX-`Vkgcc`%dUl1TeW=t+uhZSqe5rxfT zy4Hqh%mOpxbsuYMuLFLcsU>Azt@(%G5#c1vSsSyzV_px(h~RST-vil3L9UvA37qog zw!%7NrHibnO1?HLo%xCWX$|QuTDmE!Hpjz-SvJ2#Ya{tDlb>GBG{1l3{YxK9F8@WV z1-;UCCu5iZtUlKG{gD-77U)#X#o{_M&L?`t0+pZo!wnK9To2($; zQF|N07gQhZ0U7Sfs8{sA*~2f;pbeJf+Pb`qntnzs(7nJdqS3*-4K_4rsl z2L+_7VMWw|@u8P;rCBAx4?6k{nd=ErWUE;zOCS#uPW z>b~G~`beJ#&TJ)+XO9EQhC{k`B32JlA#?u5qJD?V4qzN9#`tR5hNqWWFO7M>k@`Cn zz--@-leB#LKm9UYnOL@jY@-b{gANNgFNofeQm`YB$cjx0!+`|iwnYFCiv@g4fg>ND z1QWhmU9mF~HT&+!vmh@mb_s5bV7k3p&=*A^xIV~C;F(Ugc$7W-$qc_t)C*xOma zC8EA2>FYO6^NR~g{wuhAj#XH`t^pR zh93HCn?^U51qIa%3%;li3@~S&jpcss*nHHGLw5+Qt^m~-R-(_EYHb+6DKK`Smk??< z^Q?mn#7K8W)#i6Y=q!$nt8l+8VByQ1L}VAgYJKgeZGAXjU98}t!V`pvnYzO&{2B#LTdK!~isM@k2&~#_x zbuquOye3fUFlt&vvfHV3X$-*|jiff7k$lWsq2ij)4r&!(ylpUA2eU$^$LwM1jm?zs zeLS#nSa=OZ-NgrnBs3RLn83QZu)p4Xa40!a>wQ1`MTgF8`WWMh~;fw}{Qug=%jQXoO3P zxqk<%2^>c6Y@lS<3Ozxq7|*p^0LM7Iso=RFi9n>c$=O+O8Cwp)1C#iE=E&G+(2#I5 zcAnee7ivo<#>&Gfi~#N8@{5_mbpxH?b?`BL31>#=-?9h1h4CLF2uX$hCzy)Mkmq3K zaxUxbfR>QRGUPwK;xg6J$TlZ%nddF{!WOZUo?a`P2-6!-WNZ=F99^xk8*>!nL&|Ms zrwbWqdEV8-6RCUqyfCttI$cYsNS-lRLUYtu(O91T!$k=h7{;+pOsvT)SdcRPz(8Kj zQbs?54n#Q$#?Joq^l$$(pcLI8Ahey8b#r8vr3m07li?Q!@)9)y%OgkP&C6dkFooZfKzQ6jzKZKLV6i;71r zN)0OJ|Mb5=jS+UW?m|2=_@O1nWR^Gw`hvp`E801TWw4^K*Eb4ldjIH>avlkkSkSZw zQnYs$I09m!-_5)crVXtOt9lVRq)!>xDfOx4_QPoN*zJvm4}Ye#ZT*zdbCsQ~W0nI5 zL~yVGQ;%R6!tF!y7i?zu)`Va?s`PBRJ>+@vLt?~Xy1Et?;QeNjXO_p{tzj%RJ<@SD z)#A#*v6jln@5vut5*EM%#2p$UTJ72z6B+B8#m4yiTEsXa>D~WheIO8^yuJWZLCS!j9D2VTjWbn>qHs5gf0Xe)EqL4?(1%~$x_3z@%J_N;g5ujqXpKj_+FjyC7^ zUjA1)#+IJ`dq}`d)(s*dBRm7xcN%9qj$*{S*w;Y`7(C|ML>{Oc8(gqpt$&cbo@mj4 zG#OT9trMilPV9uR(x%}nYtU-%yBc{|I2e7wjC+Cio@(I`bd1flKH}|s6zn40>ptO= zzDBl&`;|t$u6=h!^ng{k;vW};=HbyVTVZeDz&JfwlT;A*1Z4Igl0U7#(6ogpFaDv z7N-dbJHeZ#K2#sDLNKh{9?T~WbHHP}`{pn8*5L_r2IGO|W8Isy!x_%$_x^F?Hji;D zm}g(<%p#^m5mvRRvY;Be`taU8K^EhhIZ-&QmS0oUT$m)fe=R!0hql4Q_=n>A0EWqX zh-9415^zVxux}`fSgmuy^C2&wD{$ByHR<9%Ly=GihL(ee#h580?aC5S{RaIGrFbo) zN=P^6s+P(aO~n@}a+ns%2}$*IwlC+#MT||h7`ZvCn0pP~zk$!fu93gc-mfFtW%IRy zs|&(tkrzj#SYuT`f=to^UyK=BVJw&zCz%Ku!#CYIV=>Y*j!|au36~(>LqhB_k_+Q> zUUMle7m2e=duO{41~l9fQP0g(SpK%#*3P318l9}2!rOd+M!I@ZI6@Mze9F#jWTw8N zqOoG6dGGL|XcGxExy^3qSnb}1<7msWj+#(U?ESWL13%EKr78V)j>Hj_n2u4Aq4EhMCd9NVAX@G*P@Iv(% z*l>3MZTaQUrKymaVL;FWHdCJ`A_nwxAW?nJpUiKreOn2dJZ?dA>tF6M3zJ9;lkYG^ubR;$gi*<0EDjCj~HEG4= z=T1#Q&Xz$_wD$Br_0{`ib7Y)-ZO*{{Oq7jBucb%C14Fas*h%e7Ru@)Mn&fkVc=P_` zmTFQm3TdOaXz^C}BA%lMwgIzZ7*xZM$yzR~mPs{1;H5oFaZ$4ntBe=k5 zEXsUQ3I!-(NNtYQfd+0nU|h6^(o*grMhNaoy$fnT9UH?JY|I!;dosw zcvUahh8d5wP_N5`;Lu!O7;B}T#b|}!ZiFaA0pb&iTt^%}>{EI$t=l1_&I-SozO1H` zTSC%B7!bMje07CB^TCh*cxy-oc??x z6GnB^X}8w*Is&z-&9FEG&kfy|bvw@h$1>L(t^5>_EOc9X23Qu@>b%^-@(e93cUuT| zq;6>%de;2BoL#q<_8LSA9v8oaWa&`keblp_rV0%}}`p^Oc|S5zU&; zbM9eaCKLco$3YY10VWevjiVEnlFghYa)uMq-+H_{mSFbo{nFpr~G+6A+`TU!A| z*)?UIGid4RPt{TwhUgFG)^#Ec*s2DyUoopTX@V+ znXH`$4%R$+uy1%WLr9?F(t&^E7dlU4(C(R?YK`l+u5F=Kp8gkGpmiKE?9NF|gt`cT z_J*vYDs1+w<@iM)-iAu_Fb(<{#Q(XZ`9a^hx}We-2#s``4vWh>FDG>{$!X|QEVGRJ zU_EVJX#IMs;g>$;l$Hhf+DX;KDPPk(yDd|y+w*Ro=cKORIzYRaaRdJba)I1?=ewgo ze>=$QMP_gsv2(mWERVcx;oOp1s3~-(77fKXN#)kAMQ!N1;B;G7Q-5JS#sZ`qxWs0I zThRFsCAu44G33mOaJ@Zd9~rmdHU%NuN{DL!ux7l-Vs{;fk=cTRYInVBTjVi)yCO^$ z>!z;d(Botbhpkee=mi>oaNFfQAv%XeftMNc;im%qb5hdZ{FI}a1Z{1B^+vq8_YntW z+sTJA$mz@43E|g2{1W3Wv(p>xH6%p|oFkw)K4=X|WY5jJPyg>OD=?=R8W#VA zO{P&VHuax33>7E}1Wp#PHv5IN@0L46G0rSy1f}Jv!c^}qXF7-A5UzG=Vq=kd|C@Rp zHSQt_Hz%gk~D6(j#SWK`%-_4D*U8tJj#3_>yKje-DT zxD(n#4&^*%lrg=r!#dh|*1-tS%`PLBw#P|)Od<`93BwIKASj5%!D;n3Pe2jEIG6ue zvm*7C{{BLw%q`w1%LCdncRvJ;`Ag)Dv^Uw8PPmR}#^S+C# zlUl_2#C3>O*-4{gMAkLF|EO`XCZ1crFD%%UjaB|JK{i>A(q9LYy&Vd$zS-G|Jw(JF zTI`wI&$|m?0P&YgQwI5|*%g6VMEw4Ao=1n=9f%7KcphBV95qh$qTAa)f8QPp!sCCm z@Zb~|`=N*EU~7E${^q`4XBM>hu_P|6y_cZ~oNtHvqYyKjD`Mrs!ok|2juRmG&{0eh zdKq)8VV9LfjU&X}Jw0Qb7ft0z%OrhEe4u~*qTpS4o;I^^kX0}ZR7FeL7@9~tZ`DHf zyu=GSTNnI)&ISKN+of3M?C-C)zg2aQQrG5e;mJVg7cHw$&EPm|_y< zd;av^+IPgO_Nu4oaWya!w!*Zd8P4y7F+KhJi<&I9iq!iwaOX-;%gi?fH}*lH;R^d< z1=wht9zjTjzq9z9yq5QifN>4if-T;0EgHjqqBWMTOc)o)LlpIu#LRck9uMBV^>heX zhK#Xwy`ZOYZb^BZq2Q5LUWrGJjn_aX`&upLp^O4qGUT#!_MA$y!M1EjCxXkG3$gpM zemwd5L@tcN6iiS5LoHw?188?@H)m=i+h0S&9rQxULxI(Gw!&%aiX~C-wZ#lDViQLT zhX4e}QF%h{<41{xunfsd?e{FAN!&$#U*$|rb>|DMNpJCrUq7Fl3inzmM5=Fkr+B5&Zv4aCa#9XZ81L zEi~5g9?0?O|Mp7(6=DbA#&-UU38aEy@b~W*#P0}I0uwM0gcnkZJ^VI0ES1b8L-}In zAD0_09ZP6^b9)ltd20W(pbd#YK%EVzYIVEn+JB5j9Sy;!l6t-{di73SwtzRjlu zuM9oKprwd3PA9rLQO6H=Zq@##5PV@T;|Fp5Zy@yoN4NLV9@-0Y<{86APyg0~G*|$F z6O5W3Unns{cr}6eR;*4DUnI&!3xtB%U^*#EhQSUM+Q=0G_cY)k0kH*ivvLhA2SG}g zD6@d zImSt?#z=empY{rL>1_JLSJ18}&D)ZOaTq|orGL;mq!}hYsP=k84%Bf7wLj~Vy^=B9 z)O3u=h_~(NY0=!1Oy9aa&C}EWJZ9lWc(mBbA))H(lYw^Rg>iR@dvXm(cHDgE6a-6_3yvGJuQcnApjn`NFb5z}^NmbhE zjY5A);wdpE(fV5uBW!F}D#noB!q?{96%>I}3fbS${o026tf)g*CB9Cn2&i#^VM#$d z)+iyhBESrVb+^}=AqZroqiij`+<}QjO~Ni+vM>Z$Gt5t}v#gO7!4{C_S|3iX6&#bx z9im*+1eUSjOfLDw72&EJe_)j04&728QUH(LwQ*#M|Ilq)8-4# zJrs-&f zj?B~>0HXKErIgj!V&)H)#eFkBo?|)#lu%PW|E7xiioD?$cG2#HhaBWcueKlj`+V3l zmRp~qSWH3b5*BRhE-WaguY8Oj0+4-7SmwkQ^-QC04kf+LO)rhLYZc`YOx5;Xw;hrp zE)?>Dlx7d{-$#Aq0zw*rZoZ`lhH^#tCi%gAoM2yLfq`=TAXHc2#DGB41|iali}St5UP(XXUOy!=i2ZA z@02E<0*w@LmrL)9WA3q|hmVI{%;$4{ElRvB{IKC+Nnd|WZ(h`GUMKUO{l${|;rK_d z4ycW||7%62O{I%!|vIjBFq&YfS}IL2>!+o{7% z`lz^PQIIdDnO7HbIei{vKSl>D)rSS0VVQaBQ(Y9){oXAtrhT+`Rwb8(O=xoFWj-|) zAGC-OlsiVj^`w~}5qGbwN}cPo1Ruavo~@v{pV7t*fW#9@Wyg2 zq(YwiFLo;(^7Ob`8uazUdF8o>uB42;bPlKv-IH$EVyp#oBV#UWD>|3@+lv}ax3Az^ z)U~gnDglu_w7h?WD$f#2?th;E%v+&DNzfsb1UJSF>zLYT7I>_cqDp_vaP^7Aaj6FCPLN=c3%gA?U6)gS}Upoh@UMlj_UHo zKFsF$F_R~^_;ygG?L&HA5EsIE7`d3D$gPlH=nWZzGE^5a zz+ZPgtOb47yG@;_-ZkIyZblg6NgoaAWujcyrDWm%^RYYvKbAw`P)wSInS)3{zH0te z`yJmf-Onobv@RK<#18Ls3+HrCd#_e!MGi%=Y^@6lMDO9F#m5C65SFuz0cGR>NIf=Y$oJsx)IP zY4=sq#zA`ZvSx2dZKpTQ@8;9ep835^AHnTCs(;7yk7rz6erF{IKGW~yeT2zq zzir|0&~dhte>AsC{bNn*x+7vgRsdGod}$%eAi4Ikn1D`CZ}{o7u*6B{^ueS)97q6u z)zY=LSlQu}hkWpN+b!8nin1?9FNep<@2&K#Msr>mAxzL|`=iNi56ZqjRyJC0r1ofg z-7>A^xnp~cyx*}smucHu*atje<2%9Hr(IfXyo?<%v)5XInJ#@+eH|Txag6?}I$w;{iJoc*ty5xL zhqLsX`FyPQkV8l7j?x@gHBMQ77s#=U%<-eW?+E!Wb$5k)m-;(GZY%EDAm6p_E|Bk9 ze{pQS4-3=t(jZgL+bA#ZsfDSa*kul;fMS;xrhsBseC`Uxt}VP8q3yIkp70Q6rSWu$ z`Lz%1uJ}6&r`JY5z!eW z`xIsK!oisRb2NP-I8HRyk36Ke`yN%ap7vwWJC?{-%C>X75AQ+VR`v~=XI+DjeUe@c zDL3;2La0cA}qND{m|cH}{)Jue^}& z&dC?V2X(yH+iHo?c!wt*E^i{@Ro3MrQd>t`iAI;!6>(nf`o+)D(%ZkuR4^yH?D-ad zJbYE)a=O$ZG~D$S5$U3cI0jeN3|T8AY~@|=1h^mMkUBvK^4L7i;0dGL%x@jwCV=Jd znzK&g@8d>b&n4=iNBEX7zXR3|-SAOOzWnMnaC-07DuH$0l|H?_q3)HiiN8ug0E%a; zacZ$X1FC?B=l0}cpDjc-=7h&`N5I<0PmRa)3XCdYk$-Vy?1Ug5=Oi*`sx&ICq>oB` z*6-&tR%hOHeW#8zt)#c2)o%W%6qj5M%5&nCRqWc&eNR8&yt&k0u9`-|$Au}f#$bT&0 zHbz0*uU`iroAuJ!l@VGi96IE`^lH2%Fhm%Pu;~*?3-b|S>chH@>XY;b(S^C@s$44W zc}|B|MW4-XbXiL$=M(+21CQe_%KK>AlGB&{ly>*^6>)mIpVLD7R{u>iS0ni-p)|;E zX7V-Kaj+n@&!Xr~Xrt}*wXcNBrlE^?lIq zzs_zwv+#B1;syN@)`r5I>0Vad6}1jm{cDw7)N^`;C65IK@-8co$HK=_ z4lTkDVc5=$zH2D{-LZPiyXDDc!ATg2mSt|daarLHLP1T?_tjsEyDtiov_GD3*BOaI z(Xaj{FUSbG*I1-Eqc$!zCQGw#;Vr^UVa{QieVS=*=G|c)qhZH{J_@Mo>b_Pj3^(wW z_C@KaUyRAB&9|de$vZ67tC^W{cZb4tZ+w;eWVtBI;Z7QPT)&rj`A(#3nbpwHgm=ip zv@hyeuBqq!kyByv&B${pOTP4OH@7Rp)1Xe4;S=lRx4k-+p8b~GPkJ?aPvQ|TGi!;m zeb)7a?^wc}kvw8YDa+X2G$2{33-fej^B`g5(1%0GDxLbi+rS88U*~9BEe^4kPRaD2 zX-9cjbXar~au2;y;0>(Lv?FI}H7I!It$xWy=ZxfM%`?bv^v@u_;mKwR*x2)u?Mikw z2+?Z!D^)3>a7+H=m!~aK^$~E z|7%)oYDSQ>TPC1#e;KL{1QoO=Y6vLVZSi<^2aid{eJc4=2l!{ctZSAQr>_4^UB3%I z(&mgLkXxO)#k0G&ICWb(=3Hal5FJhF-SPZpR+e^pJ9Xc>SZl2Bsq4$G>}szDx_A2d z6|EiYzjK|c#2cZ1o7VP6x+?Q_R+eh%y`A1l)4UTF zA3+$~e%O3-*!ueNUcCguLJE=qeF%hI%c;%PUOW!%O1^8sZ@BMn{EAU8sN}5XX7e^uZpi67y&DUdz z9NRD{WqQr2Cg?p0Kei?v8!EUF+i`J$rq7K|9o6^o;f4cRkPXu49<0ja|ku zMH{=0Wp;clL96vRm|@A{rbci~pI%*~UfSjBsmRzqzM>D7&y4M+htXx}LhIe-HbHb^ zjDyTQWwF#8VmmG9X{K5DnFJZNy+LZU_UMvTESF8!^CT?pQoEV?-D~f##JmI6(7IkE z9v$~CSflo{Vr{yfCyjfT+Ph$_)ZQIylPIRoFSOY#JdfhLP<5Ygs+!GG_oP0%{4=aK z30qx0s_MNznV-VyjIAS+V2X0>=ts9tm`4X?d-jMWjLY_-HO*rFBq+M2TUbUV*jW2* zje}hY_LZzH?7t%WW||U#>#l{$EYI|?+AYyUIvPzJHT5tcN8f-X0a_br{E>CzZj2%EK*Dt(K{pXj+KTCA5r1Gn8)CfgI!x3ZH( z(Q8G%Rd^{Y_$HmStim@+`E7YoX|Orj7%2x5VtennH4$E7j6Jy15YOm{L|xCA;ow9+ zSCDBNf1MlD6x%yPE;RP&d&4>DEGjoXB|dn)MKM~L=|tz-+&6j_^=(#Vy6bJMGO}V< zZ?3)|51KW=Sj9V|l@nGSFSW7g$Fhzccb>F)I9(YY>|mXgHApt%#%du)a=eAz`o6?C zyKwr*LHd@m^~xn_;A9nvgFrsgTeJ5)RD6<2~uOKL^B_-d<&`AaCydd^iJf zm?FxIt&!zc_MtHzYb!Nyaw0B$;Ipw2752$k;>WjC1{||lKIP5-b-h?0@77~2%uxl7 zdEtYwY7Bm>9^ZuK=UO}5TWeF!Ez!tsZtzl*dx#eLWxLzim%UPyTb=Ls^>*;&Z12rX z^(G{<`R9`AA?m-KTo)ZRxh`)f)pcxpQeD5DRM+wENp=0US631VS>DY>PLbPf zDbDutWR5^kc~>fkq(yry6r@X z8ErQr;un@mcT7E~dS$yU_8@!T?V3)yC8O{3LAUSmQZU z!ZGTc1mPI1jzc(BatPs0r3!>&JTM8uF^(9AaIEAI!ktRZ9PHYW*rr`tOuZ7=k2{sH zrO_+#7HjA};Kx>a*0kZy{<-=n#Txs9c&jO;y&)ylaF~u?l)N7AzZ>mzDZ8op!T8%= z8v}@AZ98hm2qWLW(PNZ~ku;?$3E!R@Ir~fL z$Q#ooEsUeKr z`~su%`!EKtL_WJmjN|l9ybI{+cjY;1M(HxPqVG%TfF2GixrI`@`7`g9GSN@rw=%Y3 z3zYJ~g+cq}O|cOCZaBUft)JEwLJjLob8K%Vei-833kfv3_B%i*hx=@J$PjdcE8&R_F?VGu)FL|u)9Qo-Ra4&2M>+G?sq%E zKCC?%c9-1=c9$ryJ3RvXdtGY+TcM`g^uh4`a1`l-GUn)GSZ}PYC|&A%RN+6@d&I*3 z4?6Gi?|IoCAw`B9(tX>f!TRlRmg~1eJm$BJy6N#4qSl<3u~QG-26%s+ z`iJg)(7V1P=z-SBwlzEW`dr4rF5PwM3*rTypS?zJul z(~Nee0!2i2Xop=0+S_)tZj;`)>*&7PitA*e=8AH-9%Mbu%nvWdaHNS{`HoW%nc(In zcKF`X*ITrcVzk!q;sHiq-HNn0eP6y|sarqye3-Gv6*Jvk8UbfuPP;M=)uju5M@oJ{ zj3&kyXCB5PM3m|8!%vId+RR8q#+Z{kIqFyLnHp{5Wny;eqdsK~u}aJ^~MsI z3afee4)~xMe=-^RVC=tE4tv4R1L&n z-{%UzOu7vn7U-bMa(i3LRNn z{W0}n=*{l6aoXWT0;gp-KSB%a`Zu*aY7Rv)`_P21d-v>=J8)MeEs2Y!!~aJAg};3Y z2g!r<;&Tg7+_LIJx%9_6%mt-=qiWoN$*j-m`k@1g5b$4ilk@9Ksn~66uIAj)Bef!) zTZ|JoKIVq3_XliB%$z)KDC2VubNc5PxaU1%e2;B>HrB=mjINHk2Ytl{b8;;DOLAFF zpfp(VsiZ!q7}tkYrW>W6dB^)VzE*z0?qB9{rNf*q;kqpP@cdoZDUJiVKhH{$sA<;c zz_^l!18l=v7G+d3%EnPt1pBRiHaJI!CSgQ zIhI4nCu0y?9Y~BzJKEnruT&kYkBh@hkI)qHBe;*zK*@2&1*m+dcRDjYwFR9qt^vKh z8rP?%mjs(A2Mi$_3$~2=GN;{9_vbXtM;kt1NUvUD7+Y(Ac9_fbDyt8CYb(87dNN-B zDt#e{w7T{>Ed-sU{ZPDb;agFD=AQSu^4|4Bx99>qU5e)jBKi&KAufMw*k7KfH^BtZ zQO*=7E&lFU4=oP&2j^F-C&&BkLkGXor94AeKGd7T`Zt?&itlK@Ug08NJjGo4FlS(B z=7-C|CGrZ1&WCc)J;PDN8re!-^Fi{ktAADHkwi$EOHJFHqP(UEJ(?2Q=M5*Szz8!x zlka-%bAl-8rN{a})3WL@|2I?vEo-@I>Vm5n5vxt;Dmaif4`^TcY2jy1IHA#REpg>>%2X!$qGFiV-a{5D!b?3i&qTL*N9<~XH=Fx#c&BeYyoNui-39CCICJhP$tyUgF9PTfZz zmsWJ?-P=+^LmK=m|7xvfnh!?&L(&koS-Y?ywL6}QU2=X9UrXpMe&Kh~b#OYtun zLpGxrag8z32c$9xE`W*n+7-X$4!HC(CDMC*hl9Bb3F0;_AAgWkn5L&W(e#de&5w_l z`znyWz=cdlq97B%!cl#vdAwFJ`nq+5*H=yp&r*9ooSrytBni3$sS~pEy13Gg47fuL z0fj>>I48KUZn?C()Wzn*3#vhz-3t<2YbV?Qk4-&u2=rG=DIg7bVIC{y7oSC)G{0lx z>{0+Fy3iJ_Rntv_)1!T76iE9T2}zDd#>CP*%+{P0*fxEV!bD;IL;9-5Qk243W!#(T zuhkY3+s?-%>C)-<6>bsK&5SR}oc$cQhet)HYG-9h=93*xn>py1;VjqK8sga6D74j3 z5024D;kxuXE@3#=x?bC#UHjAhH$D9a#`{=!xFIvSo?*+*>zcXvWK7((*~LFpQfxWs za1u|4Jyk3W2MY+ZZ0R`Lb+vOXOF6@Ht%4^lo>wVr*t&i!79eGywnzH!0bv+gb4b=y zO%Lg{QZwo6^1D&IG}4J8SGuD%BzD=yY$y7P_S1aP4aLxRaG{tj}~8xoF;5kVS!H z2&3P0e^FzmZ7ec7fMLJmIv8i}`)YQ{9_9e#O>J&=Fo3Pj-1eSlYhU#KAo^e6KGpKa zeXV=>)4|1sB?YUFYYQ=lnYreHpcT)jwSn)b!o8>To+}Yf=nJ1%FBFMlJyTl@;V%$2Sd(+>ZPJ(Y zTl7m$-)RHIXGlA9$18(mL7&>pBH}S#(z-7alw+lIVs$6gqQ8ia2bcI z=QT%5`eo*zB5(&@;Y~iM!fmjWhTBf-zveQR-pkBUk7ZZ5oa+X-ArQ)dj*se@qiayJ zZq0p8n(dEVT(Cz@_H4`vval2wTIo{C>UdQj;g=CVhmn9E7+&O*s$#Lj;FvsK2k}oRj7DQ5Pp)W5SoYbktCmF ziUj9idP%wP0bGEFLc_odr}YLdVIJ7#z)Uee$la5A-uoEPeV*0N)XTB9J)|ow!mVtX zXKQHQ1h7ZC>f>TJEbU#wF_Y6uxMA7!aC(i`*Mw*kEC%LdF3$(}Rti7&=lm;JhQiR!d*dZj-E_P(R`z+vSKyxxOH0BilnP&g_0RI}V&)nw z5O@i_!BtdTFK68kPhmBDqJPJQBdiHaH?$D?hc`zxb8sNHInL`3i0JFt$B2fZee6lw zQ0OJ=M66Qo5XB~$7aj3$PNlI|pS{PxVxNL{PD`HbNoSc7rsKu2vhtAw&}aKaI4PZ{+M700JdePDfx(H1gQr6yddlq@S4(@>AlK7)AF>O3f*_hjtsa< z6w|r`rPkh1Ahr1PkJxpKf(;JCx?mFFTKqCBHMo$;#lnX#EKm8`0J@KwSanP$=}(jc z=P=>6Vt9fe@bYL0-i8dYn~(szVu5CM{&NSIPyl~Q|19`X@~8w1Ow=^0!4vHPGl2lV zD+oXLL_8biP0Q_2Ubk#|`p-LK^yhwCv!44ZG(7&)g$T<1XDAc92+pp%7rkF=`9wXZ^b5F!8TP|N3+q6eIIm~BOB%#T1HD@ zhrl~%7Pk(KTN`3yl8eWM=mM6SLQ_~WNVLD(G>_FQ27lVpFJxlJ*1AsnfdwPD7WEv}*&Q2fgzO0^@ zwu#Xm9k(RXJuH{LfZmCzKpJo>7UP1ZA6pZyLkmL;5Doem6@@O&zI(1sF4`O&Z=H%q zgFQ){3|E4-DS>pL9Tc9Fm1^&7$=MdL%0rtY5A4NDPvpK~jF2IyOq3&%0xKFNdP;C0 z1z-@2QG1e#I^^0&7sr=q*DPXHid4ZGMp}Uj6prt`Xr9WW%=US}4$ zInB&=%cUjokGw`MS|nh6APkNPCd5U|4!i~RAT6F(X@#=Tg6%es4Kp6W5r+IR zy=PXz(J?(Ch=`{7q7GU?ob2=mMPTJw=G)^zGSd&5MLxe;K`Sx07G&rMVik@taiI!w z-CBmxGZsgjtPhwA!-6P;Mwu0Q!AAlwl*6n-dl0+AMrABeD!;Uc_M2uzU;+yJR4p>D zh+N{BW1)(U_Q>Pldm2jUmSa_5H|)pEz}cQ*+s^hM;Uu^W`hbVBwX9ar#c&|FWDaac zGdpkzV`ucHE26zf0SsU43Ah5@#Q&r|b%od5DzXd<04svP1pjqRi$1U?th2E(pgH=6 z@{mbTj{62y^t+UpS~Y!7qeUDfp&v^ZsK|YwBH;&CPUR`9Rq%zh1Z%9%fDw3zvEyOG zf3$~c#X_-tg#u^PmXF9a+QBvwm8;e1XA4?HLgOCrU*-$ELDkS4Gz{hKmC}$?(@n@Im|?S;gGpr+HrS3Mq*kQ+Ocv0BQYj1zFjVy)d85vxT zlm#yOWWLaX$N+SzdojOawc6mr$^|ydAM9y#5S)X=0&mb7*kClYj`l*=!KL&IB{*uE zDK%rv`VHhzvurseMLl-w_u9W7ElnKAX z1<(d^QTpHsJu=742y+2Hpq=1h=mF|NzQ7~EY~vpJ3BDYG;n!4Vo6V9JUW4nb9hrG( z6FLGGdfq#=2Y%?A8A6^Rg^)?`E||a;bmS(YjLa*rpjBjv?Rh@o?g{I_t(^;Q>T>A` zP(14&H0s?l@EIJ4K4Lblb&w=*1G0xcu!P}#cxSKU!^xXweBE;C>AzzFr%`Xam9asL z7=ZjxX&6OJD&`SniYSJ35NvkOAzB11qJZfol|e$rSdT(yNObfgwlumQ{2&L>(_jm^ z=H&_NYwLA7gHqrLv?{cZd`C_>V1|aJC06MH6KX^*!3oS8WeKijkft{TcES{b5axl* z?2F?PA!0EYQCrLh7(=ANf{+jb9nf)A7|349A2nH%bd;?MtwHf1g? zgDktje%LhdkJs~%K(V{bng#S&+t}uZT4={HW9x5FEIIk~|AWmCdQ`Bgq!_eoqk~+U zVe+A1lLCf@ogfnxB!z%tR^T3Qg@eIejy&cPfsT@+C&2U!n_wYua#5JH1rZ|d?Mh$* zqu?-uy&!ASq!t8^T|&tpE#Y3LZV+TJ7|=mOolN%nrZ^v8oX!}o@QpR+Xcio3{sBNL%5P-DRaRU$Q@ zU6v_qBtVZgdJvJ6L_ONgwuwrfr3=$XeT)Mr8d`_yk)gTi@gGcH&nzNFlRP{;bvwJ_Ychn(_rM7z-i&{(sOf_T+6abqL zeqq+hMeRWq3=c-M(~P_UK+@I~Ai?GzOo=N)JIFM%F2e&Zt5FuatPD*H^lVm#ac!C~ z5|9ik>?Ywh8frt!vqufPA>9@vq5kNGkQ+b$AC!QHgf9k?Fg64Nq6wL8)qytrsdI4V z2{}P3V1@YxKaPnDgy)sgjD;z{fZ*5G33iG}#5RrXm{4$#mt(84)xVi0GQ6n0M~io`lc2HEz{N%C773;}6! zeR#%)c*^0OxGg#tK3WrQ?>X{=y9D|H) z@{{55kt!c}NXNMu<5z->`SBqlFxEZAZ3386Nn=xt`VohYe2WdosOZ^;p+;_Ney_g6 znQz`Pd!EyLAmZ?(wwQldfgU&rvo5ks2RU$6@<-Zxz4Oi4Z>jI2UibAIch&gVR@_j; zT=>R=)#k9TZ?xfLJ;!MaUOR0c@u_;>XTXt=hr;4bwd6y89F&P;-`uy9j{E)sFjbf< zzF$nq_<}JUQSQe{XZO}mf%cRjz~thf%N@=0A>GHo0lix}PY2Hq*W)QrQ3Fc$DSs%9 zIZm&Ue<6=CUE{evpaBKl%q1V_E~)MTpyAQ!0we7N2Fro@wCH0vh88I>^jVA02@>RYYiwwTZpaVRe28Lc7-GaoHY zIxZPE(^EP=Iq$>!%*U-N*{niBNau>wB1mdt{6-@yU2ww*D};hFn2pp3RRKbXB=Fp@kCP-ii?wu zeAW~)lE`?E@s^sK*<#sJ8KW$HHT4L| z0Tas6idEw7y%^7g_xUobE^dvN3FSW=&o{n)6eJL&urRTlXMm5u?p&^Wt~tFAe!(zT z65Y{w`P6$)t-jf<15Q@Orpz2r!{XNj8`OqRE-2rQx#0Jj{sq&fcl;)1y7TUXnl(Lg z3q=E4;)gjbvkbyy{2JVM8fniPc(;HW0@SfGb3%b1Xyw3mX6Ui@0VZ8B3C73^2 z(?vY5QIm1$O279`Hgv$O)`pSQL(=(Wo4?SLjjW;uLuFtdfN3NcrYkojq}MUiLM5gn z=ar99$oNpVx3Zy8%ru*U(Mo!EQLUAWlgQ_~AsZg){km;TeP+bxicM$gUzc4mroLqQ zI*&&N!x`WJBKoni^lbaChZskkl(u9wJ=wTL7K;Y@m=-_G*r@Zkx++fo*S%iQ z%u()AuZ@{Zy+ip}-^-EStf}*I)(wK^4d5x4G^VqLrsPb9WlLZ4^MFusDSMAW<}hNP--CM!^?W65}ltdv1b>rO-*=V(gN~f*|NxkLlcH(FtOU$OB?C zywbRM;I?uQEHF*MI~eb`rRayg3vWUk_9QRjqdtp+A&Xpk^+gAbnX-IEGfR)BbKkeK z&k(R-M_Vw}Q3q54HMmn2JU|-~WBZ3#N%G6fT%`T(8wvjAV-#_eG0#%~Ye8qcWQ9 zF#kT(sQo;q6c0$N5c7B-W6GtV8@S11s_&qTIqFJ9=oMVRFG44=RaY>s0q-J!(VWZ_!IL?-Z^J!~K+C!kkF|?LY6f;>B_dE8bqn zWhrM)!CV$8yu9N*h`wWk1sE1nSTyo37}l&<@FVt5+@D;Qb9m4085WPdTP}`fvUi)4PpXV)P0F>ttT-q6Po+a*y}Dv0TVXuJ;VF!s9i1*3-P$1hgz8 zu^ogu-lxdc2Co|jEQk=+DcCK`>YlfcfEoA8Dg+Dhta-3Z1!h>5CznMQ7Q*J(jM(Fwlct){(#fbLJ&5??L7G7V9yL9}Kg1#p{sFEjzI&$ucdivmWFP0W9r;M;41%=BEsE>mF%?%?IB1L{G*% zyCg_~dt-;$WQ~Yi<^v3ZGhp`Ou4%070|ZiUOkfj)_oT9Ch6OUxP=ME3Sz}@Y4^+lX zGdlJwvO|M+zTE(5pbUC|4opE%Da&HaDOiFx7%A|hKEMq9vv>$inVu;JHozc!!7`~g z!N3XRLj%AEt_>B6izRv%Rq2a1-5&JJYA`gv3=!N~9EW0uyR32l3 zPFXVd?qXnr2ANsr)N5s6#e4YJ{oom523WNN58yP~qjjKwW?7u|o;|hzL7`Bam+OI# zCvTu)4wzf;$=KOI1SK*~c1KYXs-#a=$-VOl+=De}42XA=PwBs#*{#S65%xlay%1q9 zMA$DW!VqWPg3fLW?|eeVqx4Y&a3m_2Z6ByXgthmZBHA&KyuHVU67QXlnc|IP7-Sp_ z@Xj2>sE?W0*g{aF;82ge@lh0dW}ghA9YyOyWHthPNDrfceKRO=wr*f@UfY@Fj!@62DAXLgjwtJWJ3Gnv z^xwZw0Ya4Rz!z35Z1BR0ePPA^sjb)-Dgc@E>?*)<0eeRFIZ$J6FfxB2gZn!r%gOw%n`7_?13Bb%^VT+ z*!eI04=+rBJh71P3lrdl3GgD2^)Dfi^}+;rVFJ7`0iN9iAPRw@`()m|Oat9ugnHSFxE$?)1uvFhda@kj7@7@L zB3n>Z9EJxk)PokG1R#bsa21#tW|w6oB4@;`cuRXg$(%x)^a!M21FW*_1(fu~sK7Sn zG|&JA^X14rvjb+pEwgM_gXL53`7U=En_{0~z2h7kt7=q@R zUrK^)pnwaR8z>!G2Vxv8s2Q4NY|t5F;Ry(FSnU3QWAF{<*|mZzz!t8EX~C`fY@&J3 z(L~1VRNN^XE$_s`Rl-e= zzymH6E*-FV1&Q5;zJdvt42Q>VEkOj_LxKwKmGA*Q`MyKia2SB`0yTZ$umhb#7mNoN zji7>8e{j6x@+P~Q^gt-YZY2M8*nuq>>^%gdlmYYLjQZdacNFK)t2Mw5=8^2U+;-Ky zCzI799D1++fE~u`xxkra9AJ$VB%D)l?sXt`v=SyDtixCxT=2S|>)Xj>u4xxMd)*Fr zm@|hZ7zenptMAYaE-Gtzyo+#*gCt-8eBuP-@H*VUyg@_Yf`A2UXh2FZgbQlC5(u=w z;D85I0Oc_UjElJj3xs@t8SLSzo0`ysyrorU3krlrpe=CbfC3|q9kSl-%9PG1tQ5V44|W{NM*D2=DmPA?DcpzDo#T?SeMS`@~@! z2;g9g&zYA4TO7IK{A~TMTv)=9G>(FB^rL%NEg!4=>)>&YSb&$N|R#>TlPU z_Bl}GV_!2mCgg4XP~=gS*Wrm?-qvWI4op<#;HG{#=hfw)(S9G!>((XjL=P74n(o5q zyl!2>HT}BI>y|S&blY=YUGBcdjx?&vMc!DsEzwEfg>nSj`gO_c)`em}?Ui$0zZ?O( zZhOeZW4-o}TA%jvkYBUT(;0jYN^w|)BUzjUzo@ruJEQNbHb>th8Jlr^bUL>l$3VI# zczq(+r)G6*=EEviTF%5j$rt&MUk;|k1r{7%f`d4c0+(@=jJpn? z^c%U}6Q#JWsC(?N?zJ5Ki<8Ld>HoT@hRe}oPSL=iD`F;q7X!ZWxL4 zesOy1pvuNszY8hutXa-e@=z^uQ_PX(rWa18T@b(zG+pto98C7{>W|aR@5kYr)Ox@= z9gM?Ka^flaPV3z>LNOIS+T2Hf7wvH!g6{?b!iy{-#}UXGR-XauGosIu!Ck0G&baZ*#G<%3i8^)`6qNfc zH%iqvp+TVsMK}L6j)6&ZQ{&@#C})>>nZU3?5j7M)IZZ5CD#pQVCWFJHaTMM6O8l7f zKsR^HAU!=Lacj=Z`{Qh1GkiMEcsM*byy;`7L+9x#9N}ZR9L8kwB|qEOUj6 zuf9Ta0!6vk@qn%j;)W01V6pgXJ@Kww~~zJ3kRzuhQOm-TRS_hoqQx&Kq2P&TrgUiSmh?T(&YL z6dXrSad)X`;`3?yEO>n)T7>V?AI``RLu@h<4KJ&>#|+h(LNT zG|sX(<$?lW?6Nv0{W_=gT$))K3tL`Q3+S^IwablHwb@-;EE8ns=ciTwu^>Rc#?7zc z529DGKHwa?(CAp6=rMgUybdrlPFPxDX$GYh4ohp12PRx@Om_uNx^UEZD>AE#U0qoB z!xhb#edTps;Ac#scj14}Gb2BjXMoW&7xt-rMI~5a>~``Z)?^E1Om6Hvhq}jGcl|I= zo((QcG~WC6H@A-s%axEu`r+X(J+l2*HRo77chs{(pJ^?0Y-o~g#SefRm$OhDT*H-^ z*gzg}p^tFc3hmW2CVNg-EylcI1*PpvnNELE{jvH}^*K?tyd)htZ~XY4qGChag0;Ph z)`DUzwey9W=b%|jeYnfFBbD0dhT`cVeQXCGNZ(4PV13`$KWzB9^j(@+{2`aNU4U0X z;LJ{Hz`@MoCq-YD62DSA+*B{e^(EaMwt$0c`NK7Z!~3uQQhBt`y-7u;z-{&g(o4G2 zZ2OUDj>_8)3yaqS2IJly+SV3Xi z?6< zXMfK+`}H~JIfm-iOd-qXd7i!3%kTYdt-bcZl}4FvPu{LpzmMy+Av|)b)z|lZNU~~H zj`qxT0R3H?p7R;|QA>%R9DT%Sm4)*G8@w7H-`tMny;Jb2QFZr=p1bSs^b6h%ySetI zCc)y-o5Y2*o&Geb7_5T@#X2#u#^mwVWC%Uh&b4biK$|uB=pM-`8mcLNcE?oo_;Vga z(ReskcrM=!n%M|v-m2a##HRL(8J-$Lc5y!cBiCxI!Ee0XO@B1K zZS1iyeyZ}|ol6$n#QxLXpBB7E7_Y^&NIKbTvj%&aNuB;^lU?`FFDhejeE!+WCjO%4 z5u&;ccJwm?>c#7`nHQ{ zzKho_CXLjOIp6SXkxX|1RAY;~^a#nr(TrRgKi<|xt}FG@W%i;Sp*?Uy42?^3+7Am1 z=l4glksU-h%J-D!_q6H9KXtiA-;**>R>Kck2<;4te^#{`J0|KxWu}tEtd}W zG_!Hbsy!;cT6PpwKPyg+@on}V-?F92JRnXqrMmWNAAKiYkCaZSRy?}0TeG)?#ev@} zZI%V2v5^9D*0>n$NGz9Z{Y1BOF;`ogP4pQuI3vn@$M50k-Zpcj)a;SIX2s%1rq(PT zc?@0iQoB_TyxvpQ_O)MB)}YnB>B`;+cmIRErmyv20}rXD2B)PlOkqRg<7yc}of{ws zo$gzX&62Cl^k8ZhvSNIa+9H7kC4x`TjwYH131$#Yg0L@`=MEY_E4(YpTH<^uCg!Ef zGr|uJcnF1Z)a_u(`{4LHuxxMcbCZr!^_87jk z%G@?AWrhr`rD}Ej_Qk_{4@HzX%q$I(x)v;TZx7CRuu)4myg(rGD=>++W=ui-i*+r! zTQXC@$(7>Ut-3bwcF_1N2H2r26lh^*gD0AjRKFDX%tX|Bx!*h{4mf_HSy;Rl1& z&3rpgEZc(1Xxz*VCkyI$tvi~T(_aZ`aFet)(_vZ+rfdUD1w53-`CMID7Oe+T6A;wk)@Y z^7=84K0yS@HfvMryQO8KYlUR$o}&8!97tN7B28KgR|E_@ z-@MmT!pau-=32+SPPeAcXJCyzAhz9{DvluR?t8OV3Ex_oF^}2|yneIVyi))7d+x6F z%7ZeE=6Q@|Ifh+&9`{0+%mN$$scPn*?h zSe3j!=z&BJNp{Eb%`g9?MOTX&UO{-Lf~-NJTkqrLucuzVNl`3$jeh+~g@yNG3)1gQ z^;Ymu`q;MxFOO?Z)BALaZm^tL7fJ!8;l1+&tsSh^NN+Fk18tsGV;)v$mO3;~IB=*i zer4{72fEF*ut{bM=d1U^yTvxLYm)V5DMe~u6lbg~HdrHfn`W=Ecc&7T$ZTqj*^0J` zLIXru>X;3O?(Eta(mc>LZ#v!G+5PBr$?$Z)(3w8Y9BTbLkMk8DmCUtN#VY~NSJ3~B2Vr>u>p*|M*OPACuWd{i<4m_qr%po zc02vH#BtaWRtN?IQxmI@VH}`#eQAH(S2p&SH9lDMpR|5LHt(78YcnEw;WjZK;H^@k z(BC#cd1G+9pIn1@j9b)(qnEE%`%g+xUoG632iwUhlpfsVPiofB>gt_doUhl_Y}TtP z)PuhF?{s|fbhUb;`dzP9Qig$*-7_$1=5v6kna`2a?O%BQW>5LYN6SX;WmY!@bmho?G}yGtsT>q_rl_uHx>_RM6g2p+CB7Y@4!4+ywiWr)4uJyr?2xpPw3`*p2FRE=#5cd-&@~&Pha0# zU*B8bYkgl&+U`8$dxC`ao$Jf@Jk^@-c|vyQ>TBhA$Jw^mv{_ybKgpIBS=Ohq%QFKEeE&X>B?^)z`HUx*i9; zbfLFemO0EE%eAa<4)RZKnAVwT{+qu!_>p(V2{@C`Bm0&ukeWI47(JGGY`&eFNYL7O zevU=(z`f`o=WFHxeGlTdQx6>>fxV(P59H^707qZsP%DR35NTx@$0Imoz`+j=NYKx5 zKVof1D`@4MM@Kbyr-?%k2&yY)aD;?;2U#PCR81N(iiSzY=%hl*cOq!Hv$C8|!j1R+#4hf&9GIoBv> zJUJzapL4}%&Y*HWk_~5!PL5M{f*0s=!W56^BrXs4fXZ1)j0OKEFfy{hj5%>^IWr_Y zbI-OzVG=*6b2$@ZB6(gDq7k&;zlxfNf^NME}a{$3Vl#z%?K4QAPIU=zoI^}>q^o2i+z=jSS zO^fStC|-_g1cSJZa}c@t6wiT5L>FU@a><)fQB*4}MFWv2^RK6*$U%L{{&58DLW8_f z;b14Q#rrmYC`$aNm<#`LCqh(}NfTB5aYlhZxPU)q7eMwo2sr}BF1S&yIowvp%n7hE4#i^iJ`OM=#a+9jqL(5C_vD;e z?kwR1H>zM`W=>w_#JwpubLROD{+wFO>9#ya{zK25cg?bH>p3o=sn!3jZ|0=pA-jiz9))P<+2s0aVs;(ePxgaAK; z0I8n-r&A04Aq4m#1o$BY_#p)N;|&1>MoP;99N|J%vhwO4fr#pax`%st4S?_>L0_(` zQV7NPfAtM@8zGK*i-5^$Q))&jHVeRn9$5oZ$FL)S7UF`6hO|tuk|z*^r%K&|KE1TJ zge=5Ks3dUA0x$?%(>7t6>XS7(0TWpA9!#UDSqb`ti>|g{6QfmsGQ~RNoTV36|A(vNCAg1h=5I+#t{u zgrb!YQXr|ChHv7Jgq&bkJ8HWr1gApE?2|w@t%aL(Uo8s^Ssnmg!ouu11&IX^@EI|D zh6|pf1HOVxsEh-Whqj1fY`aiWlZpgM8nX6ip~I{KbGV|n`WE>D5gBkt5RBGlN+ zf)qzGZY4p&A=Q%NB-N8tNJ?#%kibfWQVL*eCApG2NsTn#8io=;Ha1vEk#I??q*yjI zB;A(OC9cjsIRy)&ie02gQXMZ}R5+0GNW9FeZB|m?n#4N^u4Ft(7`#&ikbr^D zdJio9w&r3x1-gMv`2?IWk+kMt+lG>48ogjA9h4@*LSaIZXin*)R2qE#8rM1$D5U$S z16L_B%9~Yr19xC0iAF_~1Fv>cNuy^4C~0~Q2iL=hDTc^a!hvjlK@({wn)zl7w6U5b zWwbU3kIXCuN8c14K!DdtNW;(Y0}e2Xlu2T(I++nqL9e`&wKpRqkype?@~fy~bbZhP z?d*cY6UlOlBGPWjZ(E^sJw*_0z)YSZH%eX7V3@)&@&Udi+%Ur{NxAhg+{H~BkD>_; z4!k1!StSit@B&#%4Jm2io7CG3iV8Fgcg#&n&4U)%vg0?YrEPhP1#d~95)%sJ3&~7c zk2>Un{;F$Af6LOz>R z5dt}>WVXE`DT4T$$_t@`3c^H;Rl=fpQCbVEP{2y)QvpPZ5~+t}`zvx&PVB`7wT{f2 zx*Iq!4{T;KKNDycOlAmGY(PYrREa1JlaxACRK`-P-V9V~eS{+h0R&8t@ET5FR;@z? zWM)*1hDyXfijS(PFEI@iD^(|y@=x`Nsdm>LhJ)%bN3DKFZ3#K(BJ6O{0~OGMsRlvn zS}@FaoYaR1slb^P{ZNX?6QL3TKM)%cF*ZeGGNfEbnj@Fmv9S;)h5nIU)`AcjB{rRP zAsSd4($F+og#e;6qq079HsARr#6Um{Ko*2#`Jyv~Ni`~EJH*5cBV;R|@@dFMEU=hB z5jm_g9;OiU=o&#_6=*t)e1ZsW#3-T`{bq%+hBrv5j*^7n5pbf=Y%?V?BUr)5!(grJ zpe2AHBl0{ATCl_615qPhM1q~Ad?)}0_AJG3%*9YxvN6Gge}N$nWkgW9A3>oytrQDS z7}g=fZ-djQM3sGvCyVejZxPQ7GVq2kBqsie4TXdK2zAiGzbT<2QUoA7KY{IbECEtN z8aqweOl6#WLIxGzOckAq#$uU~IbA@sKnFn)I!p<=#wKj8BMQqxsIrdX3i1**a6&LG zjfqfgN z#=3`vR6zg};u|s7U=4rJ5m49|7luY+3%Laf9Z}Ra!IqvZIAMx?Kna);*7yP6FdC(Z zRzxrMGqlO(mxv}lp&D2yAQjc$9N^*P@hwUlN5-(AI;<1SMC|;l<&g;znW{O92;v0A<^m7Tf!iQY5En~M3KAfr6nV^= ziWzY&G(UYQ5F!c?MMjsr zqU)q1_Y+m1cA^;^WDs$R$&6ZqP^@AW8XB%qd>qOA9CC2*n^A*XG=y~HIHM4)Jm?!IJ>Vl3i(=rt@!T_9$NNR+?Yk`FW%N5F&r;VORNXlR@Gi~)=R(_4!&IzYv8 zc8HHoKuFkPH6f4OVK&hwLs7zA7}7V}B!Vis@_H6p|mERv&jB4U!mJ%~>UJYH!7VlWf- z7$&gC(HR>A?g!tf53`nND&|8^u1WhiO)kPUST*BM;UW_#jo(Ze>Kh%T?uScJPxtVe z9-y-C92v#MQzfVvAH8D8V`fNPcu5;jC#e*U;S%{|)IrQR&|>hTbt08S-+t3GGK9aR zRew&64Aps7|7HhikST?U`0yxF0%Zbh_>e6MjwsXvq1i^tL^LUJEWA&QO0q!k2^54) zkA%L3g$w{ej^{NO0`sh3i~VK)%tt&a7V#J4Qy%7o&>8`{@xW#TQ&hyLF$M@kIhhDd zB<3K&a%PB8@Yf75!c>B3me2+3{4*!2Fjz)|ACWMZUhx8qA^c&}A{>5$5F|Cxo}hsS ze#FeY%qdu4Onf2+sWlP=UP2qHK~eZ1s-;gn0F_`=%*8aq5TraHVE{2Yig)1Xj(Lbz z#?_l~iYkIS(xN47qOx%i6d#|=nxLI`YO$6pNoS(qVkMv8ly_t0V6}E!nj_}M2i7^(%0YbN0{=3P#6 zcP3eme023sO9=j~*!pMv`G(!y|MMuIw$o&XcRrGYD}{ z>jh}QMW}im#SyjJPzE17yAv6mT}FE&1fC^^lOVt{~xDIng** zFmYVkaWh<+*i_hHWHy@%Nf_p;QRNdx1TTlj_H#;la)M${v%rIM(lQwiER+4{VRqg^ zKjS9aPfjBoGYWr%8UhA%a-GNE%vuNvd-h$_o`94)MKgEMlcVFfIdGH{pqLTWP)J^f zAFxLmTuJy6FDEQO3A}=pFvE8=yQrslUOjMTyle0|B zL12vQ4l5TXayXWfrhhB2td1CWeX75Ojt+X z*_iFy*fxDJ-)LbMyGcAEED6w~qFC{AqNG9!-!x>n<5k}0`g%b zp~;-sYmOwPLT~WE4O`4iyi+HEbyDLN7yC>)Xl!_4k+~z5lq-fN6^yXM$ib7RfN2Z| z!vhZ+ny=8bBEgYck^=m3u>flvO& zSWEz38rk>AFtb1|lgChUSWq$)mY$^|6$NHmsXACFntX>ZVtON!G1hzs>M{)}OpqDU z$u*E>QcorE3or1%UDSwSz-Jy0ujmz7*Dr>TQ8TwOd9J{R+VD-PNDEXyI!f;t zQHG4ZF=FxDxQ0rg@Q>n?16Z4*ykMOhTZ`lO)28mU3}~FMO%E6zGBttnb6xjjjunknAk`yC>z!`@eI}f6GH1iSBT7 zs|>lMs5w{edNAp zLLNBR-T&~1L4Qi5_O64iNpL<1;!=7X^8VYBL9YoI$iGjzZ^ziIA^v?av%Q&Of98oE zo$W>99`)$%zYp?FZt@a|ych%W%U4>g6XmEfxd!w;df&559yr(C|Naj}fVosI74tyA zcE9M4uwODj$;WZ-c_Xh^11JG`X+bMGdCkP}?#piHS*Bnvg;;&O`=I=Zmmg%7Uv)dD zKI#6;>Z5&LqwvL~@Ay@Pwdd~X>D?Hs2!VoD_jE>5mhyUu#r?nC`M3=4`6|tE#zL4g z{cnMoEJjH7d|mmt9NNwLb*p|UEqYJw3-w=5?*B{;%~c99+|yn#^<4cDCf=^UANTI} z!`_t|U0BC8%bY&yTbt3$AJ=Hy?%BHjV*M8gdv)@M_4ii&0_}(OTPR`vTlMRuzK<~B zR`tlvv$J(ALDomrR=DJx|I9340rOA$zVLjmMm$&lYe( zX8ObWCAC0f;nvOi4`2DOHgLfqY5oEpNj|K**q^AJ zke;o!5XE+_kQi$*72<@{9fS&l;f<9U1H5n~L|S~*x4vCH8%7w8xTr%w5^?G+;u3M1 z2bmE*q9FCgDAY+Bj?&;2&4z6RSsOYJ3N#U&i+%kjcoZAFgzI)s9dqFooQy5*jT+z# zaZG(J>m2A}KBJ%q+7XaSdKJVZW2u-}3zJ(5jT0j8R!5=G}uxp zBLG`kf-J8Ws6uloPbwZ#z69>l2(uYCiIu!u>LpEtVyX=@9h$ zt%tF+R3)H~QV!TjQY8x#a_N-oS?^+nBrl)>wX_ypj3PnFg10m|X&QVl)PHTHI$08G zcEI@34CA8`S{hTe#62l5CSzHuX;L{*vn6oDIu;U?StCuc56(oxXn{d0E6JkqfkY~W zzS$w>Z<11D>&pj7FTp@0C3vYo5k2#u7OJQEWQ3&9uu^Mb=VC5!HH82a^`FpQ=pmsV zuUC7@EbWrEnTZL(X}IHud;X@7g75J)Xp3V;Ww&4qQz>U)N}WkLRw5Y*ORWyClaRLL zHA;u0ku~xw9Z!`^>BH!3JxK>aV8R&+2o@Ym(g{jb01x_uQ+g{s#WUZGPl^MC@0ACO|{bY>vIG!!hjPTG>ngU0+uH+M|?n5X#DSK8d7Bp8CU zv5CZyi()`9!LV3JHDmc*Bk0J32!x=Ca;v9M)6`1g7M`8ks3TTTn5-u9}_cU_8OYP{eU` z|F+hf5Rt>*73@uXFXfURDdY_gLhmJlZJ-Pk$^i& z5TRxgl&?V@g(pjibKwd~$_Api2z=Iy4B7(ml5`BO z^@;p5>SA2@;Feg6CQag(B176`Z&m{R>QS<6wj%>VO-ywWB4t!mx(g=wv8Num<2;x(-r6t{96Sa&zXFX^&je!}*9o-@!sKc>V+bgNem3z8qX;-c7{iF!KqCkQIxYgU8FZ0AL_To^!J+KXG$#ckg5`zc`oSci zOJIY7EENjFTbsBpjy1fZjqywaj%R zgI3@aOBPq3FbsMmFPR8UM+&Wz(L^7}P;g>Fe8V}jBQhNdX<3D|NSH%6qogA^Rwma4Wu?g{9GKD9l6i*lV5|EYY6i z?6D(8Cy}^CCfP!CH6~wYOk5;?d@tx=Pkj9LpDu$ndKo&p%j@xWWFX?lX2plaVl>-I zL%`5H61j-D;acJWc*m=R2dq20XAU?g5&#$c(bIqS5M_fcI?zW}HMW#Gu-HT$E(D)~ z&_lYJ0H4gVJ5do>Bq<_s#uw6(ig+mFn1$7Dss<*K!Un*SrDm}yZek8Lv-t}$!vn(? zC&O=&9(tlNyA&SBwv%DrW{Uu{;J^K-hLkd#O!Aakv1Mo!)oDNOl4F?=B0_h`d zypiv07VafpL4RSr7zTXtT6_m-qphxl189f$G!|V*2Z=Hg`-AH&Aj+aV*kdtxer@zm z{3Ny{JNU|KpoD*}pb#&}GSh4KdBWhF*b#LS55#L3p9Iyep9emvcNNzHP5)UhjXl}k zH*G)iN3}M5yMJ@>=e5Z5agAyf`4`%6)vm^SW}ESzuVtU^mll-%x)y)t3t`^O?KSl` zYso55{iJ>$FWA!lPX8uvi>_9?r`rk6*hX;o|NEpmxBckjm8mR;Yh=L7{o2#!;nM0x zO=rXPt@^ab!7|dF`i(#q*xO6S-Tk8eS$k{CrERlzP-+{qvnL|2ozE!G7itXGb2VaH z=7d46ovKQ<7cX10YcPG)ui@EKk4(R>>pNHeqUN@$eX3r*jx68okq=X|Eg)>&hU7b+ zdbvA@vkSv(;HNu1(4gUG9k1csu)I@uvw7Vvj%9y4MQlFr?*98{dbDorlXCtbf%jfR zhlC=)#TpPhHi0%?)C3yzk<)gLPm73o;9xUYB}3QWsa{xZ`7|3tv>$Kl7yG`?(%B33j`552 z+nw(2|9fqZ=56{bJ;`p=Uu(YGsT_s?-m)o~z1^<}H~vC!yvN6C@s$E&w{Mm0Csv~=l1*QV!_?tRhgrSZS6mY_0X z_p|HuJ6aIS@o_JfblPg;@9Q6JYb)V;(QG^&XEa+f#Wy&j`~XFJrhvgkNnGw8#k)ulSn#xa<^6)mt|$s=woki%(Ze#|N1(^? z-U5*m-^)Eb_RXmG^}W8`-T(HT8X|hBX#k|RHrLqA^mUJ-dr)ZrHWS~7hdE3zK-(zU z?9hbvqv~xu3ecW`K_-^r*8Y_;Nq=a7?8W%Jru?kvlKpehHHIpC&f2b?M&a((Th#*{ z5rAZV(wjiPkfq69|5z5SC5B>I-ibCog-S($iL)RZb#;x)B0 zF;({x@f{3c^C59oq=vO_#x02LnS*2GEswh$FDHAv+j-=A-#$*iOvH&H9%(H7eAHT+q2lBMme@y5-1Sk5>T=G+5AdO$|pS~wxIn> zmkWb?(x8WTi{dv+qy6nJ430Pk2$dqOD3Opify7j1kC)lJUGm?(yyotirEJ_a-dwNR z_PFlddzB!W8@*@t7SeNJ&iN$-xK5L47v9gf{_=GEBWcCEzwB}6mZ$n0$I<*_q>rPK z1ie>(o6|tIZwj)cGAL9*)sNF=8kN6Ty*My7h!yExYVN7&Q`1=CfuO3*u^4~9Ctj`D zyRoyJ1SqH4oUAJ=)#g~m;~Z&8U?fHWXS4T0l&K?j=dbI2cYe28eo^$~8QRss0&If0 zyGqJMFrU@fg3`zeO^)P@-Tp9csNAv%@r--rIquo+MxGXudahkRl7u~Su_$<{7uY)Yulz1CW7(pt8OH+nxg1v|ZNh%lUjmGW{V6p(IIsr&w*xF($IvGK_DGSW}JRXyxHPF3f2(JZ6= zzKUR*?;X)Fyg$Z5il+LpW?JVno*Kb3b@~kL&c95!&v8#_cTf$AMtd%Tan4~IEfhK8 z?B_0)1`A>7F$|+)pBFTOf#W3`L(Qkn(cNU{u2=h3ixEbQD`bkMf8E=}glqz`VWc;! zC&PWbf1EgA<}$17=Io7BPLvJzmgj}aN0^?&lso_^hJX`JD2XzDO&6zImALDYlS=C4Oi#h2P!J*5qW(f46>PYhF>t+et9zo~rSA zD0^C09hW~-aBGoai$80`mvL>JX$*x2xW>1V=;NhRpLYMeT9cOB`T6S=4cLBg#C~s|>?4!-{yW{t>c6HV$;aZ0tzOBcTG=f=x2@3aJTs1> zr^SGj30jG&`|(<_P>Dv2`E_xCoOVx4y-y+$)}T9drk0y^Rn)hBX8qa{MYn5p-onH% zHkoTHhN6H(%I0~wTBW>6Cq&Er?4KNE3{lunjL);NFtvh0)BWEt&k61L;jAIC`4alJ zUiewJGi#w3Icssxl6<`iFqdm7`k$5++O6*kNv>7Ud5a_YvU~QZ$|Nf})!qMixd=5* zVb&C0iY&P$p2`S9<*XYJQS8Vuh;e2^06mN~UM7u5#`sVSD_42cIw5~n#)K2iFztLW zhjJN=u7{%QP)~xtch}l9hdfvAVN1tg4pTWD<61i%9vM{Sj`Qu#tj+RuiMfS;OQ7?a zjL;4b=|_0##@4ONkUzGZ?^L&QVR`k42Cz>#$MUj0Ctx#{oe39eRd9U2J3ak9RGYcX z7*-~VB*yhOS2*xR@MC*MwkX8`CroW})xEsdt5qhYpI?`pr{~;Rc30o4GQhP`^RWS6 zQp5ZMZ$W>n;Qq^AYg$;)8_4fzynQ2nae!~>RvhONH*O#BG<0igtUXl6eo-OS#2K7k zb3+2dDTVgoc+AuIxb#|at8InpjfuG(kSy=_dR=8&C6d5_rJ8t_$pj>`^;D3Zu&@SeRP#w*w_ zZa1Qhc}8J<)BkpbaA5w#C>OZcwz+3ahe6v84*0uD<=?Fm(VJ!8hCXeL4Q8;0ODoe{ z?|xox=v1X*I}hdiS-d_s=QS9keV|9x7EF9lbpNvoMt;?Gk4M`SJV@xPJ(p@7?t$y2 znP+P+0{+c67X6c+gOP&nJc$Bftc0*OvUUjG7uH6Oq}gLf+7+YV+OEP#fr-7ZwX9=} z5`pA&w{vN{Rcy))eX|~!O)g*c7)MS+DM^OZsJ15^i4%6rb$guXzkj->t#oIQl!4RZ zRD~94l`T23EmKLDN_6+|^}g5y{*r+AuTEwdtoU3q4(7}dGyJ4D@aJ83^Ky;fP8X&% z!yz#1wmS4&ZtWSMy;vi*odTsrmxnve=8Y|WlP5_aU2I#y=EZ;dI38&l7V>ig-NCr@ zfi=SQDHW9~ZE;I*o-vl?h-QzhmuL6OnA_b$H)<|+yJYJ$N-7wBR1lmjYO;~MOS78O z1a;?hi=#k1wv(Z<1sfjPmdxI+z1@O*YrgH6s-)hmqF&N$+WtvFLJ!EjmE|>VqUjid zO*+)9({kJz;b$;!|9=>PN+Z7rpdbNXd9?lp0xZOn9i(?6l}(HZiS%garJVodtTg2!N%O#ZvF*T&f0?h zeEs+Q#dGy32Jn1|XDa;q$=>Hr>)YA-UnQys8$4a@zu6v|2{$gj+f#eK5b$}~{eNDx zl1L}MVWpeAEuen}B_zGA&_n)6BN>lf4u887I3N|p;cJsNZ`8Hg!EXsNk?3@B$&)IlYc@NfuNN(^6;xRqpg-LMc7Bu(dVc85pmP352r?`ZCpa9LjU0F4)8#1rsWjQUR zlM9Dv21$s89_&TqFKpqtrn`6?tBTGaRaSAS-+$em;-7dW-pThD_C7uPH+V32%WiGi z+BkJa+m@~Q&dQpv%P}k@+2C`pkH_{p zk!KIrvi-KFV9jEBxQ8{J#}asPyf|ftad&>Z*1J7DEkdaX-t4*`S)e(XhD~$YVj2Iy z4rDQfrDGG4=dlrfvmry=)nM=a$ezq?8Z9ru;f1n~7R}9t0vpG?`(H)q+MpCV=9=(e zvzLGC%sd@lVrAM&n_1wnjmA;o*TaVKfF~u1JwA5C;)|%Cs#Ra zK`-_E%hgj~e7aCmd{ijrXY3`hN&D>>c%$%UZ|_u0 zx+MdD)bg1FGMSg>_F-6s5y54-I)a2|lUl=Rl`eutDTeH*3ErapsZE}6H41#HdAilR z6?+dgg?SE89N%TXhPaURY0Asf2F92I?GlyZc4EigBAr~u*T#@Vv}m_)cXldoG-j-T zgLnC=&#mZBcNKL=0)MbMw_-G6?X?<5n-<0C(#IvMh41ge>+7XMs>9dnGX^D|janzG z7+2Qr6gH71qZog?s?g5ezuSJgb&ENknjLEPiVIERm_mZZqb!v!f!q1)4*|v8@g-#4 z`R2RMHI!lDgna@%N=*eZ^Y!}11*1hRhoxP zkTOjQ2ku0)r)g^T&$p6&Jgg8vF+HNKEHL(LI9&VLe>L`qQ7ayfi6Nx+MxfEOuoOiW z3=JjIrJC00PfUZcQ$_3S=ij;e|J>+-o5yQIll7Rt4IpHAw}^hDfJ+4g@BnW<<(qzd z;YGA`AX`X68{=78wFAlm3kc6gi}h_t8sSv^H^$9w=kEXhLCH-VGK@)YOGsOnLHY00 z!q2a23Wmp2t%X4^)YTh2dI=aWGNKkhCGTY2FSU$k_`` zWTPt7;H^HRgI-vDyt1RK6J<9X=yLo(k~Jzd9I)r83+bn=$xe z&t$6kPBHhbO5BRM|MI)de=vjNpy%)J7?!SgzL7E$uR$}L)(v{O&by_)wWYAb`Ow|{ zufLCpn_dhGE@tMg+A19BW=fXk5nmed* zaq0lIm`&n!lnx})y2)vS3HAWnH;(ZJ^J@nsOx&wO!MnVe=@@fX3ptt+pM z+&_VTL7j&S9V)afUTu!mNY?+B6z<`u=M;R zpX}}@)!he&jX#7~T#`}YO>WnF4hq}d{hu2e*L#ypyf=BrFs4nB64DUlj{}9~G4&X4 zUlJ8g_kwF7T4Hg-wiXRGpU^$FhD7&7BVLf@c@snJ+}U(zZJc%M3&$a)=2&m+jV|FI zM|VjxcKY4x66EP3A2&b5x1x(MrBPBbO*9h$$hb+#D#^KcszRUqbEN5|-o_uVWam=- zS3bC0-`=V_uhp+B^_j@{QhjUvY~iEkY_ju2QqCZHpjwAw>OYhdTHj$eeM*wS<_IHI z5jRkbM`~t>!3ktF=OgbGO}^?ynaS;b<<7W3cTlFpr{~nBV91Z8Ft^*&pO?Q;*A(!2 zLr~9)ChzKhow!y3@2j;GcDcft}L1q z@cp%(7B{ODJ%(dR-DIyeUc09{*W_kt&3m{OPr%{UcKy5as6O_SoBHB6E&grdm7l?m z{zkH6$-&pOko40;Rz4dr@Lg0yX1kZ0bPjgBSruNiZC*zM8-+<=WWA*MGC4<=NMdGL zCcNg3g`FNq)9l-ciZb4+(Kof?MMN7CF&<)BLGLcGU-JZTK4-H=Q(gw%?%6?V#v4&r zXM5^&#aNCLK3!4R=M{C07lFEGPnR7GrQ?YXXxne@nZqqIWT*nYJ zy$)u*AGk1<^kMu|Lh;m$;<3iPh0eXbd4yI7Y0_Z+r5#_4cy=!F;}%V36O$wls`U4j zF%(VTvvuUKIaS8da~uH&+mhtnO$&NMCNe-Ym7k_RU5^jm9F+Hs@u_)FdbGlEPdUj_ zM4s>CwGVz{O`^I7B3a#It8)1Am{u*q5$z9LZZ;+y6iejHpPgssyirD8i$j*%C7J}u z^WKGhB!n?lcI$q05 z8BT1Q;$bqbMk%`YSJeYWT5M80zj^QTBnokob)uj38ElUlA4j&u_TN|L9D&a=7g_g@ zjzJGRL(UIUTPMfzzHZ?LtJSzOv5GHWT(OGrbJ>CxOPZ42)DKO!>Bp)JGO&)}WbWGL zzqH8nnFjAOx3=A#H8~T@HB4J2zHNFN@EUJQTOTF$4_=^ELY^yVckcT|*ZnRQqUCS# zA+&sxq^3yi{s0@#Om1Tx;<@sE`P5~^9paPj%CzE?r9$mhF+M4)d9BY0Y{P2D-@UU> z0TdqF)$Z=!DFaB&1VqcpsUU-v`n|9L*i8V(JNepGCMO^Yms`oPIkjk2r^cx-Lam0H36B2ZAy_i3Q7i>t~|pzW=kk z{W>gP*DQc_@A0WiC`GEe2U``mtIhSzLvHG2^u{vVoPev`(K|+JW#ten0!$8jbdPo!BiHn`WyEr{2)2L1((1Z)hmI2%h*w1m489 z#U%t51yzHGi0+O0E(18#_g`*6%%~z7(t_S-WOHf7OV6Y?#W>lIjKhOu^JZU{uKuPr z|1R@`Q!{v*H`;jsbhm1=a>rTymQ|LRc zF^*b4^j1}&vX!BGbP0WTc6rUFhvD4uW;I7+_IZIi>}ot#YY_uq2JSUu0{fiO-(+Fk z%CC>I!O9M$Qw#riws!+KjgEt){)5=yM`J%_gZmY&y%@a7$}|d3 zl*U@M_DCsi^iG2A!kRsfhPUy?E^XO*J?Y$> z1hkwf5dj;{)way3`aj&NNPXP@C<=U2DYH`G~bOx1E7@y(pEKQkF1Z8z3Lf9XwUE%*NE6$JhIIeU*D$UmMOWThh9RxE`+b z;;z@~QT!GzwnsX=0>J8@S8#aC{*FR=DhV)=LTUNt*=r7EyVFl6kWWLRrapmurbaERGr4Ml3XP#Yb`5jQqo zVM(HuXxAqC)842ulE0`B&->^shQ3(e^X&BL{=0LOJR?@84}A*)g`u(feV_AsdfQxW z<~*HNGhaY9&&uZ2S%T9T)hys!T5684wX`IFlqpenPt4iejIyK7HjuoYO-u1cSux|x zMGMQ_X>`t>`(;XD276X55}&Hp$w&iV=t=lF(R#9DQCc~QNOm_xWRkvFjP`_TB$b!H<1D2&-nJn>Ei9tj(e)C7Avi<6-;K z9FNwzX)+6w+8tZg)3Q$gTR-gsC)vVQrfTKcwGg5m068RQ{n(#gEbUwKPg7r+5G3=B zr6L$__Q&23;TiDqg!R63gY=SUUh`KYbZQDBP2O5ej;&cSU7z5?xlkrgi)G#k$tEt zabx2bV+p)S z{_%2-gBu(4qfRS-$Vh^y`2ylqEk&hKdd7}U z1HNT7pd|6JBo|V;JpB)b?vd%(-Q#0>Doo8mHQnj)^(JRVY%R!bY=hamW8+^cA>FfM zt2d0+g2JmK$J{*#MhR&5#3m`}p4oI~!M(@H(26|W-ya|P&~UfA-zz)2`}^~@FRWQ^ zoZLDQUA&-B1?;urx{>kjT79Bf_GLw4de3?C)w+td%WzkcXvcKl?%B&V%Gf8HVY&L- zx2-q#EZe?U^RSW8)vPN9D!SPBs{=mS*xy%eE~!*vi0-jgkGWk|>!k{>{;EFLuGZl@ zD{aqCu6n`!ON$ZO)#(WB>U;!sv%qkxp!uR8{;(kO3i?e~jk|1X-0@Y1^M2Fg=IYmb z<9fC0Fz)nf8+UqjIxZP|aWQVg4JC)!+STc}?dp8o^9AJqZ|GpB{tKh4fy_~Vjp_r& zYLH9FUMM=ADQPXp`T|Q!-I^cf!&yA`ez12_zuU{x;yH+^U7#23b+06reQN3Hp929}s zvOHm%e~5PiU5YD;5$n<3-m~SsA8knv4Cq@{l&u&H9{x_f;Yz_znQu72ku`gv_}bl9 zoVu?h<^e}!)%X6h{Vtig?}hsBQ`?``|BB)6d$InrfXbHsR=@gNz3OkZufNs0{#N_? zTRrM;_4&~zI21o~ELV3@o4|5*@6*v-4RU(=6SHo_spfnjCCz*m?2Em=YqBKu7LoC` z-^Qk09`-QsL_>Vt%0_kt4{|c(Dsy|>oxV_Gx3b7<)#pzAk`W9KP?Gu_`BX>J|F}`1 z9a?s-u=f9a{ePjT(H~Z}MXTb>**P@XZ6tGPxk)1U7Bkmc==lqUtyms4vL~6ACE@3n zcwUk87_V9ntJR=sjFIf5du2J^u-74SJ472O(eA$16*XQS^I?fiG_L8wkOzakJIzP( zhPQgp)CxuMtZn}#{n@Q{HP`89`fP)pg8!SnR`F@`p2z#csk#}&R)bAi=deY?j+iOcn-?#WOGRI;2Dw#+XQ+AW@}-udx` z;$NPFbTCrm;BH~ra-nTHaDupV_TX(d*FfYK@g$vSO1qTKBY;^PNby zE8fU~#oZ&*Vq5nltd*D9(bxBI2|c()Y#mzdn6_QNOJj~M{kvEd!{q_PoGhoIef

    Ud`&-uu1ubb1pY@7muhHxDvvjeZxG^!Aaag;MB)XWB9puuWogHo*S9Vw$pLE3WWU9+^7@VtXp`8iP3aC5=pHG+ zM5_Q(wQ*e`xos2XwyBbAv&6Sev9_|Dw%6*WZ6TRiDBBfNM;+Cz$EM78jtt_`s2jfL>Sa0{I3q2p5M!|SNuEFB~ed<-eQSwd|by%j(hWgm8z{ZlSw!BicG{RDu_AQmowQ5~G5raCEWDhrGn6w6DU(i7#_RCWXlMtvd_caSD83~ByWZw)hdJA zT8H2Lr zhpE)wcZ}>_tnPt5AO_}2!9$ax(GbK%X)&%_IrwBO(2Ir|K_^)e zR0D5`L<>lJuBn7H5oCx();Q&2V~0#4TLdREqy#BLX&RkoY)3N%Y5d2Y!tHF{A_?uM zgFB`oU3wPYX?-N^Dz5ap`1lE!Pj;!^Cxa52Ky%kAq9A~S6{rk&>1_v_ifbl7D=E{K zZ7JA68UzldrrVFJ^+089cBBWb0K%bicNKPus|o%%bnzQyAt2c59vSd(J0*fXMp13& z{*#nsOIdMI6`f41#e@IWlQMQkSx?H?QBWMuJ4segD)k@YjMj%$SqY=?Sx|oVv?qjQ z#0lH%R;qzDVGG2WgO3Q}@l;3=53Q~1r43R@d8Z1mqh)m9B9T6g^l|D~*N-}-4uSTY z&BG`enKd9Ppz#lalO)3IXJ(`GnL8%Qh*AO`{o@mV?&==5w$#pJDy9t36Fl)nzZg6DlxPD~ELY@+M%U)L*X`v)!k|3|8tYy+ER#L1 zFk$E}JUE9@9)^4B0^<#ba7;0pftm=TXqu2mS2J5|QZ74OHB9DN)YX73eAW*fXppg4XUs4W@t%b^eY{|U2xVD15`E-CsTdkE@+&NJ?65l}E5bt( zxSau3qOft#`)@$i?Or^RT$_#diD|GSI2MCF4S~p`v9<8CtOWq5Q;P2TK^GK>S_$LJ zE+Dg*Gs!Be1s-Cs;b@es7ttPG(Y+`Hz=dX7IP5yU6Np~Mu^XaC1c2aT5UqFGF?paN zxK)iP=Lw;JC$&IWp8}#5;Vvcw7K5juKoheDNJB*%(dE1!gKF`E#0ca4Nn9}}C`zne z;;nsnalug%ca}jehW9}cOVmpe7$E~1^Jo`Qsz6DJ!kdZuPZLu0lBO5kHg3$&n9lx< zSsKgM%XGcu=p|P#b2wwkEhYkTn@Th0+Ixj)7`g$&&SGnU3(hdH z|G052WR+S$49@+t*th5uaq!`7uw@*dO$7|wdpQsr>u{6_3|b=0tQEnK6Tb8=BN$r;9Q+QoPHi`lnsaF}QgwREz0B91G9SGD&Y$I_z%;V;_i?y^< z)#OTE8OOV+e;vyd(&_E^u@3)kGurH!b3hFA0m;t{lk?R(`? zKSb6sMlclBU)N!Vo(0Z63?1oN%%5rwSMMb^!33~wk1uHXfJ{(9n4tMM5CCx!MMttP zV@JUWB!r*S|A=6tI~^+OO0eH@|Pln>@9DZGa~e=N8QPPer{DPbO-57ie1 zsGSd21_KqkfEU8-q2q2^spEiyFB)xXTF&hB5J)H5P7P)&1*rw*qsarlY17DqKSeji zg40pA8?Sdl$E2aMlh;&Hn*`uM1UaUONC?ro;|1BK;V|rjgE&qH zfSNUJCaPqsPuK*_=d!J7gXRaM=1n4uQU0{V`Pxc1n8fK=g0+ibvucL zOgr2Yg=O`RqRT@RO&Aq;mZCYurOl%yqT7TNb`nko<5mi4<{4qEAC8aZBf?a%b;`AN zMKin^Qp=HMHp4TQK5NdkX~_M{<{a86(&e+bVK{A!GUF{cwB3qGjSD!rBENuZ7v}Np zL~v3-%h8;TuAydmamC#@YG1tDt3RoK!zR`J7DENWIcd~bTsT$J+*v+hQ=eov%Ptez z!?{S>rFUVO0)xiBWn-~!B5}M7*tAQ4Z~$y2+(Bw5PC;`wc0Z(cnvxurF9rqoj%0nTCcPLLLMeR6!yhQ$qZNaO@#j$!P9=ISCfiFhb;*Ma0UI z9N*h+?iF2Pgp%Y_)sn*j+$-87cp)e}nwlu+c!v(NfD9Pf(NwKA$d%6T*UlesH{-Wk znooG7`O+@U))E6+V$j`;A3ZflH(9kN8G{HAycf{#MUTMU1%FHtB?mGgF#*F-?2chh zU+5TV7KuOsARMYI)J04=uMmh9LVRPP5DLR{8M9w3JPzs<%EPdrMVU7SwmOD$wLowW zm|FQ2Ttga_+Lfrm#i^dkD$1D%Ru~~Wu(QN!%~XciyS(WQy~U_#+69pI%3x=2o(mT) zf+B(6oM?HT%|(3llM^+(O5FB=(6JrKglO!ZAX&u=Sz%`j6@u!epu@2PxgbV|LVC0{ zo8oI-$$o8J30r_Q8$5PiTWa_|D@5(nR6awFMV3#_YJ;%lv^#`wLh#0S4IOI`L4KmrKrR4?9j$D|@lx`D63{gwB(Vra{j8BA6pN*njxcZyC`lNYFOfi!(NI+m=Fp6afTlU5Dp_x(hIa58j%>vhg&ZhNm?)|l#yg*cr?Qksv=nvk_FR)lY!#& zE&J9K%}5DhrfNbe6R6S_UYaIDG^!P?8Jdt0O32iNOeV0CxHNXM5t zjgX4r!V%n>&4D4^j#){&-)hZtr97RKWyI#NGbo^3t78QaZEc;a$a6z{EzpDolHh?^ z#1;t4=4(0*oU~e0pa}(`gd$BS3MG_kLMaoZOFBYX9Z7QIj2k)#dv)UIwsy&|l%&=!X~ec9Rnl$|Djzn~lD#@GaH}*) z)ExI1TX#a__}PzJ*l}Idv~CwBW!h`qDR8&+;;L?0!0;|*OPvr0m6kf|$r22cI$@-j zstWVDRbqWsQ!;USk~F(N)XM%)7Dv31v4lnss5Axyk0!vMB`x!J3&BCn9%Qz*Fc~K> z3!BM;Ff>ATgOJ@I$$OGia(iVHEI|tF6^{0XINB@r%|Bf-WxdckC?o>HLFF@Y;SL%2 z9D>F&6RA|9VN3pfvQTa9BWXVxr7Gn&T0PFW^i%Z0xj^*oVYLJ%Ie(UvbcRYgrNKCE z%O>T5!Q>3>mkC%dkW#CniD@81ewYj{nf)RJ{}xGunV@3%d-0P5H4lD|5Eo$=S;UL9 zbdhkA9I8B7t4RqZq$IgSSFshT3Ro$G)p+7t1w$SBt2wV{26xB=W2&+#03R)rw!Iss#f#k7xTl7P8<Ni?vye z&D6$bDvR8#VIPsF><~}cVuJnCl{J5^j0t}(3>776y<_GtkcNp9uUl5EA1Yiet*P;^lf-sST(MF+Gd;_iYI#6}8VF&)iBRpq=$EXJ9rbr8wayT3r&g=R z5r;?H)o!*Fy-Re$-xaB&W0UaIWo3%Z^=}Cg+hQ@FkF(ab2lHhz@NZSw3<*YxRCMHS)4+llv{z2iIdk_9W62$pogW{bL5P!$LOl~LeC}ufo3y6WTmHG6*`{ z=8+cQLXF#(ByUCd_i`k+CL=cvf6|G2iO^DXiXJ-m*`$w zY!ch)Zi8yrNi? zk;A^Z!e}Xl4ZykqBh zC;X-}Y)zCBnd+wyT|8ajLJdd@29ga4@`fRtcH~EhL2AoI^WpYxM2btBN(+Prwau4; zbCX2BkSnR}d*l*Km&|<0c_`6va8~wZR#O zRcoseDqtPnIhkImgQBf+WPWdxsi>{e8ZI~}9)?G}fwr0?Db%1@6adtqRMJ{BE1(xF zW7tv*0kxxTok#%Fy!|0M;7^fKn-qPsqPKP6%L*d#4hhAqwsk>4cwmTkKlu|rcPGg^>&R@|fLfTtunvGQyg}*}gCY0>S|K*jStq(# z#1e=Xw80R2gCV|13gb~Gtv2{_Z2!Ix-aeIYAlV&|;TaIm53>l-hC^t>7Mj7=E67&B zNEl1BfYU|`z_nuMwhg*f^8+p+6mStkaAQNbv6>YhN{A2n`M`&b!HK2*K5?-}#f1o3 zt=$($&L45&X6SYYwUVloy3`BF3=J`6`j zraMrI?}98Bk(VmQa=|DdANb;fMBroq9q(UDOczuEC^g*^+B(b~YRv;aj2qs1h6VNK zj)0j`aJhB^t8DXd&Vuc%lbn^>2K80~HQIkQtiXj{$2TX$`@vPP>yn~5=lOg2Cn*g{ zv}Vu+B^R*Fdq2NTRI>IU&jbUiV}vFkUsZ!K zcZJBqDMZ>6rMSo9T?Tr)(n^*{>mD^0`A|L%SXP!I2=yJZ>}t=j4MKZ{x=phB;Y5r_ zr13|q(T>5cR--*LiSA{4HnduZWh<5J5JEQWfHi#!4Jki8ls(e_T<9>qSSJf zcU?5K=Y~qnNs1JOZpX?GvcrW;%vF=qKHuHG0f{*xnE4Xwplr_(y!m25T<-P-__UB# znx+xKT_9nBpe|4muEa2Mx97`_X**<>M$d;pzXkAvG?LQ3(oPB3I0<%2pZK)cqJpbe zD&!07b|_<|+HY;!bt2l1PO>5EK=kcW%xCp4Mj%Fa`*KNKZcWsf2V^P`UB&Dm`i4sF zI@J)i!w^bgpA?1%B!cXa7}j#^cA=G6xa+7#8K}_CwQffED7Bp3SmG&(m9owQ^zgwznQKjgU zH%qi6rQGjs@7=%rworLkY3_UlWomEVCGD01BFCK}yq((0UX>%rS#snkpf4q??^dLK zO9pzQQ+O92V^mxAkGFS8Z3Cg&V0Cf89Jms;F)Sd<;2f!ANE&QK_Q>pmsRtfJFj0u? z4H40uv0$S1_g>{waQ208_Nn;xO7d_hd03P8P&j;-o=IlVVl`3e~Y$G6gL?1-GZ@F*54v5=z5tdApK9dsAUVr zONZdWF*_ka`XC6Wj9ey#(qW~U5OT1Bp3%NHHbW$!IjP86`f)I*GE*2l z!3=IaM-ij=p+?xP4N@daE6&!-bhSLeZ0VqpC4deyNp0`a&O;Z8*t10_IU(NE&TWPXxOTbV1!b3({-bQ}kBwf9renPVs)jfeR?>WJGW$|{V?l`40&Rls zkp*jnLV-nJ>}s&c>IYeZsjUr`TJwFd23-2YbfPRRC}LDWpVkNo2Jxy1Z(|U`XXLCt z4z6^mv#0NhV4Puc3~GNYSC(L>rQ?fK`-@=b@$os4UXiGYG7CG-3Sq!`Y0yiHRkl~l z_Dc0zrR-M03nWFVh&z<)4oQU>CK0u}!A=lii&jeFCJ}3Uu0%GA4#U2}#!5n$D)rWo zT(>F*aB)3oe7>0Q;5KXGr@F$w0wvb~_ z_5y-x`h(o9!?S+qNi>5O%Y6&>TisMC6bF*zGN>2Jr1wbL9_^C$1v&*UaQpiteXm8J zSK88^D}uvwu<~3&kbpas=uZ?W?3IGUU`fX59+ko#Y!BfJMYvnXE8c0q+aY84ktDtz zg8zKW0sC8csEtUxQ)DG#>BoOgoF9jsLOs)wZ*(N#sU>VED&KfBk&jF3x!d;AmfQq9 z65@zC9Pl}xy)EY(Q|5f7L^f#TB@ubu2xkJiYckxcz%vllrCXnmBsLp>WZ>O-ERPUx z;NBH3xbet~>frhYynL?-+&hKl@)Jv3N4nQ{;KqVvb;v`BNZ^e{GPpKPb_@Anp8$L# zN*qF->jc8`FgV^7k_efX*H35y@Kr@z@R|>ftYrp1YO7mn8|Lr{R+Po7D%3!HdQtA; z;Wf^=_yVK;M5(GUsakQ7Vq-VHu^LLUeUrxiL;2WL<1n9c9(kr6E|i#Zq~qyenE6IN zFN{>apc$ObNdnIU^DBDbt;rWBPvbZ4{Q(i)(Lf?z=dd|}S;v3`rx^1PVpD*UktMLc zhluAd_*8|wXiup~6?m5iAf=9HF>sF<8sbVyVmWuqX0G8OhC+M-B5q8Iap5m6JjFl@ zoGExb76CrLzK8|odLmWeg5MRh9Y#ZM4FXGxaQB<(0}>8O zZh#?f*)r^qaEpZL66Q)+AR!xq+lc}TC;m>txb?!aLcdLNTLrVtCAmVURRn@B6%#W> z(xoo!qmx37gi1}g4a74A`@al@CN_Bq#|ox!9uWH2Y9)ms$t^{Q9Y_iLBt_dU++sJ1 z6ogOgPXWe`5mOX%kE96wcBjBnFTN2<%=r=uwe|%97f860A->>49BE5?9kr!>6Gki( zv0P*pS;D$Z!bC|CvcYsokxGN9lHSD-iy7i4NXoFl*^(}0gUbAnq}K?}a)E`JV3DLq zdT^`2xl}7SZGyB-!p#!Gj$l&8*o|^IjLY!fkq+Z9bHWa}vMjH3W=Zk1<%_(fzQU5? zIR#}UHMJqkScf@MGd!B((VQh9Sg^t~ zC3l7~;SSO`!C{i;6nH&3-X*BOQ?l6OLu~)DGl~~YGUf<}Ib{Fz#U*8)Ni(O-F(%1j z4xL(3x}vObNrBIkGW7({M?Yo_^XHlP8^uFHAa2xFiS@ zVB>U$NxQt<>$%ZeR!%N_c{damFY)Agvb|-q7GCdNY(GHU&NK>IuzLA^}GUqtV z8B_C$ib7JG4Z)|J;6aDwd1iYTLBN;g73Y^Ml_Gh?i$=A~X5m7wZwA`N%u{B2eWWl_ z!8|DaW#01A>^xtdXHijJdAX;s+*4fQDJm&mf}St)E~_XkLy5d{5BXRO&F8SlD=PG@ zAZp%?d4)xJ3yZwu$yb0Bp<>Kw4l^m&TXu43Nnx=M;$2!=<}DXhvjqS-gW^IjDp^`` zqZjJM=29TjrcSLWyU{!8g0hmO=NB%SQS9@Q8DGgrH+i6#Mfo0Yk#{N7wA>h5XY8^w ziWe6alS#X}5k;7oi+0{rQkFj=a$`8Kr88#d6^-hP5yiDfisYL>-=MZtU+Sx;}*yCMZT2#2G(C3-Bq^zW( z^a^j8jKhhZys{+~Y_Bot4s*)rnuM#7azD@X?Jx3$Nv^~a_RV{B>@=agg@s?8`{ zF=_-H>M(9nn+SfU6ct@wo`-&$I5OO(E%$kgX)k6K=9hbBSS-`f*t+;Xhg;qvnYA&G z?I#B{MyzaB*^){7&EA*$3Sr3#z2%c;%$jsTVG$H@whz)@IzpTbPR%RLTWDckP*Mh# zMzsX4!(nzyY@vMA(+4+UO9B=UwUqPs3D(&5p3K$od zKNc@5!>sJ_vUf36i_0SQjxzA0yECLsqw?)}G^Ko$`qCdEgL4*^b1J|@=#}Zfmh*@T zr8>++Vuoh-DYg|1b;<}b9ish^e+0)?lBt*w%YP*QIEV3&#zbqnEh)_Zk;yjAVNN2} z|4__{vnynp#>6|~%|OTO9$Q*c26Zp>E`oVoWEUUFo;ahtWKJ38H~2`QZZRgLxzna* zPal3I`{OnvnUiYM(-*_BqWg; z`BSD$^Od8T+!BylF(Z3aRiVDOu%?zQU0Uel%<+Tzeu&7P^_Jz7pi&IIQ527Nn4_g9 zEQ+&W?8<;mCP$&!{7<}UR)w#$!l#326hcTySIsE?vHU29abh~a_#5vqu`|8sQ`lAb z;KjzA=`fQ=_p{7-_P9Vd78TKjoj7Yzc_|fnHtbjhO^WRaO`KCyKDDS2QphbU@s%tp zfnOOCtlg_q;OOSsGdlbVyRfZXg~eiACQU0}JW|-6$wIE)sJ_GWS2)V!Vk4&92u1e5 z0}-EFn!ygA2{*#Bws6CWVTjAvAo%WoV`qf~w13HY|L2l+R;c7*4wG=1_;_c-iM%Oq zMY(5jUQxMs#A%y28+8}umSMgt&nYY)tx;S9*@Z{^(h96Lj7e~qaaaD(iL^cXiK5H- zQ%hhzZN2}YNy8e;*4P=vQ2fxcFJy~G@d!IAeF?w2q&R=HMF>?nCI9*gES2&(aYOad zdq36(p)njXpFf6mio={JBMxG@5jFtE;wSNK2N>RMS-E$l&?p@btzKqf)mVrHT1i>1 zZHPu#;2O2-kl9zi{CZnNZhHCju_ZH~nQ-L;@pr}-Q*Phr4H-Gj;x3m)#qz`{t{Q&du&yVrW zI&R;VQN3(^=iMJBe*D(w-r@J_hc21<-M35MKkJ@rzv{dGgCl#sTk`U6XGSj@Uv$Bd zWJCVd682b;A6%A?!ZYT&sU>CEMMan76&9PN<**E1@1*>qA}RCzai9@@W;d3;_0dd{ofw!bZSB&qz0?u7dqKJRl^Ja^PNPY%3z z{<*u-?#X=Y_>w=yy>UTd@Z;5%W&XooRAgM1YkPxkmv*gahORQ#EHW^{1IQW5U`BkvKVn$4#--Db>JWI zta>F%8qCl?6haxnAzjj7fS>ZgH07B^tol$7aY$eICbEgFQF4)`jI9_tpEa4bM99 zudh9GdUoaU3-4+E?Za2icwf2&Q!2uq&e`Lxx?uf1jW7TE&o?w* z_rVx{NBhA`fBx|wFPry9`;)6q-sL;`<+=TZC(L+uXLi$5_19N4tysQy?$2)6_`79) zpZLzK$DXWv@X$S;uEo#(?d+{LzkN~SqQg(Ee*e$HXWH}yY!!*6Q-P}Q0A zo$I8)zo!?>EuHr5Va;z9tqJ^M-{Y5+zkKWi7l*xDc2x6~?_K`DiHko@iG1X@PmMX{ znP1#id#3B&ms8e!k@m-XA31i+^}i20qWmL|e){H$mC+ae^89fhuBqv!wX=z^=~ym_#Uh;74l^=|2`!x8{ z*4ta}Jfi!VS(SaByYp_kxbQ0X;fEx({XY8L&J*A7KBj+a<`IWZa7T@eiCg!V2fui1 z^Y2bR^8TF(pC7jR%8JOGhc^EG51-z;;M;o~$KUm@vahz!UwqCp+27ofe)ZH7Zd`Zl zpZos$$#B7A1D`M2c52^quPs^~fByPovJU$5cu&nm$v3b5!@2uj`uF7Vzd7NTOaF4` zDHl(8B<;(-+RKK<{^`Bmn;t!+=%mu$ZM;7){p;}`<{xw6aKnzxd(Jz&^XAmuSDe=J z*)cO_{$)+Zi+_6kxx2q>*cEfehOeq#_|?zfO1by(rsLmu@Q<6$JNu4-)aCxMx!3jF ze*G;MES%GL&{O~1y=}1NtbbiQ>FI~Qs=lW3$-8>nRu;Z;^8F>pxgUL@YvVaP6K}pR zzGG4G;5mQz#hb@3k9vMy;@;xh9(N4Qx^45S_G0fpzW>K9zux|W>*#|A|MA%ex4-`T zk~98x(OpryKH9SK)e|;7^3bX09ee7D_Xg7beD~t+(`Rl!(^vi6uZCNCxAfn)`{2`@ z8!q~M=#76(c|JGp*4BTXa_A+mHs1KzmP@Ao`jR<4LFd~8FaGwuJFl-hA}95zZGZA! zdg}$(e&oEP;q+@9YkcKj$4r^@&5{XMJ^JQLm-*wbIPJq%FFa`JYk3W~{WA9FXYNaA zns-oU{m1uD{Pb^m&z}Bx()*vhbK%38KY!`%c^zMrpLcn}-&Q34<;*{p|LggWW`FzZ ztFJq^B;oDsH*1$a^kvm^1v`HByX5rLjC-=KduqbdWrw_bT+qzWU9PIS0SpM12&aK>+_~cfR{x|Ka#3Gi<^3g*f&kVVnIKTc`If*nG$EX}j;c>%zs)oieWGipBL$ zpYv$p8-w3^KAdy?Wl`6^l6JW=gz7xU;Ad|duLVOe#-Z2(wnAc?|AFOzs~tZ zVDhh?I`-U8bJ}Ch|N7~fu1UXKobr0|BR5`s_l%|MUOcXB-#_zf3pO0GYt#ImYrK#7 zi%O^Ge*4Mq-njPQ3$DDc@s667-4B?C?Jr0FYhZ5pwnwK$^rjx!{M>ot!v6Ho6Js0) zt-ayw*6~wjE$RDc{TDC%ZO_(!ln1+f$9(YM>8s!U_nCu96>k?``1#?>CYwGGcl^AGl|$Dpxb)Wh5Bu#! zV^4nn=XbR|+woav|2dcZ=ESeI?ELr-nX6`R%sccX=Pkd#>DA-kDNI;&`O&dAZ~W#t z*L8=zbJDRZy)_Rt>}enW|X8vTBm_yB1W-1Mq7rKvMb<|Gp^8_nZp znemyI&4Br%IorHtf+o&vH__%3bCVf1XPO(#7_-9En}z1j<~7r8UNS4q^=6$p#@u7B zHsR(P+={6%ub4dZo=G&#=5lkXdC(kXV$8K>wRzt>Wv(=f%yZ^kQ)IT9XH1VNg}>Ko z=HX)q7aEV*X=a(ZrXOSZU2}-ZFgr|%Ime7MUUPwY(%fQBHoq{{=HDjE{MJk`3}o2BOGW|xUKRVLefW@eaI&2P*k^LKNjnQu-p z_n9Q~tcfy(<~Fm+ykJf+XPMub4^58w-b^(Q7?(4~F(%wZg~dh3j*W;MXK=iQb8L8Q zROFa(_>lTeGtQVe*O*90bXZixIMj3RpBF8v z*|&1##!qj$sqvq`_{G@ozxd*bS8urC;kQak=CnTZOzwiTv@u~0$Nhg>vgGC~PCDtZ z55D_u;cs7i?H`vs@W5?DH{Lj{`MKxrII6ljtNz(%*L;2R%?E$>_17OiGH>3qO&4Am z^Ua<;LsK4naLJ>)c71!@-FJU9?V*SMcx*?~}(Z@>M` zxovIN=Ny0hRYhl8DfD5)*%UW-vG|Iz0Thr`&d1R9s}_ z8Od(KCzP{wi zCoe8L>#Vl|7hSY#Lr%`%mbr5;TK&QcH~gWu_rzyD`|SN$zy9?hpM3MpGqqEvzINLs zmt4O1w9^9PSFe6y?X+p}AO8E_5zer%s_$;Sbx&t*Zuaub%-(R`JjqZ!9|h=%dp- z@$rYh|NZxI-+uY!(m%fRQcl(L&nG0t#-4usK?j}k^w7{dPhNN3-KVc#-&2>Jeb%Hy z552N&$Br*9zwf^4;ahIG@aN~A+qE-4|AXIObInPU4?C>=ALZqp-3u0MIIODb#XD!s zy7ivEzQx(c9COQ@6Hk2LoR*eVF?Ds%HC%AP34i(Y)0c19wkB-3h+vd-|=B}rnDt_YS zmp_}@)%B|#3m0xatF?90sqO7&zC19n?u!*GCcpB*2UFMW+&QoK%rhT_#ZQpe1h{WI>rf9vj|qOZIDAJX0go~rNPKM5z!NLr76Hn1@UuGL>1B3>8vTD$i%D{{P?o-}^lG^?L3)K4_FC(^_S$QI z*FI;z&t_#sKlAysc=P!9y=Qy(Ui$3sKc;{8?lKMrh7Qld!mz1h$2_-)i~H=7lUu2> zV#V~1^z_<8`T1tiH8o-lqoXI1`}*QX4<8oM5EAOUZe-N!SW*(odf~zu_Vec>2fe&> zPH1R6^)4vLYIJdV6=`5VOGiyjnVX$mvVx5*wbIdXx0{mEx4S!bw75Qba(QWJ=+4-R z3Q08qfhUp)2`XK$Uvo`-{rW&ACT6WDCudQstE*RLSJyfEOP4a%UcLHIHZD$dgP`CQ zp0j6#>&M0n&pv;?kY#Ck%v4IsKW$(jg8Jgcuhz-QfsE(QEnUva+P$}|Y|YD&k(v-4 zoyRTv_g4jLYv)SG#`@aG%5n;_vo{>i&HZuP!lLtFQIXneUf$LR+LqKGI52g2dgC*qTj58+c;NmOQM6WKRz5I2q-A&$_| z5p+9t5Id5Rh@{JxiOX|y#9ToEQBYq`)Tg8nDHksi7h7A2*2qXAa(0%OrKcz8Gct$_ zNl8NT(k0^3{rkjyLqo!_zn|#W)g^Ry?IL!)d`Y~lttDzTGzg6^Ux+Ue5k$nkeZ)Q? zAwp=`GGdvB2jOw=9&t}zo{%3JB8JYKA>VE`##2*? z)Vp_yy9o(I!u$8c`@ldVP*#?ZJ#c_HaQilKTSkVES-+lGpPo*nS636&p`k?R)~&?W zwQGsBKYtQGU0ev4ojZx0*RK=T)zk!^4U2urMMF53pzB<0JUao+Zw1+eU0- zW+s?3Gl@(V7J|jkkMQHvwTf7klSAaNvlHyko)OQyya+E`!7eB&5{j;_gex8~!?0%$rh0^xD~Xlx zq%Y>@iTT1pqVU59;)9+Zp%)ZH1RXj=96ETAI2aN_gd`>si61`_AGd5Fwp3LSRdRBK zTtx*@fo}#VBO}C!xHuthU_cne#uBklo)AwSJRlw%KTaI~_Ko=V{5kQwtc)ld7$63` zy$Nq=X+pZGiD<%?MDAQ%1edcj;T#u7#5p+;PB(87H_OY3aw8+c=+PtMQCb?2cJ3T; zZuf3tcU~Tmw{$77^z&!pb8#_I+}1|4ZQe|5Zf+);m6Zu)dwarOU!TywdX>2P{X6mf z#}DF%tu0|29Zf|4`bGS*u_0{k+#&94*g$MBHYSXzsR?Q&B|>RthL{l(Bg7s*CLY__ z5q55Fgxi%X#FdT?qC-T45ZSbe*koo#nAOw}H30!cfT}8?dipeRy0@3;&B`LOPMjc4 z`1%sQR#t=+eq>F{&rk5*x<%aL;URd|ts~Y63KD`VRuC(`ekHzc-%e~77AAzbxe4yE zF=DKwged9jBl_OFA>Je>6Ul>v#Nhe!#QEuIV!E@F==Ap|{ELc+qTyj;SWAo0GBF`c z4q`6(`@Y8a{=z>28Px=PLo^==fgOSWpL_GVMv8wI1FI8HlT~v!HpfoP&Y_{RG#O3Kw|<-F_ZJc?7P55r?D? zr|?-E=F=FeO>m2mI2{hbHO^v)-o$V&!=c;`xAF?7Y#oM14NjRLxB^cMX)X+9Cmh}} zxX=uoI*Ayr#TfR|I32#h9m?ZW&WBsV&jje`;0E5|wD5+zX@|?sh8qckI|+vy_ra<3 z1jFVlhV31=zx6n^S7G>W!0?#HaL~dj(1zhr1edIf;l_j0J_ke57w$6UNaJh|e<+5;V zOEC0>aT@2rO~m39G{!Vl3DLtjxR9%u;&#F1Q^DnJ!8EfLQ`!E~Gg_w^l9Fg;woCEV^uOgT)LehuOF_hb53fqS`y zsXz)Y_Bf{Sdbr{WxQJo6#?P3NYcY)`#LaY1%Qq%|4!ZKmv!>&ef#&VrAN%N1N1dMk zXdO0+TU}W+A7wPB+3iy3^{aJnvV40KTeRO0b+Whpn_S=bO{LLq&Zznb<~J`jowKLP zVtO?ASW9J!QLNqX%sHi&9-(h{_NZw2ubI9`M_P`VTf+4A&8bJ0E-` zmj)`y3b0lkxKtT&XhK4l#wlXbVrQv(pN-=7T?t~FcPTcTXGQL7xw+14Yiq^I^n~<} z&1S+TC*?w!*hRUV4F+khs;WMJ^dr>k*6OESjqj+>i?!P9@0pg*z8~UD_uj8;(#!7V zFN2s|+s+9TVW|`!*4hQRu=jd-!5Yin?=zndk|I*H&ZO!@}=! zJPmKypRxSX`!We%8kHRx9?e{4U_MCio-p0|=B{9LXig9(@68QSq) zsAIYCtlOr2n~zN8Hb0x-897ETz28J==CR-l(dV5S-lFRDRdN{>I~3%FG*49B+1$YP zC5!53)Z?D!L}mxME}^xZYU2iu-(qf!pLV<8q4Vl?@2*3S4&OhQ#JOd=;GqYzXASq& zH@syC7-c--jy-?5H-Y>B&&wB@6b%(ionYc09N@0pAnbj?k=l1~hnvt0P@+u$Bn+}ouotk0i$;<8rxK<|rhI+T`xoyS#7 z1b!S1q29Y@ruyAiG1WuE?>339qBhF-V)`=e>@K<3nDtMMWf(Th?tJ|I_~n7_gI{fb zJoZvN+E*Z5pk>e`NH=wWu~U5cWdjj{&sG;Efa!FrClQhCD{~R zzd5gytA1+HN}iYf++QJToLYW~o^sZy;`4H|{|v<9FVo+n5(a%@m*@( z)7yw8!^d)jIa1zz63%yH$VQd1$;JDvr*C>}a^L+(;#9cy){9p9 zg_kxi8!5|SeznPgclW7-!fYDP8aP#N?HnpD7r4K9shUq))5|Xwx1ZI<3rK7XQ@nFx z_0>W#=gP>Vk97j|S6aSZny8XubyUA}FiAFhpM9Lv)-^wiBI0F2H|^!(zDZMeB0sA3 zvdnt^)xoa@xaKW4=WRQlImAt0*dWNgyMNbBJzd9hccwa~=Wm-6w)QJt(TqpWJowpu zJ4j>?!;)1ywA+fu&cAKc4Hf6)zBO2L>sR%r%j|oa_wH?3%bFZ7l4uZq%R;2i>EIoE zji>imeSOp}_+(C=9S}agE$ZdlP>tmesV#?TI{515MTVcHmpR;dV0vRo)x*S-#lsQvSY*8My{MEs|Msc?uHyoDqr%&L9U)-&v0t!#^UE@s=RSGC6vAw zG_|bq2w+*eLJwe7YokGAr$cG(lME@zWK&K3{%8&FhN0%!;Z?ok{U~ z2do>fTG3dD_8bymy0P?W*SDmHG!7d!-c7mpbMoo+tNFI{b#ue*D+IV}tK-*MUJ_B^ zEji}4()88-op3G=AlT&dStccqO!CT%oSdwFfY_UZ!z z1E?a+9n--rtw;bhl=Cjogr)a7k=N^O&h2nd;GwTZrB|4VG7E%NojPJ=+J z`MPtl7Vx)t`{$Sn2fUId2al z2O6)HP82^8HrW?!z4u74*cwmTW<3q>us1e4I4dn;6CKOO#&2smJS`k=swn?7=4q_A z!gYzW;cUFN7rU**qU{>O#wSj#9eT&mb1h$YKc#rr zhxd2PEfpOY6U#mfB@f)(F?IS$=m)3A=?|BymfH6#&PB|q$&ksDZI~k*TwMmsUh>A$1X9+40Yo}%g^02mJ$oTl4V}HE~-pKO?}u%mzPd; z{Dw!>=ww$@qxwogp{N23gyJJ81jX5c0GFQl~yEMk1Jj!}F z(C|k9LtSjyoA4wGXYvuhwo~O2Hr*z%LZj!Jq^^BPT>GnaAbUYqqu9%Bw!DjJ12AlXQx;X+hHC_|*B{+jJFrhvdZs zKZlC(DoLChAGw;lcI~H{lRWnh%P7A&B<^bPDs$`{74M9|t@(G zeTZ|xM}?(I=Q1;I?o%u~Vr$z@{4{^Cb2ztwNtFFG_x%VVhGw5Ot}PoHUDnKAEIqq| zE-a!xEP8m4ga4&w{nOj)9?svX+;G&jTyr~B#I~(#UO5kYsdQUgxCl-$Fjl0AD40Fk zZ|k0PUOrf(iC$qc!TWHK#M$0q8q^PKg`dGl(iC zxYuv-3>qaqajWQReM_yh@Q>eN;#K_Zop!fcn@wd%(q{`=%Tsx!CzPz~cuGEGS4W>J zsI@7)*FXDEEnZ(uyqn70?c~P2hT#$xS+Gh_v2jFQPR_oep0@NUt;(&`|w6$nX!8Iu-z6V0ooDESFe+%jSsX< zeAx75rP5e#Nkma;^PZO}7V`CmYi0^mEN)48(@LuvJQlD`FNt1pM!xw-Co4YN!XM+l z4ndgV-d7NAm{J%K!TuQ>;#Bm2oU2EK#U^*F+Kythy{ot2@sy#O)j0AjoVi18F4#yWr)DF88O z0b<+&h`|gHLkl2=JwS{SfEXG8F|Gr|=mUtc6(GiCfEeBYF=zl{H~_@p1BlTH5aS#` zjC}wxasgt{1H^a-5W^23MlwK*696&30>mJX2O~fXMSvKB05RMFV*CV%!442(BS4Jx z05O;VV(bTq5eE=sB|r=ofEZB#G4cUo@B_pM1c>1X5W@x_#tMKKLjW<#0b*-*k!wMjVC_s#}05Q4%Vq64>5d#n-9Uw*;K#XpH7@7bvRs+N^1&HAW5W@l>#w*uO!&0oH^Df?Dt^UGG-B<#!GrK6l`q9qyJRvK3vd-D=!2hSn) zvXd)hJC8plY7g*Ve54ndEK-{1aX;TE{K z-D>$1U+7qVdaK)5oGH)Sh)!GQ!fz=OQm@t2GD5Fq8jbC-oNSwvukD`OKIiI5qiN0b z-IpixO&}#S_iWAxV_ei*4RxEJkz>&>*Clj4np$mkL5520PRI3t^Z-hyM)M0P*?<$x z;)z0Wk3Z%3dQ-1n#t;ZNH}8+WKnNxO7>m6GG~yG+@A z%+le=hfQqP=Puf}4Ywbp1!tSwTr28pIKw}?khQsW=lu6Ug}j) z*|YPe^5t*BQI(PY17(p9eJ{RV*}T+SQ}cT-m0KiKzE z_Kd5G2t6ay<{JV^VKfE z{2oJtmR93X{x-MGt?NSW@ld2_a$gIm#azozd`xGMp5t z1CL{`X4E?wKeeI~alLh~Rl|~u{GOXVs#lb+FBD2TS+`;GNv;-+E?f0u zgva~GWp;6%t8tD|Z@*8(KYVWOe7o|+?ZPGY^c4?T+-QgQnznN2+@fw^^LRg~-V?)H zniON~Ja$Y`@tRQLz?HT^nRQ8Rf}gz4X&+|dzql^dNZ7ly`jz6*s_;am0Xg~DIDJp% z5rOGpc8hM~x0hda3pV@hdG2{qqsb+2885BC>YvrE5h1an^Rqi<#J-3fRZL%_bUTWw zsnKdr(A1rRi6b`A>v=sI54DC}*>kN zg-4%no~us2=j-5bM0ne;hBL3iN6+Ve%kn>&_04!!r2*f?^Yc`1+^Q(wUQcwoer=CT z>fe3$Df z@nV@JfAWz(t|omN={ModK>7Txml;dacfkdL_8~y#5TJSpkU+m}uwzMvf7<)!eI|09 z-1eW#ziDJ$L>N_RmZ zeF3M%3uY+=w9iA(MC_oeqCg1ogT~4Si!~0i>oVw|$C#gAM{!_`qCrgE2l12(zN?22CSHS8>I7NU z2hwQ^=p`LcRSDp=48dbHfjE)`O+^o0sUJMkKG0L=z>_I}oeBqQ6#=TL4rEp@h$TDB z9&12+d4bz<1W}fVBP0U?$`oXj1*j(p5NXte7I-ov5Kf1{tUU#9z<9+s4)%9 zZ)xDNXh4_6g9|eQzcq!=0DhpqPJ({Ah+{p3<39=Z%LhD{C&;g4@M3M?#P)#p3I$U& z3fjyUYA|r?!Cf_jM@t6*cL&6m`y$b{17ubKc(4*MZfY1cw3tO#f#)Iv zIVQ+)NRB}*NEORAp^(|LL&$Y!~iiuT97tm02x9U5CjFnKdmAd zAuUK7GJp&r987`&F+hxv7NiXsK!y;ylb}Eh5F?}oX+s8(A%r17P#^|~5z>ORAp^(| zLdOskhyh}Rv> z0b+!-AZ^G1GK4?}VE?flVuZ9HZO8yJgor?FhZrD6NDI=23?M^@2*!4Z0b+!-AZ^G1 zGK7doY=;;iMo0_Nh72G>h`5675Cg;rX+heM0b~f7>YI|CKzyS@Kf%$^lFkN!jT--T zn}&*=r0M9HSSW|?{P+9VWIiVVawh=D`2vtT4nXb`0J#GII zoD2ZDUjXD@0+7oFAa@ji+%o`j!2smy0muaakoyim&KiK6J^;BX0CG71jB7V0+5>nAlC>$ZXE!*GyrmM0mw}Q zkn;v0_X>dA8US)U0OV)@$khUn69XVu1wd{Y0J-Y`V1|YW_fE+&nIS&AGHUQ+30LX0zAg2yMt`mUV0|0W; z0OW=N$jJkc3jrW!4nXb&06DTRKLC&ucF+?30YEMffSfG=IX3`u4FKdy0m!KWklO-4 z&KQ8)P5^Sv0OVQ#$V~!}%K{)b4?s>AfZSF9a%%y|odF=H2SDx{069>PRHp#QnF5g8 z06;DgfZS~Wa%KSJQUS$h88HYXTt00zi%nfZTfka=QV@MFWuA1VC;n0J*0Cf4grvJ03a6xK+Xh!TrU7QQ2=tQ0LVoGkP8DKw;6!kM*wn<0myL!kn0B^XAeM* z8Gu|506AQw3@QSUQv)E!1VGLZfE*nFxs?Fqb^(y91R&Q2K<*9zxjg{nE(4Ie20-o& z069MZa_<1h)d7%G1|WA3fLu5Lxefqw+W^RA0+4eDAZG& zjsbvNApp5!0OZ60$jJeaTLC~W9e`Xu0J$0fa-#s``T)os1|TN{K+Xt&TnPZV3jpNK z1Ca9qAg2L9t^k0X3jjF-0CLm-p{C1R$pbKyC*BxhDYRLIKEC0FV;^AeR6@ z?ll0puK?s?0LXCykaGnf*9AcC5&*fY0OaBT$O!_FI}1Q=41nBo0CJW98SCzGYUNu4I4WP!AeU_4+xiuouH+nV_~LYrLfV^Q881qGO)1Y-#*df zIdE_;tQ2ZIB8-`aoq?8)nU=!Hz{*ar(NIyd&@<6dGqJK@{sG_1NW;L+Mn_?#Vni~* zz(PaIPR-25%*0Mhu&^=EQBgBe=visx@goEBy5|2akZmNJ3U{}7T?G%hcpXPxdy&^+ z=j{L=^u8o~i_{%H_tnJi7d2s93lOhkFa{xp<=#&STMe;Q3e!#N<%KRZC~GHIDC zO}@}_5troj|UTN0&T8h?5x>_m*riX%%sZe365O>^QP8_8;ZRP9qCq3q&4a@+gs&lD$Rl zG1+R;09l%RksVDMLxIHsM|L`C7=_6pfbzc^LH0D+TjU;-4I(X*rO6j|j_iK2%gJs= zc{B$iyOHcVve76=b_v-Hi#tHJnzT%oCST+(kj*BWN;Z#d64?xxUEE311X(Rv6}iJ? z5i%QTnT(Qw8~~6O7XJ#QKl@LghJ9KLLJ0UrGHing(+I!*1j?`9FQGx9LAGhOY04m8 z)0AnUUqZjw@S+Ie#YSNp{5AM%8m~XuDabB_>}-FsQ;>bJz@O|CWM3?xYrKv8Dvj8& zsp!qyo&U9cd>Oy}>*5aJrx-Lew6t^x^ayw$=we{}6PW%ZF#ktj`CkI-{}RZ)`M(7A z|6?G>(~>1zT-*pe2)uv7(m!F@e+0h&2+RMM!2iF575~Q|@P7;#x~KkgE+)r?B_>`w z$cdbQ5!CUyVb#&>l2$L@3of| zloW+UYEcgzx!w{pnB?Tq>R81i;PS5W(n7nar}};=>y}gHb$((CL#DfZ+q9~5twQAo zmft!NCR@^)(m7b4%xB=f?(D%wj`HjlqOTQ8R~_KB$WpsxCEB9hmQttH<07vbk|Dpa zmFRDMB6~;kYV@m$=q-;n9o?Rx{JCJVaP?#B7iKR%OwD-;`7_$I>^~kX_vL-0MR~5M zlJ%wHQ}PFmQk;uSISgG|WrN<9MvAU|l*pq##`)$_zTLV7BdtokpPJEYa^zZOpY9F% zVVUzRuj8)lo#ca$+EYwf;wnCAiH50|c(A-IdvnVt#nwb#z}SkC4ObXYD0@iuMJWW?klpRGFYHsJYls8^Uh$a+M_ama_+PfPkz>Ek znKEW;R?hBLq}5ajs;hQ#?X+n)T7NjUy_t2{vyNbTmDye2YdLwU&T}QaQ);=~tsff6 z{y9N=C_{VC`Zd=+3)0f4@5lnd&pyS9>h^R}QylX_nk-9!edTrP?Z-a7VnP z?t$gNcuYb`$Ne=+hTU^IR`pBkUX#)*&2eS-e#KsImNk3eSeBrsnP^;wSytnwwpCNw zHpg@3PqfiqqvOB)=DqfaVpV?oeo^X1CWrciCsm%i=N%|JHt*$D-$l*ZuR74)?Zh$Y z{CU0pE2%b{>y7#ks@RK;%=4SYC^gQTxHVrWC}t9Rz2#SR8OM9345l5bcjPzGXqxAR zIm-E~4*E4n?ugKyh!5|)v*P-RwpBM9j!+mEZq`igwXJ=n)zjtY%l5u~e3SlR#T9u8 z4J-RfELNQSwuy5pk8Ne^&j&}YTPoj4y(f91ee3Qzv+GA9twwl?(xzyrcTTUSc{Z-R zoYIq37QRKJP$_9aLWyzf@v1Hlg<=5R@1FM@>_6sdeA6T02JDqr~$Luw2I^N+U zm3bzkMChKEfmr(t^Vtl)t?IHd+JidpKD4krX4RK44hs7E(rv5$E_;>})_h_wVtn{j zdOo*)F%LbREhZ@Mkr3~Fdh_7r5)VDA8!W=Az24RMg1uYj`oi^**9_U(c~8zgJ8}A* z>vCO#Mk>GRxs-s<2|Dq-$8`*+>TL-2h`zGDLA#h}Xz3Uz)by+@Z1~=VnVpuMhQQDK zaE(t#&BDgSK+n#?#)xMYP&4C`1rq}+4HG>J!A`}%MxmocHfnl08fHcoDkch^5X{a> zO-oNlMZ?O-j^{kmGBdETP_wepQ0NI-CTbR3fm1Q!M}|y{wB$z+I(jx%f{G=^KG=s_ zOqe_Jt*=eW*wa-Soho5gJN?@OvO~{Yf72=}9LN!fi+%D%U>zQegAm5MFu@Thj8v>+ zN#=pD{yXQt^B|qfi?Z1AJ1nmKsSD*7^ZwpO<|Wq_>sqXTu>_fyv`74_oJa|3j%~<*5cntW?{u;rq+pxyvfmjf$U`B&9fa_h zx5ZCTWZL3244KBD^(XE3`tLkCNdJ?E{3y1V2l)^vxb~qiklUffZRGOzHUjl8+9J~z z*Reo7WSzfllIh6%r!A!I-_Io_(|(uzorY|G>t0MJ zw~_7m(=O7qFeCyIG-wVa42eKQAmWfPBm&{%hJa?CZe34(#i|z7Fi`z`hRb>%hJa?CZe34(#i|z7Fi8JO|2ipgaf4BM!kn z$|D|#I0XABk9Y{;5bUEohYlkRLBKT;d=MF8ANMTWO^_%{gs- zD_HYNhy9A|m@N8N6x-8FO3$oWSrx!ydDyPh=T}~TUx;0i15q(IJkN%7psc7#UZA>MNDo-0i;uxwSP_DYyS) za0DI`UMK zGB#W?`{a@Nr&s7aWJ7B>2YA&_u}+6f^wEs(O{bZa^L#KcIK|F>X^UB5@y4$oKcopN z-(p+EWb#8gzUT^mFfeQCJ!EcS{B0op(7~~eP{&Z8bb)l*H+8NRAjTUQH(Z>D^5^_0uoV`bT zWc^us^Gn*|zM?$e@5}LSKDB%3R~MK2lKZy}#y#F$S!&UHFXG&bnzAKb)cjvg^MB9E zThsMu)tl>*cc$-5wElRRk*ZZ)JkNBH%ZlR+%fTCcug@LJI_$UVn7C3~T={u=M!TVm zmJc=K4^*^Eyb>n7OUsz9?AlXl@}(s$B{gyh^MPTDa+#=KdlszwW&`fr=G0SCR%-A4 z?sM5bY7I=o&k% zr>0^PedRK-MgMq3Wmeq#;pKVfJ!&9pBweT0M7TaP)4|8?Dm4v&+nin4`y>`3BZb7EKsq$i7yaU*{~9&;6SC^~8ztglZ=7bxI9}ceYKwlBP^< zTWR|FVgKi6Z#OrdpL4nr-LEGnB9t~eZF8P`WlPk{mhl|&*I6MUE|T@M zWvS^UvnY3iE2>rPFH;78HROl)*{v4tJaWR(-FEoZwaOko8EUFF*9Q)Y+HZPy@7H-e{-i~Cfizsl=m#++C<%8|=!wDRM=jV>#8lzmNR9sam; zAFI%#C;k3ioDb_$cDNr8>$vymwMoo@kh_t4ex_C2={Fv@x}auI{lfMPa2Q@LFJvKy@R>JrF zJU)628o@8*8R&x5V}5ow+zu6EkPgTSJMx%%Q&XbE;ENKexi6RbXL0jVHPPiw|CXtX zA}0j=pTCWNDZOFO-aO{=>yexGixpC*-8?%TmwkzL=dHZ=V#SSuT1AwBoi{de@4mf% z)GH}L>{Eb3*tE%MPUq$Mdpo$Pc)hkCUd#27(Oyckc_Z63bH=(S7F1Ez2fG!{X~lk0 zKg;E6u6flmGvsVT=CgkL3RQc3qs0MN2NqfBuzi7Qe6nO7no9`FRHlC zR^d%sS0*MWy8jHrzSi7=z)S6^-q(YQqF$eGE3kY_b0N89NX>Qk+K!y}`3Ae5CG#5c zsUQCNG^TW25XDzK=a$8W(X)Qp=G>rBoij^+@#XIlUsqMRHNjI~~xBg*`>a2FRQg`Cme|BS)4f~Eq7U6UH>#n^_cJGJ(sA*T~}(@JfF$_*1DvPJ^ZNP;hOE8&rd(zMA?2u zGu76Hx$>rsZq?fBBg^0ayvT6tVoJ2|=j(zSZmkU4obk~kUEWdIhOPPA-aO+2TjsNq z=vHLu9`M^U?OD0?6noqUi%X4#?i%7nt&wDvE?^#Yf%#it@ z`26k6R{1-e#^VyYFV;2`?>t#+Ofz`6QSL2YCY8F zy8OXKl~AT&%XPQ&Wyh9#hX`hJM0%e#%zHF7x7E)(x;$HMRVUl7@T}n7D8aHCYW@>n z>9fyZk7G;Yq^elv%&znXXQPGfovuw6^CKUt9sh7%wM8aCFYkpl`^Jg(BYS@x-8aT{ zIF_w;K6Xy<>Feens}rtr2n*R}Fi)Or9(E1X)l~IwcKqcpT>bHCe3+#f-47qX$&4H& zAAxPpooqS^*VFV*Dm;z7O3$)8pr?1)%w%WsaruHI+V!K>S95tjGIlMDg%X>3tv6kr ze9(BhaK5Q(Fi5-mMcyh#^@{1}Z^xTQ(t22RD7KUD-e@l*i_?7#d>zQ~RLK8h+|tY% z|F&BSJAa+J&>yo+bJW-M$`!xkiQiY+)^WW)O+39Lu4MXhx8wMn#TxECPDYljBAol} ztgBq=4mCS%EMGVD{OrkB?IJS!b_F>K(VyBgry8OlxL$q7#G6~r@(%G$YMn}(i}_`# zgA!Q2P$cvHLt^~~hLbMNxEEek2;s2LR2Ki`>G@emeIeOx{-W^Vi+T}~DT7_>)M~f6 znuPrr7~QH7MzBqWJ6kJVRM9){q8ljiGfn^;U})M}C-KoG!P`P&0>hW&YqtG*%_Q|a zE$+4C_R92*5{u|JeU_co&R#APTbVMg9h9 zr$p&@+8R&J$4De^+U5K{)3DI3w*SuNDaB{-1Vf9^gw~(-7a}l!+b{`K}&H4B2>XWZn!<($@Ijdmt{`-UP zFHi9_`kk5F*}wgT{ZIKGzUPV&{@>gbzG_TSb=+7J%l=)bGIwG)gU;|$4U1U!V=0B; zz`B|KUhll!ZFT(T862w1OGoQd9k+hDUHlz9Y^+?cXuel<@VRYWuZq{LxG=&isNgrI zE}1^QkX!S(%hA=~KB4)1;gPyjFN4i&w{A@I>pA&Hd`EA^t%yic4(-ir%iw(!Rh2m5 z!Ihy=Q(U8?Y__~uYX4;CUh3`HzHYKcA0(A{TZMwkr>EbG>5)E#biJfIp@v8=NZtb{oilmwn{;U8 z4QgRX0n&mTpg^b`A`1up|ENF)g~cF7NFI`exS$l`w+%%s6QF(2S|}dc0LepSP$1TT zaa#+nP6?!&GVZ~v6599}uS;wq^uV*_AkPD+04jr0v16G~9=U@E>3;$PLzM!{KmSe( zGX($FzeP_ggU(Tcl*vv)$Sm5#za00s$X)*%MsWY@@ACuy-s_NsJxxgWk6n^kcZBvr ztA>ZSL$hAyWy)fasHfkA?Os$R6S^Sr!cgOQAL9E(z0 zXww>|q)Qu0N=#I|dN_@1Yg!Bh2cz^de{R>llf$!{Keyes@_Mw@kqcJa>(=wRosxOw zkrF}o*49#m|X^qOh;WtH1! zXyn~x%)h>No^Gy6R5<_nwT(xfNd>BXO1wEgySeD`{B*kC!sl6y*SZr6Z*MdekIJ?L zy!Z7AT~~fkUxCkvX5(F}YSnDIV96Eyx?H2Fv7WqYQDv#Y;&SL zgRQ;IivWQgE)KosP6}~b+huJGS(*7Z74p8)impk!Bi!SB``b^+v~7bU$ws-!Wj}Hp zio`F7J-l*#=)Sy6&iR=2?w7PV$uGT-B4hHsIa!{@@aaO#};D6>q{mET9=MPQf8u?nW(wMyFs5VkrAG$e0 zMqlUrabnj-mx`Tlw1O?o?R3o&)CI()C3;1sh{VYH+yNVP ziB2Bs%MI=H1|OoC7N)G&z9(^VY%OWwz8V+BClg_$k}oOgBWTNH;ZT1vT%)8u za^VTb!{Ypm?10>qd9}MdBlB5}<&QIt_xYvPIINHJ4wy^4ZJU2ZX!DWl%Xt;Ua+qf> z9+u4ws#5Si6B~KnPA=TYdM=y6LhE6@souz?ZJ*{%w#f9c=*O2g>52pdAHVLPd&*=p z;q%qD;^(YH z^Y^lwrAH}`6m4Itd6QEkEU-l_yd`?2T9cLV@C1*n#caE@pG0Q$bM^fdO9f;alZf%U zG}D~UC0pHF8xF`1oH+Wir=lTw_-LoYyL(e&t0>j4Qxxf)R{ISbKw9J%-CSiQ3cWE9i)ub)Xd=#pRD zeHt zG%^e$Lk%*7BLhD&P=o`CAYuHj5DFw9GLAJ0DPbg#0coUyNG&FidH>{D+)loc`N>o= z{4N_PjC#p+G6n04Tgj#Hzw08?DA0e_k0Og{f6M)?hq71}^$MdNWCKL01Rw75;g@b7ZY#8~!iU#q2ifrRQ zh3H~vMx|}g09iR1NM3`M4x9!fBNG!dGl^f2hy}?|kSGMeoyG8*R^bHO@H=q*2_)z6 z&pCSF`?^L7OG$_uBCl@}iQm^X z2e2gPe^rRQzPSmJ*Eky?@;V1Y{DL+wU@e){#t>`E3t*f0rfmFV?YW zk6b77ka-1Atcxu2?`@0e#A5pvlNa+M-=Ym+SM>KOD2N=) z2wVD6R{M>L(9Tf^;wMD@CV>oNUj9a#q#qQ>F&^m=li+)ro9>YlFpy#R*x_Tm%l!`# z-WRjpFD$*`>b~9C>UBb1Wg69bK51jdBU)V6Ng8U)-rR_>(A;}d$F}oL#DPxDxmf!6 z*5oe=qmv^lvRf}RZ>EY#p$7QG?a%k4mj(y9HS zLrL3d&Ep>_)0<|k2%*>5b+`Z2`%M9t9)IH9q1>&O%gSOpMI*FgYT*Gvwfqaq-TQ|N zHth62EnXtR*!zv^@{3vd%oB(76|YkCzla9CeXG{nU8%h8XhB^@-^`88j+-*ss9V@I zYU|!>3m&-@+oUoi&o-`}TokCd=7GjCl?xWz7@iz7p=Q40wcm;8l|H$C zR`<@`D;Dy-(a*sU)wSgAg$Ht)&AmcCODtDPz)yoEsR^R$6};iTLz=emZ(}Sz&_51|C5# zz2VS2&#`ePd$!OAt2As@yc6>MPPcK}lit13>;ms%JI`qZir2YpKUQxn=k|ajzL1Tl z=GgeqRr3u$(mu;F31)1Y`?OI;U_HBpDxZU2B_BhE*!G7@xaK^5w zcRc-t@~J$jg^QHQKE@!`9o+p{4aK32A2U|(ame14 z9q$n`bN`;;1?Oi|C45g@#ga^mZ1yVJ?ALmbziLCrSi+jQ$0Fr?%ocI6NxRRUjGeo7 zJ7D9U8)3>{ePxHEcSn8T3|g|ES2|3Ity5^EHhG}`dTim&V`(8@b~yQn@-I}Kj=R3O za`^<)gC+|FIrBFLT@g}iiVseHn%FtMP_xeQgVe7>8%})e;@)C6{K$Ef+m1tLkV`}O z;m}9D@$9Tr9uxPT7L$hWI-hlF3yRz(1=LOU(uy=`C-@1zs@-}f)J@;$jp?4Cjh~YD zG;fv&w@o@7_9OLSZAH~eo>Ny2H@GsN579q!|B4k+X3KcffG_88-X3m(Em&+-xX#Y; zFP1DCpK}Bpy)?zHO!=(UJ{c80{eE|6kGiP4wQ~Onhr=HmGCrNr@=)}B9ui2Oo?!Zw z&+^ses8V#7V^)T1W+fd<^^a^Co8D*4fpY$v5<=GLRnhM2_*tJI$kx_#sHZ8+lEbfi z_dYG%eZza#J*|GFqT!wJRcfQ~!olfxA{snfHs(giBo2?v<($Uz;C|0<^jMO=onwUn zW8zuf_5{INA8HoH$N%~uLi1fd@kUnGxnLy^ye|~Nw{r5r08#)D@hRBP8 z3(z$v8X|pqDwF~J=jYK1r2TWg7(jd&dJBy~lMs2YbRMF>ztKai5Ie*J;a>%j|Mip* zhwvXH$$$Ao;2#eWc%UC)1erm$kR9X*{quh8al}tSXP|#RXFV11zt5KV=l8M|NdL?B z|MNQG9nvSD8R(yWm>IrU01|`9?=Q)K%ZbJ1fA-Tnl7B+8GH61N}Y5|&t zotlc4jhVtkL(jsSnN!&CWOV#cf|-dH4>YG^U}q+1Sg2_k=~=1R$bBaFk8GP1 zc93k_RdB{+v3aM1)ROVzXvnYh5G)YQn zG!>F$453VwRE7ve8IwlubzwipKHlfA_xS$&?&o(t_qnch?X~ZH@3q&yua)!Mqm}C@ zxuxAKiMn5FVv?q9*jtKa9Y>XlXEN2c^wA|0&sXlt`5bM~#w21h_+;AZV|1No(TUOF zzdePajz)izgeYvxEe(vSGz7nCr|Vt1dAiEu9R1wAZxt`Aj&ty~d?_Vrog{~!xE~2y zEADpdy;+RMy^^})PMlKt{XMH@1iV$NP6V^P_*`6)dYh6)NVR&^`tOIhV-`8a*$ydkvq zb=a>8M<%*ybz_(Fqov$EorZ}VXBmB}^9J{42XgY!{|We^*-^Af-QlN0KkrNXA9Ym< z6+YGC{33MHiM5*|756r?H=L^cY*MMQ`q#*_%?@J~CY4tAl5A2<_8CcsXsr>SzEU9= zGsik#;B6)Q#qIPEchY9t({NyZyO4F|x+J%> zOwYF=c@4n}kF1$Ob|^g#fBQ`L){S5v$0YZbMulzNN%|c!WxCZ)At|(v=4{ok9cxmU zqvX8Vq?GLasA{x(T<&sG747fPQ2OnnqroqaBwbILWOrza9q-U2e?H2C%Fix1{bgS_WD{kSPk)}a{%fSp zq>Oh=P~5nc#LE;jk5|oV23Dg|&l#O-U*0m;>3=j-F_N;c)UDwD>5*5B8yRTwvyV~8 z%=qbn=?%Bgho5f-xDv{XY+hMkk%_6;<>C@baqtp<^@dv~&A9YOx!=g{qR|(<(3x@J zsoc<`O$jtY@3*V?NS}Z0yXa+p-293F-Pe!(9fkqr_apjv`RsLRl6~)S33$19Sk&73 zua}|!qA5L|F;)1U=l)E$!|yY>*%tOMw|V@F&5EX}-%z(*Gibws*A(K@24NeleIB4c46bi_JDS#yuIn9|if0!lh(2EW%)WJqq2r@Yb_5piCdI@5aZ zli$DeSnmA@n#=Hz_IKu(3TJFCWx4PD)bzOECSqQZ?eO)ea%lYrQxt+mZE^pr<_tN2l z{XJK!u@L?ZCJ_r!?yEziXXosC(`OZO^;J`|Iy%=3l~&sP(i54|*SY_sy3V53!Ms>4 zb*o=jQC#ecudKbjDG80Cxie$@1827Q`lnqxxh2ytMs}iPUG=Bo_#LWWnC=^hO&-eF z#G5DbmBrdh(Eaq2-AQ9FUut63m(5) z3*`biWQ3=R;?DP5wA89Z1krex-BRq}p?&Kf8bu>m}~(Yi30M8NV#9dl;53 zPCu6K^yh%h?e?5wS5LT{v)wI}Ik4!~$yQI8UHft5-ASsEUIx7nXA&G^Dcd%uDIeZH zKYKay>BnssdnB9GpJ_#(_1(f*<+|Z>=*{FSK9#4WzyBKj!0Mmv$_1%*A6Y~0=@(Ad&d`$4%h~80#pJn z0!{(00q}b?9Dr*zT*nOn-T-O=8vt7X{{ZNN!vzQir~`0Kbp&Kop<~&<0Qem;n|6VSqHiK7cU56Tk` zz+ONIKm(8r=m6vaJ_4KpB>)k?C4dmX2+#=l1E2jsyN* z8zme7Ul)Ehuu(HLM?4Djk?r?jxyT->d}A^4VEK24EP_`Gs69Ym!D5 z`)*rMFq-YVUCcrKXLXju$H{hsln44&ze`Vv{}ZT4p}cs@fSS>cuf;vJVsvh6fCNuo z=9>xH8pf==bGIL9HXQsHYU%o8c1Ay{z|%gP>1$Hv1NOvSuB18;8rleUuk zL&5`+1(dRRDh@Wd6&v$A3TeWD#^o35Gw#ZukcF=)G)-;)oX@NKM3m322P1fdK z`m|22^oFb9!I8Cud%p)m152gdhkiTSKIsdGh0>3lDBuxDZ&dO;vv4BnGX?XUo$0n_ z?NX{@<0hutQ?r$y)$S%p25$T$(^EoW9+=G+A@|L#x9D9Pn|U)u)Kky$zq69eqhAd( z;%f7#OV#(ga+iL$8S*flsZo1=>K%;_XL{`PKlQN0-`zh(UpF87-Pr%fRiW?1_tIVi z>4{8_VM$&$`?7{f+xaqwly(Z+(`Jz^6*a7Oi=WID=u5}iAMW0@;Z4Gz&%rw{JT{89 z&B{Fc8Bd>Ws@vkpO5sH>JSLdicOa=Fc*p$gd>!Sly50zVn^z?*mh>4s6)bNGUxkz~ zGX38A*1q>m-|%B`1N&9a&ve-BVDe|HFJM%Wd_SrkDpTo1hX5KtsIFB+k<_WsS9NuR<7i-UR?%=bw zM9M0^fR}A0vz>c%^P(7^IXaJX^fGmH&{On>UpOwBu zviut>rN3qS^-pn%(S%f9bM$%5`aV|l^bwvzmLWbx;|}rG48{q9W_scG|NRMCd>H(c zQY_j2$lUGqg(mwbq!?s=eAm!XTbs{xa&y79>d{vof%IDaY+GqE^WW^^zxPULK6H5A zD=zwou=}qU?G9Bx5+yyUH_tB2v-(9|%E`H7vR%sSv*Wd|L4%PBcMo++d#c}JRf}K$ zZ-{6AxiWF#L$|(XO0>OxDzxY+YixIE;~5U4p;EBNr|qjd)@hi?R2 zXl4j;mp@4(!a69xsgMa}@+e z8WjJnVRlW9s{Y|ecL*-r?Ew598l-@A8_bIWKo0O3VrsAtzt7&nb~o@g;Ljir=MnEE zeS+8w#2&)-Yv@0~Hs1TOhJE$Gy#cxabJ%wZ`d&Z}J`dmlfEzFcaD~ToLQX31e8?Gq zUKzH1Al?BS|DNL(Y`a5$4feYN9$^pLiqP+cz5x2)kc;=(J_4d4e;vfFA&%qn1)PQ0 zHvoR0<9)Te5L-GQpvU9KLVp1I+kkz*aXoz*^&xRh?FVw(;f!~Jy6ZEN& zvl@CA*e4CKYtXyE_66X1urD9D9RQ!h1Ga}?KfZ_WAcpHZyw8dAzzet!z~>!+_$!Fx z`UY+IkG}w32*C4b0%9rK<8h^7A6~0=05l-hjE@6cf;e7_?4jQaJ-%OF04?BnKR6irZrH}_R4i}>h?xWM z{Bg!O^pg;uhJGX94IDcNdi-qW0FogGKc9Gg!_Rm(#0K!#(D%VMK3)-k=N~1;fj@vA zy#TgBYzOp@0M{Wl58M8*A3tmO`Tqtnye?}2@OsP*y)eWtLXV%-FyL<>t_|D@PSJ_BkX zkAQ7S;7$O%?%^1O062~=*j@vu0qDSXA>{A^kAuD!dOWWVLfi*>JTArqfvZE`34JjD zuOs;V77rYs=N#lEz%~=~G=Ol3;XXVs+#rtUR~5vuhFySo7VtvgH2^#Z@bk<7@fO%t z0$hR^zW?| zYis8Vq4y=R%7ulA8s*ngRy}P+W*zOAQ!L48iEFZi>7}F$tynB(o~g|#vFK`FjhDDS-K@Dl!OYCm^>Xd| z_NFyGVyk4NTudb00yb|95u;ltF2*V^J6)qV6=103XJ|;N-(J7E+rWTAzq*>JK5V4y z=W4pnEhky_Zfw%3#MwsmxvMF1ccY?+C{EV30=3T>n}nHUWphui&sU&UQR%GZXs24W zivHt^4HJXS(qmgK1s&7kR-a*`U$bVaNn>HVDUWULsSS7Gt{r_%15G_A6(?Iw8*^*S zaoV_|6Po3-FZKTTTk0IGsiCM=q)=3tZcv?zImwvlvU$B{QM6)VM-6+sFd;15)yUIL z2_H03N>O2gnwr|lOv=;WK+%tij*hykg})~~MetJk3EnJc0}-d63g}*J8zTt|iIjw^y^ZM@LgcQL(Zz8JW@2HE118_Qj+Hh5*EuD!HvGoQmut=~rI^`(?a|Sa% zGmVhyR;E^V8m`r|Em{kH`U-yjn^Xf2Tk9QFq)}A?aRnO{6&2xREbiuPDd$!DjJDp- zSS7HdfvdYPPUXSJ=j+EP7#QdSOw7^P4+ z*dQ^iZ$@wCZ>|}Vk-&3is#W_B2aAwEOblg|2!)7nR5DXC=PLd++pX6+9yV1Ev@u?7 zTO6ZQ$j&S%AVMP{Ze-1B0UtfW(1g}_uuX2l#%ztlHbV}Zp%$6304v?2ozMAtYML3E zrrUJ>C=dz?>G51=oHt3hDKKek7av!9FierGb5HWO_@$zWvFr8urRf_cut)7^}3c-P1}t)Z73NT>0=Y<;yRjn zd-N@sEMjA+qGD57lWSkFv?{OC(lFf2XjYP-{s1lo|7ql2MHqz3!+#q2J}j%iICBl| zgv$s)4WI$g0`UG1-e+V0Faq!%7T!-|1+W7+0XzVH0N&>l1IPgII~%{}i~!pKu7JaU zSim(v9bgDRNj_lMc0C##K6A*oL4jhw%)d8xf}Y1TAN#e_bn0GrZo#GN0o7%HGbGjY zezdCOeVX>~QRJd-6sucvmgWK-N7Tphb;U;*VrBXGeRkz+(|TPZJtQBuy@U8F{HJL5 z!Imn`%@z(X+b3`THnLQX-}I9*(nkAA{?=>ysi!Y%e6K9+6=7SP?QCP>oY;5Hn5X_` zgpS)D-osAO*6&5vrzM(vD_`BWcNLf%Ze%p46?d%dy6cjjIUG9Lr0$*a%IcPv{oEJ# zu>15CArcz|ZajE4_91ZXmM2Lk{d6CCm{HBMIIHe>bi76|dvGC({lME(XD$jQe12gk z)t`Lz1oP7oLr;VAa;$~6kGVzfOT9tudYk*C80y#MwJax4!(RFBL^SHyH6EJHqL!Vv zou(A^>=&(h3$BBveND7?FY4M2DXFfZw!O;NZxia#|YYo)DKYW#(gc^AFOLv1&2Y-Z8W+!Ul zV~20}pdP;ax4{$C#6R559*es8JN+KtP#e#t^gs^v@p>Y^vrr>H%raSpI{Dhvd>z!v zOWb74K)t+g4AlT?=KXwF7*RL>N50bpweynAl8&gK|GK_@7i#GHOENE`j=s;eAPKef z`NhH7sHY#f|J4*V^;)Vit5H|)Mm24L+Ik8F!%EcGr=MGBM~%Hgl`Spm?AL6Ye2rRr zwp;FYsJCA)?7ssw_vIarl~8xz)ZST++WYNy47Q^F{`~lLOuTBA=hBk@nPUeN5_JWIq zI{??j*wUYH4y@-ZmrDKd8#dkBnaeZiQv0gP!Cz?hZ- zjA{3SF|7<3)BXcv+BaZKdk2hZgTR>fIT+K%fH7?|7}FjDW7=O}OuG||X-&bHb_$GX z?}0IGHyG3Af-!9Y7}H(?W7_LrOd9~kwAEltTL#9of5DhG1B_`U!I)MJjA`}2nDz%4 z)3$;!tqK^^=7BNoCora+24h-(FsAJRV_HQprsV=-T52$+Z3JUlF)??OIxwbP1IDyx z!I+i?jA<``F)bbZ;Rpv9(?)?Y?ME=C9S39Dbzn?e492uaz?hZ+jA>)Rm{t~yY5BmI zmLH61eZZJ@7Z}s#fHCbhFs9W4W7^kXOj`oRw9;TqI|RnG@?cCG2gbD9!I-uKjA`+` z_zK3f!op7af54cw2#jfWgE8$vFs5w*W7;Y(rqu*v+Rb20YXQcz4q#0C5{zlv!I*Xu zjA?I!G3{?KrZoa%T1zmdRR&|)crd2j1je*K!I+j3jAWotZ3Gz8>VPq=8yM5> z0b^QTFs3~W#oKm^K}ZX*0o?b{LFlL&2DK6pU$`z?fDYjA^~Wm^KBBXefFsA(i#P1HyG3Y_buE1V`OE0 zK>l}i_*uBMzhsR1@3o){r=voKKXhm?KU2+G^JBux=!m-HFU~V&Gwn$Vakl+pyt{RF z&fd?Baixge@OJCPqc_I$s<@ekoU4;Jem^WLvFfqai9_2DKA0XHd9vx_T&YKECY61+ zfY6)Yb*CPFe)+WGOR#2vaS1KoKQADcc;_sVw*P5CnV@Bb-Xf6gW{ z)wPF}@V%^NxOs2Qz>(Q!bML}`H*M}3Ikf56*p}ByJ%82xrw0{S7x)u?(dzB3xWD@( zQF+*peR!+1Q-Tou%r>ML0l za8qEiW4msuvgE#rp!Md_iQh!(`NrQiXr6DorsM(o2{E4iO$)-&#>LL41We43zuw`32&5@v|W1wXOvoLTGgFmFh73uQ5FuYfS_g$B^;s3k= zc<%}CiSK3l{NrfRZOVy!qmNWu4DWXRdBr@myDea21#U|L(aE-l#cRi zzIymbUF`bPhm_ok{2bD$zv(8Lj7(7Z(+u7H;<)`9efa@{hNJa;De1PO7EE)@@B8O+ z8Glt--dy8b#&+;d$1btb)@O?!<#&iU2XG3VzRc^JY{vJTj_95H*}SFEVB6UI$al$7 z)16=5g{H-yPR?#_h+kv9<+$%Hp`cT5j@3NemTahYs>W48eVyma13nE8F6uPXm40~` z#1h03bIkC4tXTwWc}`X zwCGO%D_>b(9Qd`L_uVGT=mb%m)`Gou&RfJeW_aGk@m>uIgdY;>Sn{hbBrYiFN#YHQObXw8+e3_|9D)sYle)mN8I^k4po*SFaCF{v}GsD8si-GhIoil4XXojJsJ&PmFIdWhqr zPoK_xcb${O zrj<3ZDp~)w)Bk9qa$opYUClM_KHh<$(#rmOGxILpB$!qeF`EX2`OF}Av-){?*;h|nxZ-$oW8g-pQUx7xC7$f>YyW*|mjZum+ zl}XiS<;zd^SIjEisBZFfw5QP#INnNamwKpp->2(O?>u->QNoxMXP~sl`1avkm6GV5 zUHMaIZ&Z4{l6vSqF)zM(+g#d)t%FRvx@he#zqxD`dhW%uUo!pJbUnZK_G79Unn{bLg0+148c(^Mj!plrH~l`eKj_14R-v=wNf|DS zm0``HHK}LrrQBrx#4cTywKg@Kk7M2aQ^U^mS@DYZez;hUe{r1LbZva%McmoSy~QuS zi@5wKWBRB(Kb#SBhqhn#+I87)d9uR0vWikqwwlJRdU$*EvIPb~pzqGhDy@$D}Kd;K{ZIW)p54|Tl zx^nV1%?GZP*wB$1lM}snTlQZM^DxiI7imlz8nn(;R8@}E?h9o2R0-c*uSq{=iw*gi-mm8W(mc*jau4>T>VZy45LaW1l2C6-^2n{ld?=TffolD?YJs-l${H z_NjuN*g5SRZ@Z41y^#M?W!Box&oU*A8 zU%unesw(GQyWUP-n3*~7nd6E4*pr1A`kb#_!8ioApY&PTg4GQPJNmvRis5LwP`avesnprJs8q{aIK|n@lm= zwvn&x?rMIy!;gs>|L!>M-my#;_G>leF?>&j0~n21MEW(E86wIq?`_w<@?>tW@%0@M zz4O+W7xKDe2b~0aO;4TYiK|N}KE9@epX0smzsVM+tXA!RjZ}Xxu1S07JN$l!#RZeU zO6u%?j7G2eKnm?$;-Fno#c! zIWQ>RU=beA`COGEvPUHEWH=|Q{^J)_XXzX~WHzkpE3B0;kmOJ+{w;Lx31u+N=Pe6& zPd%>a4u8h)rm5(VE8t0JIs0gBC-$wA?|!It{)iIlJh`)e-MKgW826v0 zKbg~VYn;I-b#u#AH9yuZ_65;TF7Srjyzr=c+vg^|CZQ{tkD@n+2HV&qPieT)q!v8i z7_vXi#YXP|U2yBfck?^Oo3p-!mcps4mCUyKWk+}QrJSZi!mFxjjZetEX|hec8Y63@ z?O5V5w0}ljhRykd*dxJpaXq2y?${Sda4i-N##Y@jj}Ym0Kl;0S)XaNy;N78Yp0}G4 zV*2S-o^1bc;ouihMqyEVfz>`k-)zc~`S(Ocs*gEb$!q*npj}&Jeeitb$M&fsbia=s z@8Ua==+k$2q+PO+J>Ql$_EI ziV+Aicewpsc{JN;q?Y8>0mdvQI+51&ItO_^6Ziaky zN~jsf`&qnzt$=C3RahrbK#+n1{w)hUlF2n5u$yoK;A4oDbtv8ov%zg>$k_n4D;)1{ z;lE{IKHdw%hBn zVM8vk#Fpnj3pltu2G*e*59k0IlRD;)EO0i^NcoMOZLT}y14^Q~~qKLa4mzY$qZ z7#ZKV!ZE)afOCPz<^*8F;~!jN%Y6L`$NUFmaq`dmNwWB6viv#Vr19hZcx-rl`z5x_ zxq(*$FpiBh|H{joOYtBwuC~H)JgorI{4ZBe%g6B`%aJI0UJJ6cZn^Z&+mbg<{$t40UPG{EU{(2VTI%I zE6L(4Wc(Bvw_4$t{|Dd%SUPveuKze^*zmd70i^3sEO63z$gltY5XXl3ic4&H{I$SI z^Fw|pcx1oj>H)|4>YT zhU3v(V$1oRz;P~cesCVJVa|aiw#=nhI3B;4ERNgQF#p67Tju5~9QV%vNaLp_%fb1^ zhL7a}U=DKpw`QjQC(uo<9`mEG=B2yzxzrK=1Y*}-zJNbe;(t>;+x3w zzW^tVACH9%d;EJNY{&(d*z$NT04JUQ_&Ts*4*vZRHstvC3fORddI8%2IRE6=f4tv; z4fExe*m8cw3dcD4>rEkxTaxAf0!|t~6b!I694(5xK<=-NUlaD8kEN)De{~0)G{CF&E z*gGzwZxXW>%oicczeW~c8P3u%qsih1 zWcfqDNyjIDzjl)4^OEIf04JS4&QV331Z-kLNS)!}CE5fDOlgc!@1@ zF$pZxmoN|sML4(8t^i&K&DSTb(3!ZCjoKpH=e2^)@Q_Yzy?{3{&u&jCpD zPdX0fhp*%y*IMD2{{}#sf1C$wm~&`}EpwR_j`?L|aq`!jL>Avdmj44dY5e5p+YYjP z9^lmgd|qs%`6taY#)FskEa#}Na2(G|0BQcoumAhW^4F2&7m&rt=QDvUZc3Iv37j;3 zd_HVAo_$MfnUk)Qxc>@(H2MgHzv?P6ViMZ~Fk?{!I91Cyb@2_XQ`tO)a zes9dVUz4n?mJy+6<18H9HKBg^a^X+tFVhzg`I*g^7p}gVXgVoGO{LGy&^f&G$t(Mgp;tj;*811d z<@?6M?QRZ#Atq`+G2M9lz;f}4{pj5T${$nYdG+2S zE%82-)pS+Cc1pDqb9yJ_nxF2L(3)s3F<17)l8CBHJTk9c^kUxll{2GLCVDl zqiqj@QswiaelicW1s)%#?)^$#b&IEeZjJ2a$iT7(Ki1z7wyc{xdWd0zZLR^2YEJ2= zc|#o$$)f_Ytlw*$fA(&3Ur?;=Jiy8+ksHa~(=@Y&`o>v4;*KO2vxuXj>qG$K-oO7U z%-_<7t~vgMIpwAwyCRd@Mcp@Sx~-*M&tE0h-Deu4Q24QUGQjKV$1naqvlrINceK3Z ziR-I5R7H2U=c;jwJ?q7!x1Zq4epPZ)wC|2ja6(d+p*q z@dnoOa}BrI&t--S5}l);V&)HLv7J?LCPXsj>J~+=-s6f(la4(1IPzUdcES3u&C>4I zKRU|JD%>2?yWO5%?RaujHoNWdH|F&1wa*Xfw;$@Oa-0%L z7&?-)mA0W|vM#T@v-Dd}aFy66=}la<{gVgee}|0}6xaLB?H(VP4a#bL&15pHsS)41 zRz5a?cmHAH`GRr!t!(K-(wVjL=69+*P9N~u|FHK%*F|}nh<*V-iFe<&?&Tj5-#+g( z^yeUTD>s#{i1G3Eo$t%mO1p;|{e9gUsu^Q2-zJk`S+}D!rnBFQN%~XRq3w^f{|O7l zN7yN66;4fX29zvz)ilKGbw*4wlGa(IdV{o0`uq9+?Ki#~5=fqJcq!?iTGnErRtcME zHT>HkKm;HJ5C#YW+F*h667Y(&(4nGXWmmRab^k@v!275*MGpTEDDKw z-2SBEIIO;NT=HPmTfekBBZ}Lgq-hXRA%kquOjcNKdQXz@4 z*^k-}J$WA)omKL}{9Vw6hxI#tvMJb1trA>!;PGqcYyWsCtUzDW2MH5oP7{#h&Hnm0$sz%LhkzOcpQ`KFhf`$ChBr{@pp8a~@P%fg|y>zj0V zN^5tqkX%Ism;0u|;}h=Om@IYB`LBl@=eqZ6Oa{)m1UppYyga+6wq~P5)Z= ziA_+>v#&PMzVL6&NJ$ht2ER+OPV@rw0PX;AU3dY2-=|o=RRZuk`WfIH0LOX|&<$8> zetv#LOiTT2TCr%%N2@Gub{A5ZMqv4c=mRVBWB`GQ&_ z;{N^ngn@wpAtok9OioS`hYlSgGBPrVO`A3m;4)0)<>e6~A|mj|&|eAgLME)OtqChD zD*}EWnQ(V^Cr+O}O+0z>ggAcuI8k0+P81Xr5UHuD#L=TiiShAq0)D5Pc=6%|p{uJ4 zQXK{2{rmUCzJ2?My?gf(4Gj$h{O&aY=Ee8}1;pUsAfc(LNj!i4oOt!>6=7;>O6=LQ zhtSc{A>O`yOP~;G*REZ}>({S|ty{Me_V)IKmzNh|X=zC$B_$Ey*GycvaDnjf@F0Hw z{!O&Dwi1Pfg@l}(91$28NPuNCAtNJ02n!1nQ&Uq!QBe^Q7Z*pIKYyO+@9!rpEG&qY zmKLJ6ww6#)Q6VBCB8Z@%AcBU5hVb_GCd$gnh+DUA5sHe6L`O#l0p`u9B_rOvc|(Bt zGvVOiKy2K&k#Kf)Ci?pN2ryk<`Z;v?EowqZNr?a-Y2wnQO9Yre6Wh0MC&1;In3t3WA$ogz3HTjzLQhYR`0(Kaapue!A|WAxaCCGeVq;@L&`L?PwY3qOH*Y4= z($WZJWo6><;lsrK{ride`FUb?c9yt&`7#k18A&{S`jq(i@guQq+cx6j#fwBwPY)p} zDM>UnH4*CS>cq2W&j>9oEh0KPnmBv*EaB_xOKjP)g#h1eqN=KjaCLPhHf-2HeE$5I z2n`J-Zr;2}Bqt{mSFT(ke0+R}%F0UO)TvX1w6rww{rh*~=g*%+X=y1TFE3C0{ri`A z@ZbTlbLUPXBqW5$%E}_(_u7er2M-dXqoah0i3#EF?@v@zR1n?W-GqdM1aari9m3Gi zkVs5SByw|eiIkKS0#p)2KtKQizw=H!di02}v$G=>78Zza-@Xxd@7^Wgx84agH8sNA z+?-gyem&vo=}Bm7YZDq88U*}yJ#qc|bwXcXpOBK0BD%V|i16@m;_>6hM00a9VPs@P z)YQ}vU?xrs4Gj_Z?%gBi=H`gt;9#P$v5|<1iXyVJvmeX4L_WOT%^dx&IHo1%D*YON z`!RD$w)#HRyoo4|@&mo{M_O|k)To^0{tkSgF-p7FG+40XqD9Zv`!?~~jKi~+B*nHj z$DT7OI`5_!{7Ue3$dkQ=Cq*?DJZ085bp5FG?Wg{fsVi~(#;Vk5ah5mwB`+grxh_}= zTzjW<+JSxD+|G8ZgFL(MF49%IhyH173o_g@x=|%eL5lS-#m|mT-p}cec6~MQeo&YF z)b-a|Whc`UQ)l`1W$37Hd7EFuKd+fo#w7eA(Wf-3oAP(7Y{GL0J8%3$3Kf79zW?FznK~3rdqaeBAB0}W`y7tXL&d#OH=sr7CXCq z<|oGUqZ5H0$1?;n4A-+q4+U+Ulq>r4;e&cn--SNeIwnSGKi(>RhMYLojpC1As&_n? z3blIh_iHxwo~vA|JQbPEcJ)0@GW>ekLvd`PaWpekkDs?cfLS@}$W}wTGr!u7Il6jR z-EkAqzs=Z9QS!WFl=8mdj_tWIieVEU@;UY>-~KyheFy$pl-HlC^$8f;@h2qA&3Mo8^BJ#_oTylYz2^75 z*Stoo+A~w&dSB^vQUp^no1eK&*JJAbEa~-gOj+r3-WRujh{!gJPp74eXmQvu8K_mX zD8H?h-n6rAU4+1Hk@4#vJEyfZ!XEIh39>fSbc$CU?c=#TqB_1Ve7>N${CkC3+x~in zBDNDX;ZFqz7x>y}>7V)e+bZvcUk>T(rfq-bCi|?qvV^%^MXo3jn$Ey>diA%ys&xgQ?G3JP&N<)oLwlrR;EUvscr@5ZF9LV~~6%b8L`H>E4B*ST7#H}Msw z92=hg#J@T2eg9~MUvG;c;as(HqGJts?MnUTP;Z}Lw#)kJfj(|(Z2 z=vO}xBVJ!OK6|%po@>X45S2+^=lwIoEoL=)qqn8qVKvz6E`IXC^~l~0!}{T4aXF_x z4}L!3@F%Tna(5TqhcotO?}|UY(V(CR*iqTXa+p)mZMStq`k4xOZJQVlU$@PjVn;I1 z1`ni$)%+9@*&TMaJfXvKqoi~{)7FYBN9Uryy0YJM-x>bJCxGBPt)R~y?A=Q^e_+~7 zWwQ2OVgGI?x4N&{`6J_^Cp$-9Rz!8h3B^~vAM-5+251Cpuev9fWdDAe5s7q1+1)%GrZZZWM%a4?!qr2|~FE5Xz;3P;M;<3~qq z0)%p2Ae4&$q1<;6%Ef|E&J%=kTl4bfIzTA*6NGXfK`3_zgmNw*lv@u%IeHMvWr9%7 z1cY*zK`5sHLOFF1$}xgaP9B7EEFhE<2caB42<7@gDAxu;IV%v#MS@W73kc;nKqw~& zLOBNz%Bg@*P7Q=|??EW{0EBY8K`3_}gmOV3lq&qd^cL9WQ9w3xs2cg_a5XyZ9p&T^`<^F+CE(e5iAt02K0HNF# z5X$9(P;L(h<)T0+M*~7RJrK%?fKbj4gmTj$lye24Trddb3P31l2tqkw5XyZ5q1;~( z$~^_4Tr>#f)__n>5`=PfAe5^Dp`0oR5XyytP_7Ataupzy zQv#vf2ngk>K`6%yLb+@Z%3TAYoG}RHY(Xfe1wy%1Ae2i6pAKq$8pgmMfZl;Z=ToI42R-hfap4uo>;Ae4&% zp`0`b<#vHkP6&i@;UJXD2ceud2<2o!D2K~mT-M`~9ZL&bnqpal%S=2m+M%LV3~zWLo6Av6u~kJm&dro$E7JQ4{^zi%YImzEiL)6EWok`myo!;!%_v8 zmRJg5iG<5VEF-W?!lf~mPq@U#e1aT$vx4wepBnqbL;B?2xxaXF96Qe5WZQWZ-E zEdOvBj>}tIGU8Gdm!i15#u5oj7c9H56vQ$Km-<)+Vd;V;7M2-Ua$t$24@*-l&2XuW z%YIzW%UD`qS&2(pEJv{P#N{rQ2)Id? zMJ$7H>5rujmPoin#}WxkUtGT9G8;<@EP=2zz!D3~1YD+L$%spEESIn>!IBtDNGz|g zVTpsKDwfY!R%4ln%XKUzunfX74ogogCvjPir3jXSST1A9fF&fBK3GO!sg30;mRVRf zW7&si)Aa8h*<7mIf5lCmTFk`Vi}5M6P8q17GgPtWg3+#kCmaSOUVtIzQ zIIsl5G78HcEPJus!;%uqA-rvYw;`|u#WD-aBP@BbG{jO2Z%g1U1iYO9^#MJbuznQ3 znpe*q%M0>*D_x(RQ$5&Sa_rY+LpuCB4b%}k06SOeiNaFvcgz2s7B^q{50?`Ae5V)p zz;7^+?oa-2we3|p_;*ssOM>JKz-4?8G&^l2$#^H0-QRce|GHIU!uKoH;^@^)A8);} zlYX~z>vQ+o0@W8mjPGbR>9F65X#5h*%y_r-noLYrVox-tZAVc_;T@)pkSNhB5Ri6zniw@g;%zu z_#Zsj9iIF*Pqa0kwL|gAuuNv$>Mm0a@s@q(et~n6iG$GB<7U*W%7jASwMj)99RB`s zRbg%LLX^m+v`j~0+;4XA!=bS2uiw7b$hLVwc{9?DU>zT)^>qq*N!u#OxOhA_Y3A*) zOYNHGJqo*eZ1;&OB?#^|{r9ldll!5yoN$HAo41cbZ{!)tr85h}Z6CYN@zm^ggjTD7Sa2a@y0d)!u6K`}5ANrRpZcx4HRILi*z7F#6Bg?_4wfR)6k%`*|K=^Y9BX2F49# zbg^2JH@pu1oy(Lz^6449tUgb`>2Gf{Z`zifT(5H`K;G_$;dOeB5MC=~McH(hZ(ok4 z+_GjU+2bL9yv}a6X!{->Hrgla^bGXNz5bc({KeFNT75t-b#M6wbz=18n!(C@qtaD3 zKPblaIes(#q?<5pz|S9Ya&)RQC&Z#TPl~QISZafTrtFR8g4w;2R~u+04l)JTR&u-; zeE-V3bffz2{hQm*+m3K|K8;q{mU`^OEZ4*zH(%B!&fQ7QRg-~&y6aY##k{}EbD5WF z;HmzH1?Pd$9j8C5-`*8WeZXbgub=ihCL8A;C%O6L8gc1SOl37?CtQhuUo#4(;JUuf zqSZ`U@VTtK5kF^+@0HZGf_<+)+%(Oh^l)k{7HD<5qu$xo@kb)yRK~@iIo4BtR8|vm zHB>sizl;A}NHqG^`C`?5BkSMeVkcTey)}PmQ!uL?5FP05q*U7*ZxOP#y@E!A&gA$;w8TA1wLF>_mXe$^pDKIGdG-^tK9ms{K?1iE+S zv2XAG7njy4Ju^ZSa);MW8wOU3Wd#PUm2ui0SbJ?EXv>py?nkb3S;+@S?oDeqSFS!6 zyUANuBtDVd)NOYE|H=>-m;-OUh;I{N|3IIotFG($%6)B@CMQ^z60qZ$Hn%=daC{VZ~JJ zPQPn|=hX1pKfmoS_U~mI+LQ7nY)zM@1}{I_AhzkH@|Wrfk*kd~Yqq_) zzBAzHef#n6XEoj*NiEVzb-jHm>hqlxRn04R16Eb1|LQ9{EobiX*TC-3Zp#fn$NHXm zM|`QOzq3P6^+lR}@9P6Q4#%z5G`z7{jPWw_f>e~v&v~wylCWIfp>j(;m96ZT?kUnZ zOor!)Y6mMHKTF4F-?&Mw>auutFXvBBiyI*q<=lHGRqC`NZ>_VK<2f`U%;6HW>R8)_ z6Gp*jWA=X?c)t7F?4QskLhZ;E{ZjAK4>d2e( ziyptV{(cZYDjYEWapGfF>HOwC`Y(-Dmgg_kCtWB!_vx;A#W}i{9;V49N7f&0IGn-H z=^&Kh{6aRSh)JM=;gQ{u%bo1UGCmYUatxpLes)i*SGsZneuU#yO|JOA`4~&i1_$eP zF8|ZscSkkxb!(?Ws7WY_q7VcG8&d2w0fHbZK|u6pqbaB;h}c``sEDZ88%@Ou3Rpp! z1rZelJ1TapprW9N+~>@U@6Y%B-h03Gt^3Ef?pk+T+b1Vy&g|KlOwN9i!?P#5KOfSi zd&D)iRhjCWYpb8@c2fJ$a@C1d_WhoVt$%C$^AEdjD))X07Vq?kFz`0JJ*W8#*FCd& z)bX#cPV3*?y{hK%<+~3%pSR@5ro43AG4A0s^O{kotbZOp(<@#)wWmpSkMrx)zUFM@ zywQ7`x8X0&BX5)B<$-xelhTV`Pi$q6E{GZvSiNTG*)Oh7GWzW8;d~^)*68BT@x3RW z+nVr&dvfZ%)ddAr}4@RwB_SO2@^ktWpzJ9m#g=0|O zoBUe7Fn2-vGi~qqc}qIqP5D+|aQ)owxW4HD#rajUx2?N7bL+HcCP#*qzI=JuUzC)z zewMRij=}cxYmG)6j|+I7TRU`(&G&+=PPflbuT7Erm(NJv)%}-c?0fg!BYoIYjZV8L zQdOic#-6ygsQG1RaN&nuUJaiObY$rR{t6YSYF=~n+3vPbZ|rMr%S>&D`xCCuP)zr@ zyV1OOYlC{&CsW%pl zO>$R~qZIy`pAgr?$Yuyv<}eH55*yLAB^ryVFtQO{Oc~6ToDR09*zX;zjoH7-Z5Vr# z>EFkr_rl)>p=QRv{$@+g0SOofIVu;qFSUV-{nLir`M=zdH~+Ub@R0wn+abKJ$6z_k z>q}laqVX-l%04};vXio8EK=E9ffYlZWW^T}S00bjm?auaO zLt&W5#_P!EiFjh39#5Yq<;i%CJULInbLV;Tyl`kXpNCgi#254R`1*V)U&eRj%lQhv zJKvM<1;=a=Ps9gh5{vXi`XZ@FCUO+XMGBF-$W!En(_)KxV!l{}L|#vGSnP`eJ=OkRz$S zOy5youCLH{*Z0)-LcnY(Ps*2yq++R_R3DU6CUum`r3$IL)Klt(mxC?i$@nsnOf1ur z>C2=bZjLg!Od)fZdCI)-VzHsD$#)bviXHVF^&O>-GSEc1qr%bM(bLfjFC|;flk?>w zxmd0z*OyD>GPxsu<5bAq<(_gcywGd~Pr+A+6k>&*LSG?O$P|tWIVgs^!c*ae%fNQ$ zx%1sc?qYX6cYSxMyUg9uUGA;`x%71R!bM_x@;v#TB2TfWo~OR2)Kli^=qdM9c)Eka zc;OPVy?9=HFOiqnOV3N+OX?-_a`cjWDZJdhJV8cH`+wTGWNd!-XAG(^HxQ2_6xa@Ew?eEi@cWNB!tX>j;LD9&nWs;Kk0 z07zjR4_7q``bt{8Rh)=MA+pv+wWc$hd#^ zSwTK8es5%7P^y3EB8u^ttOe`{BWpWJKk-X$EAr7q*71@3$@(%a7}=k!!8L)|z+^CA zSOlyXMq-J8v2hSK4#LJk*ti&YC0J}M;%DQtmu&!(z^q|Xm=Cxe_9t4osW7tjuyVMX zc5elH_yEt;_l+vLeh2wqimoh3*uJ^f{roYJ!KRe$IKeJDm4Pz9)22!2CE#?Bts>UiHc382XqWJDz>^ zTNfwaS^cD|gkGc4O&_^u4Jn=S{l>XVZ@c&Q(3%%x8Ld|R?$cBi^10fO5mM0-s&lvkHcOSS#uu=))VVy4 zwop@5g{7vUs)eOM0=(IIDw=plb5%4|*?ggv0LRg0aWyz7?#DuPKrOC{fUkxEf?66p zHW#-FOI=%4MZnQy3sLDnRh_5C;ligtlO-^akn{NcKKfU_PTo7lFmqTBST7jahz9c& z*fl1OOo*RGN5t@JAf{Uhab8b|mv(`0=}`#YnnApD3IuGW5JokCfNd9uo+=<7`x64F zWe~pgf$*y(1b6Y_#FI!^lHCxUts`Qq5c@5I5Ud`=dov)wn*gCv@&(Qk2*;j*kf{iw zx0MjeeGie`Pzb#yKtOdEgnTn0_-hS8(^`nsHbKBQ90ITJAwHW7K~z*$)bNCO?i2{m zPK3~KJ_KFK9AXBc(=HGZ4uw$fb_f9DD>6|9gk&2bFnbSTr@bN0`vQWfp%C{~LiBVy zL|rQ(q8l9$~#1PJB|@a=|tbmB!Lew=MqP*`Rn%oE>-HQ+uj*f~`)q{ZTPYB=!KrFWw;?2Dw z!0QZgWdjKM@*uh_foN?I1e*i=oVt@QRhu9(oCGo6cnA$^;v2ARh&``>Fl{9SftNre z*%4yE$q@d10U=y7h|ZGls*XYgxfX)TL;x6HV_Nrv@a$0t8~1~dvmQizB@iYa1TpC* zh&E?H_!)B>e+-0Yl@J)NhcI%qGMbkRG2MO;_br1+Z3TpAhe7Z*6e7kV%*_`eE*%dM z-f)Njw?Gj19z=3mAfTKKG3AL6GFC!-_acO$e?lEXaz*8Yaoz( z27=X^5Hn7IIJDH>o+E)saT3I*gCQ<`4bbERC z?xmjBl->I~ZpiaXcX@o`uR!y2hTG+DwVzJ?Rm3UnyHF=$Ok?_br)`(#RDXZX-7tNN z{-)jU3g<3+ux0$DJ~bDjswak<^l+)0<(PQ2Z1%#EHA|Wjm(JNSal|8wv-3|~c2*Z)xs6{`Kc|kH_3ZkL2TiwC_!o?;`uVNBc;MHbepVhSXpp%=q?hutwDT!&09Hm1*<$xfje6eIH@6cKFsuD#ss<;5&_dRgkyQb3K3l#i=1Y zm6~=Rg}zy*?XBDH6uhZeBXw9DczY87`->k3~UTuk{ z{ip8vSxQCs?IpMA~j?)g)~zFu;iIkey8)>Vtv zIrON#W_mg3)Q6w`XI^|NziU$~viFaX>Tc^MiM}je88h0f<<|M(;^W_K=U(ZN>e_X0 z-!HW%t>0_Kj;~x?{5-f@XWHAT?1cUce#C`awQ9)z$_eZ`e$&HS zc5g%zbm!g~m9X=!@3MiZnu(KI^wzx79rp3YA&dT}eXo9a+U4c2Wus0^+I{QENUzTe zmKx~YC|q!5;9HO8>yxLq9oBm?JS29B9SfH7+`(Eygq<{& zPGU9o5Zj*JI_s!&hT8Qq9WlVFyHN*imErySn0M9J;t%WB+pLS8CeKh;gDb(x z*$!yfR2|KGvi)ILTi?@9I#+(kdU|H-s_wJpNh{9nSl#>6s2!mQ4A13xlm03heA{}ruFvP5 zrrA}O8e@Dc4VKEv8wNc*lU=(sQQKgM&pPeB!6VihWfw2jziZ)YQ}Cc~))Jp7K3-qU zyZL=y zzS$UrcNj6{hSBD@U3Ta0WKFqg798PWyKHgn7R&9<8-`|`b)92aUwCn|iRH`+wR^rB z51F+399`jTt9*~2g`*ozER1=>G3{O(Z#d&!#E3PfmyT|&{t_}*IM}`^D$-HIiYJNA z7~NPlYuYa3z4k$uO?C#q`R2P@Gq5qf`pB&m_t`;xJ?~i_6mCtob3YQS(J=4D&}F)c z#-Zo7_iSC&b;hUEMeMA>BPNy4jMsLE>=gSkA$MPhymWu`$_vxh4ZXK8q;7$vIA)(? zXX%02#S{DvSC3O!JaRzTlV66zIlJu5?p6+T)={slek**qtLT%<)i4j$<%T-lE`Oq;-PZiV!Z#$<_#5?77sQ9AKK55C`DbxJTW_QX8X${Kr2p;k7>i}fx?c|?U;!L%%1b5?eFSAnbEDh@|{bjx{up-^KwdKwJ#FlQh51({cI81+zZ(Es>qVJLM{9`}z zhTHnYnYKAExABO4!Wwbjd&=IFgphKp32~ht&g%H&Tc-W(()LxBmu&-&F7R?o$hMd~ zt88NV`KjscPgBH=XSNUjAvzOf(iWWebM)lusy<6!cn=S+Njmqx9mlxfG@x|D7R+W6^a)v@Bt9D{Cs`!4RN zec@N1g>O@hIqQTKDKG28L-Ou?Icl)u*_s=5Zkf5K>vY>9hF)B8Kl9kFnQ7BI@E31U z>Mf|)yjZWZ$qdP{SFu0x7Js$(ymGVuo>tAQ>+e$5j96Z6D7)jb%IJ6>ZFAPNocWUT zte|dLb!WVH4G1tZI;+;$b)&!6;R8=5t#K$`vfAUX`)QL`N-mv!$yvnh9(CyE7QdiQ zWn$Ur1>?&5jLI2(NN@Rgmb;;T509NAy@hvPT;7$xD8r{0EBsYNUdTCt@f$<$Iq$cA z*1xaS(_{u@r@xN`1x+<|6|R7T8g^13ZvV2(zt8asioaAQP z!re^tr19$tyZ+oVHfv+v*6K%1q4K^dGvBM_7shNW;8xB(x|$br%_hg<-B#J)Hm_Hs z%pdGjFF#_wL}A&~gXi%ewzqog+*5D-^lF1xvz+f{6ln*2T%T%@_G_eD!m+q|mAZty zQ+Jw{tuVTA`2F;O)jQIc+_3LCN7{eyFUi@MFZYk!9sF_KIGv%*KdyG2U@+I!W@dW# zliQxZ4gWE3h^@oqN6oKgL9LP{<>S7pw{FY%b?@i|soY|V^SL2IJiOx8M@dc}n)Azb z%ht;Lz)Y`+JM~ljdmO5;d-!z6gwZ_@d^fil*=1GJv=ufzk~sA(ZJ~WFcvJMxE1&na z{!Yd!IepeM5^JE!IM@c)*i=X<=eY$N`(XQJYit|4Q^cTze zEm>~vv%9BHdVR|i!(e~ol3X3_y|zy|Rc$aHAdAezYou7u;&~9fheAG@m z8M8y{+^Yo5u*a6oX?^5NbSm4DPjB%PtPE)UTJbt0-No~V^U64jwmqdr>qmT%`HxZ$ zZ@1cUWM0USfo&~KKD9cTEsx%%j(KXhLu<~wha#`#mk0I^oIA8;h6S&_vi6Erk5B3C ztcp#-!Fd`VgtJ=rEuXo2<-;2qH#erFPt(62-&gm%*|Ev)g-er{zq>PZQI6H%flDWe zE4DrBuIyuD)pYQfebCTevoBYSS*X+Hlhu-e_Byj)yKg%E>U^q-!oStkKs2ZGj}PVI zdj;mhua-W2HmQTXW2~-@`n>m=_j|rQa(i50R>1Vk*az`%3NQRBeG%ZT%-<7R)ZEyz ze2LFkAFhv6R9jWH@t|+K}Tw2?s&x0Dmn@S4S#Fc)Z=@FioQ|9$~VeZ-cKb?HLzgrglr0cq++Owmd zZJE9?and}eQ14vHMz7lmV;*y^K0T^&wvr!t-q|lxy!TM}!c(1ApH{0qRF|sOXQrK# z?M069U-bzW8r95Gc8nJNn%A}K@UxwtWbD@vevVC@^(n|Q>cQ#SUn+yWciniFI)3$a zH}*8K;zyLq!HapE6pPANS{4Z{J7uvW7psi%Da}*K^tD{pv9T`pYti9}J}keLwbpm{ zz7qSt9b}sPsKldRhmw*BAFrK%d@4UFb>+`@i@Hv_q4t6w63<@YI$S+$u-S@DE2f7% zk3G9*Y*_B(;?6(M?5$qn<@q6R|4%{nisAPz3XhGQ)}SzIdF6ZJzFth)FkScH*H>x)=Utsh|4oTMv;*r{KGK6AVlzO*GC;(pfr!lk5tD<6O#~6+ zf{6V95t|Dlwg^OQ42alW5V30@VvZnU=^$cQw|v47L`)k*tO!JGA&6Kbh}bp|vF{*a z(?P^`gNQ8y5t{@e76l?^0wOjGM63)%Yz>ImQV_8bAY$`D#N0r{j)90B1rZwpA~qUC z%mzfv4n%Ag8$iU4fQVUwh?Rhd zEe8=3fQZF`i0uavn++ls2_n`7L@XCX>@$eiGZ3*R5U~p&VtycEzd*!1K*YR2#GZnP zy#o<@4?6S7DVg=h*&6ySQv;{JBZjI5V6}JVuL}%?t_RO z01@*95wijj3j`5+4I;J`L~J97*d-7#35b|0h*)P3v2!3|Jwe3kK*TzNh-ra{T>%lx z1Q9y~BGw5+Ocg}z5r~)%h*)4J!z0TF8k5z7J*Q-X+X z1`+E6BBlc(wgW_LC5V_mh}d}$u_Yj41|VXmLBw`~h|L2Ldj%qP6GW^YL~Iv`*Z>eQ zH4w2CAYvy$#7sfNl0n2~f{5jVh?RqgRf34!0}Jq*a;A^Cm>=AK*Vl7m*cTA7iy&hCK*XdVVx=Hr z<{)A&AYxlU#MmHWIUr&$K*Wkc#G*mOPJxI`0TJ^C5qk}S^bYog5G8E0tV=lE@keq@ zlYWx<|3UeG{yW30e>dQd(f^nFxFhjJGiv_{P*Yt1y+;A`Kn18ZF2LXR2~am)0R2$` zbQcBCBod%TsQ~(-0{m^C0GdMr=pPEe?F6hym_4in)(w^h^MgHuL4_Z>fdc#;z5w;` z1T0(FNmv-{GfW+}7B(7I4(ka!44Vym3+oKq3HuB705$}64z>*T1EvCtg*m}4!@9!` zz-Gc;!8*XU!Y07(zy`oh!4|>3!L(tCuyL>(Fe}(`*gV)rm=SC*Y#Qt_Yy|8AY!&Pm z3}5==w-^C_ml5Fi7y*8#5wKEWzObh-F>E8u9aaUift`TOhkb&n!PdZBU{_&1V25C{ zU~gcZU^`%wVE18zVP|1WVc%h-;&Kd34!Z<1hwX>WfW3t2!?wV@V7FoYVR^8Hu&*#J z*m~Gl*mYPR*fH2#*auiw*dEwa*dy3*SOIJ$tPQ4%2z1$Mtj)m9Ko6h?uo_qmv;*1! zbAUO(1;7QsFTgKA{C3B}4}7Sz3InqumNZcGzRVi?gLH-P6s{#J^_vdjszA03xTVFtAXvnb|Cq+Q3{j5 zd|)D&0%i>hg$ZEJFiThv%m6kKHVC!^#)CP+%wPd9J(wq~A1oZk#Sx-l4zN;~DJ&i4 z4|@*#{reWdKR?Py`_JE2fA^8^j(-0}s)5J9e7D`c8qg0;) zW%|S@@0h|jH#0%GMt29U)B)uhMJVy7gHnm^DEHThGLIz=rat}xOG^oUn3u975(z1> zh+n(vO1jlOL)pV3l&aK?G0#XvS-mJMSLUKj;sTWI%i-#ZbWs-a7D_@sLs`R6lnYd% zY^5E_Tc&Vqt!+_~u?poXKck#sC`v8Xq5R)Q4GjSor6N60W>JB%njR=$c!JHw&$nh~ z5|qpop)BPBl)FqKi^5Shu?Xc9Kclo?6-rS`Q2y^ZN?C@H5`QRRxEUoQt7286BT-_o zSSs=HLHR&Mlxa#j$`3x*($Zw3#NbJkY}|x0g$^hIn1k|+<56C*1SJ_mW4mXhadbpF zDEpa?Qj1kG6CdAFZc%A;zuasYTPi~t!|^CrIUnUABd`F4g_4-MC_9N2$M}u9lYy9r zwcsc}=z+4CUy4oYo}$FzCzNOm6ZY**mEJ^o#cY(-jMCQDdHJ-h{G`Pf=pAn-Z(DQSvhtkMfsaP!jSM%7r$fbZ8RFcDhG$l#wWdT7>eTUr;VnhVqX#qbvga zi&#ZPDA8Jqa-h{H&zdb1YI0EuHPW6Vwda~jOi^le?mUT-s`e=P>W)&8 zb|@QKiE^VpD9yP5Wj>QoQneE0BkfT_b3DplE>KERQc&jdsgsJMeN6w{6B@lNO;OI$ z7o|5pmzvf+N10Pn%Jc+Efo?|m&G9JD`ss4_7tbPXvrn>ZtZh)r^BGEf`l6hs2TEVo zp;TuhN~9K}EUXe`V0BPd)D|T)6)4kMY2VGqPpyZg3BEw#a_y|`P`b7br8sr@d>$L+ zI_IOzX%b4O`l;g=FO)jn^!sz<&(9C?+3~ymufL;{zTeN0#~c{hq$LgO_f7p_UN}7I zo$6Ilefw&kQLZoc4RE|{oRCz0<9Ols6Bpi=w|-P~x>72Z+p(cOi zG@Xw>+fCXGCr5s`kt>O8J}b=|qwPLboa^}G`cn-|!{N9;?eANTXX{=CSm zr@Izq29)gcwsBJnoIbMPb8&OK^ym81#>KbhB<^~-+@WxI_72y}5A$9Xt@q!tC&H^s z*|yYqeb}QdN5@~9A5vPOTjFr$lY?sTur+E?(;s~hD(YAFUA4OCZsBSLhqtr!ugY7a z4qA0`?=Ye;G)t*lI?>8{`}B*YE5bOrLiNao)xu+KTN94=>^;?G=bOYc@edR!O%~Bf z-bamGazmEt*N%_ewX&dL<)p9!_oSJ}c=E4uZurz6{L&HiofmF&E15N6lk81{snsX$ zq0d?tKBrzR;)Ks=OFkL1bkntmiy{|AEat4=nANhk*?HWPxxO2;qxU?ETG=FqtL?f!@0=H1;g3l1M! zsWVP>twU1LHsiGq4FwlgrEJzOA9S{TSoXG-qLSh7Pj+7Ku01HAb$LZlyoK<71lvWY zrv2sA*)6Lc={-wZ6vWLqyJ5@JO+VTPyS_O-_?$*{d&bbs%|A?IUFQDCAJ$2}(9dF7 z)0D`Rbp^gv_C{4rykj>urLWRCz206Fb|@?|^J3^Gjh8ER%2Fp=x;6O?+yAzxzs)Uv zeQS?3_K{D1=6cLN%GVL`Hn8Gaq80i z1$Vmy_FM67)qKtXuXk?keJj&0`V`(O;*PAD+mNfMN*JXYZ!nMLHS%Rze$A`19hAH@ zyFuRD0#{1z4&NYrY`456%+9Ui$ka>mi?R!pn2#`M3=6^l>h>@b0?yO|L;6bJv<(cq$P-*qUV?Ef0D* zG-}66xt5P&b6-opoPJRfao77P>*w~eG3ph-`pbHE{Hy%&YbSCIZ#SH4-u=N|CZ1xG zacP8Y)BvZ3C+tghsa-s(-$V`U|8aW5!Xbs1zolpVh;FO+{ww>J=HlTqA1&VVpe-o( z%eC!yXETJ)B^STqwlRdC>*g+Wi{Q14L z;=%8H<|iJLoMr+3TMS!A8f3G!#HuZNBm0u4$+|G2OGeiHjD)R*wG+b*u7Ati{#lyehP?F~$w zQJ8k(ksfRysRgD8Ii|8JNRb>dwYXv0CFzSRQif7|RNLbtnu{qR1|QjKm?o4+ok}oW z#vv6e#Z(o6sgR8+TLmeOCZ?bSOs^`K%3U$#-^9m%Jf^ZSNSor3YN=v6yol*Q1yk-t zOl2jQa^*-dijmq~MtUVA(;BA2M5IaaNZSOM!p0%Zx=a>yAWe(Gv~v~dj~1r&o0!7N zFimM7MQ}n2Fxmo(agd@2F;x~Ll_JxrJ*JzBNO@$Ka*L3DIbix7g|smN>B~B#H&>7% ztVgP#L<%HCx>$}>Op{EXm~weY|4NY3X&?o>fpp+1(#)}#+M|(X3NX!=A=Mj&bRrQc zlmKbXC8Ug8OnKLlw#8z)T!U%@rsd>vXBN` zL5f4t5e^TFjWA6+BgK$mdQ?RUa1ANzdZcG-kjBX{)hA-wy^Qq21u5utq`ERpmr6|U z6__g5B1McsO12JZQ4!LZ2&5K5q(-BVR;gneFGZ?afwXTuQnC$5mtv9bx*}a2gA^_j zX;K8zWe21nT%>Vhksg;J#Y{xHkbvo19ch;)(ll+P7Hg62jYBH10cq!Gq_HJP%_5QB zl_Je?K?>@O^tJ*i79VNRHKfl{q)2k49&Sjb$O2!y_qkl8evU{P#;RbU7Sd=(q^g&Y zqDCW?C`an3hLqC@>8Kjg#2ZL+q)2HwNZpH&R*Q}mK?`D#M#+&jY9eKiMQU`BET}_zJO=5rHqv@2(n2+)tSX=t93B=~A$@j1DjkJ% zRTZ@03g`n5X<#%`&}&G`9gtG1BZZCwb-0Rjbqpv&6zIzaq^CEK>S-XY8x2YjM?M3{ z#(X@mlvImeXG%Sk(oe7%R5BRBAd4kok&VrulEDZDSyHB-K_!C`3}PtxD*@u4LM4L{ z46>w5KZEd3?Fau9!ap;fM);@u8H9hjpF#Mi`xzv@$zL$QKZQyL;h$>5Ki$tDiJ$CG z;wK3IbU%aePxmuO;-`+!Ac>zIPa_V1RSk6f1eHuXf*0H zgCu@>Jk!s#@%mHG!zHy4gUz6lLHMT^Xh>5qpT}@iZ!#b_9bYeyX2A5Jk!s#sq4?gPuLF|CqfYZDTIFtN&HklgCu^^rmjB_ z{;4*7|C8}_o4)_iFJ<}}B=OVZX+#6}Bjuk$CDV>z5dP_Y2H~G-!#{=aPxmtj|8zft zB!2q*X@q~epF#M?{Yb}85dNt){8I@3bU%aePxmuO;-|;cNa81L5D3B=KWollTde z_zAKZB=M6rK7T00f4Cnh{}d{jb_9d)Pxmtj|5Tg0{^a1W#1 z=RY-`h5M0?pCJ5GZTP2<#834zNa81L5kou~x}QP#r~4Ts@zdjJB=OVZX=EWzs-Hn6gAojp`04R9lKAQIG{QeKo<{hm z`xzwh)8mik)_ADQb9gnz0H{}ht=seT4Y{G?4?e`>sh?q|_R;-~r;kP%>9pkDcvUVljo`HPx@IBs!iYj9GpMhrtg0;p6O>$$smcJIzHlL z{8Ol8+7S$r_^EydN&Jj|3Q7F*cp6FkR6m38Pxmtj|8zftI0@X3bo>P2pK8NDh44@J zGf3hm`%%}QiJu-Xp`Iu4Q~eB*_^EydN&NJ98sP@_C*_|)CDV>zki<`qr;)@@kEfBu zPmiaO#834zNaCl*GyP1PzW+IF_{aUoTz??^Q*HRCki<{*Gf3hmZR+|1;h*kjki<{* zGYJ38cp8;Vo4WqgcoyzYI(~vm#7&QG3p@_^Eyd;h!1L^fPVx{wL#ExF4D8 zPy46Z5zO->eyX2A5JdTGhX%7R+Vo@WgZ+8bSZW-3OdS)) zrJg6pAsgA}55##;$6}66j*njIxYWMbpYlQb{rmiw^P`UjTs zpU)QGD&h(2fAc)q&lxt+$C%Z~B`tbuOGxj_QjQR!&$&6pWQXE?CVplc{=Q zMs5qN&crEINn_Rn}N~cRDB@Rpx+nIhEr!pT48uL6zvfBB4-wgwI*ag8P=k> zP_fO%%BJ7P4W-U~DPAdG$_LrO6C-9|#2EY^$iyST@n+(=aHj9SItTI^L71EJrNAl{ z_CI2F#1R*ukGvM-9RGf;{yg5F5n26HMEGq5)wKUU-UJ*k3`hL?I5zM*2xf!TS$0^V zW=lP0vFx#Wj7?p=aB9pv#2fra)c?8v0PIK9`N`{IfMd|F3K>nVOekJk5=|gpmvHR! ze?BL{dLIW?54?7^%=PU6Meu#v;OaJpRR@6N~Is4!L{^z{{QX|~C VEY|klMG^n!Mex68{NH#5{sU-vLLmSE literal 0 HcmV?d00001 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/BouncyCastle.xml b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/BouncyCastle.xml new file mode 100644 index 00000000..d27354a2 --- /dev/null +++ b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/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
    +            
    +

    +

      +
    1. 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.
    2. +
    3. 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. +
    4. +
    +

    +
    + + 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 + ECMultipliers 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 SimpleBigDecimals + taking part in the same arithmetic operation must have equal scale. The + result of a multiplication of two SimpleBigDecimals 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 ZTauElements. + + + The αu's for a=0 as an array + of TNAFs. + + + The αu's for a=1 as an array + of ZTauElements. + + + 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 ECPoints. + + + 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 ECPoints 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 ECPoints used for a Window + NAF multiplication. + + + Array holding the negations of the precomputed ECPoints 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 = &sum;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 AbstractF2mPoints 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 X509Certificates. 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 X500Principals. +
    + + 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 X509CRLs 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 X509CRLs 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 + X509Certificates. 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 + Stores used for finding CRLs, certificates, attribute + certificates or cross certificates. + + @return an immutable IList of additional Bouncy Castle + Stores. Never null. + + @see #addAddionalStore(Store) + + + Returns an IList of Bouncy Castle + Stores used for finding CRLs, certificates, attribute + certificates or cross certificates. + + @return an immutable IList of Bouncy Castle + Stores. 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 TrustAnchors. +

    + 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 + Strings with the OIDs. +

    + + @return Returns the necessary AC attributes. +
    + + Sets the necessary which must be contained in an attribute certificate. +

    + The ISet must contain Strings 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 + Strings with the OIDs. +

    + + @return Returns the prohibited AC attributes. Is never null. +
    + + Sets the attribute certificates which are not allowed. +

    + The ISet must contain Strings 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 Lists + 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 Lists + 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 X509Stores. + + + + 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 CU16/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.dll new file mode 100644 index 0000000000000000000000000000000000000000..2494a1d82636da280b3ff67c5647c7a35fe7afaf GIT binary patch literal 21504 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%0Aee-m}S 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 UN9Aue(98Hs8h`lw|7U^!4Yxv)k^lez literal 0 HcmV?d00001 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.dll.config b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.dll.config new file mode 100644 index 00000000..bd80214e --- /dev/null +++ b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.dll.config @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/ExchangeDkimSigner.pdb new file mode 100644 index 0000000000000000000000000000000000000000..2922669909b5557cb344217bf766ed143be12abe GIT binary patch literal 52736 zcmeI53w%}8mH*ELjDSRmf&!uh1mt;1LJ;r;gb<*B^7K(t%_X^nXkO;tAXsa!Gf-`P z6dn7it=Q_nwzaL}-+xP6d=_V{+SYckwT@cr*cPoiz6Yy*YW4s9?Z>$%;RXQ{K7(Py z$~tH7wf5S3?X}l_oPEw+R9D^7lxkX)E}T7S_W1FIir&?yQJzTK7YKSsXJq&>uq(5RMN%{ID1J!w-9! z`vZSIxf;mT{$mcb|0lP>+tuv)cya8A^u_1Kh+kXxrL`O08Bq3}qwcw?VPO7yo>Xaq zXn1DHJ^fofZh3Idg0H>w!fy*U&an4~-1LP{7p(eS!F}U`;N9Ny?>lVU*ekXa98q@p zl@}el;j6bFS?F|h<+raobJBmm`K76U`%UZRua2v~@^4?gwqV3jFZ}YQ_qYGg$mxB$ zfhzaQDt1=;FZ$v1TZ=Dy_VBa+Z?E!uANq318Ao0BJc+Ge)f{sr~5vYKW_Qm!~UxqsB*uoVrRAg z5yv%NGH_eo-4ES(Pio4Jg4ZhYZ#wttr!GDInja@0J-^4aAMBUP=>~=FtoDC&^v{od z=)AYz`AzHKgZ|ii_S-jpv!(YPw|%Sp{^Tw9r|#Z(MmJF9ep$uNYX7F!X8f}3&b%*= zEdP4L;uY_nwQv(inf@ zuNS^tI_j_ammYrgakoDCt7G;{<#dBWcUJq~^}W|`%b#<_cTc(ZgOv~eY|`Sxx6OEb z^+hk#4(d5>THgyBr*s2V?w3{UtoEP%{Vi|SZ2QAGqrdX<18bVTar4l_^VTH3{)2xz z^|2d@Czam$z5P---JsB&)&46BzP94hjekEfu|4+a*S}g^{mA0YKYihxd#~<)Snc2H zzVUi5OpIZO&vsc#t{fBoi{qFrW{ZIe5+s~~#`R1G~`WJ5haA3{IJAOE1`N`XUn;fv_t#QjfRet(+pZ#0a_->%e{j!Rk)&4!-{oF$< ze{ue=HjcgTq(^GsNe{i@&3;e6+2j9hUOIKjPp%vA;(n=|ZdB+K^KE54?nYJb)>ZxB z^$%XxLB4rv|Jf&2u1FZXQNQ)6X$Q*~=YvN4^ioLiTk*SfN@ z=7PG0iOIFq5Y;9tm$g(^&T%*Ka*~$S)ix$uD*a_$W9`zW)--5VExE+2Q$bLDVr6S? zVKt$!+Pd`WorI+j<|W5fj+7PVFOkw>g(bYOeO0lFM0L8UWu5A`ud25yE3(UKnQZCO z8rkeSz4Qy4YHPcw|JonGqY$rQazf0rfG>M^M<(S6#8F@GasI=wcFTbi1aE$O;s zs&Z*E)zsQjolM2cleWipNyVD85?exvH4%xOUdMUKdg@rYAi2(7bxE~WTOk)D*V!ux z>GYb+ZfaarSKHc>NY@#k-;k(loKv5aev)N;XuGnjT@bf>H-jZcl2#Al^a z$%d8n>t?0XEp;nf@l&q&=?=4NOr}?b*{x}tUBYFTXp>zR+mt3hv+8S`TA0K%EU0U& z*%vK<%!HSDfs?rp>Nz{n*wk28ov5$7*f@`USl#M&qPwitk+IC1=lsT1O8+``hMjTv>3SE#QQ=8W$1m&Kma2i<-w=1=Awh5{@7+HIEMlSdH1SJ&2f;1C?gp*z7911=FYr>& z8}QX2uaUS?Uhljy@`~qokabw3ylLor0Gp`G!3PIH3-D)PD;W-R-vaPuxRd;c`#T%kk-x00SqO|J& zo_5eRi919qzaUzrMQPQSJ?-$tFOL$f`nG757NwQ{@U&%5AAGiGQ(xSBTYo4~plxf37D}N_irA2AwZ#-@Oj}Lu7wDLouRa%tx7UDhanAd0C zEn4|I(JC!UD<9@*@A!{{e=l0up=gyBrInxaw7)oM<|(3;{}Zj!qO?SHn?SP$CBe7? zRoH(E0+SB|2Y2(f(4Nw3P@7DjS8hf+J`0l<^7+FZy+f`*V_@FTJReJ*DBlTA-tCS) zD(_VI9`<~aw~VErHr1e&OwaqGV=6=6j+A#Myia&u$z9x1 zw0U3rdi`R?%MbnN>?h{mJE~8Qdw#IFN-`D&<+M`}^db+n z^#EN13PhQD`Eu2`a><|jFq?9{(ymYn%?=&#+ElNW69T8 z3-8{@Io0WSCVg6AyhY~k9ONA4I6QVr`n5PQ@ z^9;jxIG833jsVM+fy~k1f#5#D@*qDr1{e-Z4Eh9p!}44E%9bgr@4+U|qeEJ2BeBqS zqO`{v+Rp|%kg2xQ{6k@}MW*bf?tV3RJ+KMb0&D}s*N+T~fO$YAkOr;*ZU(jh+kkh0 zeGz&g#QRiyy$P;L=6V8sW)SlPQylq4cGc^XYm)V(M*Zs1ByWd%owD>~_3f;KkhWdLN8jMuK4STA4>e^iGS7c4G9X({FV8J!OA$5Zb>E@Y+kp+ zGYB5733fQ1W8qQvYQy7p=Ebjad-ynYo}j^wFwY|M_ay4vj9}BfmnGIDiB;XsqKxkX zqV?%2r&bfJUf8#++XSPl}?m@l%Jv*81Yy`O*}bnasa^8LYp}ov&!;1oJ~$>r->*%O*=W-;#c<|ID4Q zXiFI3eHpB;%$@Jy(8gIUcv|ZlbLT7C$-z`ZtFhnux|s2M+?shny)Fp&pp3e~kznjm zb7C`h8w}RmZ3uV-SaYk1;6gCIL;H!$>4sp#f|G#?pd2Uyio^LGV{~ABRt(=}gN6#} zMqv#3$RCdd=kxVaKQG))ob@fS&?l*rJqak3K(FzFF)o81(PEIHjMO^Fj000fQ(p4U z6mw6%&S>wKc~oXTnCr|6Fl*XO0?hg}(*T|cR^KfHe-8ZG>mOvk;PB<(3gW*Ao(sCM-5GjZ0Z#6n-Bwz$pFo{lWd zdzi;&=sUquFgA%)+g7~5ZQAN=u-fVzu-d8;jDCX8fTjC$!J0>^PIDZlKEZj!=Tq~1 z{6YaOt@(KY8XZ7;7GU=UXt{uv&)3Spg?wtdgKM>c_Tv;XK>r>=FaanBs(`h?CSWu0 zB=82Haaj91Rlr){W?&2O9PlnMs26i^U@@>7SPyIhwgB6J?ZEqh#+p)K9#93OflpGP ziblukL)vFk(B7Pa_8%3rU#OscP6h4r9SENc4XFM7d~l|#Qgr=uyyj=Le@toF`L#P0 z(sn+Xas1AF%-tCHU-A6eId&UGxo*^2`95M0Ie?ZAV;cHn(r5Ctd#76LWETHrwFdJU*ueSetg z`a@wvEK#NTK6 zqaPWeJ1v=xFG|#zX=5~g`D)g3HFi(fh;>%kSjj86QmbB`G{EwuI zyHm;5kCp6ZKkrXnnL-fk8qx1TZ8k~@wC@xKrXqQT+?k{^S0@`6B~vNRCC}#Bf{q4V zoUEa&yRnuh0}Z<%v!?bwJBoRv8*(O6TTbW-Q6;V7S3YigfyCcNVF zv})HK#Gg$3FyfihnLLhkYfzHHHE43}-mN2j`Td^GZB~)NLK1wyw(@RtvIF^T8O3~_ zb`YmBYQC3-PduJZ@pls6Onf2n_c(sPekLg_yFFsKI3YU`-yxkYC$i^l?tL>^BPSLV>VgpU&00gL z!xn<&n@51vmdAnnuoB4+#sMdX>jL?DXia|JZln2?z=xkVYaP~aT3<0%*)>i+YmavD=b;d^0tUbj-n-u?gK%oqN+3{?!X8Pse!@w0_#$L1LnFwCQJ?kswm4Vi*OFji& z!uWv3*dV272pQ2)@se*E5R+`YrvRR<}q+9__yHCg8u~mJXmAm zKZCVFgI+R6fH!~#fG-D+1(SDXJeWK)Gr?DbXMw*AUI0eVnf%}^Q_licT?2!!0CRcz zv5-~M5TMB5f#_p!a4S$qdKvU{xIT~TBZ0A8FLl=mr@tzrGnKJ7fG86R`MVLrx)rz= z*bcl86dsIi0Ly^`VgJ*B`nn&#)aD8m7MZ_8@x>Jwg0TagtIM$`EI+7xG=CSbr#EAD zc7zUJ3t|!wIcF|^$yj~b3O1YL;elWY_xrkt4}G^iOKr!Vy_uKe&yDYX3p@|7WsQY( zRz3VY7e8fuX+Bs!3x8#N0{)7=7pK3B0qWcI7wtJHsPEL%CpP{s?-#1CpZ{r2pdkO} z1HL=&_teQGMV@nrFGHkgeR_2M7k!4YJI_3#^S!0XRqh#y^3TpAmnExP*}`5IpWU*q zIo(v-l4xG7eYD-RGgGEq_GsVRu=#xCoKbdQ=9Ue~1$DT2*=hE^ec6o6(_3oeWlgP( z)jX+7rR$T9NW7X0?D@R&5X0x^P=#s?!dMx%3y08d@A!6G(OkoHbD4jC&M)-2P)ewbofmPog@BqI-GHP?c*4c%(<_-J8W3QZ~h zeq^*7q8?ZdU$K#eGl5@j#o0(#iC_v4v+3wAELe(O;_3V z97N^0jXWoi=V)lQx;!<1)7Dp%$Ist9PnF~82a$9n9?f%d@%ZORzW&?c)!gP*$E*6w zzeIVh-uzQkTUO08p93aA`>&2y^~XQu;GJJXw6PN}e^2L~>igC{?fI}P(2s(2$1^(xACGwI^-bc%nF z_>Ji5Ea-f^UlU+Ap*=Sw8#s4l9vPbao`G*6d?Vr0o`i}bKH(@|U1M`=+Hp!(k||#8 zaSVa>V#ljCRv(J;@{($nnKa){zTDdLmaTsyBA@1OlSfp(_^wCp4bZ;`-M1Z|#!-sY zhOfb?Pie5UNn4YsZ%q=X{2nFodh*e849)Yr9@Iagb!o4^q3~$FsI|vR$0r@Ak3{)8 z(t+27@ZQ*x-y1v`VG5G#1LJt!4X#WCu6 z&Rk@)hAIUQ2TuX_;lxlrr%$ym^J^%b!?Qj)7W#DZ2+ooL5f;KH!`0e|`B|_GEIZXR z7x@M~s}cQ~U}Oe*W`nHY(_o%mnP)X+-~{*NVfdE2d#(AagWxjOEjkmMxg1;zz8|do ze+F*g{$VidqRcPAP2gXFF9g2|#I<^ z!=L6^=vMN+m~}dq?}E2AwR<7Psr`h}F6|(&=Ee%& zrmnKJ?}Fveq>JMmmd$-H)I}k8Hu${XMYq=H#zJ2{29j5ZSGWsa^$YfD&}R_b2R;h? z5SV?8;1O^kSTe^tJPwS_nP-l_1fRtHqu?^|ufgSxZjr;MIeezW8V9yPcOLk+;5zW{ zz$x(K;4gsx6U_Qr&w(?yf}aNeJNOUapMzB%@-X-@@H52!3H(Q}{K0mx{PqiA4H$m~ z4+Z0sGb6z-gC~Oj8$1cD{7!UO_OJU2hvz!H*x@C@@D1RZ@F1R>4&$U$~d;JHQ`I(=iYWz`P{u>5-S>9j_+9b_pGMP@A&z*>1Pv#cVx#m4yR;4-#;T4O_ zUrax5l$WJ*bK&aF&f7Lo2#r&NpOr)zz55BhqX-Z&}SIA@qs?8UI>x)a^$&B?}P zDfvn5$ARb%VHXOTR-R9M&jR%?&2KazO-XmFO}_2WD~!n=<^ zV<03ZFYWyn!c)rqd5%Z=lH4ed^yTZkr{kvVMm+wULLdi5xXvQ;cO*35^z}8i)kfW> ztW}g#?+l91)B3hOBvL zmzXoxCxSKaSPY&8UJllpnz7tq#&R?N(DS|wGsiIctOPINUh|K$ z!J2=Z4`$yY(+o}+J!|eJJ?q)M%Dxa7N!c@|>{j=uaXpr}t4x~L`*!lM_8JSzE@OQX zP-sGq>;YM(9v6aT5A2hedT0(Jd(hnD6!1E*e9$Fe*~90+%fOd{Yrvle%K=>mZUFx? zn7qth-)F%axW5Yg1@Lv?D|V`%=6SLooiFrtJuXLG#}IcVbjKMR+d*EkAAKJ|p%B
    9n{>36Cx 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 literal 0 HcmV?d00001 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/MimeKit.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU16/MimeKit.dll new file mode 100644 index 0000000000000000000000000000000000000000..8a58db8f417200e02657d58a50307cea7cfa6612 GIT binary patch literal 800768 zcmc$H37j2Om40b$9amrQhqU9TK`J-qK0B5jqJZ0fA@)B!Jir3dp93O5uA1 zF-^zlxDP~e8$|@fb#%lL9T!yGW*kLP1jP*^>bQ-HGj8KJ68_(J&aLJ35`xbB{{2f{ zRo&&BbI(2Z+;h*}PCe%}mSb6#i~o;2Vp$)$76FM7shmqk~syzr8htzDO`+;Q2;6Q6wM%I8KGUoz6u6C7?p zpMH{Mozmr4cf9h`XUEtcv{tPwcCEFnk#5V%Yv{JEcwdS43-Gk8h4OAI-3%c8@^>@h z5&oMubfa8bUdp8Wmp;v>rndfga<}zlz60(n5+Ej$kG;MgI=&|6n*A@1__v54EP>73{|CcJ09RBp4_ z>S3NunLKW^nVBrByw1hs%#YCqn$yr4aa-{MLN#kF5SM0b6$pRbg1eNLYnorkz# zkDt*N0C4h^{JtI0@pv67=PGOOL&}OIJYN!4c1GZ6VEY4ur$y%=D0O ze)M=C>h_{VKp-*s=+%hwBfton5AHAd4SWpX<9?_8dn5`xH#`xa(Ifcq>?u}4@o zoD|Aeqt7H6XrmPd(PAddg+9=NQm_UrvaOnR_-R&vPtfjKm*a_wDmmc#5ee6w=wwo{ zu!Xw6T*J2_U^nY#I!Tqo*UOVHx6+2t1%aJ&yb$8%6}7(o=!ppSyY~lP!}GL6`I^$Q z&02D?(ozO3Ezp7{`xt1sDa9UbQ;OeDiX~hq?xYd4xk6i@w0S}snL}PY^RM7VQhFzZ zhVu@E1*SfZwFb{kd9dUEfCsjrX`Z4>*`EQtxyQu&wC0`gNmB9dA(c9o!;RLGr=)T? z@tE+(7!RGABHq2Z4qj>rph~EK=R*^n(C|x(Xg$5ud?SCu`ZGGx2c^+WXSl3Oj_}@oKw` z?yt6?ZM|>>e(W~Xju$Rt^a^_lnu8sIGc7L&K=aiAc|ibVN(1Bt0qE~EKwdRB<^4v! zlvki8(M+s`Qod9;DAs(@A8J;HQ`Qabc?#&2VnWY#q3Uew?bhJu)U>dz#a)BrUEN@l zmGt#50ySX+L_%|fc%Vf{TL};62gKtZBw+m)S()gQZEFwm`$m7Hy?4@&9EU<`uP$1- z64XZ=FM@>_48Cy90`q!LI1Kpcb>7gK+N(|ko`M?vk|K4&ry_5os|ML45q1dsz^iT3 zSRr<4G=U_wb8M&Sw|)wU^_+xDdJ>O5(5?MMpN*Np3Y7IPDWGhd?bAY~S zS87snTRP*>A5~F(;I(T(lhBMV8OXkE2nf7z4Jc{^ea?Y?*lSA*weVa(@}j5Vx9C^= zeLFzlLbQNpCQZKmbVS#FxS%V9wGuRzXW%02e1wII*=n-I5u{q2xoBGbe?$}E&P$UZ zou8(y|3@?t?z}V!(u5}4f^^XqkL&K-*)-V)`e8{g&DXrXuJ8gdA9a<4`R!-0t|$kN zg=Fl^N|bG@&VHp(C--h)S(XkTE=&*;=p0Yx@$s z7JY3~(WUqphDi!5DVPWpmE-rp@P7-W+IOP2L-sV4A3Y0+Am=%Y_6(GZ*mSQWOfW$0 z$hRk7tq;Y>0$8$a&I%^iSnLTps7y9B2OLps^*(e03=%|!G)20>-h;N~!p=iqMvWk! z(he#bB)o$Tx1gs=_7tdd1Fz^iA!rS*Sj{1XeKkY#J_k7U!1KqxuWiq<=F0c%gXM#^ z6xFm-F*OWEd(U%_D|#+|z$ef8Cg|w}J-xX_+Z{L8>xL(>nL-D++lmMXxAJqa*KI6r zeIM-duelF|hL<6~?`~_q2UW1UQVSz|I|%S6BUtu9&w)f^v_e2f4+j65& zJ&wEWy1|VjhXMN1){tXe?ruxLyW3LuuDh)|aaJc#1H+b3sF!zw6w(bO`KSSOMsIl* zx;^P5m^3^N<#7YsfdJ(uDk$$3R@bIIE4nzuM1te_jk@wI^saHfa8r^EhE^q~xi-YP z!pAcc^PuB2dBV-eQV~qdVh|l|vVeV_ZidPidZVcH3T`jWSlDe1uxR7UzGm=C>_ait?xCA#LEB5*yfw$6@C~ zj56aeCwd;_5qm|kUPCBk?y7}n2r z9|r3~b_k2s3nLEP`|*Q1SqdHWQBd25@^(_H8F#%D_E6x+qnL3b%)sI`%J3qza)`2B8vDqx^W~=l;%Yo8^PTFW)e3Mm0V zo*OklT6S0te(5-=-&%Eyj+1_qR`PFAbE*3F;X5!cnzq=B=$Jg)oknA&iwNz{rKR{C zXagEs@_j3709rTBD4|(Xj;ZVrel*ELP_0g|>3L+P?cT@vWTJ!ukRjJh}{yR}(48Q7Uql4&0t=Ny|0Cj&ckN;1uP zUh8;7+ab(5R5Oe>k9^>ePD`kbO+sqbv#&S0k*X!C-tSw`i!{nuY&snf6)c!aZq|IS}NcoIqF}Nn$#b)noc}>@! zS|t~N_Jdm`ELYBYA#iq^HZ!kX@_f+Kz69vlipXSxE+)b-T|=|hicryMtuW|d)(U#^ znbwK~flk_bsok*z9Gq>hF!bQ|N}BK4C{b+Z%*uy0EA0>V3gc+6@Y!jvC_O&;w=Jl9 zjw5ElHg`?gcD7w7!^1|NuY+sGe&}rT4%jMBo^>v?*COPb%g*U$pNZOy?VLA&{rS`o z$)|RR+Bpcw&uQntBw3Reqh^gUYQ6_hkIkqNVx9mqAY*hL8Zk82GWJ_<&ht5*^tS)+ zTU$=n+A2g;!LYVyhaBA2x{|_{v9+GhZ^?)DIj^lHxl-HZ1ZDb#~ zrb>{!n0es$ln+!_aLsY_d;WEP87Jve+Aje}3>oSdC<;F!gTlW9j~jU%(Ke3PXJuW% z8*FHoHY;%xaa%MF<6;u4kW5!to#5C!DbVO^wSQqd&h{5*DRcA}3_W;%k><WKh(G}=5TVs&e?0D8m#*xGEde0EqEm^K7wh>~ZFJ4{{fZ@Ts=p_zmP~>^jNF36@^l)pp&ruAg zI^sG5W9aCoC5@W)$FhX`2d;&qXX#L-8Z#)k;g+Fl!mb{&3qgBXi1w{0_TDDZfFHJn zLA?CM3hrfWJ?}yqyDEtAAZ>PKn#BlFiGjFCt01MKoJA7lFx$db15fY_X}w4^28{0n z*!C+3fd~*u$O0bkER|ryJ5dQf&iUG6kD;zh;$1>pM~@Z05@6&z`T$^I!V^=tUid16 z-k%3pGq%cG{mXT1bsLTCi@H#*T>BMxgdb%Y!;kRyfcFVJ)DL|#;-K-=AK``{L`3b@ zByanbkCydllQsMhb7DkyF>!{M$}h3)`9#5Thnm&lJ-6fKfcNnLsQ(sp5A9`4h&i8n zThKxr)_@TrXYxXS^q){RsG$-&hhI_1#mAT1R#{VQJmJ_`jsGCDr zDUi|=w$aLqV%~|nTD@5HZj<@hAUViw^Q5{boCtmgZ{247G+*7Ah0KLl0nBiHJh!d7 zu87eh40&%jS3N724sKMvj7T`d zP`Tv8wI~&I;0#}<_6BaFw*u`0F^Qf70QF~>3W!G(8;qVGT&XXW?)nk=%DQf^wK$=~ z$VNWe2M7_c1;hF31gFMWiP38iI{IZVCN1s_NSkeqfwmQ-ZC5uP9->K=so(=L>U;{+ zEJ1mZ0K6XI=rvc^5f*V6`w&gS8U&ny0M0_!TXF%+E;mQ%e?HPQJ=*p3{rOiAPpn%# zYaIDjBA+N_@%`l{0?dWMH|Ej%_eshEw7YzZUT?U*H{!9osMM-iWA#%=Dt71NQkY`P z!CRJq%*_WeCj?eAw&AB^ct<7h#Kt2y))^_Bm%yB%FR>XvOK9Y|XFUb*4r7_oF48e3 zO_dpai*Yi-?N+RaVd!TN!XM{X3`g?*$Sj1P7lg!j7Vxc_hsRY^t?;;~H3)%nU3D3= za8&_53~mp!o{YF`SL|!De1={BlHfZt#W$1xe=WL%o&T!r6n?_FXRVgU{5%%=U^kb$^dyFhEhCcXvuZ7x% zv$e#w{#`)E`~7@~u7#ft@6po$VtO4DI=S$VL=V0@7KQ^B`f1oF>yd!+o6g<12gC1# zKLzUGFDC<kWy$dP(8^Lo zS^Tst`Z`}(e2yOGF3bG2_UJ{LU14{#!frFBoTFmc>#CIX=BCjvxppoqk(4>tx)A(0 zBH@R-Z^yOwz<}bQ3e$0}f8ATP0I=x;e1+eHoHc#|LsZ3F!5ipa#c%IJ4J#5A^)M+) z?Y>Uhq?U4-S^}|i5cxTKN>GL0L-`b@9X=rM`|;bp7eBBXM^U_K{?I~4|Du+YydVG_ zmUsmo$zS0(sqDNBkjMl<;P;;g+Cy4Nvmu4FppMBCy;}jw3va3qTTDF7kVGt zR>_Ipfn3q6Q7>0);@~?kwh@ghEcJLhE3r`$!@M@L=}v zHAp4Z2w#eW!Jp|veP|wRlkHDq91^`2K*tA>rIf2qlyj11 zO%Z9Y3%|!!|1;M&>1D7`E>y}vJt`IU9D_Df3SRwvROr;FIE;BJAT^%c5&lVpgNEo6 zz|=v@fZ{0;&)~+fLbdD~{2AKHe!Wx*Kvhr*1T3h3S;=o6-2rMz-J6f}Y(dMuhXrLU zt>z9N&p}JcZ7fq#`T+&(DdjSJsRt6a`PKuEJmN*KL*8<6{ACcWzGC=#eszO6-BWj< zlz4m^58+Wolxg$^rsyeQ$=ljOsYhDrL^U2&Ezf70VSccnHJfDa z$pefu+YO2pk(OgS%yaZ(s31COjI#*yOFzn*kDC&p23W`IU7G9EkWXgbnL@2zQ(3Umvqi$y>L5 zUR-h7>V!$!gE0{T!+(d?s;>peI0aT(@KqREug()8{UAmTn=b;BwG8{wSek5);)jeI zplOelp7FOJUg{0SI2pxQv!K^4h~W@E1R9z@!lK3cs?M+l`S@E)-jTmMjvG8~?2El_ z$t{#zt%!2&F9fu4?2Cn%yu}Iljbo5JGxR0}eqNU&#ZtQ#ZKZV)tTvsD?8VoP_^Yv` zqhs;n>aP~-Jzgx%snA7-bevO9Qn_zPCxhD^`~4LTwX z(n_wthshOETD5T@iup=(JwoGhZ+;qEbw@MF_IGGWup2QLwnk>xbp=%tu7CoG(0K5R}WoO)3sC$bkv)4?c;4 zE{T2R{-DtC3fkg3aKO|S4rq&yePb)EsW+={>^ysL<;X&NurN}z2YW_5doVcAML)pc zf%a#itcUFBFG8KwuEh73^!w}h9&)Dd;=`T(8e_>L*ZK(L9nLCK>h@beH+Ex?129VZ zyOYXy!(XEYm1E=Qu#p(1mE20&JQ`QVg^e5ViRjnrqrPd*3%snBfoHIUo^l;Oj{8fL%bPkj!Iic2!kL3_fODroYjK7)jKd{!UK7QK~N6ClNS zCG<`E2eT`o6ROjqseEjB3naWlM6#??2|*nm4|^FVhUKG5F2NHHG+n&R!r?#kwS>J1 z;Q`+H$1&A1JjM1wTX-_c@3;}%P+nkcNfEu7>0YYoo;z1M7~>XMs%a%aGLi& z@mds!zFM0O44`lqnqGhoDZB_TD1!7Y@S<6OfpIhk4S_dUUVD_cY;Dmr@a)+LYZlM)#-B5CKq3!YTlEG9Mkc($B^!S!(T9yZY5dRfcI3z| zZ*X+-B>3Ox4YDw}weB$g^LX+4dqp7QFpf`8 zS5UGphAVQ?g;CcgUWXYjf?RYX#FHh9)yw)U@X7-9`sfm zhujN`y}N#-!H7<3N&Fg&EGYRy0~2N6gq$ff`lI)9JaO;jz_~kj^bjCAmV)>uFvbt> z!)S(2`ZA=fe?nOya3#l`2%MtRjk(ggE0DaS!u(eCQvJHV+ywRKw+?O?S%8Qx3=ikzJ{aQRJmkT>gb3NQ9syOV)4)ZNHog(ra) z>-oF_Eh@W z*J|XC=K#AzeAU4DvpFJ{w*F3Y{&aTa-eaI7I02^=AP>T~Q58KN=3qb;P40OHbb9+11nzwW0Klubcn@DZ|MlV_$CD$)ARb&* zCr9DAq5gRhU_*XN3#E!&EyozCIzTY9;B?3fmd1c zLzIyA>xnU}j`C%AK~RrURsnc_zsxs{03K#~X7WB;ix9LAfDN3nwY~5dmQ-!5FwQ%J z77>6sa*_TBc{UszU-XZ_Haw$9>pQAXCE>7a7%*M%=LY9 z#1J~LS5)l82TfaPBV`D%(z$lRLWg0jb9?GlXk6Gd>dMv#Z2780=mT`Gh}LR!8ziN> z{zS}Edy#I=m^523qIaT?BNrN<5CiuB zEF>^89%rmH@-#c!Cy*}i`p39nWfsv{4n?0tN@uLy5hl6}{Z+Aks$%xFFH@HC*YrXd zZLB^yhwDPqq?sub^Q?PK=kdrb&XX@qTVrWr9FHGGCPxV zW8l<*{>bUsPZ1VJeoZls%tp__u2e@G-Tbyrrc$K*Ir52eGUz@9LJS%wf;%Ho_lf+? zBLS>R$R_pCo4}X#taClT1{?D`&#w_}GNWy{f?u_W54;!4AfUnZ1ZMcZw^{(HZNi&1TJP#%p=Crc9|v zW;1Zh&p=W(SSxz`>obD?zp^_O!?{Iuoe|Zz$d4+jY+`ZZjK(V1ZdFyVZK~CdrT1j5 zM(JU%p(YnybR@X6N&16p(NZ$|ntG4|`>+`bf0HxUKJ1zKo(-C=m@gkJEXLV}yp}yh z(2cS_X?{Hs?LGPoVANXd1=Ep&Rxa8nbt2ZXATl*Eq{B>23u-00u&i&fgX zpE*2_WvAf%V0&Bo;N<>2F^KVEoQfA`T(T;+iI&gqWybE2W zn8=C#nW?Bt+bARdj4qv(VP^YGv$J(7P6Y=Y_H>|Y{|i7z$K#C+H4WK<5R=@EzCiR} zWtF@?(bMcp=1d;_D^g=$9{}iB;3UxNqh2sFgegyoJSk8I08(Janh9Sd<7}5c_Nz>+=mlMdDylf z^02kuh_Ynb)@sNP+7?3(?#oT{N!xmqd{yAvlEK&L_OfnW&?dazm#!mBedQ3c$?FA#N2KObKzOnZPVfM)Ef^`IXpx$`@VgA*uLjQgMwed|lS@pph*9 zcp@XZ655fK&`ZO+z|Ntd0Uv;~YXB;vXv?EJzy5mU_Sd7SSblT|=!)zj#eN-^n1`Y(Jyb>IEwLF}nbp7O;IbTkcfu3MnguNZhbu&I; z24l;hxv2FoU_l(ja`ca2W9=~KtW?H@*3mod+R?iI!-<~D>M>sx{UVN3*1)4VWR0N* zm$fusR@P?a+i6cRjPnM3W(901>i6d;EBrlX?St8G#3fAOz3>e;vA-Eht5%K3zM~(Y z@Y%)A>AoXp8`c$Lf6)`c2{u7&k>D(lop<6Lr#eHszuJ>)^tM*#u~9W&XulgMc4M8> z{%1<=bnlV7W}6@$89Tun9MO5;cyU+fHm1#|V;KiGMcoFNa}$S+OX78ef4sygZs`jw zoO-$VSymN&VpkbQ6nqQekEfh(3%Dd7^kDH_SBR6mbeTOiO!*`!H-;tqK0pb5TSoMR zkv{>sm#$6rGMq`aZfVMs3-hHEl(Mi(l-M?R^bm5y1BeK7R~z;M%Yxw&MgnUmwj zu(1m{r^_{TH^5lN&R=HQKW`>({^)hF)tH$#fOkyZ20^MsY=*|1sbDVE~6wtTVyX7I z06|ukLRK(Lx6t>M4wZ{{&r1W`pS^AsWwXL}0AHh5X_37{+v`R7YJUi<-JU7q#*w2? zw3V$DMeFih_TZVgcG7BGvrt&QaqO3MPeZwRkG2s1fPPSl9qs||$N~I3DraOYuPeXm`vGPRH+*}l zE50-l%j3d^|(Gy)G2s{`QZd$m-8{$e97-0^H=`- zVRS%HGro)EoZ%5jQu3j0!YhHT20<|hmUPdDKI&DRZv`k z;wli=F5(h6Tee^jh~=K-_F%*7>wa{0_sqfWo>YI7dQx7LdN7-brF;wnyL+ZXPw6c z4{W?uDg*n`wo2_uVV?!q7=+H?tL`RR9`9!BQRR^Al{&=TMCttSUO`CSoSEWFdHuhG zE*bj0Sc@lhdq#pUt&2I)#oLo)8`_)QRmx_p)!O4|&ly@PbYA2fVif zi2AE9$D2LHynggeM4Q7r@68UlO&?=pht9gE>UewGETpnD@$0%25heq+Rg;W65;7Et z6Ws?SwR<@JP2)JEor@&+9AL;{ka`OXO*{Kkl$n1RSNCGDL%O4HBMHu&g*6m!wUu!3 z!P2LmLVjLSSSR{!3K)kx5Rhi5-8pk?p2q3eT)tgSy~dQmNx(p%M91H0**N}ADM;Dv z2)j+ulDUCxsL#&ot6;4rE3jBU!j}rfhS#|v<^^IkFlT6gT{d8wGqkaeCq`v_Csk`~ zo7N@y%J#{zf2JVV`=Ooy7EOFzvzci;0ZHNM36PKbQ|8Pg2M-_xJpoLPdfv}Z@dTu- zGm)IS3mQv087WmMa>0`=;0X}44ebHKWts!*SvcY;* z#oVd$I?n)|%Ry(nE4yrVWrwo!NXAt)6uvQg@3k=4@Zwoy$ffu(8?cr6(hk31maWDE z=J2g3a57-lFVN6AX2xh^jxjSs4?bp2^JT}(v+`lg%rK6b`OJ=);gm7D#k1ZIx*$6^ zo2lt6u6HdDM6VWmJw1{#J#K@x^VPjM7|&mYddnKm*c7e@FKryTfF=uiWL5gB>t4KB zBDZF_*kg^6ekA|7yl)))LEVSIQ3E3z?6!FDObb}8ZXE4ltnLSBK)=4%2nP{ zbz`PK7t4cZOL92J(MW6<@!$_0w}8xm9s;S*1qB%g-0RGBT`?@!CLD$PHGH#4&*xIYl%J}k*QgC8@q#yg-t znBr|73Lm%)TuPt}NKRz>Pz=YGb-Pa{Kb!WVTKh*3H|{At+E(o(ha)tKtv|5W{x?MK zHW63Q4~RvM;e7xV{TMN-z4Xw9&w4eU33420JUxNUV>z%S5e`RmU1dM|DP9QSTZHgh z{FrX)#~s}iWk!Abeb(T*w10vxNB+>LhM#5i;e#LJ>dN_9%|&g znNxolEqodwSbHKq5)N(XBBElH`*tqmFpoLi_XL4YW5^Ol4 zD_*fa*I6muvR_%x9=#mNiyddB6m#2rDSo`sXS05$XQlWDJ1fQHJqxC>barx9%FMvz zNEKVET+t;vi&ns@d^=dK0NmC~QAT~w4V+c)b6bC#2FO7xaO;@kU6LbO5R`#kotQWa zc0R?+0F5^x)s&SRAjMV!C6jYvAZEkCsaoKgO-?-f1;@MmH6(SA9;2UeBu$pY&Z4Q! z@?n$*_UX*EO^wB3#Bdyp6EAHsd(6q(M%HPj;81vqQFA`|Y96!nTFf|f4ONWL(fg01 znxtZG85+R*VkPjFp(U;BP+PZzaIy!6+0AO}4G2TqXN5>S_qYW$4M3lxXU~8JoIOJ= zdXTec2*Q(j6wv{CKBy;i3xmjC4Ib^x8N!ckf=54d=3jtL+^;<0MGTI4&z$)JlAUki}_L+P!hIbU|b|uP&`7fSR-FfEBeBfsKOztE!_31nX@X*iBF}J)p(X*<% zWw#QSL&uI3oH-LCd^AVOR|FyXfqLaRHyOK&=lZCpf!(n{>}kCjGLoJ-^O*f8Urq3F zoM!ON^rQT>=n{kFZe?fUM^Suf{mfaq*q`y3{V4Y&Wox5s=!qU%-KA&FWLO;&^O&70 z-yktpig9F1L$qa1)Q;G{w|~KgeV&Q^B|hxvSNIioCVThrH(c{@vfa81)!ljkKjH5f zf^yMc^EN!6%JNO!gl<``X0b!uKIJu6*m9SbUb7W;A;@l@28`28SU)54p&6nJ5Q$a1 zmG&KgU#u_ldF2K0bQNUXMYp2JM`t3PAAJsq8uw>CIvNif>3b~KBnlCogEtK(y=sF! z!CLo%v~Q=ZPk?^CcTDz9ajF0-t4U@)+D>F(c}xjcTFPiy6GU7DF?tVJN46*udy=TQ~pWK#o3J1FMs2F>V^M?V4RRDRswt?M7PWvw*tck3pb0ZS}wK z%F|XA-EI~vlrT8rG;9iCwcpHi#HDemk*paE_^VS;awO_3GL#DP!(gOMy$w8k8hA(% zJTu{jBO9TyIM)+X8Eff@-cKPIPw9glGNa{)+fToB_Y_soP)f!lYx28<#-Xdz$Mpq^32zG z$|3C|ms^J)uX^wtoLBKZoh14RCW&xf#m_ibB)owRww@t0xWo*1-0y&_vD%3`zRPyx zAl{K*ZXgfPEGY=u_Ut6}9}t!1<<}(qRF1X2%i`SG9Cqfj2}LBx30+xo8~qX4=qvNE zX|n*d?f*tV^e6masK!WihX2E$93s2n?j_AQJ8v4GS^{q?0(Q@nm_!v7jz6-nb=Qnc z6$Q=W4z~|@Sa65cRrS+&LWbZZUx<@nxO@&E&RW=sH%>}Bvz#knB_3_ZO7sYzF$*=D z5-|E6yHII=1|a)9HB_*~?jd}Z{p=YPB`&`;_Th)Es~TMaKCReg86Z95$>)E>^CFRT z+AeINsk*hDsSi=c${;2zArk`r2?1e0-=%TD@>+urwN9T0NyF7`j6C42W3a4;r9tLQ zeHa;e)e%MV8UKxq^vq}9uv!*PPoGV7~4^8nw+Loe?fuluqk+Go16_C7lVh+t{xzR zg6LK9wb|k7D!Oc!Vt?(ZFC6Hum-E5_^a3nqL5i7=Z)gni4K&*U@Bvd-Sl4Ij@knd% z30hWkLLUU-a0q?^j5eWAu zlWIa-vnPN%G8`+l++gW}_qLc2c|iaKDzsYz=R;^0u@?&>$I1x<0#gLW%dm&{Y)Hh*(2}U=r~G;{1a?6EuLr@E9AQJZ%;fh9ppK zB^3G#*uP%FHZjGZ-ETL)Ss@* z6#xoS98`)={Zp?=%8I_K4`pVX;FC9d^2B4%$iC_V;V`_fjbk*vS<-tj+c1f|uq@n4 zGd7RbRIML@+fhhR20U(5Ou#o5np8jKy^)fNXB0gixZqS+W+ zQQCOy=-zVz7Nh!=ydHSxW*aY8gzDJUv(_GM`kYx~%O&jh?qG1bk%8tQ#<8Xi=bGsH z*?`0V;dre!f_Z{UE~4p#IRqL0a<;YOyW;9M^j}WqL!QaDI}6Vd2_AP~fQKre$T+zK zrVgQH%fq_R@(fu$qgo!qMoZy+&4&!z5Z(bghTCoCSqOJD12?78NvJd@rf9J{pv81n zt%XOVbRHT!!?s6-=U}!$|Fm*C`U37uFm)CU<9+|Y9EsRr+@I*Zs?|Fr*AGa4wfT@> zyV1y_09U?Ntp&p|Y?po?*;}V1Nh5aT5LRrw`6ikQ#-o(Bc?#r3+y;HH0x8b5R_`Xo zNnO1LIG2g8q1u(26OA(K6sV#qX+Nw}wnfh;d8I4P2#yL zO&>;`_Y2rt(66OR(ZQ^?+_TNQwyiqC{}%tpKZhS#Ps0rb#kD~w0b><^dKq22jv=%PuY ztIb#CCV5fzwfsO5tQX8{FqF0Q5eJ7LT^Ew-b0(F%*KpPAD=x&Y@*D)EFQ!jMl%g69PAb z-Ei)>(Kd*z8=ZpR2%QNJLGI9l)QYLT#Wqz}Hjd?@UotV)eL1ObVHBo6l0TF7b7jOU{ z4R*Vb6T&k*87FP8HSR%YnnpEdx~FOV;x)OK!~1~QBp@geG1YYWQ3Kf9fSs84@_ z>DnG&KgrkX^r!gfpZ+u-l8^O8zqaueV!no$X`_}Dlm$oOlMuEaTWHX)2UN4B??PKH zaCw^JpAy$%Y!J~OQ)4MN900M;R#=-SpcjiBF@#&lg|;H z6arZGcDM=5jh>GmNrzizL_DO_iw-y-huL>6=McrbV>o6Py~c@9V|4vAokexnZ{h_? z;Yc>z+l);HfQ?o5|P;@ zr1*`d!Tf7SG@qmgJzU(YtJ!iJATaK~Kr=0q<=|#@{pJqUpOB8`6gcu}P; z2E062WFrH4ZmFE<#Asr4&)kTi_YEl*Lj;<4?Z@$_4IVctBm7kV{*!ggFZIY!$`x&^ z%O4Y8s{jA_g2J#)Z-j1wFQ{Z^PVAzelD$*vU0Q_m0xR9)ccY-<&tH$KvI^ot5l{Y+ zV9^Y}(1x3k#BkLWu8v zN8K3bXkph%petjKtWGQ3&-VQg+i}Tz)MU&OMVT~S3q+<~JzW6t@ zuIDdcrbHRiGqh%CgeCGd5H6O8ydVGqqXF`Q0O}3V#iuDL7P@PO!SCgq@+p7?4@?O-7@FV+430iL>jSN) z0Yy+>+G@$O+}bNovykvuijdvfhcGY3Dky;JPDLesJmerTf!Si>7r># zE5p7Zy~?84x*2fghT?7<%^t70@-i#j#DLXRSYpNY0A}kpwA-nH6$PCPW%}>lTJI(U^2Dzb6@k*b?Q42+)nm_FcP0pN=-~F1R{x zLw+Y*%!X@3R1zY?7fl8}GZ{WPD}y9N2KIHt#J-K~*Rx&$8M}nKTEa5EP6*oSxN;@A zNR7D#jE+t!u(=$a3tQg+{;WIKcsmKjZUy~_Q#o zNGScQ$s#(twJIfx0dtV`C6XmPn~yH0_zUP7Cu%9*R#6OwU4&-0u1@Jg3EiU^bH+cW4cA*GDa-0r}%}{6Zqofa_eTGF%EVkV*(bn@pXdds%UvZ`5g-k z;@K%Bdsh=06!RUpl*)sYf0&3&wZXrB_;CY&WPKVht));+9{dhl`Kooob zT_*n$*JR{?2D2;wno@>D4Ilv#g_ww%tW;cOSHi0)fUE2QeNlaX94NekWeqtZlFTS@ zkB3X?qzH|}e3--%N9+K+5SNk&)z~UR%s9`G7Xti5CscpO@$snU2&akgbD57le?+ug za`|6)IpF;Unc6E*Nke-X6Xwvla4y*8UdF61UNmpUAZmW}pc&Uzp0!Cmaf(2nQx<=a!RuHEVwW-$cN8hu7|xJK)sJS*## z8JnV}_Dzpnt+ZEyH{q2?qsiAl4yfilIWc?-0io`3a^g8=_RZnBw~&wT;Ws*rO<~Jp zI6|=?-as6-xF6Z$qZG{~-i`Y+lXwR^MR8!}atu91vA*nJ$0))CCXWou4s=cb0}7qt zS9SVTNdRX*Rw42JMkYZelb|BGvGaiXoT+6V#p((n&DP7UOMj*EU}Kc~TAW`Eu|xP1 zyB@cvYX#raGaD&#Dw`V-{>(Y+`-r6P>zGpsnYVLdVWyvtGQTbZH-$87-eV4Ev8^lq zeklXz&dy^2@P{*hfFFy1X?$~GpBCA}HY{5-oQ#11baJkr*gs|Ri1Ah|A?kqg5k;wrlw(`NJiv=iGi=gF7j zkhmk?18{O#>7o>;ajs!9nLsXU@(xyyo3Bi9V!}L(*g6q(62>7-mJM+}x!kIQu+DrJ z&yz2Y%fJqX@6vhl6}(a><2xAWg}!Ke$nM2#b7xyipBJ~qYpkX3j^96LE&qP}{wHhY zlDLhY+qL|v`2BTV%l|Qc|8m#zpT+Nvy?mu@+C$EQ_mXygDTG5N(80HijC2(~HaYzP znhs-j$E!f$MO%={8Qc&JK|swp{y0B;&C~t7-g?&jWqo_TCleE-F?pt3pD(P-JGj<} z5av$V_$AU59r)e~lY)>LNB=(8?8n_z?*KU!eHe0RpXIoo#ae)J7>Z^8K(4V0w_>fp zX}FWu4F+TVcoq==-xdRU##{!V+j@X7^$`~_KJN!tr&p?4YFyVSFU05aPE6}6;InbL z_a4k@Vu_2l2V0`JuO-9-R~H_MhZEKCEBe5-;MuTVKpJrp_uKNEe9-fLbAZvtxk|XT z!E1k;&yEv-VN>*D5ufVv##0|lM}XNspx4d-u6Xt!(!0*l8DNQE=e5q1;f2w{ZNQjLFd5|U6zN& zI+ps6j-`S*FB94VHYI*bxiws&H93S^0M~p2MsF)tysaC>0$FCFu%*U(n z;bF;Ebz-QTi`D|EIB>Dp60e&#@WM0NK=(rbPoaFXZJ^s>daKu%cd>ji{erV-lw~Nk zzRkdg(A;*5FEO|lz7X6qiffWi-E$Avl!LxI3Q5B}G)7~2>+}jvDT>43y!K@NN+F<} z9Z|xxTVfU{{L#PH0fHGvght#}W_WIFvQ8r`JQ_soc?$2MIRBE9c|Bfqd(GNN2Y1b?00EoqXk6H@X|YoMgw2_SQOt zFK`c3Zi85*KAZ))nIW3qjqXEU-DK96Z#_|fGDv5W+~}Tc^rS>HNTc(u9SDKJk41^W z&TH-k^W%Ihg&Tc^x&Ib|(EbSCa0Fgn8gsc&Ds&v*?cmrOIPR`R%6#hufGOK4y|934 z3pWC|g2fsZVNY+aKfDHMad2Pjl}KH3LkO=)lyAKSLCUnjC3@k4oX%d(X%nfSm)(H6 z#~DVD+!94JmR$Xy%1ZpOL2on zU+bN$HJv@yNhHKU1w9Mkqs>SXuR-6ulFnl4O!{Pg2VF4@epCXxwRC`z7hy>Z6~Q3B z%xqNaCcNv)+EVN7c+aA-TmQ{`cAW3wBp(JS0L6yadgEdMcq&N2m4SZiACfP>9yryr z>J_JQR=w1^1L1kqA2JPQw;D^V%drZ|khB(GN|N2W74LnX#5B$>c{pSe>wSWuG7i5g zwr)!jg3*{pi?Bc}U|Z>RPghOcTvf`q4qr;>r;D^LjUKP%4iOk5`92fmV)Q@C#9X=z zF^ayK@AXROKUj-+3Y`8C|I zN0ue?hHF$Rd7tV&w1QyYj)8ThRt}j88BnF5a=mc*21I1IoP2@HxYV;=afQpXvjgnd zW?bC*s8Di%a##*fmdzr9p&k(6Y0I6EeMz<54nmZpy^zSHa2vF6+bd;EQTF<$mx|ZR z4Lqi+bgMyqL8*xDvREo28n)PXy=JAgb%k|#<=QH{{1d^exT<)|Wp6&Ns*fX49K#zg zdkb;QrolKy{C+m{!5+xJEko<*)eup+e;Lz#*!^K{m*TD3USetH2ROgECi3K}rt4y> zlVRCZ{C*O0q4l3w7`$+7GaBGfcQFIgXY9r?+(L!v(k<8;C+6ZYcw%g&rXo(4ne46~ zE^U_pvsu<8)NP(blNKn8Tc1zL=gGBHhRPclJ^IT&%MW3L*Y(;uTTD<-ZkG~Uv1oC3 z{R`)`9X787<2HdmyLHjg;1aAZKNo>5iP_2+S{2{Sr29TJcz7LDWFMBc^mX;QeYrlb zuh8fB<@|-4OmDuiS&9Bhf{5<9xcLi;@rNqPpWQsvFI%Tc=HNLR~((ot6_9;q2cR+8uFIo*+bkTEVkKyC7e=Y2h4kfK`$jM z?eOKugU#W^*2cqPUp1VxIMhG#rE02lS zqdIc`5({!rT(A}6wXXAkHuJpcT33#@wgc{qQRnHzVIYQDF}`#bgDPl<=mzit`!L=P zrJ=T_%(v*8Dl>U#*2wDQp~|}>_t*UmW$Fs_3U(mNHK@H;(u&imJKS6g3HQbdcEJm8 zVtvNu(CBy3E?tZLz)Ju_=dGgu04bGCKLg>d|A83G6elj!QnJM`?8bD%_$!bAW4CqV zaFBAo3-;E}kW8e{AJwsMN6;}1r=i$%kRG+v zRpZv^o55OL67x3j0b^xO>~}`oj1c;6eG8o}_dmdQGAm>BdZbcWl&xk#{RFd-$2V7; zVSkHK#)`-^0uAoNimFPVBc~rVeB9v{ zEWt$bv61cLH29ps@yU~Ncv*%2x8Q$Zo)tWu!7U@tAAb|xFaysix$$fC{a^XMm+yPF zLawL3i0?Ws)uE7pnd$nXKahb9p?>FZA-u}_^5&sx&?>-Fed ztOwu(G0I!|f_$HYyE`lP)f5$3K|ZWYEY|-QnDYP@L(ZA{&P-~)uLl9v1E|ZGg_N{# zAz26?i}k=~@#E`Kc@A9kG-ZsITcuU$P{eC3O}>h_@Ml2Qz0{uvf%-ha)t?oM*!gpU z;`)|&RO89&7X2cqs*2<=V2W(wZ~}ciU-$)7O=f-D% zJj_?41$_;K;pIqCOAK1K7G4B2pmDx$e5pw|HnIWVM)!0f@V^1-ZOF^#=M~15jUdvh z`4#xVGmU2$D{AL#G?FmWXmV&YIc+p?|LAF>$)$}Z2YWiF^)LrmHkz890!|xD9GWzi zjsUg}OqbD0k>-H4Nhm}|bC@$amH)WdiNFuX^}<1o4AWKG>E6gnyPuKvpuW&Zd(8+t zj>phdU#4Q`0G5?^KO^r1rt)4h;!dCx`CG|eu-bal1%sUUB6Jf`dKT0O4g zINQ44K4Zk`MPslIb<@g2Jr_v@=CPcL*BFUZa_ZNJuB}e z6}rykeJIDPh$lJ?1r`rs2s_Mc{~l=qd)I03tzZZ7fX@?pG#=Bo;pvq7GLqO4I$X@j zmfU2?V-X-1;eUNG?&^COY3d8TCHmrHs|!PHo(F{O*5)OGhV|s+pl&-l12J+qQII#M z0eN{n{3zn#M`AC!)@NMo4>SBpcb>@gy*!qHv|>IWkUjAy;`*5D(N{|_6wKL(D0>yG z)m;XUgMWP)6R9|apC`I{(MO=uF*|^pyx}sXpXC17q%Pp&pJZvV*M>Rb6&H2;5od{; zi|q(qa?mLG`l9Dp!l=OrCYhzjK~B*GQ(+E|f%=s_^6~-iusJL0)z>FkscJI`k(HK8CPcHY zXCSlMJS-v5xt+(^5qjOA34PyXU0%<%;5xg!{TYbskR4rUm>{Dr%@y5+D9HLnh~n{K zL1ojk(C@a61MqeYab>LI$(PU$w&260y9DXV#qm{02(Qzn{DO-s{0Ee?+ye*IGZA98 zuJ@MWfM_wI5ee`?v;#ktP2UEaOFa>cW7(zYwVnd3almVockbIH6FhFW5HpG5=AUUxn3=mqs#fasMJ?lBt_D4mzCZJK|vYxmJPjq-I!0Ozs|26e~Q|a zAA(JI5-R48cxG+Q|AYzlIMg^!p6m#J3BC_U`uAkQNA>i%@cn=c^)71!_TkCDL7lwC z#r9md%rh*xI2mVHwzvQp=UBG5$e71iav||8LrZ1J^DRTmT3ptA%Md1a<+-B8<;k}U z4HjBlgM7>0&!W>@aV`2od#EzF>Bgbz;OLD*1Iuq5T0D68jYCV8+&Hv!@aP+dmJQ-< zdH;=jId9C>wyS{f6Tl zCFZ(}=>zgAOl!9o@J9wnM>_rAeAOw`FOWc3l7B+bGR&Z^virlYFbuWvp9rg6sHLC! z4}9Rv;osn)Wv3k4a2Kv1}wk`^)vhg3LNc1m@UO@E>t3vrz|*flR@SdAw z%@c#4IbYWhq1(5vpYW%xC9|b}8phsO2 znA5+r1{WR}OSUcS(g+3VOzxZ%U+_xs^;*^k*lZV_?)pNRN!u#(eOq}^gzp{mOT9aK z3~BcTLA-VF3u+(8* zv{EJfGUPA6b`kbAQp!x}h1WHlpP=QK=)nsMET=aO24{>z%B=#{B)GDNbSqY&{Q;{E zCadS}EOPX;nQ7MDMJiu#Qh*`g=iH3Rn5qVeS0oe1v) zkr~urSSDJKgSX5J$>sx^xiSq$BHOooE57Ff+iRq)GLZWj1kO+qcTMiw(acpIL=pVT ztG@z84V6J1=H07+E7*zW&~VSkAR&fSL+xikxOssHS|D{)UIrv45dh+}Pu5k=u1+kp z@ESmTxHkf7&bm%yM|F}4OJ!|uR!Vpyy9oOPrA36KyPoHCgRC9PAJy;e`5BO6a=GYl zl~?b&k?-4nhV=?SbC0~v+%b`}o(a3Z~uJIwIw4m`Hp#ff%6=@8O5ySJ98lRL;kRDiHHSp}E>NkV<(ior*5&K+3=p;9|CKB5m3C)}!aKO8y3VlK}!3 z8eRza8_uW?#{e5{wWr=!XyVe*tsz$3d5s)5q4bn6xy02b$TN0tDPJm#9foC4MQK-H zP^p;VZM7VXKMW-xq}Q>A5X0&XFA|iRqYPfM53G(gq!|vEirNg9cLK7Ps)jJ)s@?X$ z*m_eFx3W)E2p~luG-pCE>^2Z^kpLDO$0Z5Iek&!p6u(jutYXC5(aVrzQVZKNhQ&&v zPLhl`)OKAtp_9#=^;+$=;~G#kQz+#PbI1-zfR%5KfJ)XxV<<^nHJy%%jHygREh$Y1 zb2q@Bfxc0Cd@1=0$h&pzn0Gr%`TmKl0yKo%)L_!;r}URr)V>|-;5ig~N#ocrioW;!qsDD7BWW&<+S2A__*k!a+6%ry;tbTgsv5Wu$-ahU z=)RrsTX<2ZI-b!xY~KJ}mE!mffU4E%NAIWB{0;}FJaEXY8p44gtaKB*AF-HtQax;@ zL~x)EyboUUG_U!j)=OcXx88~$PFiB4wf2{oIa%Z93$i!|J>yUh17P%0o5xVx@SQMH z8*n4J5%f2FRH9EaGPn6m^kPn<&uM*>Sia1Gz;lRsVQVq$UvV1<+M1pZ&XZsD`wn+t z4Xg}j>tJ&X>*FA(O*sz1=z(5$>1g1n62K`5=6p6s&IWuV_>^v2znR#(kovz5uH1dng&BWsbaX%&*V~QR#D@d^alK?^y3JZNC>oaYT>ugoHEH zYWAb&L)UYM$VZW8beWsWM;sgFqucNs-jAP#k2{%{))v>&xDR#2EvXH}EET)_DnJ~) znS~`CJ3$BgJ{Je&iQQfilo4UnA(hNxf{2pMgdI!T3HsgAUZjZ9UVPZ2G<-Vpl4zwD zXX@zqfOOy}8lJh5LGn*XI5461`~j%*H-R?k_w4Zdh?2e!3{ol}lEwmE({HR{^PSh7 z2ip8JF-&{g8!*ie$B(cWFv`Z^ZsP89DHZNP)huvfYET&fGbS*m$TedD{tR@l5T{~^ z8e^Oje5L&2iNQagk3Ep3!UTFz4@>TXt?)Dje`^$wayLNh<^VJp-Ppo|Rqr!?mB6uH1{i^Ur5kaaizg)Xm#-v${?9=S6IuO0CN3wxo!$awIUy=+Bz)t!%- zl<#CxK4wz>icTiwJD8;2Rc~P96==9RN0k%5D9A%+pD6#zy2Fjig|eHWdfOid{m~Sd zXwQ?1n!Alp0Q-`U#%#chMifvN1&d z7=cB9@z@~tm5d{kjix}h!H@Yja|w!TCAqy*Ao+;Hf-Wb}tLvf_$D_O*McN$o z9E$s9Uh5+KIhjED`WNK8iTPCb4XaZ}JaX!H8A0DIem!yG7|k^o2a2m_b3ogBJjOnl zKswTDi}m3d0_lWowM96uR3M#@t+wb_M+#;z1%p(%n@2VMCA|1W%!}_p$KIUs;>_8+ z*fIw%>UARq92NGDVD5U#p1sj3TVDoNv^oiOR<6NT;s>4+pX6ta3 zh5*u_I$Wgz2Q`i?jR)Wbco*3Ku@FNC+lhS08R&mOTlp2`V?(9=Kf1CQ`(x$o!e2A^ zyv5RY4c+|_9>*{ZZtSI_M)enT7nkeso+-KSfGh8_=UwHv0QNGyyyBwx@``f`yZTX~ z;)j*XD~gAsT|ER|%H&bV3I=)?M~12)^H~p0SK%F?LecUio=O^A_XUiJeHAXxyZ}xt0tCH zKrq`ic$yo!eAhKF6QJYm+sY+wqPJqBB=*>2?!L zsFAZeo?i`FlL3CC2Uc?X4Io3v3||Ps*r?zs*o)WVerU6F)m!$2zUtr;+P5Iz5PZqe zyYM0!pj+0z<)inpU^1(i$59}cLu|_(Cs~xhL_JI646FM*weM}~2c!REl0F`TYHl73cbOMM+Nw0Jo{ZX~{E+f|-c)=ag#yyRC8u$EPCmyj6F2UD3!Rv$EUjydC9ND^8B zhds?4cKRS1x9#AIvQFFiPV~d?V*TnA=V6F4WxxVmEpi9UeeVE^}%92b<$%U{+CPLw%X-?e-eOSi%Iq5q35m>?)ii7U+Z*)~h3Nv;}bH zy!}QGn(0C3NTm=?#lofEi${72uu5-1+sm|!0&ufw@Yz6y?5!Q9I9omizUV|Xjuy~~ zY8KNJnO#O=VmA{wQ@kUP+hLJ_25!1t8J1GMX+#Q`ikVJ`BE3_dHd)6(04ZWzY`i z7Fp-|f`Yc+oN@7E;0VroM3J97>(MG|XL-7)UFAMerj?YbIW9E# zQ<727LzA`1hV?o8luv>4@|pO^rDBC`CiV#(yQ2jv|cZ zr8>5O*!ep431Xkov7ZooQOCL*V6*TEq+=nme*pG<)Ovj=-0c*i0 z5JztvY)&0)0kLJe-{Xj#tYcRb`@D{ACHAV09oPr#7<>Y>$S7>Hjy*_skLuVP#NN`e zCKp%=pFntXi7nKz1BtEHu@i~a_&tr-*}A(g61zjkwi0_;$Noml%xScwU@Uj**kWSK zb*xNmgN|KB>}nmmpV%WhwvAZ0UyHW`##$^(%+cMgtb>gZJ4|=?L1LSA?6x}YzCrBU zy1SQ&{Z_}EJg^~r0{M10vEy{?5@I!cxq{f$y1RRb-LGSB5PM64zaoT1ZX*) z*eN=86|w7e>|4aXr(;`*{Z_}O&H+}Fj&5QOK7n}mtK;rqVu$PQ&L?(}j@?7-ejR&V zFr5c~A+}9-H){}BA3gzEC>5ZV=7n@ulaAf%VEYg|SP$<^Vw-gA7Gihm*w2W)s$)$< zz-r=65v!>SI}*#`6G+EV#A@otdSYeW-A9Pk(03WJt95s`5W7>yeo5?g9Wx5RqWA=8 z$rCH;*j2K+*K}<6oq?^yC*baEVjtA8TZrAMV_S*6s$=n8 zfYtD-g;)nZfjE{D+f&EZ6D#Z3$B5PN`6^=9>+T*T_K1%CiP$?j)-?~=I`&m!-_o(45PMO_8s-C=icf%+Pujq0(y^TG_S4<1Csx+6>xk9({XDT-ba(d? zdq~HALG0H$wvAYLfks~n#&Wlg?NSF@Ol-OCZauNGj(vjIbvpJSv6^%|MC@_h-Cycp z#xUGP@d@xWM{E}zJBHYaI(9X&ns~1#_C?*@gT!jWdz4sBcu&{CUL^KQd;;_}Ed-Xr zCxGojY_X1=TBmFrL3cIdQ)~lI!cMH??lfX&>v4Rhj=L`qyG3`mmDsB~W-J00#V3%C z9f{TOG)HW%?rzUI*nz|j)7_m@2m27QOLTYNAod*{dzsklI+k4w%)uu>^Pa>G(6LL1 zU7=&&Aod*{dxuzfi5A|DFqZptY$35_I(7=NGj;4TVxQ8nJBfW;$KD|JmX5V71=fL2 zAZ;s&)#S%W9qce-$LM~qCiVp#yQdEJcpdC#b+BL5!G2BbO?(10$9DzRf=>WjOl(gb zTTiU4V;>`Sm5$v;>>E1v9I;>Mn6V646rVu6IbuZ}JAzmZPuCNx39nqo-3DUk;}eME zraJC!BlZp5-H(XX(DEFymvwg?yG_Qj#2kDA@h&E|T*nTp)1oY9@nwI)WNn9 zvsP$v48d4lpkwzzB=xPh%LY;5XULRYT`Y!j^Fd^xVxwh_Az2t;S-4C9%A3q zu{Vg-l(n~r)zpP|h}G2n@Ls@b@-0rRW=z;ZtOK6_Ek_YsuVWvqgMEzHr*wDUBleJv z%~}a8hfg4m<#n+Ah#joE+f3{V9ea@2qdN9CVl{ITb8ldAd;;Ws;1h^rh}Z%hJCN9F9XpfQCLOzuSWR8{GO;^!cUy_Qs$(4o0L$VNpkh3Nh_9-2Elvquj{t>a~baySQfOX&#h$v+?9qfB` zu!o2}iBEvOSBbr@V|@n#8^R~x?qp(T>e#Eq-q5j$gMeL#Pr&ar#A?F3f!M9OyYvXK z3_bzB`xC42dkC>3b$3q?dsfHRzi+bNGO@Gq3B>Uxv3GQA%fY~|#3$hHVPa3|Sm+R7 z348+X<`b)_Te}jgS!-EAY;WD~`-zow>~qAvq+<^dtKrN45c{$2E;$M;jZc8SU5V|b zW9x|3>3&dW*CqQ%a*kmkCEQ3$L-6~>- z>evLa59`=hh<#1ReopLHIyPlBFdLsh9J>R9GbU_JN*XxX3GAv$&`u}|vQy~Mt+V=vXgepLti1F^sAetQlB){jqsmR*VMrDLZO zJ4?sDMC@xi_B&#K*0HuVz-rpv8N_<<3BUwVqep-AJ@TNAoiN>?jOYLBed}PVXPhJ>`ZKt?yf}a13LEE zI@qnmYQ|=F5xZCS`$uAL>)61Nz~%!h<#VbD0;efFZCt5`;G1{aTKtc zJZ~db6W%mpE@3~gHN%v$r=-45|j?}S>>tJ#{tEP>(hVE|A{XRqN=Q{S+ zI@mvm)ucCaEU-p=0=!y6Y!4kmCiaw${gK$)I@WwVurxja`gS9>uZ|sE2Rnh-xbE(2#O~Iy zw~2+;X>p`sEN66VKCxYOYz?tvb!-c?}`0Y$J*8dn}$!22X(N$ z>tF{FJ5=|(h1iuk_8766z20Yty`a1MBeA!2Y~~5TTzmrbts*w2WB*kLyPVjkb$1UC zdrZe(Ayz}*?}+_bch`9$u$p*h659!%0DXHCd!LSdnAqhy_5`tKbu4xgup~Z#@Cw9+ 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 j(OpCnM)2JM2)wRRf;D7P#}X(x=5oda`m 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 + + + 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 CU2/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU2/ExchangeDkimSigner.dll index 96c80a1674f5f8abb99840ae7aacf8379128c4ce..3371725fc7c30ec691972bebf817d8e61dcd14e0 100644 GIT binary patch delta 137 zcmZoz!Pu~ZaY6^PcuCd9?(+(aESsYhB^3o?_{x5&7N&Tusj3h7kmi!Ixy7lUmCHyWoF#rJ*5X&$!FjS-iu_psVP_Rod|GYg4rT_0Z%x%qGQ*`}q(&ipdCT31% gpju|2YUa(;eGW1L&586|52Pk@1{ec5wgHEk0qIsMA^-pY diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU2/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU2/ExchangeDkimSigner.pdb index 187ae4b24ec9febce554a7fa48d571eaa7bac8db..bd29ee37604084a1581b6eab13e5a044a3f6f426 100644 GIT binary patch delta 782 zcmZ`%Ur3Wt6hGhg?ccX=ZZ&O=wYiPvhODTms|GRmZA4)(wH`83)VJU`9EZ zQI7FKy(Kx&%K^ZQ(lzh(WZN3SEOZOXckq6wkU#sS01_1Uu*d_M{tXf4&D_hA2ST(u=>`}ORq{GCXyy6Y**t*68tZM-h>{r;Lda4J| zGksgLt_$}@(OtPno=ZzwP3N15S%=~?GfGF4@4Is>F7-I{c%~1TZ9n&O#plB(FJev< zbedjdWhvyKL8_4Y;d3tuLIV;cE--iW0-K2X_Xe@63X{HQx(P<}5{zo+F;=a_eniaz z>7{B(WKFTq@dR>K2@I1p?}&hO5rk^n2}oBJ+fy+fBrNGA?5LcIF|(Um$!JtEnuUzi zktIdhr7m#eXZCb(wX!EWB!&x0fC}E`WAvl=AVG}Fc*9rFPhsuqRwooO`tWyT&@Bpp zA@p^{=0mf@l#zWsY+|SLH}H|=mHZ18R@u#&{Wc%B1JT+|0JyY1ctCoL9 zxiONE9q1bLIySw~pqs+McH+v!iVNP>6plfn9-@<23$97*Jsi6hBN?Wf1jKt6rR|ar b2(w&zQCruJ^oMYF+PoDBctW->uB!e5jLWd) delta 788 zcmZ`%Ur1A76hGf~_wVXjHgk%tZI;=C4|ZKvgRyy+FB55K4-#!)5cIN;VW9OgDLJ01V5{}VFenJLsGyjggI$QA1BY|&`F`Iyzu)<8Jf)4N zw9|rEf3C|MVE|xB&pXd-y!20uMWd$pg3kMbjOIA}r+dlA_9u8o!MB>GNaPAzCO zot?y}8qrg+^@)LdgeBU9?GgDC*~8lc{X5-wU4?~*zOECDR1nNv#m@#jtjOO6tR1AE zip78CM6jpYz&yJpM-50IVIwA933%+Z2Ne?jWjR0)+7Cg}%IINkb)R$+~H~TK0F)TybC3aE%*R8(d#q- z=g~iDfUkA*@})x#-k-h5B&D34)bXp2hVXrpqR{ZazbmHL7hVg9uPolyG&X;*{Tb4P zkwny>8_;X{eBQw<{C&Q~dmo8y!`dhkAVD|KNvI9KNoWEI*J32Y6gE%{^}T|zPT42s YSh8T;9>n$sv6{7RMob~7*b6JV--Bqm3;+NC diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU3/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU3/ExchangeDkimSigner.dll index 060f3cd0983498129a35e5fb4efbeadd56df2cf6..dc1cc8cc97563e7106f80738a24a7b85279d34ba 100644 GIT binary patch delta 137 zcmZoz!Pu~ZaY6^PcuCd9?(+(aESsYhB^3oO7I{yy+I_-zQ_nx9->-_lZEkVuXJs_m zEaKtAr~_0R#{dLOKrF+^z)+D6#GVWcLBTG;m0PzJFFl>?-NhV#;bGszC!2dbnV30Q hfNGh6s#!Kq_c_Q2G$+z;J&>Br8DI?L*ajSC1_1WAEZ6`5 delta 137 zcmZoz!Pu~ZaY6@kl`HSY?(+(a%$uVXB^3oi(`$k(WttsVySZk(^W-hv+~U;F%4ob< z#KVVC2dFlV0SK6YScZ{-p&}iKJsB8+f?a|?1bcj$ni1`{M$uaO{Su+9%{`t>%$&?X gwah@(%$ukC9ApHV6X~}eNKNJpFa~mL0}e9-0QU@cVgm_6+93uk*L*>?O#Y;~odv`I%UwGIz@yTWxE*%Ah;;%bRoSrqR zUDB)bQ0VOFl4fOjkWi{RCs3 z-R(w`S6NAdn12r$ZT@Bz!@{?Lm4QKxje((rhk@Y^&qPN#*(;n34E|g|>ybb%kbMd$ zW;S`Yz462VfyoQjv+#NYwLW8EV0gp9z>qNcy}dZ=B5no-?#bK^#+*SwvH3u(xY2Pt z<0K~z_MDZy2jrNpP3Cv9Wj+_Vak9TttQR(vJ)nZ!hl)&H%DOMu2SN=9&D> z$x0675SS8)zQlDPB_Ical=yQ^R&q|8yv12Z*9@o&rp)OUdn8C1$h{zCAh}c^4Fh*3 zKXex60{IstdxvMTmW!2V0? zMu-`Zz5)#4d>{@1$`wF#GTa8z8o<;s2Z+U)7#Ny?_ze>{q9-Tp;GcZYQebk#_7-3y zZ@#;IH7ihda{J!WNn9+FxRO=zX4!rBSwI^89$L&Kt^QaXYLya@26;pfh}nTybn@<_ z@|-(>4if_M1Sa1;s&3i{bOy*%Gl3Z7S#cmA2X0KF!**^ui1 b0~^4^nO5Lm+`6!w273jz~P*GzTbDw?{~f%OKM|D z?X)1)jdq$N3;;fd_OD*L_+IyM;G(!O$Tq@+l> z*>UgqSpzH1FMT_c>bSyYnvHrvHUsd~{Q+e}DjS%@OBsnzdg?JN&q>O6&r!j&O%D*Q z1Ss%6pYu{sa6B^sbc;CqFB`x-k2N>H?rU}R7y%~GRU@KZI)Ehs;62tOeA#Ey-KYRC zadUes_5+y4b62WkmL+7P;a&RTqL_WbEwWeparh8FD2D?kj(r#Fyu8YV3_~ZGVPr z#z-Qn&<*G{{9(??Ec{Kb$$JlpRby=o36P+x=p@vJ-y}4SgljO8VG6%c4D~&au~yk3 ZW?3R{+z`O_yRn+Fu0>2Cpg8i2y59%uwrT(X diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU4/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU4/ExchangeDkimSigner.dll index 1071fd4dc3bbd756c23e2be54b8b94300d05c5f1..c69315af809bd822e259cbceca5feb9fcf2c4e6c 100644 GIT binary patch delta 137 zcmZoz!Pu~ZaY6^PcuCd9?(+(aESsYhB^3oOEqUm^==4^%uJ1~c;#VK-+1%pP&&p`B zS;WJKQ3t3tjsXamfLMl+fuSNDh&>q?f`VOw!~ZmX-_a88w%63d_T9v~8Jl}NnV30Q hfNGh6s#!Kq_c_Q2G$+z;J&>Br8DI?L*ajSC1^~wCEC~Pr delta 137 zcmZoz!Pu~ZaY6@kl`HSY?(+(a%$uVXB^3qK&rjC(S-rq(mt@Ez{r3ubn_HavSs9Ht zi+K1j>HyWoF#rJ*5X&$!FjS-iu_psVP_Rp|h{r9B?=M_E+WzJ&P5yV3adVF+6Ei0> gP%Sf1HS^}_J_i|r=0y6f2U3$c1B`(j+knH&0Gp#JCjbBd diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU4/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU4/ExchangeDkimSigner.pdb index 7d25b37610f20604ecf3443ef4579db52fd33130..01e181babec11c53df4643a61618bbb741836b5a 100644 GIT binary patch delta 782 zcmZpe!`v{3c>@cVgm_6+93uk*L-?P@?>kz;-S(P#*uI-sH)FF5myUu$@zHh;5=jN127fM~^++HW$UX%W zGn+iy-gshwz~lw%S$MsHTA#5nFudVlU`Uw!-d>z_5jO(^_hfDdW6mI;*nA*X+~~NS zagq}UyLMvU0Xe2?llh%&na@RTob2xuE5{AAQv+zS^dket+spfcGk|Q65g^;Rc_x2z zvXTQi1g1oyFL5163CMvUCH`EKm7LQiZ*kVqH3RB`DRa8T9tlzgaxX|3NG=sf!@!-% z51oa%K>h{E-r>qw}kXn#`L2Bo3 zZgiO}tOU{u0wAY?0LU#M0P-COl<;g;WIM&UDM}@PQDn2~s%9ShQ_Ktue}JJm7l_?} z5n=|UuK+_hABaPMas?2b47Y)_1~7HZ0b+3`28L!Je!~Qg=*bB?_$S}96qp>by#*M_ zo9}L4%?gyA+`hMT5*Ldku4GlbS$5xj7LbO&hZZwQt3MWpTBQV}K^_qVVs;=FoxJ;~ zJm(Ie!-Rl5fyuXzs+%?fodNRHOdtk%RvgF&dA1+uY!M(00zf9%0Fb#oK(C2yHsm_M bIOzn3s5j7f3!vz3VF(RU=(Ab&#A8+fc44v> delta 788 zcmZ`%Ur1A76hGf~_vc<+%eI_iYpybV@WHOjYA~jE4P+t>?LndqMg%=*$nZgZn*EWW z7`E@FXh{$eWQ6k~%l^TH!Rn!)=w*XN85RYBD>A57=U^8i=)mEed%oXy&hK}=n@H;u zY5lw)HB1IAQ3e3^-eTMO`(W?%&*2-#s(GevliHh``#ygiH{P#XOpJzic2~|#lvO#u zG~=6@HnGyv)%CNPo=a?@-E0&T3jojD8&N0Zs)@shMu2!N zK#|A%u8U#8`CJ6(mvHu9HiCHpYaV{p-{~GO1I(gpMnwAz0ILGP2dqc=n%`l#Rs$e% zOLr&s1DMBiccy2Fr4+NN5*uETaxb}6@##N}ALfUYNJvBuZ3t|7)4@tNlY=KPrxrAt z&W>Z$jOc0DhGgsxVTm?j`z8KF@$!zq&~^`A*I<#cFBO833W9lR_+-G#iu`rJ)pp_eeh4zFP95YnH{Bp3hGay6jMS0E zY4e%zZMJY^SD0;9TW+1M^*`1Fe8+vJ(S!IzdojMi9iBuV#Iwq%KH&*=qKn_HavSs6_> zi+K1j>HyWoF#rJ*5X&$!FjS-iu_psVP_RpI*0(TS76T>kg&+I8&a$rCw7JKViJ6lH gsFoS1nq~8JpM#7*b0YoL1F6ZJ0meX%ZNOn>0MHsCNb0OJlPo&W#< diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU5/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU5/ExchangeDkimSigner.pdb index f3bc5e6a80a679a7f1b32b6d94cd88b3fa3faf0a..22abae678ccf1c3b9d218342130af72cb4576175 100644 GIT binary patch delta 782 zcmZpe!`v{3c>@cVgm_6+93uk*L)N!2T^0i+?}Z=xyw0+&+q7AROGiPW`0Gv+r)Q07 zm-Om96goS)q*+-WB$TSo3Dl}pxR^Cnexu_I#!WgLY%DIk3=ES$ngwl+Gm_+BGBKTe zce~N#RaTN9=HEj`o4;Abu<&hQWnfTaV_+!ZVPLq!Gtp5__6jEhgFhG0dL)nwWS;_x znN6N;Z#*$TVDf_XEWF-8th{E-r>qw}kXn#`L2Bo3 zZgiO}tOU{u0wAY?0LU#M0P-COl<;g;WIM&UDM}@PQDn2~s%9ShQ_Ktue}JJm7l_?} z5n=|UuK+_hABaPMas?2b47Y)_1~7HZ0b+3`28L!Je!~Qg=*bB?_$S}96qp>by#*M_ zo9}L4%?gyA+`hMT5*Ldku4GlbS$5xj7LbO&hZZwQt3MWpTBQV}K^_qVVs;=FoxJ;~ zJm(Ie!-Rl5fyuXzs+%?fodNRHOdtk%RvgF&dA1+uY!M(00zf9%0Fb#oK(C2yHsm_M bIOzn3s5j7f3!vz3VF(RU=(Ab&#A8+f*(t91 delta 788 zcmZ`%Ur1A76hGf~_wTy3Y_=)3<|?xXAMCoU24il^9yX*geHhUOJ_NleGKAEp**}6} z*glA&Wl>;|5zdP&vw{hODN#`LvcaMZi-JIl3X0h|*o6o>a5(3l@AsYa`kmMikV}fC~79e2+ zDDgh8<5F0#zc2uFi#Yo)>&Lu^H5b3`ZFffW02Ann5z&waU_}7x0H*QWnf1-Fv|q0?h7K=_`B&WR_ozP)_wpnDSkQnR_8_qFZ5u1!N%fq-oLbOm zIy;V0F`}nn>r;LA2}`sI+b!}XznixOqT5|~U4g}hzOE6BR1nNn!$$*dR^o30mJZTS z#nL}>;@DGZV4B^Orv@aDuyF&g2HbYqg93^DGVdn{?S~)}^4KA6ancPkVn{|5$VeSo zf;OKG-(xdJcZJzzx%uvCqjyma@Dul$LGQvR+K2Ha?r;FT2hRpK?m`)33qHU#bgK&B z6#6F>@YRk8e}2%xqq#Fok}J6>4Zrw!2;Vm?3Jw4JyArbf$!h`e)rH%t#^(37KSOq4 zBoVdfI`lgJsNi5`{;tsCd4R;WU~LQukf5vRB-DoABs7JD>oAgG3hO9_`d+|jmG_Ey YmM-eI2C@ACtmZ5m5mN}t_TsYUH(8Om3jhEB diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU6/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU6/ExchangeDkimSigner.dll index 333f10dda93cb16ec12dbd57c3391a987e9e199b..e9fffce2ccd8a7b6bfd7838e3d18633177e6679d 100644 GIT binary patch delta 137 zcmZoz!Pu~ZaY6^PcuCd9?(+(aESsYhB^3o;b_8y$XODJUz;Tsf{kcavn_HavSs6_> zi+K1j>WGz8#W4T@6A;TVGB8x61F6b1)qUp~eHK0z<2Wt8Ok{J9ClfO# h3s5aHP&Lcu={^S;f#yW|tp`$*IRlJ=9NU1y%mCE$DEj~a delta 137 zcmZoz!Pu~ZaY6@kl`HSY?(+(a%$uVXB^3n}TDAM^Dpxx8T;pG|Ec)V-%`Hy-tc=E+ zMLc{Mb%1K)7=VBYh-DZV7%I|%*pq=FDA*v$@BUiJ6lb gsFoS1ntAhdpM#7*b0YoL1F6ZJ0meX%ZNOn>0G;P3y#N3J diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU6/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU6/ExchangeDkimSigner.pdb index fcb1778090f40d151375da8e57ed63c9b1c553d0..079e425ead6dd708e36f32ceff91b593ffd4a971 100644 GIT binary patch delta 782 zcmZpe!`v{3c>@cVgjh*c93uk*gZzuf)qUp~eHK0z<2Wt8Ok}eRmyUu$@zHh;5=jN127fM~^++HW$UX%W zGn+iy-gshwz~lw%S$MsHTA#5nFudVlU`Uw!-d>z_5jO(^_hfDdW6mI;*nA*X+~~NS zagq}UyVymw19D8)Ci6SlGM|gwIN9GRR*oBJrv}hu=|={Px0m+?X8_qCBS5xs^GyEc zWF-f32uz7YU*bBD5|9HyO8mJdD>Q|5GwJrbl0g4E96 z+~_h{SP7&R1VBy&0gzij0OUImDB;oqsV5}Rn0v1rPl@@zlQ*&;w11b|Gi0U&dGfL;^ZY{+$h bancD6QE#B}7C_P6!Vnsy&}XykiN~w}ur9A* delta 788 zcmZ`%T}V@L6hHs%?&IFMmd%`Ex4FuU@IkN3YA~i-Ld>M0K1jHM4?zzZGJH_!VfIB( z4BP*uk10_PQA#*3va}DFFjzelB)x2~J`96`K#K~B**VyS2s&^$=br!Xf6niB{x_D? z$CCOPL8=;Uw?-HMtoQ7F({%dQk?V*1EGO?yOsm_ZhT7VWFW-iZ56kCbgQ12pj`i|Hu?zx;Rz-!~x%)&KjuqN@DlwSf52;%!|`-3P~? zAv-XVh;nojdIf)!but@&pRM;kKw?|4HiiU9&^2@t>cDRj8b`tv7|Ae&breH=FJY`y bo1_d&9+u!dx*`(n#>rg+x%0ym?%`Hy-tc=E+ zMLc{Mb%1K)7=VBYh-DZV7%I|%*pq=FDA*;~!ES3`!>=ljDNTBo5^k0oHurckF>^8l g)iMKBGjE>mbC3~ePNd&@AT^mYz!=D}4LHmU01_7_#{d8T diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU7/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU7/ExchangeDkimSigner.pdb index 10554815f4cfa810ee4ea164fa573fc65fe8397c..f26ed6d7554d8f264546861f00c4036b1699911c 100644 GIT binary patch delta 782 zcmZpe!`v{3c>@cVgjh*c93uk*LuW$yA{plb|K$~FJM0#hQazQngMmelsVmEj|3?Lxfi4iB$o=LVc^c> zht9%WApe47@9<34aD-Ps?JlhX+wg`|00U#4>0La`Ppx4AU8*&|B boOFUi)Ej8L1yFRiFoXsv^w}(X;xQ`#7e}ub delta 788 zcmZ`%UuaTc6hEI{|J=KoE!T7`b5?6Tj97QJQZSvi2**ga9!8|FhoG0mkUh*jx%G#j zkmc7yk&U2-phf5|VyhK65UhuSq89}tiv@k&uWSb|J8>*3BxnlEWu4rxrAt z&Q4%djp(UZTXOU+VTm?j2POU_;NjiDk*zMguEHV{pVtURDhTFk;8Q^lEA!VuOE2lC zV)>srQS7NUFy%HBr~wHiY*gg+pvO*oP$7|@=6wXA{SahMnLfxZPP#!x49SQB8L1<&*Bl$B-R;u}V9l!W+0^c_!39bM8yJCv{(JKM*_2rwIwvKn!KSQ=* zBoR&M2J~jWRCF*ie_QPI-a}%Wur`eZNYGVu5^BY75}HK9%^1lrg2i?4>ul-_@wJNdN!< diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU8/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU8/ExchangeDkimSigner.dll index 1ad05b809d7f4ed2712d2d3ade9f798369339a6b..1623b72caccf857fb5dfac2eb6cefcf99c7948bc 100644 GIT binary patch delta 3927 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 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU8/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU8/ExchangeDkimSigner.pdb index 76633ab37c2c93325bbde74552055825394baa06..f344ace140543f71d9318fa5465115dd76455ce1 100644 GIT binary patch delta 8646 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 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 CU9/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 CU9/ExchangeDkimSigner.pdb index 962bf07af41f27363076c63ef90394439bed6b47..72ffb0c98913c48e6c461c16f524c2dee8805f04 100644 GIT binary patch delta 8646 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 F{{nA5ua*D+ delta 5460 zcma)A2~?EV75?AP49pCm!y+Jq0s=xLf{Dv0Xb@2Z*%y@vhD8w+0R^K`5`hGjgCff{ z^$@M6ZmC5PaH7U2E*Kk$8bXdqO_eMfTYDlk_SmL9Rq1zsB&9uPz{h#--gobJ@4IjL z@0&;2Zi}+}a;=|jsw7EQ1saqTlc(hsaZI+B#Z!}zABlQPM{5tMw^s#aZ?A>P?#=H- zy~fen^Z#W!l}lGg&SLhnuqJV(#y2nW?Duc1IotjSI1X!+uOCzsyW8uc+-elCn$ z^3J3TM;;F)Wz@#3T>)?YW@o#@N{dfcg|6OreSd4{0a34?VAiJK_VSB&|MYEJ*^JzL zQ~Bz!>c)f>L)q;9N88K$*Qey4{lgiX+MN#qzHIUh9?ItSLJx7@@nH1~r|Wk{?VaAW zFyZFML)q;6^El5>e|nG;JSXQyaP&<%)?@1XL)lzD{n_qIt|>>?|1jUAj$fL)ml| zP4QH$58*g|{b-%L8_;^-sYv>W7y=~LC z>9;8}#LG0n@~WtRS>u&u1!-7N+Wg||qT;mBrTNPXmKU!n%3M=elr}rNIB!kiDr!9) zNFfu4dj%{hmZT*?X|F5T%>ThIeTMCt>`Qyj8b&{tORo`wIdP^J&so#eiP{n7!kSF} zleB~S(0FGTao9tK<4ZRuISk_J$vGX(oNPW6UpjkAN4qAEFzX}S>@<8SeabkqcE0rG zdC#HO)0Z00IF24-cgl^k2Z^HQBcCA_v}O8miVd=%JyRV9@zXhN7+Fm-zY@OGGJO~o z0by=qeW`Pr-ykc}7l&Twhr|1xr6fJItP6D=wg8!ulVBEVv#KuCX>l#O*JVixw2-7b z&+;skQakDk1NtoEa!V~q!SKf=vyVtqV6TC^2(=1+enQ;@*$5=$9#KC_Wov_8RR`$_mPhcrG+c4S!*jTX+Y^Ls``iU-;5j@VhIQErs;^=9{n(!5?q0@n z7>s4zKrDyTk6pI3qzl+mB~Avjav=CA=GG6kY5d@K?3mY&v8)@2<@xqw)7zcA8O!Uy zSk?{1^7{5;tq+w}0{#fAuLx)d8M z>`BB03s;&E=Zenw76(u*ENk(Q+AX%r-l6OR?acR+raWP{nXB^u~E0Ilg^l0RlND%l@% ziA*jPNz{>SMEqj@kBF*g{%QG^+SIsUks#F~56FEMg=lv4FJISQ2P$3UgQ*-`WEA_U zdy!E-tRtt?L?C$kr{<{VZ3Y43f9lEh8i-w)GV!`3mFb-XK>B*b;d+>1yI+?E;Cp(m|`-A3%FUF z75IWX#B(L7%o8*Q^hMA(P$OtO=qsQJpdoZT%c!kEPv9?%{+^Zd>Sgp^hpq#(1oQ?d zcCYM5(04#J7#zcv=|DGuT7zx@^#H8|9Rs=*)CgJ)Iu#Tnl+7|7Us5Pz(S4Q$s_iux zk}l->Q^m43`Do?D$=78{%=tp>C7)b(vDY*wcc%~+se8Gv>qTT0c#-%(JpywNeQRW# z>lQS6#cRTu-dYhXJm}PlB(aTb^CrqSR5U9uNUWl_@`A;BI+eFozOSb6mCG@ z3gQrJWMS0E6ok?jqL5wy&t(E?G&L0(OrIC75fridjP^bT;bk663AGO7Q8ZK7n=*@f z1$35AdW$c}XRW*Zg`lHzohWVXBaEG}F4gXu;=8ZGk2y;{wXO3~ zvs6!a*X@$KWqSLKu}m7@*duBwa(x_JHLNd%{m2deT0NrU5Ux?ohPieZU>AX%X$Or0 zy-Ei+7}@xn4Ijz17BsBJl|Cr(6YZw%5~FOF+c&P#j=|tN$!DXNnx#7_W}``TkSMK@ zdo@&FI%Z@qZ!lE6We31`W8^vLyU?}LiNc*kS)tu##Z_P94TtGeUgoQ2X*xBP<=7t@ zp!b3Pu9n7@kFjJi*x2#_p`o|R3$;6yv4oUMe=k=8*!=cUZMwE^s+(!XJLj}_pY;xr zy5f#lVERi%un;Nav)LW(oXy1|olc>xqVZeuux<@ok|5t(X&_Cdn>PKKe}D2!bD)`( zleAUOB$i4ZuC3I=W^biYuCg%wv2vae1>{rZg*LLP1d0AqRgS2m@mupm1KKEx-ln1Z zTU|sWEkEu;r({NRlB_iEhWjAb6Re(Z2w?IKyHQ8MQFTD_QJ>Z%PM z={ic%ZyzmHEO(bIr3!oxDjY7(87dWxZJaKgXi4KbF_LaJmRP$;Goj>?L79ga3pYA< zcnLm1uOo%RKy;)S3Dv5pP>i5;O{Kz-er_s8R?9p3Dn&HUMtWM^>}<&iCrr@xW+$A^ z3(W?c&hBP|nos97`o7s&-3`vf9M<)v76ZPs7_=8@d5b~KpAkNx7H53Rd(mHtaCAz) zfb3cg>b2+_=%rR?ED`#==4cxg{+PmFRQM~*t8W1vz-YA&d#X|F?CBvaQYiD7LCt&b zPj<(g)x77H%poS$@TtqCa%lLhXDA#Wy3Gp52ksDaxDk4e8E}(_nhdxEnBUL5`Y>*j z5%duD=fPP~m&uuLz0XXp>ds#TxbaxP7k3{5w;c<5ei7iNW5MHo0dBc#7|EJi(b_Yw zcEx=>js2_n#tveRZ@S|KwF`c)L@50XT7BGrA1c*o3l)B?!f#agO$uMlym|+0+^Fuj zGk%wFpMR71qwhe`CmaL$<*C8$ap^_rr#cA%A|uF>g`|?yIA>OpM$%H;&aG9(JA6+@I(9#IKf znnm=z6H88;fBU>*))wB+c$wAm18~$J+Tm^E2GQP}q@!(ZUN{{sZSk$~J4C%sxM)Qql9)3Gb8c;NuIr8OKowE`=5(HkHTR`8H0)xq7)=I$qtos?B8(yhlBE$ zgC8u?NqiUhyd?hbA3kLMbtNIqNI7t$2kio7TmI#R-w{BbOgZ&r|(?+l{CvA)?)|i$do!zGvURYO9vnn_HavSs6_> zi+Ff2g49lq_mmX)uPLatgR#bMn#%W$XLg=T-Q3~H#>~mWz{J4Jz`($=dAiR*MxdTZ Szx6kYgKgm>B@*Dkvxb delta 117 zcmZoz!Pu~ZaY6@kr7Q2o?(+(a%$uVXB^3o4E&jC#9Dn0EyIh;`&dDWpn_HavSs9Ht zi+Ff2g49lq_mmWfS>>6saLR1w^=${P_|6HOxVgiVjhT~~fr){cfq{W}^K_qsj6gk+ Se(QnMWX=F%AjdY~Ff#z-(kK=H diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 Preview/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 Preview/ExchangeDkimSigner.pdb index d3b5601383bfa43babf071b349782dbac376e846..374fa353e99426bac36be34c7170a5d32936e643 100644 GIT binary patch delta 806 zcmZ`%T}YE*6n?+$+fU!VIc=^vY-%OBCgWe17@l!X~WJ9-wA)iq%M$C-y?}0Y8-S04J8n^M8oSzQ{9dukA@v95LxTsIc zj1}d9kS8#)g0ZNCvCHf<&IQB*CdRrojD3LbgS08c+l-85i~}Jrzx!A;x9S+16B(OF zG|s;@+jaL*V^U4Keh4YWXef<$y>e+LxkYKxj>WP(svL8fFuMVrYQJs~rXTblI*Bt? z(NvSn7nGoj1eGZ@{l^~>g@h6%DsfNv1b-U#Z6bYTnlfdG5sh>cjdBTK*^2y2*ecQ9 zlr75K8wu`-qi4B+`B}vqYCx+Hg>uUqWDqZN&+S})iMVtb#LcL^5pMNRDH%y6BQ0dK z9a&OV*Xj$x(9yaBLbX~y*e5p^w2b}21>S+T=ph?8flECDKaAYjzm;qn*nlTU!|iyE zKKQ(5>7jW%Z{Z(zRPrOai+E&pCihT>EWiAsGbM?R|9z_t)%o(1NCk@{_cSqAYpg)ET3D=KUA4-r6 z=jlh}SoteZsPrPUqG*D!{87*sw81KkeiQ_1ln|_*ml{OS3op-m&Uw!JJny+Tp3=rs z+Pk7$8*4L11jg9W@%<;pu8s!o3_gAtN*zk7>*c2U`U5N9`lSa|)A8Q$X7BRlSW#8x z?hU(#2lYbX>BsK_lfG-hRFgpx{bt7a{5x<-0*b`n?) z@>J&5CXU}GE_o$xNapi?7jF)9ZXj!AT6f>qWulRFqP0};vjLZo=kEj7R+^YL^Z)2X z(6ijYJYAWk1~e3LBSu~dxEyIL%ak*F8V86%uRxTvdVVjrI_U-lIiw&96f_-0)TC~b z=7p&vTf)K`wPF0C$@4_Z*bkAh6tYcXY$x!Aj-f3|xg@622h6t$R{(D9*%eaWymB8zqZ`;(%oI2PEo0=uwp2GZaXU!B|LNZ_OzD+-kCCpwYZ e6`)PsA!mh=oS`NNv0d2Bpa~&GP<7-Mb-w_UIJdC? diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 RTM/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2016 RTM/ExchangeDkimSigner.dll index f2c721ba9378601602acaa9408db4e822e86a8af..f01f5419ce1056114cbbaf8fb70a54818b8f42ee 100644 GIT binary patch delta 117 zcmZoz!Pu~ZaY6^PXi3$^?(+(aESsYhB^3pBbQnE6mD}#LLtt*2o>@}j<`$=ZRz{P} zA|4)$Ahna@JtYN-KbT#AzqQV5>eTfo47gL&Hg|ZkF>|soFflMQFfg!ep6+vy5vV89 SZ#|Hj%o$(|~mgz{J4Jz`($~dAiR*MxdTZ Szx6kYgKgm>B?TlqOsN diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2016 RTM/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2016 RTM/ExchangeDkimSigner.pdb index 145a26b87511fb91686729244ee7bd4d05c36888..0b23dfb0d8fca645df2c842bd4ebdc1dd78237a6 100644 GIT binary patch delta 806 zcmZ`%T}YE*6n?+$+xGQsbJkqju&p)HWUa7aqef!;HYBsKtczA83o;^zg3T_1hGNkV zVYrt;7mHOlfkCEUG9xMzg0YLB5F?%a30?^nk=-Qp9BbfB2M*86InO!gIq&;+XSLl~ z?PF1P*pe4J1jbn6Tk!qDNNR5;GgzoMo~%{Z$$pO~@$+eeGS^f4Zfk0f=lZo9)jIKW zysIXA(09r6_Dp8|Q24em?3eUn)XW(F9&A@T0!~TOu$|B31AHLlq~p?fKwS*QMSar5 zSjp5M_68?bG1ewy>JR()-9gdZs$*+Yk*s2X?w5Ymcd7;_wZ>DEkgi_)ll6C2`f%5k?5v+K~Q`fI%~{h;sAX`HEw zrW#FrQ3<(8P?_TBJMoApB$Oy^GWSMK@h1`g7SdOyDN}|R(MUJZDAx%rTZw;(SY_Iq zvLzGuMMEud^ei_pk5s&(2DA!MD7Ugf4)HSg!mdqMh)b72+??7I3k0`I_^^^gsmz@?spA4cx{-%2(Otiuyz;dVSn zFMM9J{Lnl;YT+MuR`MhH%XnmUCjU@}EWi4^D=mx8|9z{3>U!}>q=KdKdzu)_b#x5;Bdx**wFF?0u_&(MsJY@g~X%){hYs z!}$>eja64cLZv5J76lWe6g_^77|Rb@(1mpz9?DQ04< zXi5j1+g=zM>y#n-SM;MUVDGesvA0Nf4LC4XOb6^zmw~aYAsw*s4?dIbGgeW);Ir#) zfMit7{w0A|0JzErjFbpE_o$xr_5)99^Mw}Sx?rgw7&SaMWT^)qPc7MsgOq~@{b{FJ55ZR#ea07 z=vi%Go~X@J0~(6BQ6sN}JdP}uRm#cTEki`1S0GAOJ+p^fopghO98!=43Yv~0W>Pmw zGs5_x%@JXh>biZ-b^P+wv< zsGUd}rVgn`*27u@a4#%bfNvmQ3-p3d91HAPfxXx_18H!HFHdiEq;OJ?6$MK66P-xy d640h@m-E6%!O#$f*iP)`(1eg8tU3zwx?eg-wgUhF diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU1/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU1/ExchangeDkimSigner.dll index d04bbcc9de599ff5ffc48f4486dc7928af7e214d..3cd702d162873f1738454fda4d174ba82847a01f 100644 GIT binary patch delta 3928 zcmZ{n3vg7`8OOhK&fU9@?B3nG8}c9lvLTNpFOm=?D99V~0s?3djR+bAg|K-#g@Bt# z@lhWoUX7wvc{nW@pc+#Zb<_kHI#i_6+A54PFlwDzEZS-jr^Nox*-I?i-kJRN`+w&< z-}&x$?>)J73T?_5sA;%?eyh56=~pc-iSOfK3|U_~?{{p1u+%MCcx;AEw+Y4%E%J+8WXZwv?_MSdR@y-eiNstJ6rzEsVP#9dC@DNC-qwAwe;n7xk*Bm zt4DD*x;My&k`mBhRql@Ll$JU*oQi@l>+Ngypp)X{blu4SCihjv98Qb=omv>10Il4%|Z8m_T&Ouy97Ml7&wlcJLwH zjj64u-xHnwzuhy2-O16J)&e~>d6x7G!!&_%rF+I~eS4B%tw8Gk}XQfrb zv0g-R$LrB5*da$bM{|RYNVRoF&+y>B_Y}HKXJnq0e+COZ6)fC;het3Lw$>*+#AaD;?@rccl^7}T9P(CA_|bFH+9a1xD;BgIm(L@g zugE;PqS-R&rY4SyU+!ygJdD8vtIwN=JTLijzz==7lfnp$Cx~u@nb*>qfM+q<4*UNs zL=?hOzp*Q-GEguwjkNX}K3K0ABaKTZTJIS}I1Sz30p8{BWb^t(U;=}fXimnAHnWLk z^?zbMDPmuuYZHTCgG+qUe$jg#3JY`U%m$&;5hc55xnCzI9mH;jP}-o>ChTD{%^NlSiF)Wps4tN67#Ug zpvktn%{&S<+g1s_cSV@y*(%9*Ld3#U7ni8}w8*42_TX&SI?AFpTP<=isExLI+5MTw zrp>lG;yw%YkgeYHd@XXQ$5#LFd<*rAt+Eon7P<5*TTMy$R^-O$d0S?BNQ=-uTa|g- zP=mJG?+;T4f58j!iCAB3R~@=h?YlR*vjjSX!&$CHhI~n zdQUYKP^{jTD?I_oTWr;AR8t`}+Uiat0Ck70t`pT%M0eV%5jSPgC6{76-4h=}X@%N& zdRD1J)ab0HQrZ(AqqBOMhJQ%?=TbjmOZ(Iy;}-%8Xe*t=1G$yUrQ;-@ z{c-%&;BN4zIR6qpAo{=|u>cR{UUMBy;3a<^yAgSs{^AQzCGzLO zev$TrZz=8zjG#U>Yay@I4kKHG@q1dqx#5U0FO_?Bx=odpNOeXcUJ4#Ea~R{nP(Ews zp9S(^UkDVlajd~82k&!F$E-f8KxAsLf!6UgXh)V>pg?6PQyC7kHtklHg~)bRrXsWG zbN>T~ToUYHD|oVrcf}GUmA(AX)yF2WZ=5fK-zB`s2I*UPO4vEr)7c(61TOLX5!3>o zvTi=h{W;sp)6IXvb1vZ1*aGsma z7q}^2!1i0h-=loyqRI3rchNLD16C-z2KG35jh@nqD1q9+5Zwu;DbHB?CG31U2u`3g z;FWY9oJl@M5mi$LxR`3d>lJUNMX*=LlxU?55FK<6xQQNiRH|hTkcA~bQWQ+uW7$qR zpW+`ooIT6;~*BiYF;{hIc8kU2#zHlqM&TLo!2g znqsHoHpKzOQ;MXkNX2Q2%N08nwVV>hPKg5bb{_? z7BhG;zZO^XZvHHH<3-s=f((4w_;D$S)_W&uL>1apu+f|iZtzusb*@_Q9rxAXzdTF9 z=?RkaJLZHj8HKnv7=(y=*kAW!JJBnbwJq41BO)&^|8n;YIVJ z!0)S8I2@XCfPaKsKN#V6xuuWE4<7qC!u=|a<2^&rM-!y`PgZj{H1#BZT1a(CZvJb$ z))G#W(;U3P%HsfkU!Jo%r0Y9_=s9ZYKM=klBQSs8+PB==$MbjP%^31~7hY}^m` zpPbym7t!GLRr8o-)O5NvEG_$|^*>fK$WYtT j`LByoDz;J=oP~1NPGDvIQ)=I0{7iYjx#%qGE_VJ07h~*+ delta 3816 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 G?0*4|d~fjp delta 5008 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 HPI>+VocW$X diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU2/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU2/ExchangeDkimSigner.dll index e66f5e1b784295c82d991b9998c071b3bd5794ca..aecd7d4ee4e921eec0b2c35524cf7b6f3945e27a 100644 GIT binary patch delta 137 zcmZoz!Pu~ZaY6^PXi3$^?(+(aESsYhB^3p}9hk6x_7ZiM^=5&mcxSI<+uY*R&&p`B zS;QlNQ3t3tjsXamfLMl+fuSZHh&>q?f`VOwHE!g@t~OZbxB6!A5ubb3s+%Wx{$t`~ h0jgyNs%F_d-RB@9(40uW^+0MeXMiz~V;gXo82~?BD&GJA delta 137 zcmZoz!Pu~ZaY6@kg)8sI?(+(a%$uVXB^3qE-t)inpnQ?n%KZ-%FKWzuvbn{npOw*g zvxr9kqYhAQ90L$A0kI4t14B(Z5PLE(1O>YUGZ)=yPq)!^?l+Wu`@uBl`Q{0p|Cl(L hfohq7s+l)W_c_Q2G$+z;J&>Br8DI?L*ajSC1^}}mE5HB% diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU2/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU2/ExchangeDkimSigner.pdb index d4b374fbdef19738ce9b5e1cb3470543e5933cd6..274038eb3eab3d9267980450d4de229a011c7763 100644 GIT binary patch delta 765 zcmZ`%ZAepL6h8OvZo6Kmx17s{Z7pFjMPkNHbRy~|F({>6#EKG&iinD$gdrpb1r;Lb zOAsX02r4ivy@-9#B1w{npnk|yw3+13tRMXeCOrok_@@UB&w0;1AJ2Q<+cRkC8MHiC zw9T%|UF{MP1=44a4h4r>hh}2$_b$}=%`IA`&v)t1OC!8|b^F&H-BI7o8@EcWN~WXJ zKe)f*ito#r+gnGP?ntARs!fR&5Q*Q_ZD#vUw<;UE#QeA+o`&4)W+x2uZ>U4DB^*Q< zM}JdUbvlnIreW+loP+-vu~0ryw@fqxYk{;`#M@M&q}tz9As#$a%J*1_mKCC3h@L>F z^T;qPM0a61JVF=U)Eif%fv{>XZp@~<^0d&y^~#4@Ll?cxL2)1)7wK@^t3y@*b*0~f z(%j>|*lGA&&VqD@XpMxVn5c?4HCD~Rm?pX+AukKf)rDv6hq#U}z$u}8v5LBkSd2K2 z^SwEk0iOitz}j;S3dRcGaRa^+=kmApxk#(0P ziN(5OVxe|}h>u^x8=Ldv!&cGzCgJ|y|I}%EQr{F#%}zX&^XRRAsf0&}kx6HH2?V%s z*p0zDcp5_r!7m`H2wV@|2rd#oCL28ckXVcp11`ySBJS0PE}P6MEhP<1sje0*qXyB} O&NYTh`%KT&lJy@>D6Fpl delta 738 zcmZ`%T}V@L6hHs%?(4Rj-d4F~3r&QC33JSvqcz=Dfrd;$kT7XM9}g8HL=<}1gMC0$ zlk*Z}wWtSQvh*f1EWyDlDtfaQ;|2=r$v!OVrB>%)7kuf!k8}R#{LUx;%$PYdW_~2e z?xFokzW@O9x%Zb&?rn@;Z}P5uX+Hf?+b;WRYC69C7_!c))0uR#u66bDu&xD)PqLBh zMVnZBTl#rnvh9YL^4YD@0R;fR?(Ww510K5wpq>xngRqCJav`Yw3Llj$gH8Y)Q_(u_ zI|o3QOikCx8M5DyFNAlauF-@aa}TA44huj@0{CPHI7Ug`q;rI`L=Kt(ZW8Wq08liw z^|Qcon{11;w=Bu?3s@10NTqE(6?i_@ClqXoyJTi^8^wvQVkdU+1iR>2z2q0}YpID- zWb5{QC9>&LUUweqM4BC-_@2gDXL7B#}`}2) sjC!&(+-7>QkO_i_T<5B`?|DJspBIiThp0w~T(hnYUFPKtj=<9IReSXQ$)>U0@s+%Wx{$t`~ h2C8KSs%G9i-RB@9(40uW^+0MeXMiz~V;gXo836aSES3NO diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU3/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU3/ExchangeDkimSigner.pdb index e88ec9681546f21c20d7e1b635f5dea011bf248b..15b496fcb9fb0eb0e0833f7db3eef89c05fae72d 100644 GIT binary patch delta 765 zcmZ`%Ur1A76hHUwZoAIuEvMPAttA*bBs7-j4bg29i!jQCtPnA&h^Q#am_lMuP$9zn z2!e(+0`nm(y~O%MMuH>}K|PG6tY(rAJ!C!9L!k6K$iSC=aQL0?-1F!6o$n6BO#^Y$ zW5u?)_+nqDL`1z~?XEu^BmU9vsZ96Y(QY$L1|2q5&B3ru^aXV{3(eI9=B$UgjxWF|dcIgiT~;gv z9o>9y4ral}!8x$@T!Vrqg|E2*--&bi+xpxD;u#{%Uj{xgldepoN$zLErWG3 zSPX+N!-(3AZI-vvk delta 738 zcmZ`%T}YE*6h80v?eA+}x>mVm3x60SESO`}8m!H2DP+nN1PPNC6x|dHhA4Eg3ymm> z$>}1OR~_^@&BBLT-j9!iPO>Tmzxpe9S~3h-0W?g8n_cfM z06j7_-69vreoMXp-VfWy<6g`?ky<(p0A&f_lNsO)CH0cd5iSzhuLrn8c(@HfQEidW z0xNB@sj17fCNGt+CK{5;d-`hda&$l_*c!9T%;YwT6<@ETQ$ zGPiw+DZCz2IJUK14#(s5R$jR3#YEJrzKHkR8##xCCuZT1Sa?a6A-?oXVoJ=OoEiwf zp+o(qL*65F7y%BGF41vQgg%O;Hj`kLbPIily99?0V3hDt2WXp5qIRSf`}3p1r)v3W z173eQ;{4y|Nvp2K4-zpeg$Fu!?WB9X?q7p>YP^H&CIW9@BbW%gaj{ru2~m_iHY^vz r&MXbLlU^)jf*>N-xuG6?RS@`R*|O^d)d-Ml!M>@Y#Wrn$}{Q380Br8DI?L*ajSC1^{pOEJ*+W delta 137 zcmZoz!Pu~ZaY6@kg)8sI?(+(a%$uVXB^3o+Ry~-qn9j&1KQFc5Lg$t*+uFnK>(_1+o8(MO zYiVMi=aT#LshgYn1Gl7s3dJmk^N7T6Uz6Uv-Juw?9b!7Ai6?#syGtXQ{@33kn`1Vj zj4d80@lE6qMXVUR3TNPdM9iN{)NUa93TuS4NyM8JqNEZJc*MP@a(RP^XhA0Wh3GMK zI*Sa=NOT*PMK8Ljx>~m=^#m2m)^}q=E<;+V!5Vq2T2n<=y;tlHM#V%h>QW)A40XkG zUTNx4cjP2|E@wfiP3#HzrHH5u*{!UagAuD}3;A6vG+P&(v>fC*z5u8AbHy_1GGaDl zKg##!UO=lHzoA2f}y1^@s6 delta 738 zcmZ`%T}V@L6hHs%?(4Rju4Qi7!X;9|f;CpH!J4~U1sO60LBga3MFiCd5rrQ1U>_jG z+`Rbsq1xnAdk?duQ zSa?_dd1)ecQ%w4-X6c{;fZz6XYP|usRRmDa2k}wZO;)8C)P9AJOQwE1fR3qXljpq+ zphKpnYve51bL0!*y{K~};m6!#sin;XP?i9`SOHE@QYYyg;T(~JMu1y{2kQV7&C&W* zU?nD7RxT`llxOF$MvX}2&0RHkQSA{5?ut8QW^xM&lBBFFXyoE#4J1#3opsi&zGJ^j)}>mV?EKg zbg18S$UB5XW`Mn<=jpgOZGy`HFhuxl0CW^msPC)A?);DlXnKC! zgu^ce-T(VMeVS+HgG9_q@xGzC_HOf1{l5kUYP^B$Z3N!HL9h@u;Y_LC7NID699S+z r-B}uLBfVJ21VKcub4}a-vMBJ+D_h+Wsu3dBv~yLH3GJHa^^)l?js~vM diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/BouncyCastle.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/BouncyCastle.dll new file mode 100644 index 0000000000000000000000000000000000000000..17e4744bba01fc38813632881cc84ecc9142f374 GIT binary patch literal 2049024 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

    5*;c>=$eFKE3_gei6{p(#Bx>1_@K+#j9y@r9 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

    3wZ~p)$sQ6W!5wU_}oHgL!t2N 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­^+B|2qb9$aTdGnk# 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�Th}g+tyGUR?-%5s?HO;)$h{;wf@9>kteum?tG4C;s5htWF*weqI$O~|$1CFMmZ#TkZf_$qeD{+5)?fo|+DPu8xjtw>*t zVzQN#a1IGOYuC8CQ0Pt?4&+rLM@9KY`!>RM(5r1@db#G7S1ySY zg+-X`0(EJ=h>qGOl{#K}8hxz; zth1RdmK`T))!h&3va>SLJG&GV(*)Vpg8i-_c_0DkCYF&5>T>kMR-16kT>UZD1dS6- za+2jn;XyC83V4lRy!NrBlXJ!cQ`Ds z3}5unPP<|~w6k^$CQ=DGl_tXzR{6%^4OZpG_1~b@8U1#p$q;bhoKu8LIu9DD;gy4r zp)w36z^(RQEP$)Mbo;GgIs=5e1NCSsE7EkQzo|K#0jXQy)2@ZUNB5Zi!j3Wcgw$bh zz-55Y15Gbk-pv>^M8O%v3QgLKqEnCJ7P)*QOgEz~)!q&3t$ws+y)|&-daB7w0vjet zc7Ib6?E$n@Xzqw^CHTaZMn7qxKKaZ~tcm-agxZ3);`>oZm`&!_B;AE34*(>LuFR(i8BDlEtcLWneDhJj#hKeFx{$_bXDzKIu#T zA`1KBFKr2UOZaGjY^D4aHOnGzDU*S@B$@5p2Y-DPRqT_$oOq1}UR+9JP2k1_xqFc@R-qFb}Iu@{XNK@D3Ak zHU|jFY?$So5&#}hJ)<>R#;iVNwZ4al;Jd5_M=ezZAUH$FLM#cY+3AcE{M%B5&YoX;~rw9U)|I-aIe6= zst=1D<_uqhYJ#f)vH>h#4Y%`BMB~W`@WdLp%~0@q#9QHy0513u@;9Di^6$5l_|mZ=m&m3A$}KF;ST}d4)5)g zCY@xOG^`VmG;J$NiRWeX{0N#?mR&7`52GABS@pD;D|nP>7QiLD;puE)eq_l>mfDov zz?F`vfV`;hc{cNGq)pf$FFxBb0cDcbb3un%>jQvNi+Yc|+W;ML1d04o-MiQ)#(y{b zP=H})Dvfa#H^cH1SH7I6?dHtQIxho^kaf!ZIvD&lfq3EhXpYd4_w%3SJngj>FGnk0 zArSc+{1SP>K}1?@30JUoNQC`xfN6H;l`P_Pw!z^tgn8*Qnr;-|W|+()9wfXfiVzPX zI#Gmp5HS};hzB%uQ(r)PUV`>GjX_Ke!O>_Aj<@gP`rs+f)w(_ie*@gn%*W8rIWPPP zoILi@X>8mIP9vS^N7*KBK7<5v$Ar6cT)iNV>~zJ4YnZgeqL_�BC_U0+eU|;JK*3 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
  • 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

    8~FZf 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

    O=qdK+mp`KxlbYi%er(sEU|Zy;7XI|7o3s@rcD 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

    }0gR@jp)UXrZ=f?4HIyA2)a8s9~sfQi8%RUAY4 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%0DF$2WVz=mjRl;|?SBdV;#6V1%@ zq^ybdHP6V7ZX`RsHuCN%WapOR?;;}Pm`?2qeSVVbGyk$a?>#oI(0R>TZyOXTJ>f4= z6uf%BN?wsJK`(OpF2V^nF{-zq#t0IKH4;8XXjznHA*m;gDm~cCu(fDO7srtB@feyvA(dXuKdD^*eY9^tGhnVfo=MWxFU&}I3&4_z1y%}yvbB?O7>7;k2yj>qd# zqQ~qA0#p|&Y44sx1yn|!f^01cGl-=pAg)WtXpkn&^G5;Gb`k5ZTbMRSH`(SkPSNH} zfBhxg4<_1K#omLoSq8+iH6USzP~OSvK3S~{xsO)MKv{sl+5tRCm6XcLa830KFN?O;>nI}?sNnnE;FYEpqrT?>YEwi z`va0hwUgEaI61}XP#m-$5@0(b1-c|bS7@MwrKQExXW))+J51TTl^aKS0*N41U*1To zwEfW-+cV5AhQoY&=SS4=g&08|PR;u&7qMi}i}lZf#@ZAO722Y7lWpo}o7bkUhwl1N zqD{^H|7MHsA3M{7TLU-(Pw;sX_65Zb{a=*0ft6{^z`wfaq_X5G9x6*U7ykx4Doc6j zp30Krls4bLGYZO5j;Aq!oEZNHp_{KPVfIc!nrH4ranloS25Dbeg0!Tc4#n@%tFj!Y z#-qz(LkbRytzzd=N_z9E1St%j2w=(iydN2YeNsqW)3D8xlHZbHdlKZg!)W@&tgNDB zJ~2f}fQ@A4F-1#&_9KfzzGCSKh$&k1Sz#V7S@P$29~Rq;?5OR2H$?B|cm$g{9w+K{ zj_0u594{;9L{1i3}b-5s4L@Ke&j*ip~ozBC(?LM;DP;(RtBDBpwa;lZ!|^8t`Wqu^Q7J z@BM+lxQH|35icQv%S2s9Bh!UOjx7^CDH?fmmWf^_wZt-!z|f+^g(XZ^mx;s%jg1T4 zh6}pMapBp`8y7I|lYjmuN9X3v4diUqKf#`x8&K8C=12GnOZIz16sNd;eV9F1%QIc) zagu2d@e2j-9#c&V2{3~9!jP7C&8hd4GcjaBKor@Oa+3kt>+X(ae&@fXkrmxYR@GNv zxQx6&StaJ5f0#mk$MLAzJHKdW%jSgi@0f~nF6KSzjki3Ejne>l7ij<|CiN7yifY;{ z6f+J=5hS0#G@j5#3yrT*MhD<}AiXT(K&YsyaE>i0#`UIWLAQ}!Z@P>NAm#0$J;2-N zxi+XM-RcfsL>4zyTk1EUdJ5Vb&cm|6$%X(H(}Xd6yi5M_J$m;}G1XR1&E(xXlsReh zpGh+lqYD#7?13F7@0|%-i=J2vS=PpWDxTIhHAYwN``1bDOB69)Y@uD3O??*bDU`FG zcMa1ZX_{ScQKx9Ar>EKAWK}~!Y~kDdWTKT!H~W>DEh*ZAbA0;&m(veF2lt$tIQnN0 z%cVwqFbiKHUy$bmrCHgrf)VE)+y6`4_%n`4+*JH`lt;+0tur%kodNxysRf6p@cU66 zD~r7B*XspLBfWsABfE2y(%UW|!>x@B>3TB!rzgXI{a#HGOBR{MI)0b~B)Z#KR-Hn@ z%4!sf$Dmg{baF}L9eyW<6owI|9Bfy2vQgn*eGt{A+ckM$jPb|YfGZHj9}iX}j6WW% z$-$yM(`E;Y_DowG>5#EIJ3%Mi_s*d}kntFDO>w6FRZz>3a2&TkN;( zr%>L|Yuf=5Pu{kDcJ*a6zpLaGYfaeySkKRG--rqsgJeRo zifJMVrO}@xGd#R!x|Em9yzMTKc(R;w>r$`JboS>mUG07I>c^p3b+yaNVZC?uv=ghi zc*`8P;Chr32aP>)LYJ)2r3h3X<>Z^*eZ{_Htn|a?Xa$R8q;-=7RlLL;uE)rZE@UT59M~_RJJKz(dvHS8MKX!^cj}+0u}URieEsR&MIT{X)i;59A;s9;MZFZE$@4n6 z-HAQ>*?rv&#pCI6_pzNei0SFEoxx1F3_rEG{=s^&to4=!Mvjk)=5IS9UL~FHM!S@jQsa+^cOR%OR=;$bi}*RF5tT6&M;Qx z9TUQAw{ovf$z)6Gc~_S7AmxTr&Cl?F2ovE`U-PMv2Sim$f?M!qD{wqkTI4b`ksfA& zjFkL`KL>hP>P(_z>gWh~9~k>7uVzX#56N(XeoGpz-x4ua#RSBv7;+z1r;AOU(oNRs z?oy|lrmEBbgbtLG61#z6TUn6~l&IYi<>|m3H~{*#?3g&U@qe6?higFvJPpMwwFQF1_s4l~5i>2zYg=%A+%bZ=^F+r^E z2$-_&mYBMuo2ALS9eSht2+XwtUKs?u@&hi>+X$GcQ;H`cic1P zzX^2dl!L3)p3&GB?giFuEjo4S#lH^m$*N=;4<`FI0yC$}VU0N$&yky*9w7yNquh{gb}dKYb1ApWp`d@31GSf9CA!p9y01Pr&&4Pn_TA zGxbk5S^o!1{dfMt_TA)ROw>8wS${j+O_5E7wLqB!%i^;+ZC5LMXBo5}xhlL+S34Fx zVJ{iNE3;VM+aA;BM`66|jRK%^>Y1;(sjYU^yN1jGH7*W+2)x-V1%8>`V0ROW$?$y`H}7>3aixU#4$A`fi|afA|`lix@C< zNjF)S@07ZHd9u3Xm^_x!f04}my5tL5-mKzZ>)Cn+=Z#>!anF|dY4|1>6aQC){5lf`~LzS(91*e8V0mGA_13UOS2A!4k*5D@Dx!o~`+aec(b**+U@MiS8_ z(x$@$5LA2h!~bnLGG{ACXQTLB(8fyi_3cdipqp$TM@aj)9ffQBvNI&hEGc0vLgO4PTGR!vk6w6q^g(2w2H|k z>Hn#i`9ifpo$O%hgl@7tvPG$;Qd*g!-Ou zB=TRR-;(;iGddNw+4^2Cq6*)NBD#gaLpW192oP0Tom^b<54RqSD6_ipL9)In;;8yq zRC!7?JMs=oP7mqG<+4Ho`ic2+b%VJL9}2`C?9?)n9}m*iQ?F)!Gbi&bu6Njz*GfUU ziY%&=j?-vD$6x#)Ag9b{~p6Dj)DU^EJ1x0MEcTqRI6LKBgiES(ymltn#^+?fl zxIF~i;}!%8MK-n?7;2vYhm$Eq*`rRUmZ!Elb)0>6wpVp(pD`=w&&K^OLeFg63Bro$ z!V5sFE*Rtcolv#??hNU7QYH%K98z-qj$psvv2?cIxg_j&Xh00hvHS+M7CSS~3(`&2 z>Bpo_pP#%=)2Yi*r)QE^eV@9a-F%d>n|UU5fgBKRF(0P5L#FK@gQEc{UhY{v1zCr0 z1K%~=Z(Y5Jp|>+MAE8?qdIv-8_1zwaFr&RHV~4M?c6jWvPiueI&(Zp=E5k6*nGsAd z=71$BlBRt?C|!c-3LFgbyxh5P$FD6iMeml;sZK0Q5hU%@J2a;xeMB5^U@qeknWvA4 z?NNe~i1s+>cpHR`hV@G~S-)pV{njDE3H$7S*_N(;iFG-M5?LECF-u;__#worEqyjQ zJ~wJ;_kwpj9ts)MqF|%CNR`zlVXhhReHqqSw39*<5v5a$MDFz;H6}n&hOa~?w1VcI zAP-LSpT4|yC=m7KwRh5YE9W=wqVG2P-c8@_^c_aux9NKiecz#PIep)y?{NC=pl=0z z|3lvq^xa9{k@S6!zW3617kx*;SAUdpkgvXvM$qV`*jn>0rXA2twu80O4rcypigxh6 zl>UpvKW>cu7j?H@&UXx0w&SaaTCaLLmL+j@ogY~|O*W%LLC=odgLClWl`Rr=sLpLd(i$y-~n@m3c&9Ut`u$>;|?}TI925|WAj%~N2 zT(%GC*v70T9NQxF%*Ndytk~H0bI_^_#`v*KsM@jZ6Ee0*nPhAuB{#Ma?2m0MogLd; z5;L|jJki)jqSSqKlXZHz)M@_{Q?&X2;yOZg4Oj?|2mcf3KGBWuV_nDu{z`J}`U5T? z1@E@rgbZ|_V52{fDs`WP8|yxz#C0E$W4e!khPp2?ALk^Ea;BS<^VK5fFa5uiv&ixN zD9Z$LmJd=+K)lNN3kf-=p7i8QGLW-iL%s}B&Ju1cXQIUAOyroH2^cTud*qwGJ&bJW zLbkDe{OieSx_Tp=kuTHltthTtZcovg-TQEuyc(N_YmPp~xX5{ap-*JWvGgci&OPW3 zf1Me6yL7ngHx~a5VQ!SU>aIEN`i&u6hT#-@d&1UuyJb&PZo0`fbrVU~mx9Gf?Uw(- zcqIqnK7b;{$1B!KSO*wq)0`0;KgWE5FHoVNyULo(yJdLFWSRnvj#N14F=G|6H|Q}^ z20g~Qqg3PNyqA$P-K3nqC33!YDmfqhAGZs1iFE{=$K)KY1jH9{>M7ebc~rdHg<#T4 zV(nF$3<4vJy;aC~vLak$#fV8{^*SRfx=C4mS7fylSeUd;{?__v%7Jm1*O66{m-dqSSQOUx{qm%bTMMGc1Jd{Vz|cs?rEvi zSre{b&^+CYlT~JeaM_Cx#N=xoIbd+B@ml;XyAeMHS;Cs$B-VW?SE~d$xzR#y)eyU& zI)=k53jyY7?M07onib?$&E;1V`5@n02=c?a)7TV#7{#yEm0&3w=!Bs$Nxri*HOU|w zo=lotclizk7LGF1UcZ6OEV=HoQwCq_ZtBQ4;0?_rwI>=0uPHkNf7{^ii};&`KmH^9 z=lCQ175w?|y%El$j^2R34*2=co)m*QVz$Fsbgu)FYpmsvUFOYox|1cPTO;lr$ZR}4 z*?nGMx!&-!>pmH;`)Cg6bbNy<*69Y3png-7%I|b>Mr_~vq|ARvQF{m(aq}O7{T{;F zxAPyDB~oH}asHl*cBK$I@q}kjJOv{UfoCOFj7S?4d}7 zszEn~BE$qEQ=5$A%Wo@Nbbwd~R=0~29R=5I^Y1}LAsq>ET zqu|A#sXjnyzDB=A(MZTnkd9NAlTwDINImlQTF;9z@b72XqiefGAwBZE@bc1xyr51p zsY6iC<0892Mrm`OCtqfb-B&L!0h~&{-D5iVu3&p8?(kz$nuC6WX0fP@=L*CwvxUus zk|+uaHi{=;xDw|0l}{aP>NEa^2oZa?aC;8eav((C&XpzW+FTb2JxqFDq+QSE`sFu4 z|J8T4p ztEK|mEAR8-KQ-TTy&XA|QHz&R2JaJPr2XjEAS^-_Fl|!`V>xnwaTc9012 zaBLf(tg(`YQZL0xeUcIU zNs>C75&TI;oa0g?@;H|f{7I(x6eA?_>~pbloW}_MBvYKv2>v7^*0_j7=4)L<;tR8N zE+X-T*{2yHnI}kHzzF^%Gr!P9BvM@DA`+Qj>>?7GuXhoNn;|YiMEtwAnUI;bhszLG zU+jV#7<`ipUe4fgE_ellXS?8)3|{MkS21|E3x0;dr(E!}45of-^ZguyTe;xX4DRiM zpJ(tW7yJT)XS(1u3|{Mk*D`po3x1Ko-@D+K7;Jyu=6fB3{VsStgNL}_ml-_C1#e*R zA{YEhJoc;c*c%aq(&AYC9Qxg-pnLTdgqskdzOOmo%}jd>DIZ(FqX?Y=V<5Z=&!D5Ur4Xepy^X3;V#pkTAxqil$7!!N2VZvAo9_)*Ru`CK>TNCn< zkq48;&x|~n^Z;h$!K527BM&Bhff)&`XJ2V`<_(LZ(-<=M8e_i0*P{iFoQJc_Js5{L zCc*Mcoew)!ifIza#XI@lK#1h^X$&FK0m3BXKaR0)GG+A2S#AmPQB&~%GknvvrXnm^ zPC-TrM5{jo<~`e0EfnSPAn?e4YGYtcLQZmhlZ==r!*8KKr|_@S-)17dApvvU;kP7^ zSF~FZfDmYlo~`5!eVr}Mo8*0DxpzUbx8G_DM3{)3R})rZ?;{I8=H({65kQ#A%+;H5 zg^qBBtp}!d@0By53ovgDfPYn>ZI9#!32Ox4j%R$bdUzm4r?dZRecS%c_(nQWqSfDZ$QS&> zqGVpNzALOxk?(NGEz>easeLG8eY3L0r^x>UhGoB8&t)*wciOfWXjsnTzSXZ)J7vHAZ^FSmd%=A*K@;nbZj+VRV9! zpiW5OMH-+IH6tQ(A6pXP;tkGQtp=DqaWndn?eyWDWX5#s@6m7i`(5n#NxK2xS7a*nv9*Q1AXEM32 zMOro!OV?#W>AFmm?5N$5gby+jrkm`jTTd)u{aSb{B6yGgeg6cz#myC;`31CMyGU?1 z*uXaZ59s8=d*Jk_9_8EW{Aa7o%;)7=RY_z7stZ<3Z&#+=IbV$unvf$CaY9E_x-PGr zoM(@(zYtjjM{KwB!X&Xx3<6@SF6$ey`$J$^4HVvs052Om*a(M$G7z1Ia0?d7y|4vZ#`$w^T{El#UUm5nLbVT(1JX5Al|B9btY%l3@Q3 z!#>?4`%9)^-wg~)i3t9f4P7Db@kzMw$q2(|v;gyC!^+zXD|C~rY(E7n2iQ{Uc`6~v z_Logzqb7Bptn(45t9x%p4sLaiV6(cnGjh?@z5Kby4m=@cGNfeOdKYM&@78PV*N4@; zkSyE?GL`1q4(4-wb2s~^StD{GimrdsrxIdo zb`m1kNNC%ngdmq(YA4WQzl+X!GCR}V^3iH2GnaNiidPL^h1Ds$6e99%tShv^{sc)} z6W*Vad=QXvx}tg{qkf7gO7a~>l5{;u?x~X84OSzsU(e>MdlM2JPnOK^NCNZBDK*HB zP|A>Cx{`}u{-~rxm68(I3L+8@QzpvK^}xMgr{K~lbFLff=nnzU?sGOHvf;8|Go;Tg z&Idy$_ z;cG4~@~!gl=YZ5cLLyv)t)5PS|AMgN9m=B&zKbYze99R9lEF7KcrnBsZenmZ7krGt zB@D`|qmMJ#T_0V8d+y}KdURv_`2Ek{zJmSFK=(gmN6%Ax&I8L}oBNmZAUYf$)9TxuSunb+)SjJ8 z+Y5h%P?~2R!Y7>XN#}dY`F`zuPdnc;&iAbI{l@v86Cc~>mr>?%>z(;B7C4!E^>7p# zkG>*E7EG`cLGodOv$4`iW=wDnV#$#S&P6QQGQoL>C2uCU1%hPI1m`12E={nj31RXo zVbup!cJQ8)+OoZ!8QW`eS=e)L#bUP()R3UL-Xi=h5_2p&)YK{6BbM$lY}+Ujs#Dn9Z}m#N$0E=q8|9Ke(W`vH^^G=^GH3$pZcfH!bH6V=+w<4*`uVZO_VkgnG)j@NEM8+uTS zkg(^fmt%)J{4=PiMy~WNF?OBY`Lw9yRJUAB{ugFvL7|2^)QyZFQo~hG5}SZ#6$I3ibaf->ut7oQ2sAr^4%RAC6etOlrjhyJBsmaCb zGxc$da&?!bIP9{DB1^A2jEI=h&>cBRVAWAL>W|v+ODsne{9gu9EV?WPzC)uIR)M&P zkpyQMFm~e@t-EpT*Nm0UBJ&=e`@of6W?U&Z*FyhM-e`k~qX>1T-C$Y*|8DrJ?I+rq z!@*xcxVDoE{*A$!Q{{hWaGs0(2ZPvuDp&8sND;n_AdMZ9xkzoNI(C=r9Y)oQI6V9l zXl#ojI+#Ipy|#F=ZHsC7z69)6U(0to< zw;f*-2QC*>`PA#d+4Suar=$9PMT4JkkPRhUNQFVxu!Ox55iTWSgeej0pEH1N*N)LxdGU2P9Z2a>{-RCW zA%Ne8F2Wxt6Z_#0kB*=vi}{WlrL|o@k7gK|$kjW*Yv>~5s29iLI6x|9{Z6!YZ$)HZ zb5%FrMH#u=FMLJ$%xF3knhdk>lH&nr#99spwJEdj=2D*k^Xr^0#C3dnU7ilv`}?og zQz4kKu(!MZcQ7`|`~x@XN>9I@1)G69{R{i_8ozdh>LR{0mw+szxg2Sl3*BUM`5X&9 ziAHkGt!(Mq&$C31RD{hwb#h9Fl9I>L3ud)M$C4^ijm3Nmr z0HM_1Yoty$DfR27kb2YwnHy{hAsRs?R|AEZi9~S|OjoceheGOzhH__u-sp82%AFuj z?lu4F0MZ>Nd1exqJmt>&WV*-o`PsltkMb9N9vdKH_O-#qtXcl>ZlRp&3g-YvMzPOR zx-N8u3&~7fX?ZjCXcU9wWd#gY0bNL5tYtd_e{BlMA7xs2ITW5frmXZU8k14xEHtCg ztU^%-OwPKHB2Ztb3>Z{>@qq11xs;pPw-M@$(ZViOo;8!d3NL$?CZ!y(mAn1sO|M2J&O`>8rmFohj|r&HLS< zxWmdL-vx)OnWCazNrFbe`Ocnj`A-h^9czk7H(AW@NiipW_cUQF=z@M1GPM$2xe&@X z>?XTW1qwn|p%4^YXTF3zlqu4A&UNk2f-k^(@@{)HZvmO-vc?iu^A0^W*ab zQGS?=bz(?*hQL@hx+qNKfya9GwpuBEW3 z&4e?{u3Ha$g*8 zQ!t~990Gs}XS&{*c}ZU$-Unn?N+Zdu!^XLhEaN_sTaWQy~pQ()KVc}fpy+QdI zE`eNYZJv4glXR!M$x)N4JM;MGqnmn*`XNN@kYd5x=_v?DMoHQ^%%W8FZF+W*-=@3` z{5_fle@2{gIzqT;scl`5MuFG*gvIuJQOZ1wIdb!0b4@0<1^r~?r<;O;FypOCLIU=@ zWGS`8v=QtGvhdPQxjo3h$T1)&?KPL;y~FDp%FE~Mgg9sW8^$QS>9zSy!gdM#nZp1< zRvMcMqDeXa`KE1~RD8K0hclizo$0wWMK6gdhU4L5%!@t>R=;<{u)k02kQqh9$6(yAT*=ck5Z>*h~T%NiqWs z_K`i{@}C{H^r?-lK>$m<+tA5|3+Uv+g>G(n;GD zPu@01*F8fgt$Y&|C&`bCEa*VHwRsH~);rB^vM>%6x{YEH#u`OdnUd^|iyW89lcd8E zjYCBya*%_?)FCzBw{-(7F$K$2Ata)3ChrrhH9b4@K2xuBlcUk&M5~|8Q7`$zB`S-u z;xIx%&}C)NW%1~ece-SguCTzmEu_AM`iQR|lGs)9Oa#;gDJG0(f;=P6+Y4j1GHNkj z?TDJUPXY69vg1>*U04~k3CX0N5L0!6{DdPr(?A%r17p~Ocnm9_M15%^ssX?Pi;MDR zQpd9)<6pWGE+Y15FMbyV>GUWQOVW@ajaW4oO|f?u4Xk8f_yQ1LghdG=38bsNJbWQ@ z>_jvccNrm1160?eiJ?dSK0V5;78TOf-=P{8PLb!z*%2M4os_{|NJTjDG9Ou_`AT`; zpvA@eNR!ghf_5vGDTJ0TFr_0`D9l|`5Q+(aeM83COth{!IUl{7!Gh?d_&vLA*+tp5 zd~XT6D{!%9dMA2{9<9SjJq_|uowb-Xn+ccD$%TD%psf1oX2Yct%!LEu=ELp8Eri>P zTMT!A3mukAwNFc>w(@kCKTpuSA zEK04Xsj*U{4B2-nCAyRfUCMzjOG=j|qf6fDl2^LIlIXZUqYuP&9BDfp#|(T$gLxD| zzM_eC!O4Z_II>|?6mMrX{80b}7gSc_Chj(R;8lJ+&{z?kc5rd5g8XhEq!~SAV4Z zUyJg`l>agS*bu}`=>DCEJh~%(MfWqU>VASW!s&j3;=12KlDeM}N!`z^sQa@J40JzH zCd||7ej;&gI1|}klPB!mLMhupC}M=mywKaE<<6o^PD=|8!8szPr&GZ|zYB9RtkE}N zSvWKi!Dne?YY0J%RPqyzO_LIGV-vAV{u7N&lM*s%wSpRsO_L_)*fbRjKN>ro_o?j+ zPRGumZx{N`q;FUHK0)7Z^nI1S-Qijk3|^ zB;|T*1eI1V%{@E_P%^+Ybcsb*;9AO+rj&G(rJOINOe{pHZQ}$+8LGbETP{yxuCEng zPA=G6YdfcY+{c~()b*@`!K$Irx1&AP%7Fskt@1<6-lBe~+S^{g8P(t&X2PSD+)M}$ zVPT{7FA_v!5hz5!AVncz$UHA+_~K(Vaoku;B*3y0vS%=wKp|0No~WGZRw z8mlxCCRdqu_Q96YFV&5Pl`{oGSlh)(rd`lYwu{$DyLe)P*3W!dHs(fGxz#xzH@_(3 z$f_Z>^aY|jVKa?yWI);kjl4c7?N=H|`%qwx?;-DuprXRVcL6~Dh)$OXSO*y;96Ksf z15c+{eaHxcZc-52i6FY08<>%D@6G_@A2J;RbAtncX%2a3do!K2Y351CcOy&av%~0Q z!}pL8%4^(rGaxbU&PvWu4>*3VB=ava?qk{cmz2bds7k%C zU|KJE_FLU^HT_oVML2XSc~`bNtk!+lv|PG9`YM}V9keqMP;KOuF1ex0-03nux>|77 z>#3&SMso?Kb=64%es!X|66DVbq8`s&q(v|rJF8$;J_R%gf_w_9Ub*iuEp;IH*&y?Z z44!-L?8(TSqPfewYmQ7oj4Tnb>Y&evA3O%~#FeBBw zv+g-WHvW6TjaA{YN_Z3i6q2~?tKRy~F+?6c8oy$rGOgP91Zjk`@d=9C_zse^@fne{ z@tGBE{MVzfu5;Clc3pCPk(ZO$2L1(;r*k;eEvXHx(V&u1pIPSjchw>q;!` zM61uok~MR5Tu)TsF+H4>SlEXVT_UkZh}XttkB}}@ve^Nx$}xvGv2E8Uev%$FCS)+^ z((P^I?l67Q)Hp%l-N;*@T$k&-wF5bvf{bEs8NQXdB=+I-w*BK+RBNwDLph#BI?igK zP!P;VRuUDNC>j+C6nrws7A9eDi;i&VK#VY3bmrTSo&2^-tyDS^*HJesQ$ z1rsShtzVcVe;vDzY`sc*W;A$U;g`|L(TFhs{PQG~)CT$KdJ)<)l1 z5ZmZ9Z*7@rMchmr+bF)uRO%cZl!g(HLFq&~+3*8&a$y~g%HG{OV@_Hd*-IPIq-HE; z$(4!~l~`{=(0mLhj|3`hr}kGw0vj^|qni}iauL|A69|lqP+%+sU1myGig8EuAsz8V zC`6Pg3^C;!I-;6Z>3BPqnW7PKzKQKP`6v6}A2FQLjX13y2>g-bn8%QuVM z+2CIh?RcWqUyK*XI|UUfml1I0?R2eV5M>iETnV40VP45YcytJuv8p5PFx5U=t9=zB zQ0*tt$%Y@KlM6pY2e!zE;fgJi<2T^m*^x%JgHnpNrDTY&R6m6R3i;S+E523gHn0q) z81ce^7pH5u!jK2mcPE5BS4(wDQoG!0Q!jL*deN`RPZWXg*3!W0g%nu`N|o}UOLpjz z0lJbUZHf~hkN8}GNztfyhLWju@VEOxq~lo#6<7!a`4&QCV=yymp3Kco&z4~?RO%vm z)>$vk(Q%|L-Ko`jGE(9ol(EnmLM4yV$%d!U$%P@Dsr$AjHGTU&)}>I1^=%;->)S$G z>jD>3%5X&?UyaS>5^Gclz%6V>$QHEs+W0}x{P z2%TKGnhx6fN8y^bzAo0*-Mr%qFvdbAuGnw%mTY4i^$!KH4>%k9fm)Z!gTM^jDK%|oZImsTFoJYB0Od;!lNK!0|ibZ zFzxVl;F0oY61q%5S0oqdsZ$9?uN*lZXUVIdBv;l*D3>$R;zPl4(25T|j$boAjV58X zq4aF!c_c&q`ytW37}$CL86H}cwnZ0hi-rzAu%J8g38qM|`YdG)7~K(JCcWz829NH@ z*@_oCh;}Yv^}Smg>j+`~1YGrng4#SKAQ__yeq`c=<~AA-9cKps#b$K5dJLq5H1pHd zPczpC{Im;_X)8E*<|n>_Nji8|gv_YAw_?qN9|H^x{WMkxZG7%$MCV_vwIsIErxC^T zzC-w1_Hq1}Q<=iHIg1G!GM}$3Zr86mWa`Eo@M4VFp_h#6XG3hs)3SC;(O3;ya!0|L zSsq+z-3eMr(@J)SRkxhRio|g{x=Gz~k<{Uf6V#zFj<#!LGtu`4MDx@(t!;ulwXGz4 z9H@3u^>EDh2ay&1am3@Qf=k%xPltb;F)k*PVA&-wIW#P|Zos>eB~(F3i-sWRMuO1! z^5r6kZKgMF%*=$HSV((jI^m)h7-3W>`(NxF;OR#Gbfau_oV{AIO)S59hRu4bk4>A9 zRlhTknQaZ>nPe?$%@UVYC>Umtj0={>IN`!LBMjpakxu}KE^!tUCpgfHL+^gb#!H>6ws@*&vcj%mxw8Y+^Md70Ij| z%d}CDocL~|e6&Y>!bp&AvT1*dX!Ye2^eC2qq9u=XnJHb#3Ui2pe2pDnt7jTBHfus( zp+M=7makAETanbI!bm=5D<&uSoW+Fa1Ix-pr(tUViRP`}W6{R-b6n6Z&53SO82=-} zxFRkLub)SKPx8)&k|E^5Amt)quL%+^C1QkWf{}HxmZ>aFXHN)J=4VH0(*nP+4{*`5 z@J$zd$Lxc9$amsRj~^;*OJg(89l2M^_jtT~IwtLw9%aU2dh^T7>%DL<25Lr{R?E2! z4nGkh(?br~4Cs&@6>lA2QSq!{6o+;ib14p;-4Hs*hq7L|_Q-!CA6#55@}Zlo*N0RV z(g*DUeSy^zI$dQ!+NXi;mDG!)WKCxzM`=LBU@mQKDPV!derPZQX|PKuw-wYD=gZX( zAm8B;$vj{E1p`MgfS6kuxSavjGd*=&fN|o;d0ctXT&kl)IfW>w8^;9ehWve?0e^#2 z@YjqqGx0YEe^{VZ{(A6*30bpT(Y=o0#vJwRkjcolU-fVzq3X$+R=rs*ghKr^U{I(R z(8+}t!ogR+nU0R?V@za~uvsE&fULT;@fw+)wqzn}_5I6hWaKNcMkYKuZ6a%A!o5|@ zvXCZ7^`&j&4Y?;+F4eZUeOVeJ-DE?2Tm*Xp2sApv$ud!k2zziPJJeOna}7aLWufQ_p%rLyQIE9*t6tb=ck-PPxf2B??3e5(-2D~)S@yOAu{mTk*bU!Z_C zAXoH=%jsmpE9m6HE9qdOewDbn@G}}-^;&3Y^ziU=g64vsMG*6Op5yvEGFv3)_{%Nj z*7Edh?{HSOTuRy6KDfYm02(AZY&BpGTk(Add*G^q&kjt8XS=4?+Dr(CyDH6_xow;2+u{t+@n{3VPZThCv7YhccT9rWJRERj84(d@cT{ge^+J~yQK z{Rq#uHP^N@dr{5Ux)^TbkK2o4nWN39hbP#K0=;SN=o6_zYSDJ~8<W}aKnZEVi5RV>lzR6{kFr3C&j^`` zw@F=#E~e(hR$`+|Rg@P}V&Q#CnBbDl2`Jgvh?4tkM2ltBiJU>dxgzV8tJz9*MS3-x zt?o&zW(%LI2-15X3y$M%?@n(C4D_DR;YZMLM_#4^O0VLvZZ7-KRapIo#0atwP3`1p zi}Y&b726{HJOHc;araG+5mRRFW(@lG8@%DVACZ{Y;8d&_x3R6UaORE3#8K4jY(3$6LUZ z0)v#eP$Mi0)d?$vF0-IZp6RkG=rTLHMqnHRxE~Q814vB908*1NfMnblK-!*(N9|6K zZ{kJPFEbQcNmGE%x1IQWJYy#|E)icshQjenpri7ez&NU zk*#+`ZMYawvR{t&c_XM=eYPCse87F5K4V(_#*g8xfMcPjt6g}1xV|5QKyGf%m*))Q z>(S;arku?!h3*Z7RI0yN=$=+grTV6)^CLgt(yGu-=R1c_2iC~jv4N(bSUcxB0WJ}d z{zw=7k^FM-pgU4w!P0tc05HyS6qcL^dsgo4=~3pbgfJauK&TBL#$7xEAgST|xT%72 z(+1;t$USBL9HlP#sSic!=1sBmd~dmVQ>CT;@Tt5c4@W}WoPCJT*19hpi3 z@WFZ6_;1^ZWm>OiEig@NIu(&!rLoq-~xa>lt zMAwtj0+kYM3+6i9kGfll&vfTf^!m5p zQjh0Sp9f#vt}nS+s9eoM5*2s*$wa%6%)xGNa;tGsn+?g`%;nf-=f^m0BQq99#@slL zXieeNAXVSYRKhcagfH<$NOV0R)m&2|L)47ShAv6b6#^_X@1u*atFolFT}2i&35mud zCDEQFWm;M^_a)t!u}ZzcH7;0tn7`=R_VByFGIpb$OuZEV{gzTryWyjFkub)Hs_gRK zHZC6Y()bW1uPshQdHXn|3XyQN$x3>{ZzI0vc5_X3%mD7Eyb=bmz@$4ebIOeL=?a}| z)1%)(c+p%~sw|FJxq4JjYKW1F;_R|acn5*m@PFX+JeSZO+?f&t?RFKO`_v-@G74Ap z8Z1fb`pVAaTUUc{kAbuVx=HhBN21jqYGkURIAn^&64K}g1^Esr-X@4++Jqu{;~W=5 zn0EX)_fn#WE5S#2Cs1w4ssj0*K+Hihf!qZMuLi+I2T~}y$wKWeg_`(sXq1Rqv1H7E zu8{S<%3!>-X(C9QCdRns^Y1e`xWP37!VTRdH~UP%4dkkKDSuYRDw0&~iZiXzck%?A z8@CPz!Q^-H!U*~j`xNh}<3AO#IXHSri&uS7Pj}BqR944C#;u$%(EAtLkkOAUSzo)lOB5yx-f>S5+t}1UZde& zxoeFv($so*Ac*lAf-I=d_JG^%bU24B4q}zQMu(^54YYee!Je?zJJ)_l;h^xBn!?jf z*7t!^6yBT|wgSvZZ#auq(72?U0Qdb zw0&SeMpsFJ>ZWvfFoJHfy5A0JliezYn+vnpbr>R=_D{A${xkg(?V#VabGC|oT?k!5 z3Z0db!Z0D%G)#ms^Z~|FeNhl}rBrO|_PkOwFCnUEG~(JpJc?#Yi6-fom5BQGzS)eO zS5>)gL<(0gViDaBh*n2upL=VdDpmFXqIgxp26R1pKv@WwQ_xHr?bGW4=43nsA!JZ9 z)RC+iy2+Y3Y>JwJyhxdHlU(5nS;}uG)DOqGNI*mt0TI{AFKW$985f(#Z4Kx|-@&=| zyg!@ZPmsh&ssBXd8L*$X$pLn=!?$Rr`HW5Ow+$aeI<#X|=WD66e<~1T6G+Mk)1AZS zj!88_hwyNyU4%zBDZHbm5T5R(9ZRfhqlSEl-*j0%m^5S;H6}bl#Dr4hQVO^N7oEa& zsJLxGTxVM_fv;R(TM*#?#LaA333&)aVg|aX zhldra*ANQi5kNRT;5ds&mTpqACrlw($b{MHyyGAv6MxUio6-?+oS{v&jAD)2Cpn90 z+i3FlbLO_eS_^4hL_ZrZ2Aznitbc>`S;a)^WT>K_5fA*(#&{Q8{!6do*ux%3H!5oN z6`aEx8DUY4ZBRCcw&iX|J|;R+pF$9rm@`XmH$x_pJ6z%REOjyLqlO95fnKq6m5_W+ zOPw)I`K&*{lE{VJzW{n2J2NKuD1(b#@Rtl8_$C*8k-?QN_$LOVd(i)kptmgj z7Y5N&u&5x-hi=q-^vv7n6b%GbYi(y7Nx{MpiK;zg-yoM)h6y(IO!WMC^bU!zBDD0K z+^t9}KF-O|^%BV79*V_gx{bw99e#29TTK=jBsSL5^U;t4f2Rt zy(qH~idg--VHIYuuu3<{>e>Gqt3uMXN9C2U2D}nH39mxwb}I<8f+)|j{R0WrP^e&8 z)}C2>*%XHIpeCl9EX?^+6vl24WkTkGb#@_|fMyj6aT1A5Nw7GU?uhmjAG?X-#%|(y zmj!CV*l=X}-&f#nJ3;^ZCx}#MN3=;DTHSWk`&`Q;Iw08;1(!nc8 zU)$G$iCz}keVCikX!l<*@~4}W|3y>CAF^ceC{wbD zeNTNyNauWHQ|Em2X^V=@`3N>Gs_~qUcYA{`=t!1NY0;;&XaKq!`3N?&I4z3xBx&FK zf>yk)$-1rUJnS+Sp?WzI%O(9}&V=w8DalL7SYoj|_bbUe_u00NKz@6w?m59Kpir$CtjS-eD6egVxrd^# zYk_7}QBKj&b?W?4oio)rN1fH`?5oZ!O*ey%=okOyU<^>k(njN<#My|XA`XCwD^(yt zHFTdyulk~C26WL3x@n5!N3Lg9liYDWM{ar6@6>R@N#;NGZ@`8~4`0cxubHX(kB`Q- zAoQ?qd_`xOY1OcUTxT+-o9rN8lk6wiZRft+{>XQen|IkaG|aWY`lwAyeG}~(+11od z;YIFR;1-62+>_9t0u&@n8S5zME{gpsQCT}bGy;%=$ z)BPq30LdG&(06#-0qwlOm?Spe9w2B3Vto*BPl1>vYq`yOFF*gvipH%b z#IXC=XU3Mn|9bqr9e?k|-%9+kTP)+PI%&KkayPeQUk9?wE-?@}#=kcqpD+;l{Bs{b zY9}*^1ovf7-V&4G>lwsbVkY(t4B{;@6WotMyd_qt-Uy+D`!k5Q#47SOS@=c<|D|Cv zWroS?P5YsnY(KY3`+k)zplvG4E6zS(eik#I*C|!c-S~z9LFeOHpa-vHC z(WPYQQY3UK3%V478=KX}qabuVrLTdtM{px+uOF`<%6NJuYK;G)9W}Bo);9T;-3KzR zBkTeU9Av+G9|W)fx`AcT07h39L<6{rkEPMT94(Rt@CGrT)jJfafIBx3AoYJ zo!Rqy6QVI~c{80{cmR?4YTH{F7TU!H#=cEr$-&#j$Gx{-A#(U}VlecC3lZxbf;B%qLX{-8L0;AwVQB;% z&FS6&&p^Pz+FH3_Wt}drS1X`c8Eh@4&po#Pse)8Vv(m|?UO@YyO%}Bw3RT(=#VT!x zg7vL5%D4IySQIObGBzQ!Bg)i-(2yuY6GBU(%uEPPi83-Fv?a>KgwU8M7ZXBjV)-@H zp>^94O2u|)4R(Z5RUM(!Nk=Hc?+8W89V+4uk)axn)!Qg#>gPJjj*|$$^&RDHNfwu9b@pg*I(jb{;VFxrf+x6S@*GS|^_ zv(rz)NLF%38z*I45<4Ah`TDFXY4>oeAlFfShH1^Vf%qXiCZ_@-_jE}BO-S?yZF`+3 zkc#Re`Wnm=2yQe_pe}kTn(Z?;X*1+R+6iAVlA)W_ z^DnT7lb9*d@GZ*#LQ=}QJ<1Bh7xNgxw1gDBo4pWhO87J~xypZ;2yzoj=$dj0w)zs; zh&X?r;rvF!IbCort2{WXM0Z4zOu{*g43d%K-K;2~$$FZWIsm-$UwPy&$anR7fmTuP zQSf%E_h@)$tM?dq=cxBsc;~A3IC$r&_jq_C`;2Q;l>1GFd%8)v|C2cNN$fNBr!&B# zyhRXS0~34a{m2rl11G36499F-^eu4RjE16O*zGm>+Lp-JbJjiAZO!5ZHtF!~QW`x0 zkIc}j5iA585%2nWzQYlcgXjhwsYiif03lc2mpu;MM4{gabyN|FxGIuls49s>**WK= z=|z3&G_WMG+H;giV(S?MsESrPu}Bh*&El9xCe`>37~NAl5lNgt^~M*07`syHqArlx zy8R$HBY?08e9bfgy2&Pxlj+CACf1>5R}M3A3J~8v6q#a;(`3RLuC!t9xYC9Wb|fWh z2$8XD_l%~?c)Akr-7-NuQ87f6;fa`X%LGx)Neht^*BkiHa$r`(L*OSmRe;zw z8SOnvb2AP5 z#!}mpj*_4{B#9D87>&ych!Q>{Gbt%Wq+>s13iSl0{Y~T|1J}D+#nlvM9PgR|E z9O{Pu65RhUhlEpr?YQT|_F*Uxqtm`m?LHF(v7!_7f>;0FrA~ z$)n^9QUa2llpkkv65}Fq#ut()Vucj>W#nvH16y4d<3ENp*k9Y;9%to&1+z$^M!8tw zrvb||%0G^vZsfUR7Pz1@$(8nD8dOfV5N!G|4X>DPk+SOg zJr+4YgFLHUPM=ac#HU8Ep~j98r)Kv8bdQq-R$BBat=MiS!G_kj-A*YRmzUzU4GUv! z8!k+fo$4+Sl*|lCP(o(K{xDo`0+2P0GRE$~Tr3yaG=d^8fZ=WtV2gKgOMUNISl2V( zm^Y##$d&5QeI__V(l}>PVbfujVDzJ7esGe zL-Q5peQeBs$WId6%uHns`MI>mPspOi0L&}~AU!<=?afF&0U#Unw@rhln{3c~P0^qe zb15O|+W42HeG;ZEiHgLvae{5DL?*FT39X=%*k97AE3ih&fA#BGzjDsvETkUePyOR~ zlf8<4fM$*OBqR8fj5ymxY_xy01SDVpT`Jhl+65m7qK?Z z?ixmrgJg=eE+Ua)9V3{m{%Ab&PrHbx;}I9Qh!^7#7czqMlB6zj5eZTkyNCp-^@!-X zcI*;3>1rBp_hp8$a?m_>8338I`Y)wFEB>AzRbRn#cB_f6K1QmKN$RhF)3FWkjlF#? zBHqYmh_*0Ic7U*ZgY}rV0EVl43i;{*jFs>E({i8cshLzTMuKU1>Tcx+XiO4w_>Wv1 z>*zVuV^mRiqfyVk!mdfQAJ+YQ_7aG^*fw%r25I-Ix0h`jBzrw4baPkuoHqk|!NxN? z!E1rhswM6*lC_RfAev{#O-D$8;eJ3-#B?kL`vap^v?>vL#GnnO{e-1 z$P6?8Z!pjiew|LHdK74}vols_H`Xg2g1Ku%#^o%E@tr zV+NY@U48wzeAkYBp!{B@t%PJ32RFNx4pmPgq#WK$2=(V3$mgprpJt`jqE4$i)72@V zF33v>#47^}3SISq?qb(I19O|YmJO7HY}bJU?Ln^lJP;hfRnUh6wFkTm%q?{7IZ!Tk z4GjcMT?+?VfqC#iKFDoqy0FYP@mXDh)0ULsSBFO%XAnQm0*j?%w4S3Qy`agG_G$_jP6x{h2ff-&&4 z;2y5Bx;bsQyGLm0FH>7uFGn>kAmLI_-?88rgDqY8{Qht;Qp3P#f8;D6lznd(EaMG zsDqpY3(Y7Elh0p~?*=&ap5;OfP|}`1s98uL)Bi=q)ws-1SJ!)vsATZFqB8UzlOi)D zDIjk7UM`i&re>503t}-ZOGo)7;tgIlaas(EiL7yw8{y8m`!V+&_^yIrx>gKL?QOKnx zWIV^U{zA}Hs9ajh!6{#=#cJ>W6;P(@0AZosqVs=?h$TQhzjp!THP2CLGss=-hZYAb zmx|!J+WQ}~1n*5(hrojlC7pw%e0sLjBYJ$-4E5zenw5}cVoP}Oi}=0~ji^w(|1zN! zxobGg)t+f|x_)}ZyWptUl1e+j-I+y6W$?QYVo1q>K#OIXYiR0JwRYl%N3 z_~oU~2F>N51;ZXko&tO}qg%_fI7!6cW4HPt2Rs=1}OU(hs zU)DlUTpu*8+x6Yp?$>G{0CB7tjT>5r>dx)F0A@i`FFNlY=bL9wvW1#L!&1~Uc^scnsX*}hoje4w`$%S&I#mxIb>lQ#owU`sRTTvwW% z4vZF^v+Pv%n%NNE?AqSt685LPX0V0V47MoEizt|>eliCYKX-X) zPJk_Rsrb(I!R&Rr9v}4+01zh?FL9{&Wj}cthf6W2^C(^F=2ZJ#I>x6`zn<3qmuWKI zr&7;n+F#CypKCDNqBmjZC+MCAkC@xI;Gw($7To<{r?vni3_Z5;=*J+r0qlx*P|!3W z>ag!eHfhx)H5F|_GGb4h`iC%_B;#eaRWP&`W)mk7`NBHQYD3=I05A?3QPXzXcMFb6 zXj0q>0|M*92k?tLex%NQbcFA4BfX=vR(odw;U|jlAf4)oXy-lY>IdjRvRq^P9Yu_P z_?%7>vc>QE0|M}&82sUn3ATk`u4^?5%ML+?ol$1CXuI?nXPNj=Nn(Tn4WL&F9}?5e z`6-O`vcm9<6wuLZ489gaV2d;5+O*2yHe2!uO2V$;QRZy3bU1f2yzEQg`)?Fnh1ZCwdH)JitdHj%PbvY5fAOqzr_!ltg`0}Rr;jQNX$2CP zv-_1=cdGcbz8(UWYd-&_`jR}f4z<4SKm7hsfaUO~%zuuVQghAd-ri*As$b)%(%;go6@!YtKrI#R&@iOk;8Q{$k@D@tZ zNI>S;J!zAT>4pEHvKyj}%O3Ujw7mP-&AClxX=kRZX(k)e}b7*rquWK+;>bx$PP?O17q^%%Nu1(D1B5FA;Hb!%P*5VnNLUu6!fKDEA{ZAKU zeid7DdKNTv&FLBVbj|5E@TEr?BWq62(W7Bmb7BPQT;lmbf~Y;S=2S>M1+9WD?w~ts z$AMC@I}4!jTx#6UM}h15e<>)f zQBHkdE(p`RUjojnr=puIJ0HHFSXtMKALOwPnGLnT^eva#%CsD(gU0lAFlnY&R+QR; zw!+fg@Uvu&WYdPZqGs5(Zrzf6fG}`iS~_5VJJaK@4NSIS*79`;&)C2`0r&H4FPDOH zX(p^y;IzZi4BC-r5CqIKuz3b9&p`4-7&uL^^@Jq=B~Q`_kY`Y8mpt2pnKG>onu|em zQ+`3Iv?0L%rhL#;Tz6bI57D0Ro}j78`3K)$VU$`aj8Naw*2rILjxYw7qu%nauJRko zr4AUng;EC?=~!2qB^4$Csjv=ISO++srEDVz##vz<0g3ENqcJZn38o=y3iBW~iS5g{ z0yJC7*QTRw}dXa>u(d`=OxVLRqg+OVt7{gH#%Ky0$Z^06uZicsJ|mpNBDbn z{-Dku;bgk@8a@+?NSUrf#l`yS`6y7jt3UiRqM?ua@YkNsR+eNc?YQSP{1p>duOw3S zZ23J$B%r!|6f&TGlX7JS#d$Y$8@Zgd_yG0f2bMyE{~aJG5;_{_eg%p9c28H&Bw16k zvLL`}5@1Eq@sS=zD+0zW7Tvp`8SClR#)X>sqrtY>qOHV5ZFMriXg zGqPe8%^9j(x;csd|AV7kQ~1?$T|3owgx3y6|A9jFPDA8bjI4wVr$=AKuddQo--m9| z^K^Q2lR=aQTkb=%_uHqT{V63v-1P8jro@Rq64SuVu(O|JTsizJovvf5>zJZzX?m0$ zYEXma@Sh0i+#n>-?^)8y&}^~(B13lhQg7$yw`sG0M4E?obqs}U_jayv z9a<~@p^Dhzhh=^IW%vMKzFZ8aD~sXu7&yM1MBs4YEnU4_`0g|O?`hm2<1RGr!Ev~f zsD7GhN1p&S+_zY%RM#?$kAnd~|DjVWrYmKIS1&@W@}5p%7fSx6yDElq-MIT0cbRby zR97}5)T^b^%&TjZDD6IeC3ZCATW-lU*S5wA=S-|J=Ld?JVnNIbU1iSo|E5q`(IQfA z%l19ea}w+`)-3As*Xlf_4l9`a&IN5~bkT#gz0;$N?&>@OT9C=|4~U}OH0@-RoKf>v zghC)aN^fHZiUh|jSXxPhkbt`8> zvMI1)xzBB8P`K?e`vDPO*bm4^H9{bqSM4dahqgCA15v2Cpw$dOdjc>&5%$pe@kQ1U z<~`)^%BNB|qZnIHFJrk->{qO3x1w4*VHUUKi|Y$rGt3flYyS&Ux%2v;N{_w>IhU8J zA)%q}yTR>}Tqn$<9Svj<c*NlxcFJI>Gw2K|OR#>-rSN`S%^l?W zwhd+l?Tfb#W>pr?588uSL!Ixg40L$OhL8-8W`ZiOL&Rcydm+d#ZOJ3W(E398vRbq8 zdNO!~k)>I}LJq8T4wb-PdDpkY-t+cxOTj!f-e=A`=U_CsQmI^OUiLSPrI0Ob%VK$h z2s3E!f6+=iz@n>Nj}EM~f$${ihKtrPt8yxwUCsd^>Pu z9)q|!`HBt93FhXp+@&#dgL(PcHZU*PB0t9lwg~3u=i0!0UBJ)xT^>MAvo8x!k#q3d z8O+7+>|h>#=LB2ecWyBMvf7U1Wr^d3J1Ctf#-}L41#due47$nJ!M0RSTJraHzxspq zJC~Yfq0FtdSxB=cXj(!MtSL1WOGTUDY3wpI4Z@1WY{y>(rQOKc5A56)n7=LLV=iV2 zMeIiCC>M+b>ez(NvhoGal9+;T6 zwFRx!^E}a9Vz==Ypg>E41x@8kIl;x(N*t$~umKlj2hZ=#A*OPvoq2F8PI83jUZk6c z*z@rMfEgR3(a<722BcjDX@JzL3F-|}dRaYSsob8P9ki?Z?V1s^h!2EoB-v&&w+W4e z*Y-bchh~*gOaDg57E9;r%WF#u({qD`md-Be&Q9?M3sHd!gM}j7{@;Lh=WH7>*@w`aH`H2S~r z?#L~u9+h5@E${Me2F0%6cLv=YSet8o%1&k-#tup>qfQpP3=+=fH)JY=EXZ0pE_+u@WVce%OAEhsoa0Il2-6xQSWOB_=ZZ#EpX-ds3DFLshkg=Kfcum}p8 zPTQMq$4a76CNFUJzXQ>nuwt0i*!OGy;7_g}k5ab837Nh9ZOOOq;b8$f{7+EmAC0|%NuPv6Ayy@fcA|tc-bV!*ukqV~i_)-ouU+(x+S~ z@4A#LW3>76so%mv#s@9B7NjO*Ru+WRpHn~2BEoEK=2#Z3o#Y2Q2Q`d}cntMX8GJX| z=w&huLzDlBPJy|gl`pHNQ@pN@!MkpBGJ`du!G5vS};4w0xZS0;2qdJ$FND=Lx9b+5Qf7sd0w>V0NIx4643) zLp;T3AV?Y>dQ;akkbj%sq`^P`{Or$x)QT_>9>`;U2N2X&ydj8&S~WLm@R(b$fGaye zsK1z0lip&t!Wo4iJ)aVCWNEXqL1G>oo7-s^ERAA(zCcXz>$n7F3LY3MbyI^#)?ien zv1p_ulU^!dm?GX1WJIGh=P&;xg19Bk9>Pp5svXgYrx@=WJmPXDW{FUx!%YX?5LAn0 zwZO7171^a%4}a0SdheXK13co*=a=$kc941* zS!XeSkzNlp=;q1MZ+81syv80I_%?9ybeq~e*mfVng5J@I+_$=0jG0!!K7KZCmeDhQ zaj_pabZGiSLzkq7ba*Pt4Pn8<6-E@T@Nkpk6OT_9(ls=d0p|1wF*$-?Hl%{TdXk3F z$Tz0&aI-t7nGa9!2`mhyoB6pIY*)uLRvv%Tv%2e06S2+^&q66{7{}3E4oae9xG(7O zHg|ixC(S0Q0p9=52t^l&k?mh*UsOeF4q6|ollGiUx-)L>;OBqhod0i%!FZp%)G8tq zB^fRYqkNYP@KzC-D51Am_;G4tKR40pV!T6P?__s;2zM6QJbtl^F{mf`=m656spCz2 zPBF$9;&nU~2Ikh|l%^Pq*K6|aJVm&f??QJbu2EwmN)P+laOpIa!&Gda$W2W{GuP?I zPuP<5m`2pq&(IxWiK!ezQA6N23vT1;C|<;?8KCs|P(N|=wE7{N9x&3>-Ly%d;;Crs zAJCh9g}j+%{K}C-O0|`k*@vf2j`zM$VFooxzD%1=9B)=`p zc9|q6MFOF%{rD-#?Vsr`#6uN4ITTW1;Lvhh08)Iib*GrjQ zqFD)8;tJ$Ze?;#&@=;FWG9JHMgE2X;g*P9;X*k7H35YLm$V3+o&YZ!58%vmQoujwG z&H=b0mM{?w*=rh2A@^B)Z_;eqD1XbtwI|c`lPoOD?~B)8&fxs}5d8i8q7>qn0c-u0 z(`23g=*q8sr}A7MdB+;csAaY>bDCJAx6yh^rrf;~gQty5y5{>4f}h@!tM#BZe$q#V1)Eu}F@V#05NJeK1LM;wxD?$?!0V5bj}I z#7-e>{yXwgGKlZ**g@ky!6mF&x!Z4%ZR(uvOUS~~fM$*T;L#3_@+C<-C1Fz&2@ zvVpVc7(cHXJbF1^2i}DyqHxE1rI9oZB-Wmaq&scS zRQe`1DagW}C~s4>AEF^_<3v}&ZgD}B(_Qc@R-j|;n2et3u)=N@GE4o<5Lz>ER@m1b z{cp7XO*740-kGs9s4tyqk9rH2@C|_e9{Ltx7G9jiuSBwREaE+Y4*>L|6VmG`?FqKh zfZ|0Zo=I*%C7#7cck*r=o2)d;$cA_bjAj`bV3sjq8IzR}QRy|1l2+aCAu2mL8wZM5 zI+gqcl@=29Y1vt&yT~J_<(MiVkyN{JuMl(}2|^W8M}nL5#&_#+#M5@hvrgi%Z4-P5 zMmlbeV7;FX?&MtJfCNJ6NH854$38WZX&zDA$@z3}Cm)~#{P7?W)3iRuImMSaMHfw; z$2SCJM}PPNHeqE%9Z&jD4uM3+kFiy!j3T-k9|ydFpllOJe5WG_81W@LTZWA^=}C4G zY0{KD7io&;dl8Y@X2C@{@ZdT#J{_mI!%G?zoDRUu9v+_wV3@d$Eg^ownaT4ai1#q9 zVzZJDK^{7#GCErEffUo72bJSF(n z(ZQX3TCx*LVhE-q+TO3jG!ghQB$dKde$yWf$#(?`7yn8qDsXdHkpaW(1Im26+Sxtm8tKe;FZ7&Ds zX5y@#+>#PN&y;EU5dER=C4%ge_~%M=$icdCyA4dkSE5pIuQYfoV0@h*F%Ju<7n3`<`}Tdf^LXpM0ih%aE^zw zVYi3}iuRfm?d>Vrb9A&5ZB@~7BV|fNOLy5jY=@yTASl)@h3uEO-K7QW$<$RVPQ7S6 z6F>gK#^M{JE9hb5-%ZHZ~>Ju z`grQ}D3=yr6N~(5d(CXCAW8+s(?mFh{Lx&NkvL+*iKvXH0?cjkm$tx{LmS{*qQ^<} zFd+Ob(Kz-K@i$0>Ygi*i(yoNK87aX0W5>)BLCJapdqTlPH86ThGa!4sN3X*jJlF`K zZsWOIEGTV6G9#7Dl1YpKC}X9QY9Jd}zj|2hujw}0AP<|6hb(_-uPF8>?OdDolu5LO zzJh+(Eui!_(BheeCw>PSaZh|2ex1?-B%pa|4Y*~}+mKA<;Wj!-S&6f1N^XB??LbQC zOa=d?(Ap&Q9TG}wP@jd&m)X8VRxN8}ETeQd`sT!SsdVnlooJdGWGB|AFzh#!_&n`Y z(*$d48AOxLlIW1SmKdH&=RXM(O0$rUKxqknJq2Chqo6mj05mBdg}gp5`^a0~M={FI zyOn)(ULEbD8`FGrzk>hLN2ig{_k@qq{N6E7%X}nF<}3yOrOXB-^ZhFPetJy%EHN*Y z);|3`g^^DS^ELTWO*1eJ1Wh_i;=a_i#9OI!K8jWO{mXQ}d+PojzZXz;KB(;X9g5pu zS|^x_&HU5Sg`O(l3rXmQRru%t*i~$n)YEC5|7|IZeB`dLNm4%Qk_Lh%oh6Y>T}y0C zrSpGG`KTXqqhr(6AU!*$ip}Pfon4iE^tIylm)@V|qca<(3q6&OT9MF?s_;?WMmp1p z<*BsxQKJHVoqRMb?NrmONdrNX&XV{kbuDpLV=XHmt)_~j57T`#6*T|3{%SxOe3JQjC7G)fv%j=7P3AEL|7G60k<2fY%(T9DW16Tt+x#8#dXT6u zNmTj1w?kW9HoMY<-lgEbwC@rU`jxUz_vdGvu4Vq1CUd%i|59delDW5%%ro0*nH?jk z@}8mKzm(aRWbUgZvwwRn^RhIVYZUyKGK)#(ekC)lZ14(RkBcUBkQ)9{RDTk6fJBuq zo6>Es?zR~uj<+V?mtf$ZVJF>1JS>I|| zI%YoZsPlSbn$V_a{~e*%lhA`zv4kUw4#l4@&ds^WM1)ks2 zRgyLHBHW_jxfSs`@#DA;;%#r4IrT8=H(Z6}BXq!*+30|WQNQCz54QPg8J*#M8DA_T z%F^@dz|548W5i}B|Dc0Ad7KUqaso$wI!@_r5#YcD2#Iea-JdLKyWlU5?7(_Bj88MVLA(0actC{A>%rXl|PVvdiBqa#2acsJm z_DK@!I$pv3O#$|W^T%7^$Ir>!cx$BTDZ=e2%fOx>qYk6Hu{hS1ftwy9U}V?jj|%bq zD9!rF!oG24wo*n3(q@T5$PU=e+*V${LYEaZPdZZ|xwH+`6tu-pLrkhY*T^Y29ckY0 zN!jjc{*6ioZ0tbi^Sra5Fw2+MAFtam;UsF$&Kcs#893;j1w231+j^^+BlSA+UbUm) z?P^$=2!zx_Hix`nC*3&ELmRtb8qDE2s+XFE@hW^`mJtm?hiC#59|{_FaN+{|hVX5| zn6J50+7Hn*-ZN`hEtR&i=Vs!K``k>ol{+`nv1-hvm6J~PT$-Ehc5>!=kfeo@j*~mr zlS64t%5ZAnI#y+RJ8ZyM5i{MenGB{Y&cUojcPvaxDvKLr+6Cidw5wRu6U(5P9Dp1F zVN;q|TTl@ssj#Xcb_T76NKxU1V+_-RD#|LTB&$|sQ4K1Jg4=yEPqfX=Tu;=m@)h;v z@;OkMyQr^5@!Y6)1Ww7W8kLQxTgix6^U78PD_Y@>omp8{c4b-lm1X5ultnorlewJA z=YdL#^MG6;Z#q{sMXqv&bH=>6#h5SVja576EW8)DvD4ck8>?3q*;s6{$gUCfED~*$ z+ZgS0O1 z9DzXyCSrn<3qfH}Ms%JSNWkvl8AIh$n3jjyr+BqIRAq%}d8o^ZSIWbd zI}}Jc9h)MKxbYCV6pe?-p=dlr-fGN6rv574>SAu`=F08a1LfPZsA|LhQ+sCBoSW&j zYR%2`S+(b8`mH*1v2G^4jZ^JgTHA(cyERd_Fe%!pCEGyEzIJNMHqajpICXG6fccFb zx?<+I7aI^{(%KTtenx~*V^ErVgRji-L)UYEi=-rUs4*CmO2F=b|B}B8rCUpvenTLrxYqs$430 zl}qKc%B7N9xl}@xOQm(?Qo&-Xilq{*Tq-pxmr9+=r9#$MD3!uWrIJ^# zV|%Kq+6KF3)Vs*874^jka?w`8+-``%K&kA<9reZ~>z=e-wqfS1O?K#D( zY{)5IsS&5pg^#GI#NHcep;{t?H|3)ejH4)cQ$8x8_(j>O))+O9iDD>RfuTi<2FMWX z+NxS;%wCVu5(DnuysFhkN@%i`JY7m?vlX2#B{bSfo-QS{+5!tuLm^5@ z4@}ZZ3H^zp)1`zCMak2pgdRm;X{DqGNol2ozE08UQbK2^jiUsCoMyyzHZf1rR3(d{M?1S*!%xYFFG8ap5|0ly0(HquA zb4<+$4^yH+ClBYrXvl$1Y@!+sJ5WoT7DXIr#`cd<>_8nv0!sxP=oj~W(P%XXW{4X< ztO{^oO>t&sPG(kzfewv&XoDXg{br*9z?$BQqaNxe%ia0;@(|k8jin8GT2LKLjU)nS z`LLyI2uM&2gF?{=S_s$*C@i1|79M0{wR{v%hJdi;5ynrj5>Pb(Wky4>hOmlc$w5g7 zjG3^C80DZO3h~ralXy9ri9l9+SW2>_rI~0}TEPgiR2qS0Sut$Z#5t5k(D*3_Mo<=| z5!jj(x4S`hjm!`YmT0*%$x02DYEpX*ByFtJh8hAudaOjvY=v=GCR)G@wp7}HZJ}a~ zVFP7R+CW)63pP*|r488Gik(Wnk@*SH@^+g=Nvkr!hkXo~Pnt!ZZwVVny7X2Qq8h_e z5+yASA=52j1C0=+4Oq|?s|_0{i_!)f4raioltpO+R_vf>!tzT%GCwq0k5)(EA-rg( z0~%>?<6S*9Lad$|Ay!X~5Uca3gvTJ&(QbP57A%tvXe8c6#o zO|=8*0HvvdARVMM)e)paG^*j}BUDcSgc%_Furn-b3!n(bIaxFS&4fc5SFRw`N0+Z4 zh~Y{#Bvz@0#L!AstRgKcSCOWbt4LnuDw0vTikt?!DpZjUm8%GaXZb2pvvLhNy>bm{ zQn`jSu3ST6m1+oj*Gg5SMdd2eymA%6E(R5=2pLhKiZrcUMQR{J<*Nwa=1{KF>PSo2 zMRhB!j?}AMN7`1dBh*$@s3Wn;b)-S%I+9gY9pS1WY6({jQA<(-c2PBWh$E^7A`MZ> zRYTMgt{Oc26jeji5>Yj%`#?x@)sWSMtA?y5Ts34hLDkUJB)wM1ih^2!nj`K9WJSpk z6@_mIu=50N2(qGCv8;3E|Ni%H2yFBli?F3xG=yJ&G>l*D{*2#XGy}hA`tci%R>LnE zczyp+*Zcpr{yvt89(Ga19+p}`9=YlgmbV+!_{l*mm9V_spc0mYSSn#Tex=4w4qT~( zY0ygTAeAr;y;KQfgLTmmqJ(L6BR7O7VcO)G8$y&Y78#0$Fjc}O=zF*+OqFnnY6?>& zTtd55Q#BH!KMZf8nKU$ypkt9E#|Tv@%2O2gIC7L2r5Z)HhtQwO(IjuvNV%kk#nps7 zH`OUp>x-c-sZl379?GBx?Q2+I7}nD$8(lj3xD0^>s9I6R0^qGYYDfE{|CotN-Q{KLzzZ00gF$htI zC$JE7AiMAlMi|oO2y8~y!f*k)JV6(Q&2RzQ{TTW@fn~yGWVf0aQOMgtQK|HZLe-?y z?VzYsqOIggrAHL1CUK?GBML4vU8zzd3NlcQD0D^QN>yP*p{r4P%_={l;5wuq45w8g z4A(?n)2a~0Ysx3O3Sqz|u(T?K5u3o$st|^30>jfyRfRBS6IfamqFrbB>3dog!WdU! z>c$s?TqRD|ARUcq_q`bA3c9o!gmJFG(rOR}x&lk9K^W-@EUgCN{y|`AH3+u`3ez)gZb(5Lj9j!u^53(yEYdsnV(t?hpiBS{1?#mBP^EQ?zW7NExNGV|^CjE4WDI#4ePn+*lWxsu61=Q#G;e zCX?05UVsgm*g-?~@n4LX*kx1oGDw{9jD=Ujg5LQkQP0rj{ zhihWz3?FzCz0_w!U8qYg*@U&21FaE65$iBy&>~vlBl!3-C^`?!9)8klvd3y#Q(n58 zOmEOb6AbFxq{0;lrN4~>`&O1W=|9PvbV_-*KpxG*-VC$0^79^Y#~Jkb#~SQUtfUl{ zWY4WWV&EbNi+kBob7T3}Fo3P2MDFO!8Xmx&S=iLWJGU5H5_%TljpQ|A?LXeXx5maL z%#4@nppNAa!CQ7D1}UE_QS1lG?m)b9X9DSt?71PIHG;ONU^%`;K26%rgXR2OmIw*D zihS8dF)}h1b4zN?jFN}3USa`?at5|9aM6U(ch9#*()VQx76SEGGfrmHb}eyy&CHLl z%_jEo<(g)};>wo`)`6(Ww`S=BxR$&H3iWi5Npxb1dNG;O`06VTvxZ@23&-efI1}p; zppO3#j7-VD1+P(z^0`%ZD`=DS0}|rH*HiH;!dRS>ZmW!b;}60XnzzCy6#XJ;#UG}0 zHp}7io&>F!WJCK(jls8QS+20LO)X4-DR@-#X2&V`C9m7TUL%4|aFrBbhbn)-vK?$^ zBXU5(JOzCKJ04zq%RsTn16$^aFNH|A({d`?a+kCPUj+th+4>Obm`p#1w9L&iu*BnN z7+^B04P_mf1NlpPXEvckq z*$>E2lje!v5m=?))is>)m_#I(n@z=av~IW4!JWK=4w#8FjgRi+ojB40BBHW*-83ym z<1;KE!W23`d};E&tYR(|T@pL}mJx6KPJHr_;fmoIwYeITJ@RkFKW7<1=O64sli5L<~|F$&g8snyxnG zomsd7wRh9OoxFz*P&=EC?&Q5Vl6tzFQqN~fy;w6>iZZ$#zo)PY zCPw1KD^5a*0T);!ec}YmFG+Dca2mw}i7EX6$qd`)7}%wbSEAGOVllRqHLF| zEsQdvM$JMa^bAcUqjU!&^q5K)iM2(B(Z{Gi#)!~5qg1BnlEGLyiUVbqPU$$0j$%(? zx63eIr#y?RoautblvyH@V5~8m;579*@rMz!_-=Q=3VNE>@r=&Lr%an+M_LlhtX@yS z1TY5+i_*Y2IWgp$SQ|wg?}}Q}tfnvV-gIN6I0^X@*)!xx(~vih+wjs$u?7mOuE~mQ zFRy>z(=5|wcSmjEAvla2t{j%>u*;*4_BrKS`kdrsm3FG7{Oy6iy~5wJz@qdi3q$zZ zFjlNEBEsKDKVw9Mzma}b_}DPsHS!OOH1&BmffwuCzanVjRg{YBNXS zNPoKZW5HM=OteyD=?G}H<0BBYqsF4t3U0)CD#V4pwCib?gbB7Z!7WX2gbA3EN~V_5 zmy*T8?^*~J3No^oj$|?QyN*Hoj=Vv!R*x6B7&Zb>umXX$!yRhgO=Vhbe zR>{#BanuyzE8<;%k3u!66)fz+8a(k^k=0C}-86(3l%;Da-+!RG;v;nJC{!zn@Wxw1 z2CtYj%gBfEIK0*%J`%sB?J(;yl!edeasHa#Ah<2Z8^4*fpn;-%NB!JzWd^Kfh0#FM zM$y2;v$7#*CmOP*HKKv|dq^}880{!fx((;F!!+dvmlGt*_Lauq)uIOm`M-bVBZKdTs@?@C+k&##NSKM%^NFi=kA|MuWms4DVQZ zNGNv-w!t}>9$83K8eGOvPy7}#4!g@ysKPotJ#lk~hKd)!7v$6K9hQIs&CgOCXznr{ zD+UVHogm^ORd-M^mJy#jxttED3oH2OPOjvmlYE4ap5!VzPAuk_plcj1$w!frATg%u zpjk$jWbG>>A=s^eDV_Lj$W!t$K!rC6vP5B0HAy*wNFXV~u9C1#CBlDi0Bee{R-#jH zbEKrc97#5zbTj-r9^V3k(i{vW|AB0j_C-q&FGXQCsfGG79)5Wf_2ob1#_i8S=x~OH znPucWEHoGKh=3qG>WD)2P&|4NkDhYz=&3p$v4;=|Ly=QFqIy$s`Q1{cQMDCny+=lRSYjGa`2QnDULcmc0Htk%&WK8K3u`27K2vs7DdPOd;WRoccISGyQw=G6RWVM|2>8(pkvh_{?Bp1f2%O zX_OZIcj5jQjVu02P#*LjTRqbJd8EW2VM8VUPc*~(^|6$f zDR*b#^8{io-U&@Wb}N*lh6*00V#YoS;K|PRlwN=lSHU}^QP5x=RYf*}m<`P+v*maz zv0+J<9bW@&p~BOBaV%o-ufXm>E^0$r^_93@%`SKm7jSq9hf&z($K=+TTVY=uh2U@Y z>Ygm$=vu^yDcaZ#${okef`51R%-ZPBN*7aDN{J<;5wqC+nU45YqFB8?st#?liy6D| zH<2l7!nA&_Vo?t_QQTtis(J25XctAMqs~W?M184d)X8B38f4=dH+W@K#Pm!#o>>pu z_{NvOGE_jy!vy;CGq%DHjrI2)Yn1(Ya|11HxZ9toaT7*cQA270KjNDL$6Xk3QfN7REYb z*-XJ2S)|gz!Z<$gEJoN~#>)9ZiyA^EWD$ruSInk4v#~AZ9z<6TmnEyHf(AZu)3Yxb zcVxE^RN}V-g=b3HEZXuo%4*W&2t6LBIDiK}8Q5!tv^DVOw6HyPNfSJ{d8ItJJDuAt zx!uK}B^zj;8mgbMY%UYTH}FJNXhF+{qVlpg}wz zX$((gvYq=IA}olY)+YjkF{VL4_zRjiXoQ`35juEQi!a;=UJu{T$pH>+W@S27HlF+B zmhiq+$$ya^x|hj^{I|4xeA$-lD5J}z7uJVx%ZcAY2IEnWG)CQ0MwdypM0pZMb528I)>cGeT%G|M!CchdoEH5d)#HqXZk*^H7RHwdtj zi!T1fFH%sY*d1^r=711J6z zV7qi@E-2c8CEgxC4dPp{N^#V1(=Y?^&6KQ{43(U(2t+C_`!%x z>+}`0K+%_;jsYu{m&KPsRY4sf4X_qOntKP-Sp^4>d+M+;Q4gcQX}~g_952hyj(367 z(h=Awr1U)qh~J1G>Yrx~qixA&4J+m#q6xy7CXW6U4G2BrMBj=e5xlbi+dzs_!6C0x zJh%;vC=Bd?hqhSz8V!5%dY;_oG0guGrAj^8aQw#&2p{RZaA?jIb*0q%` zm(hhbw53%UlVfiw04SB>BqcoYkHGDBMmNBau4&L2MaTFqU`?FS4JAg$_;-wv6(pxg z%8J);3M;-PD_*BdqMu6H@dgo;(IsIAGni!rvmKQ1#1H(B?I1a#9U6f=zk@tmJbv`s zdOixb^eYTnb_4nj#q6f&C2e}D{zFcaH}%cPb{L43{Y^S#C%4f7`wig` zza5$7XAQ}>aLVP@4SC4taSYRA6D?ff-jEWGg%^k{p^Pri8rCL;&(tDi@;Ul@x>%5h zA*WPDF-LXs0V$WaKF6(@U>Ee_y$0F$gwx6lqU8k|{;e71Z)F3eiSZb>i$CLO}19B^;6NrOJJK$W7 z>omPBF4E%uTJP)>q1JmCSUJ5VJrp4I8u%i~q<>eT_i<4Et^9_1YC^3y4y>Hs_cb8( zTBLVp6?z+8ti`GPE&(L`-1ZWEF|jt4)_MziRnWUq15&R;df%=>?@>@z$Zyqp6PId2 zt@k@%!S&^-Y0>T)7$(q1xUR?()(@|dMAOhf?lhy z^7B%p z!wa^eISTNWX*s#E!o=BEYBh<6QfaO7cVJbjtVJq!sq%9S+Eb9*!7B!6iOQE7aV_Rc zJfFIfsCAX5g08h(d`V#Gx)NV$Ko(yfDg8+1Q{0oV&eI2KY1oQU=22>$m%5htJ(bp4 z`wuFwRXepVDf^g|srw(+^)l#H`PHtVtKMLJEipBf*18S=OV6R!RiAWyB6N8TU4A`> zXnFqp3s0uXZznv8^6Qfry~9w}B%V%D>+-96^(izqB8|IK!qHFYf!zfRL>UEct!Qdcw5wMXgd ztMYaI^;!l#aHR@PD*GaJG0}ghCe+H_2UexBmZa=6;YN&e(#o#SFfGQP@1)f|+U_i; zMyx~P;}k_=*l!5Nr?p>ek35CCGf3T+Rr&Qp zuqb``Bh&mkQsl93V%E)?BGEIU(>jmA(o-nyNJ_s-<&owyah=!(4y|)gqf|Y7g0eX_ zv2>Kao=A??X`RjDf1E<&IiztfX-rLF*+-}6<1@K9^26-X_d%t`(L6z_Z|BA&ow#;zD|$mF~s(9ovU?CF{OX{%{-rL)}fsX?=-_ zsdRbWJ8_{Z-4~GVZ>!KfX1tbKA>SXRt|ZPX(^QFvQ|a=$|HOr=bayA+2mfo`TPLJ+ z7bJDMyzaYjp(@=yN%wbE=)QEKmQ*3%ucodfPQOJ{B_2to%j>Q&scPN5NcZ>uwQgf_ zN_QfaF0XqpE>xB8KBW7HDs*qVRZFdq?~8BKR}ychr7xSJ@$$Mq#D%JKUrxFY{nxtp zOx5}lgKyXA^1AopLRGp;NcWFb=stLdmQ*3%v!>}QiB@-}((k3x<#ms_t7_d>lJ1}W zYuztRPw5^!L#NB@wr5tYdm!olxeDDE&C-%8J>7VE8ba~ysK2Wvp zp``oQ|62F)hqS)Lp9^%lyl!)0)w*vW-M^)D4@W=tE}oSoe2c-5-xLo?&QmFWBB_#r z#Iuy7ovwok-x5h0;s-2v{_Me;F42?aK|+JXc|@VN#iqy4An>YNvJqs%k(3QLR<_}J zrNW;$tdfC5v!&XGTPR89hUDP53M-yh6E7+Blzu3`lXpc6Mv(=-SK)`04K0?*Z2A*7t7IVYG$ln@xR?KDKU_dG zr!0*zWW_Pz2d}XgW$_-x!wX-k+)uRW?!S&0Qexgn;z{MAOj`ti`+tAW@l40@;0*w# zLeYQ5?#>sXHqROvRCx~46?vQ7SKDAwD^DO+w%TT zYXh6BODX^VukYJ_3jdeizrB+G@21?FmHc1$z4HIkgUSnu2H$D_>wVpWiB$?crT@$C z_FmEd_mTyc@_$-ieC?0QhT1=98$MIXKtk^WA51JgBneJwL;2m|E81{B*;!?V9A z8|MC`ZCLWNOa>Bq-}qo+_2K_yL;2n0E7~xhY;Y?Z9Qv+}7@N)gO>2HnB?Ae)yF5O7 zazts)6-`8@9lJS(uSC+gOgz;szv+BM)en(sN2o>}NYmX*iS{REsbnCbccBj^wktGr zO5No*r?04cA?fyM-Cl#{jq#XtCV3m+_^RKMBc>{nF1hE(U1YKre`q~63{CEK6q zenRJ4@46pMJgLyMe7_9tSR}oAmEVuQqV6Y2cY{j0vrkHexWiD%Ktk`%A546y(7)7O ze&7Czx}PT91xh!4(~9aA4=7Txwf0ZtVSPK5{|#lbdwM3z@9JMs(Rxx;sLR$d1}a_j z8s49%Z@9#rRUn}^_zxx)Dl{#Nl{J^&`oE&)=Sg#O)~wzURguSuE~!6t%a~8^9r73A zCq0|xKMqh)*#=V9O88T}yR1UjRc2*fweXO-R-ITdy|R}7c0ff{8%b4LnJ=&I4@A3= z_(|yqB=koFf{7`X(yW`~{HipU|G+>+&99K=Gt$cP6mgTZm9|veJb--0u1I%i`7aPu z)U}0lVPzN%zqs$I5H~&CQb!=6KSmHt#2lqLmCwqW%YUYzqUP60a~JJjdJkPiSr&Vg zrc@r!!t}JcG^g@dmFDsv zJE*962Wjr6{fm9QWj+%-=)pku)_CS~=?a8U7Ao6Ms0@~_jlj|%r}~24@obM^+AK@C`KF0FqUASDVNVM@Q)|Az2^d zKS=QRLpPN-yv4`M$vfY384k8uRH=Pom$7-L3#(twexEqeW*MP~%h*4L==SK;Mx8nY zDdK9GPR-G&^EKTBoq9m02J6%l;P72eI(~-*!`Z5?bxny)*oS=a)z%Xg-A1&k0;>-x zBDK7a%XoJ-*?jYSmoevJOkp>U!txJ~k>n2DOqu#{qryJeucZ8Rt-AU+Fu^f-oRU}L zxT4#lEv++1>HXIg%F?w-g*Cg)WsG63HG$1*Fag&wrd*_S41ZQhj$flvqc!hdotmq2 zv|+BI`$K!J`6iW*;lq^V1)BGq11cXcIWD8a=i~$TFvFO44cW5FGG(fz#-7vIXn0%D z4Y*3>$lR@Rbko;{jGQ00D!QwY!*2>mM*uk&rLeF}rKVi0Qllm)c`Mc_>n|Lvu*07y z9g`3TB05(cRleT@%SEi6`@JDk!$&IKVJ%gv40=UG97AM_REE~^8ETlozJALkZFbr# zx-ga{iK}nHe(q5VRc`mZu59@Ru^~$9&KC@sqsuhMdTsqot>azogL`$3 z&eFaz=P7yqDXQGA`T+eF*R7fnQ>MD1RtW4oUA~)tQ&z3LUHQO`+9>kT1Cb**#v&!K z>z`FNH|?y-=)dNt2~qV38sGVc;?Q;|W43vF!9VwdqUrYRJmJ+&FhdR`%x zQNvgQ{(G>hh-eH@)MI1!g?CAnQA4`^f1E4<%~S^FC{0_7|+PNPb;LlF`1Ev zFH&4JjOmPgI8@lv!>D5{W#lZatFEycd>O`1E+wZSRxgqE=Rd-?JlVpA#!H;{eY+G* zOJfrd!?;N!t&ACzabr0n)g*EckVhGrh8QCn;#%#Z^77X<4Hvvm$Wx5$!RLV$ za=7*z?1BfUYANdBAm@Ns*9+zLU60jCHP? z7&-k?g*@lFg^`iH6tdBEHzTt(&FijZto@yy%I2M}e=*IiXaU=wW+Ly0T>mzyytYHm zQM8UFKt5vR=H3eV(Y2qs5|=3CC)Y0++GiNANtz7T&o0X%oA;s}B{^9@9E&1+56X*> zamHbn-=eZO<7a^s0SPhJGO0c2`o&e9k)B%eZ>}0FX8`)$R()MYPvfYo4%19QuR%x= zkbFiO<(m>Y=4xmyK^$#-L(mw;30G4_YM`wnE<&0y*E%idgsV9tgV2Ks$%fgQZN}yx z#uCJ05mpbJ!8B(sacSf{p$vj-!WYQ%3|!g8MOV@j@&*_&wwYnre*fRVW`Daje; z)ok;Hl7^N#3}fUjNkhnu%=KF%Wnt7D$w+(2)yq}Q9Lw6*#7tw7n{rXj9LF^8q9zF> z)0|*YBrHN*{`MHrWSNthYb$D{LZ&e?aFe2`Zcb<94BSNsnr!nPmiz?bOCUMsy=?Pf ziQuNtT*@>jFlH4rx#r^-;Aa?Jwd9)S2DT@R7D>?5Ha9cZD5-0)tG4+8(_Dp-v7o7A ze!(Z{hiR7EL zY>MZNh(n_3X%w1uz-1V>;hscr6`J`>F*TrJEdEct^AgybGZOS2gxb>CE6t<6r1 zRL8H7)6VS1$fK_)q=VUqktc>I_if#*E9TzV|jK zAzvBBnkQTmx!jz}G`Gx8A$Kye??r`NVa{OW0gT;9PE+#=a~2T8Xw+WOl$i6FW}cSQ z-(1e#_!!B3faq&&y$jS8l`3()Q=3~E5GtsshP*f zK8zm)*PZ4?xM$5U&O1-ZxyKy9G`U*Wz2>z{(@G=r%;`+y*7=%e-p@!w-242z(`6K! z51WhJ)Iv7F2#t^;W1+c%X}ZI!3V9TWVLXM1B4k455_2un6k{nNA-&9%=0-P_^63~^ z39gmq>rC?eNc1a) z@wE9X(|omAAVolab5l*(in|!18D~6e9tVwKP)kclSJ$)VNw)#04E`ac$au~SIOKV1 zdkMMF^_-c(NODt(CetCwvk+1D;eKtL@v2#qkwT1Q6jIx9LGm(00wG19$zx;>bO~g$ z*?^HZHO*GDIgkwFK8?I?c3{c%CJL^e#_MKJ=IWA0(~D_-L;R5BC(Uic^4idWU;y39LY2ht!ukk%E+^tYlnFokPM>^N=L|f-+Yjf zU>dTVefaJGA^8jAee*G4q0ZMw<|am-8n3i}WWLI}e$XEK$lS`vNsWAB?qsfyz!m-6 zW$ZO~o9{ESSt5&p>|*3!<5D!AFcL`P+9MF;UCH@^k=YUi;S<$wu~&$G~bwKv#yC!SH5+~Jcp54TKgfhvj>&H*a;sBdww;$ zu$)%+D(y$j3m93oO5~!4@w<5uBi$#cd>u1;Gjc~wkuTf&!^GoPRGm+@;m^2Q1CTDEZarwYlpc6ug3PUCEsF#sRVEHdg_pEL67b}T+- zq@lH+kx-r~kw(@bMxMJw(G*zcdr8jemO>g^rHnk3tB@wvd`8?26;fzzW@OCy3TbM6 z#|Q?(QdcvpwvQzL(K3ZJVC3JuQb++K1FNTyR*Y=clABp=eH0tD-fEFs08;Mb{UV{O!l;~`mu#=b5ls1k)bsNve-J$n!{WpC9)jIJf>-?X)dsqGfi8G zthO$+)-cV9Hm1~dvGp?3v}`MoXRM2@-HhaG6O^m#wk)hTrtn1Jkm$421i;Q8`W~LdpRv=$n!>rd>*AYo$faVRR z8I(rzCL{lxnv(MtBkMm_$PLyzjNE{c4C(sXy3zWO5nIa{VSU7iscA-9pE7c~rWt8{ z#)vNs`GPInD7EA6*!qfTW~R{yq-`3qk7;h!HjlKv_EUKsM-L*rQEDAxnkAZRtYrkK zye4a|ah98r^EJ(Q%gad3G{hgE@+!fdc&A%YS&i{lkdbL=NSL|0N~8!h5k|J+sV#98 z8A&TEK&AX@j>|axDZ^N9O|fb-a^o8YBSpp?RzpVKZ*4O2j5WhLgORflnZ)(FHOuP7 z$Z)h{Le4C!gps`+6wPewYDNsLYqoVGBh|F7Io3ZIxm4?V(7J<>@nBm2-kQ7(#%$E@!diD)@bS|=DW zwLR;stRVTYqqb+ARfmz5+Ma(}jTlL4IWJgeGO}LF*$bDMQPHP<_8QMSZSUVVbSKITB^&umc zmh-;#1tVu^IiFZRGtyJr^Qq+vk$;}i_IzqpV`PAq^SM=Q{)KU%jk647#gw5BssSIaqU-OtGNTF$T53P$eK z`8r~4VB{{%b;R1jhzspJ#m_U=@79NmTqJd^wvJgx7}+A_?6i(s?lAf1Pfc^&iZC)x z+Pu>`Y1Lt5n~sE&RwG6Zv{JfU_F0VNX*s5iP1YcJzSd>i!x;Hd(_mW`Muux$jy;)? za_ z)|GGXW8^2TtFGG!m0C_q`!z=1(YjjNZ!^+E zmqly)Ge&mlm~U-=!^j^x=1;dzGBQr%agN=Ok#Wc=AOfz!e&BVx6Ze3XQa#dE+es) zxX!olV`M~3As5=K894_dJwemkeg$vR@NQy*%gCEf{qkk@t5F&`JhomTm)l#JCUd1g zyv`N&Hb(ZYP)M=;5hE99n*R1amUB8rj6(82`xmBJ_K4ydWP7WT_CXrC+Rm&-K76>d z;=0DpXPT$qOd<8Fx$-lNrMR;r$vussb|E8|;x3Yq+RjkBc{LiPyd^EfewcPEMt*xu z&=As&kqF9^xCrUMNS`#Wvlw|4PoES`7e>Y|PsurtktguPOwsgZB(W45bV0X&$UhSpaX*^kn#{=Kc#foW-Ns0(`6-&IjNG&?h1|}_Wpz`?U0i~% z;>iigp%R?V3ie|Vyn~`f}x#v5>?K#ybdS|{NXo`&C_B@s|RYqo! zag+UMHF^tE9WhpW7sY(seuBBS9>TkT?_I`|PTc;0xr&i5LWpJ;(|poGAR9pQakWX% z)wq|U8Dk%2nwnBhk#UP{Ws*IwK!%Wfi|uCQ~NWN65L~?!n0X3l;K=eMu(OxbTh2=Jj@OrWw&+ z(L84tGtF>#K*-r-moReo#R4fYHrqp(>x17_F1FaCnPw*LB?Z@O_83Mk#?woIykSpb zgr3p}WV?MkBegD6$PRlZOJ00TN#1GCVVY}tD9LZz_X{q}H4<{(wI5`zC!SKs2li4% zoUr2h&|bz!H!XRedj%t5jePB1$;jBFO3p#|Bbn496}M4xes!;6nwf7YnxpRL8QHQ; zA;;V=FtYLwg&cSPE0bEJ8_pFu#oJG31LtDDjF!cY%XyiRn`P83$LBFNvz+f`)U5*Y zDbsuFJI%5dL)Vo}RZeRNYUjAdER-5k_*WCTiBg~aithl~*R%g*u>)S^tJ+_?YOfZ0vY6|iI;Sl>)$s%}!|1K+PAgAsritJgtngtgPaY#X zbl%%}PGjVHo%b_5O{TXC&lC_D}L6A!oHi2zh>mthvj*C7uyN*Ud`TAWxE!R$9&=&n=9c zrgJgKb0^D5ekT0$oHNLC7ki@&eY?oTb)I=lbD5M}WZdj|f{|Y(SFv}D=V|7;_esIE z*%|A3j%mg`C6J-sv7VP1xm@cS>)FD{c8QGiPV($znGV_U+8_ob2oEk z%CUrDyx^J5$UCwY5OP0r)&5+S&I_J-j4abWeABankwx0`J3LRY_Peylc6gp;$unh5 zF^nCa7Z~yD*x2FOo=tUdsE#p0$cNYK7~A35!CV)(O25C9X zyww;fM4p74&fdC=%+y>xybT$7N9*eEJrfA#t!tVA-gB6yua-Q-dl4fa*`~3bJ$AGA zaz<7=0x9;5_Fl=zU0#7qb4GgyFp?V($Wiw{yn`6&rR9wEUeCx;Npp>Fl6Nd46Erf} zJCTtCh$x}`R__!>T1Z_*#uV>ej1*v&Akj?nP4~`bq#b5H5b~XGhW9~6mTL>|_Abq( z$Slwn-s4@)G&gDsXL}!IB!YgK!RsC$+7XGR{> z+8^~EVWg3ydB(Te`zIrhO3Bao)_85aQ_C=VX~}E7z8d78pQR6vx}WrhndT5YAJog;dm1D4wS^nJO&IAabrl&edg-lShVe1(j!D<& zzD?eijC9moFMC@v^4fZrwC7dt>5O#OG@HF07&$IuqsZ9eJ&Tbox|Cn{c4j0;>YC=f z={=8;@!G4~y%#caob-%HGo5V%fhLG&M1srky~D^N zJo^%e>3g5K=3TE4%eRYZI%qDpZ#N^KYc7xPGv=y3UrF}*zGUPHJZFo&PyX@w_6f=G zhCm{|LyX*`X=?banp9pNNgCUU`9h3*t-11jnT)K|NK;=!Miyx~=lVL;r1CN)4Q93b zE@YbVnx==ZFC&XJaKntzOB#v$Ze^rDdXU6rl&?{~yBK+8twKioX4ag9 zT#WcgA^-5*!}fHOT$n%WdyajG z$WF3nqVFX}Uc&fLAb0w(zc}paf?Nn>mhU~LS*>aA^X+Ej3N7aW-vLI7H1d$|M@D97 zWSQ?IBh59k+UKoBC0MVm(*BGulaVV^1E+3)7+$Kj`{9pq~r}n^M~(V=IX7vPWtX=n#FGlnx+BM{~#kX0e|DKUf8maI9 zg^@AZKMnmS7-_1t7x=B(6j5`u_9lLZk$s&^S*ET00Y+YG>@wPMYuw78#YpQW3OUoC z4+M7unx?bAd2JV<_r7)+n{KA}Dc${@nCtnLSk;98MaCumix@enkv{%Q7$?DI{mR`IG-^MjoH9xPJ5hP@CF>_ZunX5C0LS znWed$z)40nYc5~Fu0yffdW+%;27HWMq>)e{QiuAcU*J{Jj`iPx8cZ_~wLs)6Gf;<- z^Ild+cAy?3ZY?J}(14M>4P3@b{4X+U1e(-=IKz*AM<9&?9YJFlA849_z`4xzx<=Xr zdayk|Nd)uZ0+-bx&%cez@$IK1`K-Vdb!d!q_HS4_0Hi~(Yv3O&Cnk|1qidjykqH{P zJTQ}yff^YRSj0#`A{&Ae1M66FlV62o^k0Feg`8g$GApo&k&CpP2LtajvP*Jp2rdi! zz{sD671y%BA(mWM${7@VI^fEq(itX^-N6?Een#Gr$S5Gy7&)fxc`1;~NMo&iYoIP8 z7iyaK15JS#Ml)^mM}gK%bGAnI2f8p4(8v#gzKkr=$ZvsxjP%inD>#giHd?zoIG&Mv zwf1muG9yzo5)IB^l`9>qH zgF6_>(KeqE{FITET5^}*cZ_V+NKx=7M%HVtZo%IeIi`^w!Q**U2S3wDub_>#D#N&3 z%jpvgFfv`!3=KA9e(n&Q80^h7XJ}m$ zgO@YXO-r5{90CL@^EJ)g!5djlZH+7sPGGLbHP_q0xr}@)wf_?QAowsN|CGpXAd4Bf zN^^Y>T+Yb2u4u7qP~WsCxR#L)c$+Mc&w}e?RC5OwDdceQEv7k7BS(UtGEH-hxI<<> zd3B(cQ$19Zk@*q{hVnv<8Cj~4R-rQ)xk<~pFw}#QH#AMR&}EDiXrxzY1S6|8QXHDh zNUlb%4n4$3sYEhDBSUL}U@oVo85vs7G#6-OZ0HR}CTe6#Xcr?JG;&YqAS2Tyk`-DI zI>AV9jXWH3*ClU!CG(XPS{Mp3a+CCYMrc(imyt|e7OO(1F>;Ug#$%x-Kn!CnB0-eS z+E6>DS)ge)hI-a@foQBo-U@-vJM69n>lXn$xNbDfR5 zexjLb><>+-y9Bxhy&@39I0%H~oVy(RGO(P3p(GK1Om$a^vut3wxs&tzn<%=__Barh!2hOv9G(mpVJ1Jjgf zZwwB{PXmcjQ+s1fc*1Gqji<{57v5HcXE0Y=+<%E&+#0?cTp30jqc4F>4d2hm03FX$ z!^@Z}`xQlVM|cGzKWXjL!jCf7+}?sF!*yqPEqmi4DaSDG3O~g(S8r8v?h3DCIZHIzsfX8O*1dNooQasGz-G-FpXE+^KkeBrrCjY9F)^( z#=`JNjD)nDh2hX+%wDw2BCz$K26Docl4}0oSd9Bp>S`!Y{qsaWH&ez&- zM!m&|gtxW`uNubMa3<62lSmPeEJnV^NLZBnGvQoDJX-s+;TR*>TTIey4R>VZ+*cIW z>)~^O7)BEHqBF+ELDw7Mu1u2)3kk_^?F#p0WVfdIHaw&r<#a#R!x9bd3&J-t&3euC zeK^j@#QK6}cldDl_IfTTTUB33o@)FOp2l)slr%@fzXKs}^lxZL$-jrEGg3N8$eABL z9=?Z>7c^o-9$;jkL^g$8kwuK$tPwl%2x{nC3B!IFY9rxnCom$n%Ws)`&my zG9wKd2zyqA1CiG_U-NXnLXmCtsBJl4a$)~EAe65TlIv)=Mr1o9_i6vsjO<{f%QE4g z`QbW|cNv+Zb>&5NG4ht=S{05(K4xUEM)D(jIH%nuSCP>$vX5!5Zm7zuQRHj3xiRiR zs061PjUwMLvPtKn6Ctp9fYyGQMD}W=IPxRYWJ$^1$biW2j7-rU8xT3p$Tp1(j9Acu z_3!7XoL(1+Fk(wNtHOy$O-33?q;{k%(tweJI;Ulk#*7Tt`MN#Qu|CCE8=bGaBIh#A zGw9JotS*zt_1g2xBSlPerj)ZgygYI~%lQDf@Xw0K1xzzW=lvOp{7WOxMJ{F1p*lrc{37czqL~xf8JWzI_eriIV`pRvb46cP zT<=DvG194<&^{`%JMsX_S%>i$$?1uGs1`F#{R;##DzYcCoF(7>t&;OuWChdQyg?!R zA}bj&HY?;nWHn39lal8|evUlPG{aY_eEl5Rz(}FC@JQrUM&5WrX+IHplaW903}5)? zWMms7zyB%Z6d8X;b~3VF=gZ3Y45fowuwK#F8T*;$ZRwwB5j*1>Msfx!$?l9F8Cl(5 zA>NE%81bwSa;8NxGwPwlvBFxG>BvY{Mj<0V9ZW;dxGOq!TkQn^s=rI%W<< z93|x{h>T|DVJlaS$b-y`$DATE%_0k!nPw$z6IsPf8unX6=9tLG%v`)onPVeAGxLx! zZ6g`=T>Z?(?uuv~7dgD1E7x_FSG!1Umg&7tWjaP0Gt&bRk!W>_6tmV%-Gs^ZIz`$r zvtbX>(LfEVo)kHjnX6Dg%Cu$XgfBc}j%Q{%+Dl|QM^0j<_qLEZg_$YvLzU^yOkdm( z5T<*i2Q!_1RhhELS$x%Ea`a`#lv1zAt@Yfv@jW7Z$KZS* zGMbr($}wY@IeJbga|frK!pJ7+oDsQ`WwrziZZt+Fa$ct(4i}l;k^5O|!BW*aC-P`L zHUOR>f<9YoeD_QHDRbt_YNWaJ`X3nT1DUXPp7x|i*Qba^9uMv^{k?ovv zCwPLC>%s`tciy}9En#{^Zi#rzWG@ls@yKnF!xiF}) z-qG=qj`dw^JQw}crBlfpAL+s}_jD9yL}X&5D>DrP{}~i{Fw&>K^VM&xRv(J=W0`F8 zxy6YkxQ6)-AXzoGKiU9f;!w9nHm|wOh2o!$09@7!YzT5==HseG=M>)FUt%>442rt?DNMP`0KO4FGg zS;S1GpH=3?$lIcIq{_^RtYhXLW9CM_Waf&;G_QG)ADC$zw5cC?DYAo^bj$0N$S!8? zovvE*BNZ_(L}+W!?zcx4MGBb7C=;1%Z&9QcGgnwTiz1Dfc{=cf36a+#EtvTz@Pzv# zuSbq)z%A%$UW+3gSf+!OVsYdoX08dm<)O$Mk?zdA^OM%b8<8H&ylz@cBK?^;)Y{_B z$R*62YHjg$#6><4dfse)Cvsf_H`etHe1quS$OvXm`#|z?%&pA$m@k~KhDySEX4ad`hR9dk z?x#=Ibbg3zW0|>l14}I268V*x$MKeyFh56jG1Kl^v3XErYs72l{O9zSG@V}}hcR>6 z-jJz`Q%HOr?na!{obKwUMYJk28=q08bu^cm#V;$z!K{{QdNoH=IsamH-dogoqOl6YM z^O?B~UjvZb%c7St^VGef)hya0dKEJTzA)9n3}t2>_AZ>(vC%%!>zO&ci>A{jdIK}_ z;Zc%uzvvid9$BkQ|LEP!q+=IUWX_LHVrKX4$_$83VPzMf!F~8*gY1C(CC#lxA(L0&xi&d@2Y>ht5Ov-BG zm*`{6^p2{`_UO~hWd5Qh{Wbb5GdE*2mUMoL&Sj?N8^Yoj_?2W#|Or($6 zb6DnTW{!DJWh!NU!AxsQCoA(uW>$QqGPN@QV#a+BQ*y7Jxtp1rF#b4ZQ)Xdi<;KpV zZa81H3Nx!RbH?wgRW~!2nKkdIOvlW|V2Gw~(sG@YnP}`rwgExPxcijZowcqB`l(}j zuuLzEbuRZ(8k*UQW$x?i(G_FdSa(O}namuGRjn{%GtX=6Jp5f~Ii{5E%^b)wL$TN0 z@)f7`Q0C>F@(Yl040cm9hqBD^YgJ}i<}hZy&JmeGk*70nW~L9`hm~|@WZuqsO|*2L z%^WM~pxs60h0ME|ImdFJojHk_zL=?tQ7eNYb2BG%I>W|#^wmdh7h+!K6U^Lb%qyAC zv6lPRqLVp;UdeocnLqJuy4N8$C^A3uHD(rIL=t9k=G)ACjD9N2lFav+*>txu%QHV= zX6QI&R%dPigIIqPR*riGMtfE?#vMMuk0Y-p=7hKAf zvLZ*inR*f|bWAB#&Z=>wv*#E}3z$e&1J*k91AL8nrK_LjS&f*fwjTHGnQ4*LjF}yU zD$_En1vB$H;k(l;(<4Q8ep<}YDR z&Kk;031Sjqx@O(T%qhR9Ot-8N%nUZBN7mh3hd-kZomMHOvhHJ3o(oiJ7mg z6klXL!c4?+|2pewW==aywZ6@Io|)^>Xp+w6te2VTi(AUV{F3z+Gw)kl?95up%zIYS z-B}+oQ|&fQCq4TsW-dbR?eM1Gpvd9bTeuW=d1=hxq%V6L%hb>CXe;-WYT4VFxfqdy zFx9iYqnu~DFCq$4JNs~EPQFfM>SSjg<$P>C>c`2HQr+xame~kz5v?ZKdCYXRyqaa# zX6C7Uk*OYSo?V}r+fP!h*4Yi28Ht%u(rJ_3jG0y&)aGNdTQM^q9wjnuvyWqDFJf9@ zI%IcYX8A&8I%c27%p{EJB6CvqnanIrSLWpG{>)S`d%9;|#wG2KI=q=jfK>L-qg;>s zZWGRFPj+KM@9be<@GURM2y;&Ma876OS41_Yx_&w`djvDnGScV=c<`Xe=WWF!$+8921P#1evFx}#;nSIikTaB z!s}ROP4=_GT%ua*vga_<=}2YPXD?!A8OA!%`ZW73X0ElAzsz32%<2)E^0(RRn3*$F znO)gmGjnK(NAYoP9NV3}k(t(r%!S#T{UbBaBkry4RydKgoZpz~(-QBkGn0|Ci_1P9 zwc(gjs+g08^&`H!8&|DJP6jg_V2^0!Nzpi zs*Q;8^(w9p7UxuB=8zefQGz7 zC0dJeA}lk)w3g(=nCXRG2+?{crxr6Op$_xd$ClpUROW}A^P0MTdI4&~rBg~< zat5$W0p>4B`PZC_nHho`0>bRbxssX6R*FAzhB5Q;MJlr==T>HF|D}0RY&0|JXk|$! zBX$onlQWg67`u;|yUx>e4vjs^%r2bxh*s6uG-eibRVFj$cCaJ#(_l>}CpL$f=P+W4 zRzYkbGbem5QVdx4x*Vsky^1O%(#6C$COe$_8v2{(7!~cPV8f5N^vG7 zOkwN`X7tU5DevEM7{oE|G=rnAZPjMZaiu*sYmJBk?>c}hBG z#}dq(X}R}}9nDOh<$ivwl$qIB=9-@i)daWW7C+aV|k5=O=sp3oSsO^V`8(I*VXH`(%}QF;;__QP!q&V};CoWx3CbHDYFy<-Q=+oSEsR z9&LZ#MMR5Zt(iHdRT@2Vm+N0kV(pk|V9eXGQfB^ar!w!vIy3X?XZQsL)_O12otX;X6hcQGV5bkBwQa{g3-^(l+q`$ zYgy)0v+%drbQ%y}3gCHKE#cQbRb$?T5Z&&+zv zup;B-PG+Xs8Jbr{?i0+!Oe>x{lbNG$5v}ZKJokBKcATnO$L7vv=8}n;a@*Vm%zTQu zKuUT_?h0l~te$)2ZeV6T<{h!8ckWjABO-J`P|vs0*}1>5%tbhz6q)k_W+Z$}n1Q)} zvCJ^6t%MnrTcNr0!|SXRSLRk>W`Qx+?kzliQP-VM%2^ z${pU^os1L?p+L*4HnTaFUbF(I5bm#((yP7LyaHtIs^@HQ%x~4^G*1Wf2Ry<3Wk+{b zo6C$_pSr(N+F5NLYq{t`m|fKtvJ8IaI$(BJTihIrI@%kgd@Jp(_8v30U|-Aq-Aae& z33J6+lGm+NHDG3%OmV;rZm2RR1kBOBl{qh9PP24;$DkA=W{C{G9T6~#aJJ?CN@+~q z3YMvY6^Ah6@>b#7mH2W6VgO<8$#Y+DjnD>TCggp}Oju+0<$cMuaYbuZqM7ty-Ud#2 z{;86C#CtGrWAj6h&RIvOJrCt=W|=nlnuO%_T;30y&N{>r!n}~Tm6?*MqBWCV%=?v@ ztFW>YnHTeRaLOGmLU9Hx9DbU} zkhd)F&|>Es_kGGrDA%&Q!;4*Qgy}5Ht5WP*`I@?-bt}D}m&aOL9~EXv^n-wT;sIqo z%&X2aC4oIlqO0<1F|*c~)p>Q8x$P0vT9a3onUu+_&1=9+%u@a+uQ4+dO=ewQ6K1Y9 zne}-IW}YyakMmlHmdSjQ*NU0jjQKRL4Kv@F)@ONbnW<+opXaq_<_WX;i@Xz=*WrXpafgy4oT6W0;w0Om6;N%*-*SRsP+a^1`b%oon(Z zaKCsDbCdM1q4^V8W-~@~VTR>TVrKhjCNTcols}D`;omAVB7ZtFYcYnqzle8h{&UP6 z8T87CH#&bdGcTLWUHS94R$sPs#^=vx<`H8i<}YHc7FdnBzfzi%{{}P7Co3~0|6OLf zBW4qs$MTml^Qh%DJ^y`XO1gD)aNdX05`2nNaQ3{BN20bD79YsJ1A76EklH^<1s$>-j$w zr@^>K5mCFpTWN9rR+g!6{&tpm&gP5v@^>)veo)eg_g?;=Z1aMLrR+Sf75UV{jhQoyS(%^COjYZZAK(*mPG+>pe3*Y2GhZ09D!&plpIct5^Q$uR zzARTx`=XYY6!yeL< zf5`8`Oqt1S$?wX{O(yeWes^XrGMS(9%a~beGC$|1n7P+vw&tI~%mrr8w*21AL`~+G z{65S~vvjuS_haTJlle9Od}g*=I=|%)V5Y6f?8v`_nQu(y_x#J4*MGGDmEt82AJjqNqOSz!n8D?UZa_xed%v^3Vbqk(nrk=?(D45O6 z4y&=o1#_8cXIf1PUS=j`xhD!1FcUMTMZqFw`k2nN7cy(R@6X)WaewCg^!=Gf4@hTla(|i6bN6R{Js{;7o%WYmbwC|9KA`Mdi}u$V zck2Gkhy!ZlgogXe+)}td^KHfbneN&9GuZ0pzpxG)9bnI?2bBGe1M2y_1Ij*kA5U;I z$Ty3m@Hq8=A4X~PAl#oo?uB$MVx>k8In<_)M@@m^R4og)H1IS|=hjdZH}2wqOVGGE z9<_i5P6M7IYR%{{eCcC6WIg&7QAS%%?~oN99nVk8aWCR6Cw_VZPPI;E)E9T8y0hGa zxF6kv(Xed%HWt#0(&bGhD|n0&booEE0J)vTx`*Rln3V1LUpyMiDNn;{S#moB za(y}9kZby~N9QwlPJj~B8N0!*o zd(WeBK=>c&-OK3j(+f461rPkk8jrHZm2duQn?1U#eHuN^ax>mW#LdY0_)JDy(1I^8 z+B3nUIgIi?(|XyyThTA`J$i+o#@_enRYvm--H-ie=Q$oZ-*t8G(UQZ&C(+N|(R`c3 zpQXlKzT!inkAKh$Z~k-2Wu_5Ybs2n8G_ozX_plHD25WpbOzWU$2anzX7pGP@(O$++ z-)*F}w8M>Wse=LdqLP#IXxhD6@~aIUg27R0?U?!M&+i%f0{0uGyt5bR(-Q;Tr2pzp z@zVqq-GX0GMjpj9ZM*ccD9vu~(Hd|`KkXLr)1=>JvZ8PAP;|#QMfDz3wAP*uxmvl^ z4=eihQ9%jX_8s26Mji>eG~vnta^QFhd#W(_-l^ z+|LvA+9XBq8@kfU_LtfGhqc1W8q%ss|BTM6`zz)IN$*oc7J^1+oj$=%yR#sjZmA=^F`d>2Hm6e~>}|@^ ziP&Qm^!7wWb>JHtIhD_`4i~h!M4x8VRP#sXTX*rgv8`f27l?_Vf%xhp*Ri{D3>sQljpLKAuhV6PI$Kq4kE^A_5SNYIov< zi{;XS87!TS#@!sT^qaQYZWGah!sS@q_i3zhH`vo7ER`+&RO67fioP&zEHr-Se9yzk z>QYYn7YE*+pc_&5&Z-36H$_m=|G(?2zYbRm)|-!qquJ&5bk@x(_mZJktS{VPef3+@ zI4|gB>2%pg+WOC%Hx1jU+=)H3CY$}P?J?jP3R>nbyv-+VbjcczcA{P|pPZl?Uz(q8 zhn%$03z=zwM%WjgT&7P4nI|rsxO;2UUxpL$dk{m9iWeql9e1&=1Z zEa@RG3w+$8^RUEnd3dzwWJT{{v~Xh+egVZ$6-zH->HUnFlsqy5F7)>Q%Q}6nleBNr zUmmo1f*$Uwee3>}VpW3L1zwk+<#@M4dfq~mQqbE0m-I`6sKBF-QGZgRZb^~z$VKMD zWnwiUXb#3*K|4@#hmw96J?P9{=Ih*D=Ih*D=Ih*D=Ih*D=7)24IEVh z9`-U$H^tXx#uc^5SG1HuGbidD2xfzud{rw2yW<=@d=dMJpqu->n z$GR9UomM@keR?Uzc9B~F?-W$&NBo*D_vznHkg+}Kj|x_rDgU}4wn+Jh1d&$CpK6@O ze<_Q@QohDvDPQBTl(l8b+A?KrnX@h>VJ9cQCIO)8~ekU^b1QCW~pVp$`L; zP7MRObh;RI@BBWU2Bm3xJdAaow8!T`1d#OqdrOnP#$ln&WxhsaWfmQl`5GOT`5GO< z`oO+oddARVL$_i6b+J^LuhC|iza|);i|Gi=YVK(+v)YK+ zJor^mR~a;WU>Zk^88kSEeUknsL9CoXlMyM%%BEdJ^2neW<7CbL-{{^lR&=orLImpe z6q3ICva4&4gQXW*kU^mZ6(gdXL2HqU+ds&_8}+*K`rk>p2zOxiO}YHoS>57x9XpfO z-{4I)59-*NwEmX#!!_Oi)!12){=f|3+N~nh?IEL2McN$9x)tdwAU9rBq%NpGkt;U2 z_TXH5RHPChksFL?y(LyR>2x@vmK+}SqCokK+1&maca~?II*+|xFSl&8LLY#gKom=$;BW= z^xHSWrPJM0rS8+|(%L%GJpQUj&7qr4qyFY8*5~N)t@goLV=hkjoGd$Dg>((pbZ!@{kPbzAxV@1$z27p8IzR&v z=`O8}1&CFgT%6uP{33F$1&4t1C=L5GojJE>OQh~gXjWB4Tk9&S*iq5KW{Mi-D5{MW zvun2!+LNYeO$SAvR8(~R5`3W_`9`S|VnSy@lzS_^DevI52`$9(Jkng38 zyb{jI7HIqHs->2e>a;!0NsMH#M^BcFI$1>;kEZr_Ke8rx=wH)6N;-^at zJ(8P7lbGwd4KX<*XVt@uT5gs7&Xm9C6^#@!Ue$Wmy$9?8SM-AYwRYEeG?jH%9j!JW zRZUv3m@Yv5No~~sN^2<8XweF9V6yJj*x8m;LQdCjSVJuIXgbSn!%X))Bey5$N}ix| z*JED~sF*&QEcH@Mm*1->dz@I0dDYN+f5~nc_AxQ*inl+8cv4VaXWb1w8v97XJu+U= zIMbMC8cj{3t7*ItXr%n(gZUTHSAejxsjR(h%;8#-OFi*+k8Yf=bKW}ml~^!zk#b`f zE9z*d`|HXreIGlxTtltD&>CN7T=xYkx94+x+Rkh_>ub#|(@-=`EiE(adm=)1KAAyn zG2^)Q&7e=Qt0A*}&%ovkdJ|)gYpo1wv{zEjpi|H<-FT2e1=ztA&;ADO;dG1XMW9#z zWvd>nEf)oC8K>KEC)RlcMzc-Q`WW>(%Kmel&S|gx*7O7Adf+R$ z!rg^FBXaG*2~t}y$_KW@No~Q`iSQ=H`$#Y8KOgKwCw=$zdRLQiKEsglV01g#h4AQ@ zvvoEdyOPMwc^+MKjz=G|RjViC%`l)6I?={#EHs1B``$^4ZZ}kHau|Gq**Q!(%To*Q#PEW_#@LZ3kCEy>UMH2awEzyBUS4 z+^|JwjX(a>^jyAa*zrmEFQL57UohTxlr~EFJu%t}_skqc8-h6?Y@-LMYA zI>jlTozuDb{1DhzX!TOa<*meA%h8w-7`bx9fQre(JFo?es^dEd+tCM;el6^tyO=fU z*95AKrwMuz^M`wypt|VOF4jxX0L1)-cv?cyF>*pwLYHnQJ|!!mGUE!d-kJm566%MU z-Jt|UgUBuEUsPS{CF!4Zx}q#k(K)RJC8%djNhLwg-=yeKXh?c@`HBjmD_pwCy@ynU z`^vcWtBL(DK@BkaNXb`4rQMQ#_a@S+NxwsYV0lmn@ZezO;8A6)OFICh4qpiy=gPy`UPHWb<7VD_C zKuP~xjHm8t5xsM_XcW;h^Z?h=MRXX;Ibb>B4f|TRr_7hzmadNwe4yF8$ri(_(|H9BG0rDvO8ubm$7q$JP z?n=5;PC*{ov=jB51gc9T@^B){D1q}2S3`B_56B6sj2Thn#toJkwgNRkk8-nLf(pwlkD8bRLk~uS@zL1v67I{eZaB^={NQPO9D0B5Ht@oXa;vXt%K*^#zwf zS0Wa5byY%7AU!t+6wz&g^+j|)+U)|?%@5kLh$>mDhN;xY8xoSm zMkz-VAQ^pbMO_Iu6v*ion+0OuAkJ57vWRw7N~5cpJLFERD;OOG{}X@t96l*%ElT73 zrHBe@D(Vo?r>DV7L~c~j_e;z-lK!ptm-ieWsT9-T30Sc(YK%P;hZ2;)KD9$h|DibX z*%SO3cZu97R0$2dSMsRK9_HlA=h1Ou`8-DL_q6?e<)7Y#r~l4^+0E60mwPFSz`lQC z%e;NcJO01SEmiBEm3-(vCBOe4JFgl~RjA?#GzuQYqqbNYcAvpY)cq z?#g}ATgBXbv|w#UivpCOgQfS(K3=kpHGbYF4|m3j+dwwkyE*x5=3d4wnB<{#P~Ot` zK2~jHje>nr*}~lAhiWS42Q^tfmAm(`ZyRf@-N(Ki%q9XQCAy>?o+l3%+0eJ*K(A%pvpcL9L^e#?2}4W=2SQ7R}JFMgIm>S zAFHxicg#L{OF^ay$9Tm47dzB57C_L{Z~FpP8AT}2m2OMB4<^c24Za`a-H$*@*dzaaCsMB z{b5uM`w_Aqwtkbu#qNAd)5|v0x3bumK}X@-`5fqmdkS&7{A}4th|}vpvOBW|QQx_c z^QhS%#G;G}E>~0$@$)6jy;wVq@0=7-lP_ho&7jaKXXzlwWzfFXU&WlJoIyRmQtLNi zRVn3dh5Z8;nP<=?uS%U}&~PAUeFmLwT$tNK#{GS5XgM-y-+FN;Fd6hB_CX|HwLaxv zgeHJIy*^aAE6{?XvGNkN?+TOq#H@c4H>O3d`#?pv<35~l zn|@R@GDDwk%~ABwrJ8cT_R77{SW!)!tGQIL9}78Y-(4q2OXFTa7xB)NKd@MQDCK8V zS9IMPeY$tGB1~nxdV;QTzoK5;c$M^@z)qz@*rBQ;d0+FtD3L>P9xaB!n{bN( zd!SOvQjA;?656ifHAZs*&m9)0}Gfa1{ zJ-x!7-eZW?wsGh6QQedJ zDmu})`o@uQV~qRVP`h(g_e10IjGJLxf8*v`iPFze-HFD1W@wP11}3-hSk?Hbt)fN7 zJ!{;h#_cuknl`HOrlD?z9x_zV(2s`N_E+7j4AnN&(@>hBdkmdvZC+;W7PnT|V71%U z$F!dIjo(cvyV~qiE-Z@r`$Z_9yV@@X|yqPgQ1wA zJ*K{Z(6BP9^n>QOb(zvLV<5}a*GVTxKjxd{_vT|%Rxe>;_VO(G1?z4J+ z$?Th8EuA=0EgfQV6HM+Jlgl=_h9=j=RqpG{fJg09%<#LWybfR^O%ag#gA z+INF-gN>_VZ8^!f660oCDZ5x69~*a#aTP7!$BaAExZjN{v^-ujTXve@<0hMKmZ4h= z?XdLvo9_FjTWZ|1#vN(8kDBf#dzv(~@@Tbcs-azm<{Yk1XC9{LLgOwsuB~xhjXU`W z)hM*5yA5qHxsQx{+qk->Tfv@=4Ux%RXnkgSnMUUCBdV9Uv-&)>;6j|1N_4$&kw&kd zo~UbsMK~3dr|%egq`7j_4K=$)b-NhqZ|FtSeb+Qz3Qz{Gm}MP$N-M0pVRr^SP*squ zKg0rjMkKK1#aFZ(hc=VdMEThJcU(XajZI&x#-67Y)u<^?u}U~p*APFRBezA0s7E4= zCcuIs8V%&`c@&v_2iMSb=)s@f*9-TmIK8GXc=QNR3!*)`CYiHaP!Hd|x#wCYtPPJ& z!usejXn0g}t*m-I`X1>yxgr{ShNgVOUfHdP(*nGg^%OMXDFqpuT+ z<{Ns;(3MBxJ}b**n#Pn1oDKvCDklV%a zXkoKAP@F-EXU|7X3i{gQTAN&sjcd4I74-O%yD7pZUBJyAr08-(8H1JEZrqcG zMjP5_qv(5vCfd_$4Q)0w)8q!*s9f8)kIOXQwZ^?{=o(L-VskLC{>NfPJ6@Jk+LZsD zq0J5CZduB2f41e_N@dbziCORIL2n(-K-?x;uZ=JYGFk$DD>;75!XY zN1wBwRk>OC#;%O9o3X@2_P3@%Uw|a^OR#WsiY!+{N2&o7fYskITE!=IWD?#H-Qi#t1Oi*Ha@$u${tc`{-a(b-39t-WrxJc<1w$>WM;n%+o5Vc%+Yk+%6A4=dXJfTH`1 z%Q3lO##MMw<=mZDX}4M?H_Es}eYNjJ<9cJH5shAkPBpa0BI#cY)v%Pa3{|w0w~yEK zDw$RFOfF?9hdY6;J;Z{%sfv=uy^1!HrVNRWKWhrB@hN$>h#4ZiS`y zd3Dve&7QU~jkU%-W!z@twi>t0&^MOym&PqHRNGK<8(-1_g!dO(%bZt4tLn+jUPQUr zD|K_3>kD%KFXeyOQ%9Bh)>@x8lX8?$wL*N)6?0<=RmZq1XcXE=&j&e!f}gf9bg`k|9@luNyP=m14ZK-r?4gF5z*2X*gm}v$1sAor zlH=R1h*|`_2hPpx9=WK+l>_&j4HY0Raa=k*gE|nD8QiK%r$f(_F(;jB1QA|3b!jd2 zmrjctNDHP@Pu$RTQCd1RHFQ`@<=P`RVlHVy&Gpbk&tH{2P8Cn4ck;9u~A zC_hz8Gw8%a(kKQFH~SH~yH-v4C&UyrGOlsJCH?1uRZP-7qSR$> z#dVTz2A@ziVlI0KzQM%kTdYl6FsjihjgDs2{RLS^;Vd;HjgDh3+8cF+HqM~ufA;7^ z=Eh)6cM>BCJiEBuJ=L)|D|aJOF>THvP6c;xja#0pT+cgH?x9Y~WgGW%J>@cEUFCjUNm}15`wR^p)><6j5D_VeZQw8T8gq_@!>PJ}mFwpPL@64u+x* zPUBR5Iuma^Fw&G0)bCSy^CeF2-Kf1MZ1d39E<*(B`bQBRk6~WCsp~xTwF?68EPpoE z(^`Li(E17b;AWWvdid^rsdL~jJ^Xt2D2f?sfyhIi9)kWMXe#0oLEj)1L5E`XDQGq7 zSx|S=tzo)5O{3Zrl{@lkMcq)_qMK*jjTko^hu^)))Rn7m=*$4&o!e7A>dkekC-e9{ z(QY1{3$FZHw>3_4Wi|T~mSci8ty1nj^jbGIWl&YjQSRJ6gYLwrasj8TC;b^VV*b1H z`0#{$`4KYmXV5*EiCwSFpu1ks)A}=To-ABl#N&cKL8Kt4T4Q~>au2LxTdv0VC+NUg zynJu`dp|uBafy^y&zLjlz`mM62lL&~$2X%-4`QpFKVQY@)nIhYpnodY8~aGZpqoyI zVMMx#Q)%)gk&Htw4w$xT$K zf)4DzMKloeg7b|M8og0w=Mp*-dl~L4Hzl+e_lDig| zOvBM@$D>5JMSY5ltVNWDs7hw%WuM4RlOmdVoJIhP;V*7JFFzyBKsoM5DjuB>_-PU4 zFT#6^TvzV>t*MOkZcl=~Ybf`Y_LqBdA31r4(sALtP+=Yid;0fQiN=h5(vurZ?nYFo z8|D$Gz8E`SfJU6|xcQKPQMRQ~t&@om~#=rf9OQ!G0-KE(bH6 z%tB8G@qNnwJh zDd>Y>hKSPu#G<0n{WI|<{C?&qTDCIWmlusD$15sor;+p?-2D*i|KBM2e_A$={#l9e zmKA(i$}!2>?Xy#r8)&=x6FVq(S+=5LYq$J6m1~845J|72p-q8qf*wPx;_gd{zeqnC zj5d?VazPD6dpn?g*(cr2z5QE1Z1b(w`iJ+^w*0A3W(|*KXK8B{1!Im!KR4I541L4Z zuCoR2ZQmpQ9QL<3-TN!C1#!CWMfo1%!Fo!9##q_@uj=&Ry<&42ew~K<^xt_&oIb{z z5ze3E^xrF@B$ej2YkER}lKy5ybM9$^_G153@^y9an$(M-u)JX@!;-raz4;%M zD6}fw-sQpl)1c((T&M0G9jv=iHdoK-l)@||HC}JKNAGcN{o(EIonU!y(S2tT?^~TM zbD6Z@zH&H~St+YydEd(AA#y9Myn@2=hNTQ!@L=ucYHjsCR!PeHb79J1O?G}pt#UQF z{$JFjN9`+0YsuHAT)ScJ#muw@CHLr7j6;I7CULtLoAok|yWhDMw5YoH3+}QS`W7*l zJgxhx`X9f0%^s`i#i>)Uia`q+8iV-Ht!LsiGFaKfDda+*oco#jX;`P)zHwTzOv;8e z_T5?=Z$rcFkx5N{&UvV%u9R+`iCga}KT7Sw*yQRZ9RJFX_wM^D-*EkDo&M9W z_#(EQg%}IEaoROZ=Zdg5y8GyIM_p5n(}RdIM8lnnyS>BmT$qY$8PWZF4VA+?nHHr@ zGxVjQtAn+(#8+;Y1o3J!S!Ll}+TdyV+vOR@Ywrnfy6a5h(d1xuf&T@2JlMPHffYU1 zhMRljM!b8QTy`%*`yMo_+=;4qtlAPMwY0n~%8B(qa%+WFg->;_z@yqTHRYcTg(V7Y zKFdm}Zv|j{S)$RQmNMxdtcI?8&ZA%0mfJBm{=T18VIBvowQZx-zLpgfg|>v2)`o{j z4Ml5e?>>H)a&Eqqr=j&(n6cd(JZKM#hO>9+`1i0qZHZJwE^L{})*kBubg=gDsKZ_2 zIjF0+_QB_x3rhM$l@#UXDLQrJi+IOCzoquU<9AfoyF5a(@nPiZmD%M6n^wHevV3d*?AJkX5 zu(kg4nhZ7OVyu&t_Y4)DN7Bj5#4eVWG92dDC^R*R1-*xZN?_$3{ki++{y2)O6(*L@?Abizhl9tl- zRVi=y1-Q_Q-8w*gBlHO82cmJC&D~4g8iJ#OzfUC`<-_#C+Bk4TI=J75HtRRG!ncWJ zY)YHr>h!?eq>T>2(>NU;tW!|q!ML0BL#x6%2ul>^8}__ym|fhShetX_;Elekw8q^| z{{H(Gm4nzPPCp*4J)rp!7$?}~V*?bYHFKp-<8+CwqC*Qpt3pe|);h4{Sgq8=F9ouf z9A79X>6aT1f|ia`zo_=8ril8SCwf#LZ7XOHT3XO+brjuItf-~Q4Kca5Ozv)zt6?d- zuM|jnw^vu>zEU7uO&dEKVedwwjF{apwol3P!InC>_j^YGI%w1 zG)k193;N0WsJtI+#94>yJ^21c1+gmJkM&6BbB{Iz^8&txV|!Y<21AXt&~egzUD5Rl zv`n!g*U$IgLDQ5|ehuupv?MpjUl#1_Bx1e47w`Up(vu=nATU zQo533ly5IqCFmrq2;6EcLG#|yFQ~LN?p2)X%hSHWT31@(ByNSQ?H-?BBA(8Y`YZ3J zuC?}+OVCj4!?_YAXg+QPI8;LCC-r3Xn=$&diai~KG4VL$mY{m3d$v9OqP0G~$ezxy zr!RHar&BED4>5*GzVqzl_9WB2%XG(fQr!ynw4FWux}H8=Y$Y1E#6Whr-s@4BZ4uT!l*@e;SU8K?XjGOEP+ z+tF^sjMKE?GQNa!fX6$ZP6J;F4m5BIfDuk2luJxQ{p#;EN@(OYGRl|G;;R)6Gqldo zJ%*~9#!tpQ6CjM1V;bx&YeO4d$RoJSK zd-pz%PTP-Lw_3hX7pLRa;Frws6p>L~+@oN*v><+o)1}Zom!Fn45wG*8Pg|Yow!JF8 zk@UM^bXx-pl72r!wNO@9yZDMsfZ{ahHwyMVG~YP?-df<`Nq`y0Y?{?UJ#NVwZ5_EM?LkYUg&}l&p;me0sS78l>wYD;dg5os8PIJTdXnL;p z_ycRrqb(@4^Ah|D24Xl@rwPi~q7lm0;mVCRt1dOGN`4nPe910Ye}tYBH;)Ld!uM{i z-Np{tzXcO?U>?|Kz+Q{^f$EmeV+?w&#Ia#{)gus#261AU-wvMRyspgu9s4;B;j4ea z{%!_M#Z2cS+6=l7J7e-Rg&rzs2YRTWC2>Is+fzu;b;pShC8*B%icUi+ZdVAgGFGk* z;ah7_Srg+M3)K}pg*Ay=PbdB1#fmO#B?#yCfz60_5m{b>cEWleDa#7n?IH?tyNH6K zuuqUirQuG(Keu^ZWwpK)N-pJi9x3lzq6B?{S`@B!O+_^^vi|>}y#HTlk4@vX);gKL zoNaYqWOYBy>Rvsfe5>|F|8U-!pz-h!hvIZfkRJAog7o5)2-1twGeLTB`%YkZ)`9&_ z+rg;uny#21#!jUhBf@+=T7^F2TH2#C@LrpspTCw8$>=D)@d@5@5HyYy4Gp{`L2GlA zJE4}K@_B?7JR4Z>-{e~zJ=u*Q#a0`|RvY-$kDxa2OCZ>xca|2@k`hJLJ1csrtD;lO z6de=v&|-=QsJ!*B-=pjJ_i)lLHS|z0=6JN#>iM+~W#+_NYX2~mcP!=Qmai`hkj4LljNDQPBscF~T%X`(EZyv=iDryRQ)N2sN1aDFZ}yXaMHb}_Xex6>;q{H=gH$~1O7aLg&+ zk8~#=ziDe@o&HiM-lbhf{7!JVc8-(VjhCpv?Y!TF){oOsSZ}#DD&MMqz=F@&@4qtS z_S{CWzl1%-)%_^u){VoRPoSh5d+5j@ zT9THQ`g1!8Zl1yK<6Lg0uoV(?y4B?FAokz%+s3W0Ao0sZJ$;rt{oRgc& z-W1AdU&R-mcOehXHPzTcUG`MH496Zl^X zI%cX^(1OMXV{C@q2EuM!;P?0?vtZOqx34ARw_I#A)1K_n=@zY5K@1|}-!rh(p|DRU zXwP@@3#P~ebuaUDN1Mg3wOPE2&EmRtN&0$QDe3;|0_B47((f?_&juIu|S2WKXr%;*`gF zfSxwvPQrt#v30DX-G-Li(@zZz9ItXe7`i5i6w1$0$D=QZXZJ*}6;u;_LC~XdMNKeE z3il5Bo1p60$#P{2S0@>Klg*u_;#cz~NUzP{-!v0WPh{~$hak@W*F8m2cC(d?7IonV zg3iI3UC@EOqKF<0Ze=I^cWsso?|Fo`G2AT>nK{FIGT#kBt?|fumBl6fYl}Z)w8fcq zZT9Ez=0JFRQQti9$VFN%<#ehB>*W`X4>P2rd^%OY{3dext^$6i8o4_Tvj+AL97_5V ztQ`N!Dw%&~FS5i_V2B7K)$1{GqQbhV3b_Jb4j+A)gOHIvu}ZyN*2 z({1RS}T`O-}1Yte2U|Sue<0FUVOh$XPGFQLRsq zTAv`bK0#`Ig4Fs1sr3m`>l38bCrGWwsdQj{g4Fs1sr3m`>#+(nxpvs`ceRUs+n|(K zr_>iNPH&weH$BU@R&$Jm(jLwe1s$y24%S*>t^Lzf{=W79C+WHVA=bP8A;|R)LI2y< z|9x(*H%h((5l8%M3v{Foqc7a>c~t!>v07Jc>S5Bm#q07A!#R{7ck{=g@~!IH@}GFI zE62a`=cIo|5GN-6KP^stJLn5Ze`U}Y{%85R))EU`YYB4o_phvy(d>U--v2b;1dpQo z<{Oqg=}&A)JSyXBR>2sHeMj8Raw9cvQW?rORMSu$L-hdr(2xtK;!G_L4i&=(ws6~=7kW(BbnV&xH%uSesi>ONAvUE&d# zyRnbyqA!oGMjN?QJQ@H?1r5Jb(K19g!lh$>NOI#7Mbvu5ijSjJ+{l&kpZJStKK@Jj zV{w~L&?KZO=`b!r&n*66&}v_7vUZ_IQ(8`J&%U7RZmt)qt=YVd#cj{ zu7p}*-vSkabL<+18X9`m&_qL119Wf;9z96Dnw!Uab1tSyr#fc+?rB6T*yd0-wA5KI zzm4ir5wv%%o=xmFw7fvugNo$jJFJ(KfAMs=B@iNyR09zx>TfkH$l%|xbMKuTylgA1 zY|FmEcj)$$8}K;MdM?LulUoWovAOCzwYlsz{hdem)P2Jxw8g_UO|ib1j{ZiX`VwmN zoLFB%g#p4Z(;I4OPe&V?`mAasjl0&+-S)J-aWf3{xKll1yrH8FU1{iML-h^yGxUt1 zNx0P{9yTpNh4f`*`PxyT?WLvD*Kc4y7WF5$NxuO~(5PU4JV76RDm&$cc3Y&7^i8fp z(qFE`O_+_+LzDhJ!OjkTi*pmvCZrdqDaPq9m!rSDCM}bob7tXfYL+{tB#nLn@@Va2 zm>U^|y(|;HyNkIKfaJG%i*_rz!BD-mVsrVFkKHWqu!S6MFdz>PyHD7yM&Fk^J14_} zip(v>{YiHx(4)UT(BFNHngzM=7wO&e>L|K8C=uRCH(Lq~T_2#(0^BYNtcug7AdfiB z3i6Fp)u0^6{T20M?LGJvO=!rS#diW!LTjE@|C>=&(dN2}sH38J%@h^pD0&JplK9J- zii+~PDf$C@M)Gt;2SsyGPr}_`sGp%vFmA}x=P}L+!UhJTbSgtB-8+Tp^yfBdnRI$F zO*yUmBJ)%6PUj^FN(E(0(4wGhxW8K}DJSU0plk`+j2$JHZ-PEXJxg7EZ)n~Z%IPm_ z;*@N=aOHoM{pxol6}(S(p1vLT0q*v=l;xL6-N+iJVH-7O2+?SaNbbZ=+T8UmkE-=c z3wEsM50#Yho9oYbbOdS+zsP=;&L8e~JR{)B>s}5G@zWNDGJ~4L8OZ{iDsn1LH=mJz zb{f^%Kb7OtsED6d!c+G~AAY-VCVscxbl+gVcd0Z4SN?40>T1$P__g|=-Qv^(BdeSJ z%3E4?rk3Nt^2W)f+=O#`4*AN=bTjI?7+g9nL9MwtG@UkoOVpa>KA$P8@;GhotZ$=+ z^{nqBLiaG--)G$^FQBzJz3zyNPGHpgTp8=q>C6D(J{(H#&e`!x^@daq->eDb!d{Ej z3M}o!R=IMV!l-j^E$=Zw3&v?^Ff!miO@MHY*h)vZ$B>&VIid#}ea0h>NOF3|xHk&; zX&=l-GMAklpg1kxE91ezYs3AfveQV=Z_tob!g2S7c6wvFe;qw5?}w8qS-(9y8xas& zuzHz}IXCao8hUr4_`OG;+0#DVG`%M*cLV(1jXvo#>sYy^9O|a?NxGz`dEo7u1M-N|)Vios zq!*{$nE3cUCC4n}@=f`(Fv<(slcwk}JQ40htThCUsivrYx}u7h>E!7`%m#uQ<|x{V zS;KL0TGQ8~D}fNV*VOv!@V)k#O%?Q(E(rd#z7&!BXzlcwk{;3`@=nQ-b znNxPZQhqI?d5D^2UDomqZKIE{S9K$vmal`RXa!e8DgOneEXb`y1f7kWg@Sfr6cBV6 z&dLSV#fUEGE#n?}T;+aTtY{g^A#wwsQ0`>dBHRsglzY}vX&zCHX|L z>)_84zcj>2++(o5kbA(>T;9in*2kCUf|J7Xo{~1W(^rZZr`b> zM=)BX`~i(sE)VtMcp8$DuXbp{7??J7##OltY&=0~f;#S0oGD_`D z(+Iw_s>Yp@`=!yBoL*1dP}{)hbVFLUl)w3W>|Ww&%3s_~(Q&6^=ZU$Y7>mUMSMnd3 z`==V(ZXRikORfEaRLVy@neA~)1sv8rHcsj~3h(zI+H{^6r)B8-yI6ND#^N;i0wT8? zWju}3uQpQamt_((;&WYBgrjXZo|d(h`b(!37`@#npHAz54nfLTzacl-7s&lkQ6+ro zN4SOdbWVWK0cI#4-PhC+p+2jFyy?XfGr3|njsdQQX4a-E4ml4yl}r^ z783OCDn<1XvkG?#;sZg$jf)+nPe&T+bfj`gvtWvGOMlXot0Eo>^0lY4EtQ>yj%cFk ztuXY3X>7MB_fTv7>F{iqvPZLkWPj)wc!{73f||r?b`HL=!oBf8gi{8jEE<(3hy`AG z4XlJ+9&vgsNTr0o=+GGHCH?$k_37?N8Xb%MoD#|%m`2Um#~o_9Pre?dWB!%gws+J0 zh@;U8Zq1H6q(E(;;ZbdPNjpaFYjje|pG(r13rqCxO76a8(Sa>^6Zy)QwZb|$ki(m1 z!5KlE(ygal-B?SxEvPHmA&`1`2IGcATF$fGjEEkOSh)#mBmB;L5&Z-?(a1uy%+FRry(;2a81DH62%E27S9y`~%|w;FSK#Hj#YvTwejuC!4%uD=!E9VqwOOtBQd zgK&mepY-2{MQ-IU`S#c+Uuo4d!3pZK&(rc&sik2Zz$(;>SbCt%*w3-ib|lIrzVR0# zMyG*ujQ|zd&Ngn(2BV5cZnsBb5WRydafI`sIKKfe$gMdAx$kWX+JP~)Kg+otAmQ8_ zn-?)x2VV$tT=_Sj-B-h8|M`f~IIrZV?pe-7cOT zx9?fT%e^W3#M3Ah_l3^a5)I)zZp*`d@gvR_w`(<&IsF#7%~sU0n%dF>^(Rj!!lwjnsG;chI*NALQ{T`Ell#i#rWLEk!d8k7 zv3%#4?pD)HD^$7XP4^ws{mwMD8Cq&6(^CE&`&VN9Rx8^Wll$0m+hUf!W>5dJr4$YRPHOY^svgR+hLrf7pD*27r8jC!`wLfVduqe-RLY3e|FIW*7iXhQApPU zIUmOkDQ4&4jBdyNi=aU}HN9q=Cm(sFsE{4AW(x>+dYkHg#}=oUk-VEhwq z1jb!Kw_mMtL$K-L8T_O~K40U)at4f7pBTKp(5`?|Wav=i{766f);y zh)QKVQAjeEnPaR>nUW9^rE?4?Q*sT|qwx4DE$v6o&wi%gMB>^c`-zE3-<%Y`3_*FYy{1R7o2<(` z@cn^PqBjF;XHMUk(;^MHP3E1Q&IsFSrDYfwIK)t^R}3Qr#}?FVdUHW6rf9@jgVe`V z(l5%iia(zb|J~MJy!#ofr0ZO6L~NYPOCzywsl&=nWn$7qGk-};dU}JT@Au}Cg38ai zCTvTznVzV-o_hK_c}i`8Etje#@mBao#@af@<1w{3FV7BRYR#P@O*N$uQ;)sD^Mjab zWA((lO_GkM$@o!tk5b!_`ULeb#zvOvS*a*ybIisJ6lpyACT1P#inMBxNSkela#kw& zEI&<5>WMcTTr&0TnmFCAz?WKSPgyD7X`Q4jU$W8_yHj-9NSK|hQ@YjS_lwXjsr|;( z)R*wSM@u!XOPi+mDV&0ZkBQ{gW~rDudR3`C2vJORMM+biSWL;AV4RbI9?y9C&66Ip z$_=)R@-Y2IlccNIdE(Kz{$Kb74cJRiV^O{&VXtMW^q7Cn=CvArMf4i?r#Oqa9Q_~k zaNB-<-qXkYqasU*NgLOQ|NbjIQs#arrate%brSW(wgBo+d2K3h^@AP+Ge+#wkT*P= zb5DI3$2Hbd6{6U~*H3RT{c~84S_<_|2!WjP*#N5d&%)!LYJ7`?9bu(U53-*!j{tjvyW6=^!!7PC=S>X}DoX|vxFE4g-yo^PdoC=U+%<`*KRKO$kDgrE88 zY-_JM#sy~6cFWU&r$kD|%!r>RSiP7{bM+_X>8Gv4N>hxc9HP3Fs$P|p{(?0fKb?;+ zn^+pxQ=}gC|XKp-SD}|W{^)&buVe}Tn997V;1pVz2+iNgEVmptO7&H2g zfTc=riqshUQq0a{7ReHQOUBXy8{#g^P?!zHe8cFSkr1z9HpeVFN2JAF#PWe%65=fS zan_sPUZkuTLz$haD$?*7BE2|Hq$)ea$^$mUGV9&znESAmjds1T7c&oLKU%#5R&SbR z&kh&8nSDgcYeqHPN{BYy7=BJr<<4VwA8k58#ak(_l{R7JKu=>z$|$DZ!3^&*7*^UR zq}^~z9T+4_r=c^#FY)@+rh z3yl<0%iH6(9&t7!rb;3OER98ucwG1xPow(jLDT^HSRu&SHO@*<{QzSSpKCAS@NbJeDNvZ@}AGbqeV17q2j?mghb! zrtW$a=M!~oQ@4wUwpx2batr&@=6vsRj-y%9u!1~GYnJr3SuZq8>Sq{6I#{N4fTxb3 zFUgHKJT3&ky_kCHbqHrJngYY;pY+Y*p>Gi92|%5>uT|i}X0= zb(H4jNyWh^w&qEdt&|;4ndLPSZfCO|zh$qy;gIn%rdrsXZ^r!oE?q`4PRCTmbF$iY z;lFx%txK(u_dx09fA-%c)MuWJ$e4#6J~JlARA4z~dUXEP9u9jyX0L272>VtF&adjU zeA$t|jQG#{bqOj*qSTV0y%lLB<+iJ)NR3*G-b&jp&o-2&ORZiv%=x(%kFhOzXAq*k zJPr1*s-aXl#F1cEhPE zUPPoNs6Wh}!rL2`YGCwZiM}^riM~N#iM~rP%u4jt0<*gpibUTzFr)7rNWym+NCEXj z3F>C?ma_5wXDbh&r)GO}M+(nv$ui9%gB8&Ks+I($HPh~Cb-Z2D9G6q1nwDKFC@ha< zzgf1yhG=f>9kf!kkc3@f*#K+hj17Cj+8b@3=C@(T+prDo)2mi`!0LT(t-NAGY_ZZb z8)A`_ezYmLX!U&bC|rWwEOTv$GFIAcB=j$49u`xspc zBhbg%;r%9Gy>$n#aCvn?J%gu$^-(frc)UKMl>>b(figGy&oO-xntOTKjpARN zVk`73Pu$bc2?!n$gWolF@5 zU$1Z+gBB}QS?7EOM&fFaa;iaDWmjz!-m&~WL_55lmUsQ2Q zrKd?us@zVV(wSa<`b0UA79@!D%55V3Xx~yCvTrFSmyxG_Zk7_0>Nk`e(RVRyd6Vr$ z+n|)0(F}v7*heDWVWh;Q#jV834m(%Qu=D5XramXARyCy*j+_-MhcKgH%k{U5^tQF~ z+Yu?%+IEilP93o_*Ny?@f0M9{&WNrTfK`U)r_bZ&^5w#H7LY>C`7A z-raYLlu=Hk#kQ{1w9?KR^7OFPE7d~Se;y%P)|DDYyU<+2&RIWi8Yxx=*itBMrSqn= z@T=#KO5R#`mJn+(CuHyTx2vp4m<=7_ni`ST@n7po~qy6q|yNO}vRo%Q17~Qm6=@avXiWNo*_2ig!P>(rpWcowt2S4l7+Uy^5p16nz}E z0=FllM%0Cb@3C=iiF@VX7s_Ou36Dq87vnZHGpBacr&dxex%W;`bqq^T-(&BZRyzsm z1m>r_?vdS9{QivDUB$1_TB$60WgcB>px0xmHhO-RQVWSR`a#*Fy;)l5w_s`faFn~5 z=jb<2Rie>LP`_@HxqR0_?8%ramP_8hJ!D7SU{?R;A2Jftca`K*tUeD3yNY!@kJBr! zu@v5=dmbZf16>N0Td`ko8{HAn8`?%#UG#)hGWaDf^AzQg%6SXMc)a&tS-`-A|j=K!BR}+KyTYrmuee~JuS7gD!;4RX{pvR+#wDL zzqyO~6|Z`~GH){ylUl+GvpGve+WDotK{&CVrI^Z&{mu*8e=DxYyHq;kz&USnnNuHA zpCQdu5AeG(*`=PILYtv;DB+c6+ABE0i9NQMdI4`jcz+|yL3vN&nf-fwMQ8knZ!ME> z!?@0o>=$GHht$(d)w8AQ*|*4^3QCpcww(I)1#rW&wnBT&953xPv$Ww7=PjK2pdG!6 zeI&D!kN2=VKfP?cfz$Aqxlt|?)JwKEd(+O5s#*4$9brpYslAcHt0Fn!f?v15Y>8{c zcPB;qvX<1B{$)fuluM*#B}97GN?B}(!Il-W>H%*0sK)Cad?krfX0%5ZQ^9&c#v}eh zhS~>yEB+6OZI2zho7=X()JjvW^rDqETd4}_B$v!vcr$8hNhk61*)AfD$BdSr=B_9# zdY7<*lY}LV5$OhYkGzJ?zxJ8EHLz?6T5}YvGs47t!ppAYaHUs2@>LiuSF_~K7*ew z?jTlX4G>B76{$*TvCcEL@qQu=F2NE`{`8mq=i8A2?g?MS`j>mcfc=E`#JzP37=;-HKP`(K_1BE{cL!-n z_IG1;e>Xv`HaWsg5@sJMrv5-}r&@=dghssEjo+&6&NVTnE?|YryW(>ZmQ$6zh@;P7 zB&aK$B_H=-4}kM_cC+|poqf7^sp!qjCQ`ZOB2BP*rPGA%wCwmYVMi@{#fDvI+58Vg z?_J9#TbAWnd75BS8dHHMmt7D~uEgw`eR}LI@ymC^Wrng5rO)07W-|FI$a&E%7{&Qq z(3g<-4Cy$m68LPWjCA-7H;iw?r<2FCO_G^Rn_L`6f_iAEr1bsm;>j;;oh%;{KhLQz zQo;5jjjJcpwYx;BgVCN#=E6#rurpzH#lv&aLvv)dIRrKKHPj)D*2wt?EuDYC(e=tv z_w`~aL7m2Wfi2IldkRHvlQh5jp~O4a6}Aw&I2>ZoC}G8361}mv$4v_(Hn}@UZE_FhgD< zIbS(jTF;qJI7Cd*85`cGUbs!3dYEZ(E1QHm$-9l$f5lrF?X^W{dA#dKt0&gWvI93T z=%;r;dPhs&pf=H$*fDhgZSX@a)k7_w4Jkp5S|%k^-_8J*+0}c7-9Pxs?jIDldjQMr zuE8-YJ!y9ha#(4D-7Cmu!(Oy(fEmGJYS=58=i{djNZyL#9ol@I`X^AnoDV8#mZTn_ zx3FubNqD+QhY0$iL8b?Zse)IeJPN|k?E9IPjXxtyYEHODbi`Bk_y8+Wh~+vqcd1xD zY)iHMJSpkYsJoo1JU7J3vlx$7BP_mcJj@JhSV*tyTKpz<->9WHYMzzooh#SL;k%>+ z^NtniqU|>hTIqSrGPoBwW!d+=h3&FzwPiiK%hPx({VTh$%63-zyJej%JKjz7j@YMf z+ZklADnjkBv-N*g9^W)AvOPQj&HaBfpSZHS(5mzLyoM=bPaIfx^n zB#+|QVX-~yCCujb=&-*)oX( zUz%WsLOnW0Dia6Jo0vE-`k6TRoDrWI7r)@ms67SphV4ZQH;}Psa7U5eH@h4XgQ|Fw%A)=8prn=$(M>Q*W2hId)=>m4`c~`Q7_1_&GcbNx(BmTlJJEzW=6ag+8q_?Wy8X?WGUu8T+%J=Tt3))U18!# zOxn6n)>h5;i&PlB8OM>^N_00Bv6u>W(B$k#Ouf{=Rln-|{)thN^Be5aeStBaYwYdl zkuGRGDM9RH4UpKfyf0E6>{xLMDj4bJ@p@aOKKH@+OL3swFhjnKI1*G_?AMWm-Q=rW zZnz;EBP{Ql(*85G?^pzk=l{_5rqh5 z=A}?~vuNgjAzya|Pj41m(?ppy%PD2tM)11aV)@^Zf&@kPX!7{>jC~_^<*cw1_KjFW z`v&I!`P;b!^%Z=_vC-U$rCL^sSn07xrM(>S|}JryOh0ky|b^ffQl zdwgSUpH9Kk@A33zZ?qlzmK!Y$y=XRFM#1cQyR|YoL3YX)8L#0NVeHel@sz^GY?;T@ z)26=Q+%?|%avl25WiBCbmzfRmv8_!(-b&iq3rjbvme8#IQxaQX z39-QR;MP_rQF7YlM`drw0P=}TMY+jwPpM$p} zZ?={m>HW6c?_y49W}Eox7qfNly@%L&Y%1ov%tjRE*-}hZLVwRpd=*o2Z(hva1c+}; z&`)wdPUAuaq%UB&ug2`Wd-_&AvKPM1FLTMn)Iq!>*r4k!?a-5i-@44ny&irayQoMb z%8S$oX9KwB4^sN?Z<5$v$wSf;2ELLvNikJ74c^qfV|63p2Ic=rP2~GoOW2y2&q|Wt zaGBGMe00N~qyBf_O!4=%wCZrw5sc!L58R!IQM|48WGZGdm357foTJZ1UqZXO*z-lW zNA*)`=iC+sqRrI&hau`|y&wdA2hP3x7}TqV`e|EJ?{WGQU+*;oi>aB&FH2=DlX*!@ z-+{O!l{rhn%xy2;gz(9|#;b9zPsi~C<|}xr*}@^9xC30s*e$tR#^#Z9cI$pkAH8a z+;-Kw7;mNd=?p7%$Bc(rf6Pi*YWRj&X@_+@vt6dYPf$OJFhE<-i+hzj5|J9I)HwXrQWv+D}ffk>^?ga49YS%Q+fYx zX@l>ab5vLD-9RspDwugmOx4LP{Yy~3d*Mm08z*s!pX;Oef3vKm)th2j#IpUCJ#N|k z)?6oHXFI~8y+qoxUY_=^Cv4z#VezQX zWW`epPjOF^pr#Dvx1|YcRZG@OK<~*C-olTTbwx0%A6iDAKpx3zOON|5`K zMOLcvim(pI5kJjurR;cHz-{IyvvPH8ypEE1(N~#xaT}G1*HIELZlyM{Vduz75-;AY zo7gaZSV`h_l*AiTbc<>q-L~k4hyhxfj=g$b&8oaIr;#=tzCUc=*GhGrN_B1H4%9&{ z?ZCQ>rLkp1nvQo~%pT|~(m2Bs)G=5YjCd1N2CT636RfZ_5ms3G3?W#m1uHBKGf(l` zj~F$0UK~i19z<-gj5iO%IY$^Lu-8K6fjN>H4e4AswMhUUfVB)+LEh8%&??d)vNU+mO zPx&-6J!OfWvLq=@P)8TaXs~v>NE>exDPL`owwDp9N^X%Zl@KZEA(3X;rxPq&Y1t<> zw)?I0oRz+@(i2u1Wu)-FROTBt64d)>*)&=uCf!;<+WwJY()N$o9`jH)VfC<+#l6b@ zcSZWmhWOdCvsTJ)qy!bcBsYm|tigR4>J(0nZ@a?(j*H9-X;4W&kBfOKeQpQ$cG1ORox&&`-FX*t1TJQ}tj%ttnKW20r zQ-Nt@@NFD>b&# zvqr)mQdY@%Mql=_$k@$-DUUGt;|&0L^)QVA=)3y)EV=1Ff@>Aumz3R~%l&D&oq#cThxM%<2lBu>@; zxw^5nhSZWt4@fPUfqKeyV>%@MrIJpzz7)fSJe;aD)H+j#HjDpe{UJ}kxKC1_fs&!s z6V@ZB?HpEW4$ehBEMZ@;ZQ-&l-z8SMnqTySnwaN1PCM8Ml>M6BcvxNFet=7_LoMGVIi!BAw(@L}uv;47_6E%q;$UwKvnhDW#@02e)Ml->;x!3dJRbKX zXqGZU;_cKJw?Ju@?QTimElToH9B+&{M~#Z%RspTo5Kr09xt^3#xC7~9%Uh8T&Tnpb zlJzPg1?-I<+lVKV;&7LMw)Zgd%Vl|6OUcppvckF)5qks6VV78kScTGJd+(t1*$3_5 z7cSpiF-h}}@HnUH5yZ=B>FtWt2=+Lo_n~~*-i_xZeO-}FF6pXB0mpF&`DOO$2#KS( zt#x(s$u^f>Igx*|OdPjWrYKwab1 zzmXLuN3~zDX{vtJk_-QF%|2a0>>VC1R)+N9o4?9C@4_(Ki!+lF?@v8_`QVj+Cb@m6dr_EsPt zT>oxMmaq*1b5`0?C;$&}n|=zVz-68bdE*f4VUNdv zb%>W!^)UK1uFs3nA8_l=3C1CcmXowpMXlqfSy9Kip7yq>8V?_EY^RZW4*MhOE?eG+ zlHoRe3LfWpYoeZVkDiG7$03^Z6i>E5`k1|I+sA;CQcsVfKjoVJCw#zdu&wp!op{RS zQ58Ao6b#2xW=(A!f8BcW4C)YDIRg)Iue=>;xmTCMedvK7)Y5WWpRti@?3IIMZYl4h zj&mG&kTJJ#O>{2 zv^@4{Hspv);R@2su|0*-VredVbPD0AE>(Dz=BYHypQ&U#)z`A(o#iQgw@6R1pYSTa zU_`w5HAa+bHAsB#AfL{93;R+ppjVFRTdqk8?KsmW+{uY7xpuiLR0PMvqMFq(qguBoJdq|%(6`qDerqCJvKw6 zvo=I=8)A!%gG!pMT(Rsmq?A}VRf(hU9g9xYFVjUTY}xja!VX(W*{5GwHYdC2EwJpn z3Buaj5Kr2tonM!yuUTogl`dGRiw!Z%N;$3cfR)~}Ay!za$*mH{`&Mr)YBA?Gr%lz; z2Erb&>=7&Fg6}!RMQf$Dc^dZQmZ(zgv?u455NQ%>6SL(_MCwsSq_wDF{FJ`UWr@Dc zWr@DcW$9Q$k={q!XEqn@h$Ule_DHeEz4!Y*05n; zwPEi?zs4yzV8f1iOIXo2SPFY+K59eJ z@+It~(&`=eK`m3N3*x|C_t-n6?~nKfGuq?!^j%jh$*HDr2w^exJx-?cyVMTYHQ?_I zxBe#I89uTSV-&`Pm^zQ0R2m_Cm9c_vy7kq)+j-RR)tqPWzIGZt9sDWwr66H99#82v z>pT^Qz3?Jv%}4?Ef=XzqKp)&Mr=PCK;;Js1#k~WjbChz3cM|YBo;&$uu&4T8;jzb4 zQ7auD%<1#g2ff8F3voi1JyaEbVd>o6A`Lo((O$>a^hLbY(o%EiRnSrgd^KHJOViFe zYB(g=!n;Kt8`o^+{Kiyk?6nY!sqRaSbCd5j+{9e4cK|J(;LwH9yi zcVJA9sp;4qOmL)Ee>S%T8(2wH}bNe5R^c88Z*-MwIIR zN^kZoM^)GMw&U&&ZVUg(GSY@tu}Rmpac|c5@kB&Az1Kj3;$qMk^rFq8S8*NvO``JlD8$J#4r?QOL7{%LufvG#tp z_8ztNc3FG>wA`**dl#*}C#}81*4{rY-z??DL(W4Yb+Go%T6_Pr9^|t2vRiw-ti5a2 z-aoA`F>9}YwKv$>i*G1t{-^co0c)?6wKvk*%VX?0_7|pc-u4>D!QUy-sMaJY=TN1J z=zi#nu_DdJ|B2!Ei}2oxdMWgMFU!1%*lQTeaJupj?3TSxPYdHc4%x%#dXLN=PVL9< zy(4T)ZN>Ln!*z&U4f!oz_?K~8binCH{d9npUNaK^=F2!d#V<`-*4#=%Y=|Gw+oowN z^eZvnd_eJv9_|vbdJ=+vLxJ9(<1G6E9s_W%!!i6qkB*J*YUiiHTvVRoPItsMRmb+n zBBg&VH>PUOb@W-fm>N5fzyFA-LobPR2Jf==!&fnN%1SkkU|$8}TQOBFhTk`Vy<(xT z6vxLpj#}387;E{UwS2_dJ87kDCnVl?v4e3!k8ffx_#GXTBka*z>9BXZ7+*Om@D=@v zYd`oD@6c*MHmkF{ua636k`Ghd2Iva@i#5tM<~4jy%p%VELaveI%!hA0rEj^mb8} zZf@`YDT|2WE$ih(YPN!FHvg_~b@WJ$izxg}ic5VSC;hRC!3tlKl)UFQ;XYtI zbJTcEQuEHn&d(;qjBfxm8K!mqrOB*Ns9hlV4Y&|F0OG4sSbHeNmXCo%6upNOavCJ6 zdNYaJdR3`c@az^f!;qrw9DFxGWIGd;3nyI*Wg&9S=rnnmzAYe90&Q5SWHsd{NBs`V zx2Ot+%zRU+>mXUxL_>aqPTa>z-AWS)9V!n_FQy`)fZ9@)xnURyEyMTRWD7B zI~0m^a;g+f*oP0m&h6^m5FxMLp;l;;tSDav!J^!xr#E&N z%A>q2i4@z25jw0B*@D&?g+7+797>aR&})2%UiJM_VMFLRRP1 z?{L}>IsxgBiJZcBJum#54v_&Mg;iq4Zp#)4)(=bDQ1Ei?hV#rcMim4p;20Cv+r+B7bqJ$yIw%;hBnwwDlM`6~FP$krq z`^iqKI)5B9XOO#9h9=3X0(KJ@g50ATKR`OksvLT^6(IMjjfS|;`9hQPnxv@KkGX0+ z$bEPrOQBNK37lr$3{qO7yPpi@De*Cbt?!llbXn^q_H7&7!$&S`?G6w;wk4=FlhMWINCa#|@S5a3CSzt-D0_#Y>QAOo7MEZ>?>Ru*J5!5JZaaB|m zL!_NnQT0rybH8wTRZ;B?nYuy9OD5Ee-^9)bM&}3gB!zVfml#rLkdSl}s`(!7ZK|lF zhTH;DT!$Kq_qg!0(>;%?d&nwkqao$dhkG8Sd6yyiEIF#ldZ!`CJ=#te>uck_4uY~&f1rP8jTurrlSQAHj zwrZ+Rh&+P09#vyCS?^T5f$!x&s;lCUP^eT@p^l^Kfjp*CG~rs;4CHY&B}CeS)KVEt zl%%<~>RpBGq{O}PFQqy{r?whs$VDIDf@zYZNibT~RvQhGeAQ9es*)YVL>iU3JtD>VIC)BzrXqwceQ!Mc)fjPvy}hMg0mg1f;$yVaQ7dafbow{1d7|NQdk^ zsVY25c2X4SP&;jqshu`dPidW?M{1~gb12J?3b@@k@TKBn-O9xv^*sVZ!Uw92OHK10gi!XtH4Rn?GgAY);3c9^;y-6RhK0hsP#pomXn;xSYxG291Nw)D%PFp5U2YGnHY8wA^Ou7?XHuxy{rW zL!{+4Q~u*@Sz2y0m5Yh3^UYLEL!@prSIrHPI^SHKuFZDd`dsN*Tys^a4w3coC2>y} z%^X^&v6^swei!*_p*{|g_dycXc1@DibCYlxb_#&FDy( zwpKHk*qLW*waAd{@G8xkTC4Sj+~<_@t-c76+<4epZP6rI zoqGcNL$j4?qb?hg8+l(0(pJ&=FKSJdK~{mZQ)@L@@4SsrYc%;*lN7ZAWFyE^D#MVZ z^W0LNRwqI_6xTBV(mexmG9BPJ_|2v%0+@S>|#_MNpkpOp{=Ie^x!9 zNt*gJg1tDT=UG+VkQXrS90cjAzSksGbv}tV#vt7?^$Fe8M~x`1An)DPl1yYqbFHJE zynx^Ff}QT_D^1c=k93@81$j=LGvxI_O5FhIsp__%P-$vB#+3L^l+CS(Q>>DTz|M>6x*>fqn$yaqpURe~Evq@#PS~BQ z2r^jZXvwjY&ch(Ds?nMxt2^#;RSl3KY8var4T66ffh4QhnxrZ}hIg%+oMRo`n&!ph zYcq8{M2_Xeno#9vMRD=0vK>MVS4o-#J?#iJ%@COpjZjMskrmJgwc8L`0gX^+43Qbp z2=%)mG9wy6%^82`j;w%2s7_4cWnMP|w^y@{%F9F02+SVvZW zqgC$^q1E4Lm93rDu|5A7RmBkL`N!fn6-g(k&tp|rCbmA0Rj(P+V+KYmV8{ye z;V*!^q2?GOb$*=s!Vsz9Z>sHvNDUvajv6AhH&xYrN~cFP&yKIgV0nUSZ%DNzsJS3% zs;42nx;QEsWTHwAkp*6! z_J*v%n6eFIE)5X)OHty(d8)G^;-C5IJdYvUtO>286y4a2G!0G@oKtSZ%Ele zTo1od8HQYYnaM_VT9agT<3Y@AkkfC~6P-APQWl$3`w*eB*s6Mm2$jWlH9AD7EOx5t zhIB=pF9OTE)xr=d1@fcH(V63tp8qG6KSZeK->1ri2=)92GWGliGqr*vWEOwv5!sy! z$hBRLDu>vQs;z9<&a959T_Hka(=oL_M2dOXgHtC$ghtO3D(+c|i+5Kl!}19=UXx&- z?H4t?E9nF~cqi3ZO;X}|RCo1W%1JfRkXJye!_G-H)sXaW(1)S#J*7S}fj1sAYy^Gd<)P^_3wqTK%fNG2{Yf!qjK}sX0GLK^$1Tp>7!RuPCp?m6PQ;_RoG0dZ(bA9EQ~X zhHJ0m_=PEA9oX434`a~c>@ z0{vK7MD9DC4M~R`+DZ1EK8EZBp>f%FUNa{6C6kMI=cplv=W%(( zJLe7g6NJhu-l4B2(VF7MVvbF>|K8$c!6|wo?}NOpNe)96VJw&ilGVv;$QF>9niSV0 z-M-Pt<`j8>?4+s3@Q#D-DZbSyr%9^%GZDXD0&<&E(~w7th*~vicd7T1%NGE6)`J7^!q{O{*FW2XM&V7b_214~YpHsn*yUub= z$nR7!X@=ao3TGJ5bnkNBGo(03Zg}A?hkoOg zYRh<|Q^c8P$b6$y#93;{N00DsPt5t+kgq|g9>$#QhCH{L<0|T881g0v#Z}ZfWJo@f zuVT(GhCE>MRm{1lNl*`qI~gzP6xzP7gmW-Na^PVJ=a&$nk@{{^6N0xMrJRdeXObF! z3(6G!DdqV6$#SZ?bQLRlkb9k;n((~tEJ$f5$>`+99^)S%_dBHqaH!H9Ty-7f0jIYn z9ExhogU*l;p_OkLXKaX&<+9EUV`o}h+}=1B?VZgW16icTRzXh)hzf>TD5RJH6ErHX(&l&M`*a#jpvI~}m!TM9aroNXae2IOJq zc!*R2sp9-)$iXuR0aDG0dztM#20KKmI}aN|maBu*aOmwXrI|=wkeW_6O;Xi~+^&wj zwlgtADE7L}nh+t&^_|lpLYAL&@}mEu5+plhxuHY9%T007-r&(J*gJJ58$zqd#?Wcv zP_IWiL=r)o;!2x@Yy`AxfOe~DA5J37mD?;QDNI&Ob zi2MRFz=<2eu~Vq?AOoE;A#w#|kkiVLA_p)6&%+ycXKaXM2YJm|6C!tl40SGsND+_` zPKnnju2i-5Vf_9IdcTp*lbTFY&uu|FhR$ebc!*R48SAVL5lZto=b|Awu&$)i8Shk2 z;#_=C4<`W;YJ#)I5YnjylICPfW}Qx3IIg#xnju1Qz3sdbA{5s<&JsiJkKnuq$a~I- z5TTkd#kA#MhjXe^a45(1VGG<92+LEQ;vtdGTRQ16H^p{BU0w<>? zX{x#FU`|J*xFJ6tL$3y%g-&Bbes~!>Fi6j5PAfx(;2p}}gS>aqUEvr+2=dEe%IugNgAAP?5BHx0GZ*)o!H8id;E6dz55=f+V; zJDr70)Ee9@#bo3dt)n(tl4~rJFKY1Fu$|5nLvDWqr`{3!PN&oxq?4wqEX4eIKF$|A ztuz^?T4gA$^P| NVc6LPN)1=cpmC?ZPSm{@LradXsgkn^5~5x^I#8&Tr(z8x6Ft zgU;9xi6GPwXNe*8aeo(e2S=UDhBSPhPOf3U#i^3Yb}sJ5Y6B@e?sPMxe=b+$dlb7X zPN@m3Gp7^h^rSQ1kZ*C4Cl^AUbPlGm&H{KNKgen4#6%{AuhCgH>}ELa-ePhnf$jY2 z{_U2v)!GR=@b zoa*ne&R(2rqV!yGs=UW!0r>}Zt~eE@G0BND-bAiCE8b_)3o9}re>(Jw@8tOzs0sHV zh1Z<>L!=zY4X27B0}5eI2jaMN?*xVV3*QXZ2Fc=LcWG7zqUY)@L2|gOnW#I_hqnj0!>x;r(@>E`{MNjtIaZ|?omyW)fJRB zwTp%(7eQ~+$lbV;LItrmayx%dWSF`Iex@>QJIb?7Z9qwn{kj+ zSP^{`kq&O&BSg|vEA(SmK{~o44XKDJ0nIm_&6J+5?h>sN#NO3??I_vdoYFhQuI}g% zXYg3$^F@onds-KSAWUHmN=C=M- z>)7&|=5}FX%WIn3%MdBAY2pprQl?uX3nF3l+H))OD1+HomuX1 zA*OU@xf7Y#HaN?jihWh83DR~xahGY5qGR=au6Q!a+7@%L~~ z`=wjvHztFMI=WZ?(p{rTik@pxZ@kvs&&2Mpu656AGD*=1lZRn>t?OMNJCjtS$8iD& zNQEcMy8lz>P}35c|m z&F(>CS$eiDV#l_WZI(z&`OXsQqjtEZ|Db#YyFI&XzNEJai1aqQ+zL8W(A(^CAJrtt z=`K4q$@soYVz)UBh~zXNl2c1;pRil(*qr`oiR5&z+t{Q>a{7}yfQdtd-YFc&l=p+~ zFs&2x*azJS9LkP*hurCgh&K+o^9+%4Kjf}7L`JJaZn`0o(?jk~LnNn%+(S(4Oy;nA z(Gczv!iSeDq&yW!h==Mn#+yI+&Q^6&2P5XphK zes|A?2)&p2!?fJsz076zn%0@5nsw$~tjlik%jCmJY7F*QYoSlL;?^`|#n;&N2f6BY zHDo7N{mntHx&1<<9msWeh9U35P8Sf@``(amV28ev_r0RnwUiP6C6Fv$B~5~s67RJ# zM7$C2jWk3&md#uIH#^z9Z~tZ|yZ5spQaaha$W@9x7~^t!e}CI`yZ86EUAKFGf7^A3 zcbB%qWpM)*b9)upa{O1AZ=Z_gp}+J`Zy)s#}4wnT;Yp*>M8>+3h#t;eh zbfyyQqE%DtmJ%G|Rl`V6euTqH638jTzbwlWcKuzd;W^xhCu@_~^*CKDB4t3lqvIg%I zPzH;<<(dR(zF8>V_dD(kYslX(FY?A0L15H*`Tk;&w~j5xe_zqn-=r_{wq>%sR}(HT zIy1S*yUd|%dKP;T^l0IBy4cGbA{1(|H&Bywrzys!O{hOhype{a)#Fo?OT7$3j!xiJ z@4@Ppq5~yjxUMd^P#r9(#yrfrf{Wqx6wJTS=HF9 zt8A;3yaz<`zS`RLTJN40)zx6&aI?|dpc?%6`iZ2(MKxdP;*N_)*^U^Rx zvdKHj#J1B--UGSW&(cmec@Hs(r~Z&bHPR$Gt^#g#V#2eypeNbn@xCaxI7)Lsqy)D} z{fS5k21H75tLWS+?Q5GiPRAaU;5N~TNC|GUu}cYB9a~qon-MlWUP^Gg*tu0oFd$Nb z0g)06h?L-VZ<6ttl;CzrPrQ`icP6g&k)F_{Qr_uJ*P*x-G{s!vdv5{TQR1In-fBa{ zKfArnOya~p8D56b5pQI8$Bd5D-VE=Dn~nh+4l>0Z&XHDR9+UG6kC1%yt0P+a?L?0-Fm zUz)?Jf4_vXHQ`{UnsCtSh<^@RJ5r+p@+0n(B~Kl)p~Q!WJ^BqUY0FRH`C+l6YXYU` zhzZ3tfpm^}Rdpz?2`$lbk9$wD9a|HA_SzUC{yE`wXJTu@NpFDBk+J)vH_Q<6&q*)U zgp#^(%A010&I_?M!4f-K1w?XsK2x~|I+FK*NZ!xeG)qkgh>U2zdFk3eT!M6>{(`rQeP~PY zqIbj)$=C1RZ%k|nUh-}j9Vx*}UbZ`Rjf#^|_>z~;5Xsji?`}gR7ni*9hDa_hdDS)H z6h4JIcFAkRB(BO1UX@(-IvSGiw2=OWcz+2QsY$Z>vx2KS!_H-IiYCEq`HFX0lVHYp zB~xv=l4<|vN~ZmvE1C9xu6hOYkv9U%*Sv!Th)hzQkizGXo@-w5LQEQ9<@zGXU*7kc zr0Fl3>5SQR@3J9pKY}>`7JE0mqUb^Bz4@&>u&P5SMZ|xc;+- z(D&V=Ks=vEM)otUB7Hwe>oB2R5#JvlBB=-!@nka#yz4j(p>FZ(-bMLJ(f4bS<*fcQhFspjdsbQf!Aw-w+Pp)R)qlh2 zywJ+k`&wE31%{m7iT$CE$<8)I{z~OJZC3xBvGW_&)*m7EtbRrj9lO0ZBfEc0lVNe) zF7XW^+5O)%Nsqtt3fsx<|HTB~mpJNE*vanaj**>o{T)5+s@>)n)g<`#_BQ`sO;XgW zNHh8QHouY~`6oE~6jKhrwjuJ}UrxVOh|pJlx%^a3(jC&FF9GlL-w%<4Ao=}`CKT=0 ztw0J3`QL}gT9CW^C-5$c(o8yAL5liqLL>vExZgvQpth9sM~298=#=yqh6t5=DSusv zP`TgZXK0eD`i*zg8HBpmuT+f7y-$8#r`+c^W};FaD3PnYs%}=SJ~=FVoU~wi24?eWZBkl=kz6$n78x_{Bq{5J*|SjV8%z0Me5K zo~q~%Fl6c`-g{5*M;bCb#ZmVn)I)y!-5fi4wTvbOL!=tW!+!CStaHl4S9Ks&{Ujzj zg{?rU`{P688IZ^Py!Yr(aqUK67agRAU&N5l&~SQca=#(pAI1t%lZOq-e?&+fCMtT! zQ3JJ33qyW6&*X8xlObmgGO6kJGlcw1-&WM}tK7%A*zh5~`-h#{eoaH<3-sE46DB%e z!?jNP5P1`%zF)UA+sT9U%m8WZH!o=IGtFL~wL*57T& zp_Z;%1)aA35ku}dhut9T(zNwY8S*Q1)@mIWHHrE<`qHf|q_%!8L*$#aw*K9QtV0Uv zcVXN5W(AcOi~U;*sPynzt>OGgnPeSAl?0?nxw~nTAAk?&-q^%vKEBGKj-ga z;$+Rs-!t~~4;xYtgl1no{cD=6SM4s~i$Yj_-mg+or%-=aG7Mrbzm*|!yG}2EjV8hD zqL+V}iHhZO745V2@|QeBb~w%SrP~Ys))1lIxVQgPh!jWcef&729{!1Mb&9{(ebLXw z#NGn&qCd(Ic}vyLpUlMGq14aE$4X>Jlg|-*KYs>hFl4#QL4M!V-(RQ+?#U_as{0Uo zfB&>0>#)009%O)DstVhYQhv$rSCt6Pwxg6EfzH58B{;AS7p}fED9|#f3`$+$Ch;&8l zqy6@^bzE_S_wej%oIg$z^jgLn25^o*>+$*yf5sG^Jf`yelW|bUO*vmUY79c9`cvwXPMRvQ z5BG6{r1{qjp*K;}LEiH3s>eD%B8HDaCi!&?>4nl+0P?oq&X9R?9JK^wvOn3757A?P z0rHN&!jM;Abkur~cl|2$$#SZiKG9KIK&JTZHAz$Zi@9ni$W;G?A>Z#->L-wCe(5JT zR5PUT6v+Gj6iw39>8yBT5Avbkz5%CsZ(hvh7hwd`XH1+nc$YgnsKSk>VJ;@&bCrwh-a~b$z1EKc#54I&cDe8$g@wEzOL_hh} z40*(meSTw2lC{nOgxc@VG=y}B9Q02c@-4_OAcy_o?Kp+)Kz;`~>f-}Oo#xu8eWY{T z?`Mby;w;7&8UA`hHl(qglYZT&In*SOtk5~_&oJc5e!Q~-`PKj4kSN~o5IN`fe1=1H zeB4n*Kz{S57?Sr4zCi%F=x1xsIybgqO$73XKhKb}sCAElT=nrmrB3rthFtUO8Zsgc z=j)+!-Jfhoe?wH{pdoX=z$_0sZlp2h`cz(9K-z%#k@bdD=#1MWK%$ZMomgk&yO=41 z#6>n5@{%F9L<&Ni>|}?>+CwK>1fObZQf3U!s)O7XIoj34g;3<@+avwD5gD%D1tCA@ zik#CVS+y{B@Tx6$Eq`e`eL$Ti#S>Ka&3L85` zBYB@^vdZMWc%-=|sjA%@{KeeekrSGvs21qQ=#Gw(k(s?HREqLeGAR{l{{oY7sJ&EI z?}=>d&6a)4r@ABddm~3RNl~+*L(lGuH1ETq27~m5PU%RgzC==0MfCji4d(rkc82VO zzll5;8E43`WPF*3P-PSH65Lmr5LwZWbrLZqjDXHVk^A~HDSr;P^@3E6bT;I>G>i-&k3_B+;=}SgAXOs0 z2T-VBe6Je$`)Qx5k#5kI*#*twszpv{k{;i16_4+aM$Q@11%&1Rk4CN-Qtd0&sUC4& z)^WwR1tFd4ky{LT>TA|{EONUc13*aUu}A?!vKgHkkz$72V{~dnN*i+fTDJ3eq=F%3 zLCDVIk*bEwz_>#*{F;$khI|4-GyIy7hD@CCxGjO^>a`;644DB!d9M{YZHRxTt8Y-L z9f=#H^W_u*nE|iXj+8QF(Qcme*NHSXWCIA0dqvxcKVnMfiO6L`uA0($BI3NtIww$n zXeRSyB;Js#AoT3XNG>K$u><(MKBTZgWQrl)U-*6(tBHn@1%|XSq)}vzAt(3qyti>= zt0DPdhw{}pvWH20&edFAjU$JRPB{=Nuf~y6hHT7(`@WF(CXp;dbef%gAmryJkrIa7 zY09f zLFtg47LlI}`3r<}T10v#u~&CgWv?bi`WaFNy#(C|lo&}iq(n{LRZEPFGNb|sJIXx{S(+#PD`B+)#w2XXgNF7)%k7!#)mK$=vsdX(Q>kX-4YF*374nsc0yMCIl zwu+) zF{oj23qZ&l&qj(eQ43?Z=^8rEMrs?f3p#s2x-~&P+V#1@jjR%fb@tQ9LeOR9@y0ec|LMt6qBt(u#3C|tImt_3{fPapI?1-E& zWIA$s0c3Zi;B3|z_9A9pOYtT&(&`f??;!7Yf*g#zV8{{>THPFr3^%0BaNH#WonIm& zi=aqDYy8uZgIXu3tEVIV=CI|)4biV6)agi-xlE`g)BrgbSv{Z0veS-g0`hxg`~oJk z9zvfAaw&4ukcs87UPPLZLPw1=NFI@ain1ED+NZ;wvVB$y-J z9&NESNHg7&b9=OVh~BIJ!a(cvLN-l!X$7$P;0o(9p$Uvu7H z@5FbwHHm&?$Q$^rV)A^G=;9D*j8ILZt2G&+cc|zLOta`K>)1}hZI}&0r+IW@h_nZ3 z5&hVZwK!FkA302vP;qnuhe9PvC`~9-%jilD6*mu|XpYn>x>*z4i}fnTWazYtW@y5* zg5DslqYtgu>9ITQ?V|NVWH5BvMcZkz-nm{3C#FE2j;`52q1HR`#j#2PX&*hRNs8*f z9J{0-oujz813D>cb4ORb3(_STGvqCt;A(~a!>-ZBhScxQq+7JNCduldquA3zsP559 zTeO|HcMtH~uY0sU6ZQCZ?61O3_h?T;%Ee=bk5E0L8HN;w&U}#PqTg@j^h7%2Hg%Am z(WGrmW+OeTK%S3YHlzj8vkv5i=oEyfT&#u;?Sl4=zVRKCtCul$LFdKjMnh&4;`wU- z=yoRdr$dKeI0aU!vGKr&P+*qJRJ5X?k>g5z-0z=l7#Y+75@JFIL`;rZ0}qZuOn{KF;&ER4NIjq9`r4=anr*=uxF-N+AkiQB)R-mTfJf zuw{{KDV3gc|A#|7cPyW#Huhcb_` zII}omS^hY5y&znp*gj!hXqbv18=8P*eO9`10eI~R%|LQr5BQ}vkncio`$&5r-v_RF zU+81BSpzG#GuZ44edZ(CKz;~qM^XYdeSz!`{e-0P8mMSMeheM=k&!?Sgr>k*4C_T} zP>DN$91P9yk;y=Q3jIt3;^Y816gurAGlA5ErYA(4(Gcf3AcsTG`^ZZ`j)XoyvJB$P z2l8{M2FWGkL05nr4W00jr9gfOrRyRxvsn$~*N}naBgl3+kl#X+eB?_Y$3hu~@M1PQ zf&3m)Oh)n*{R_Bf1oB6y7m{6t@Lz+091o@bzVbvU^~Ci=DE0T1Cjf1iT>R?zc^%3^WHxlrQ1-xPb zueh4}Y+YAVpRMa^>a%r2&20h~fnQ~3S7@ngL@&I2S?Ug`{cL>LSC=k?zFX=6AGs8W ztrnjzY)B6sbv2U9!RrdJan))hY`u2{QcpeOBRzqf6X->QKrb2udeJb@i$qz>|tDL`7PN06AHl#cM10zo+IXA$H4e>QX959dwe>n{W8S(d<1u9*=Wu_L03ndaI8k`6QgK90qcO`ht)A1>`36O&@@R0|A+^JsfBh!K0t#;)kpL;z6|$eMpyg_ za)x?b5beE{@Map=%ur9GP5ZVm=Q+vhEk*Bi9S*TQA5c@hZodR}eg zBN4d&nyq#cM0x&t@!n3p+S^Ci7jN>_Vjp4Ow|POWL2?W9ltnI3PYRO8$gi;FoTG*y zB71&Xd zs=pdg^;ZL`J~uGOURR4!uIF`iF02qX=SibpSAP=3)2MmsA87M@E%<&o^nISHz`Yss zV#EM4U!B28zVZ-~H`FiD=A|WRN?ovdQ?2%qCP3a&FM(4z|LQIdT=N1oo7>1ST%bMx z&ybkcD@)-&c|n{7>I@%g17x8(<2GSK_4IA^RZiqQEK%R`5w@2oQ5X3L+e^F?82R@C zBmZ7t z6d~F9m-wB+YIOl8@)rlI)%Ve6&tY-$zgjIv^3+BmdjwHd!WCY}BiA752KU(Fnon^u zT{$0AkUhCxt(L-R8oS3o3GZv&$i0pup|{Fct6jzm8+NwLPLkKCi;&P8$ZOR#oXC@< zwdzqMbh5Ng{h#pSrw0R}t#zsmwT<+UohPhUFB3#rUkl!%1e-FokB^K4@~Jw`NA3f% zQJv`{Gk|=q&O`DGjOrX9U#TUWOjo{z$a8^gQKwB5{bFy7zYAom`karf0V71Yiv#L$P70L`55iq9cpXri z-^H#lU%3R%sDB0W6Ka$^)jzDJp1d6n==|Y;&L0lw{1LU3wQeHY0sN5y;i$JBE4>JO`+7QCNv zOf@Ho?9BR~ScAvZ=A6hicuZ}BHnif7sRIO2Xnh@1r*Iu3IbK9{F7@M;lskzpL5zia505{!sfPS=J+6i9j#@Q19>&_9n`o>NF%1q3;J5 z!n09zjgPQ*%ucEsk^BgKXDj6|wThGJ%9Lx1S&YS$uR|F?8Fv>wyO38LLuE&gw5Ja9d6?LlrM z*4H@j0vkb;+hKLz4J4txB8WB@=X^qYn-e+b6WRy9IQMa{b?8O^C0W;Y38Iu^)zh`Z zXhT&`*G{9&-&pl@E$b1U9gV7H*6>l*x_n2`)>?2PM(io@vb78!nGM9z1`48$J|=z{l+?x}xoVnt zODCy4h~xqwInYK@EAhp73F0KR6@qxVsH<&8!rlgF&nD_>iO0nF(0`h)t2IGF|7p6e z)&of??i}iBH*+G#u&y>l*mx_ht~Q1fIS=bUc0I4d zHP_Q7aUxdS0wCvT>XZBmd1SV$Y^XUt!hUUft~Tu{X~WiXV{NvNuse<>TF%p=^#^ys z(+r4wzIOgI((5B27i#T%WG#^9TCtB*0BNQ5&68eV0l7qb{8>(viB;l1L$%e4ILTM; z*&+U`NL%d`+OY3|>;kXLwL#A@ujxt=T+cor?X-QI%u=3!Q&48pUOV%=h&-=TIwx0X z#%xZs`ap8Pzk@b~6Zq!mC2*GwquN0$<0M}>brqbQLYxe(LB8-h0)%;8t@Y*PMMWPa za&fix8Yk108C}F2%hWy;UJ83J7hY{rGPO@Q$>-!4MDC~^LlXHuO<|;~midCXX6E%b zkZZKroJ?1q*#U2|K<(+FO)U^MjIf?&YsMTwYP|v9wFaA>+9^)tYU-u6DP%U&l_z1u z9I&}go5sm3WfwfDU~zhD<($YB*GFsklJKen?@u*_mD@*~#K|n}1-O6Dfrx#y5IW$S7?nC$p5t zZc0~f0y0{Qy(Vnl0h?QajMZkmF377u?gTPUt2a-O9TVY15y(WX%Nv4Bg8k3o_u!3i zE&WYF9N3|M2Q%tkts#|!Y2H#@Ol$gr6Bc?ybfcy5!%Yr-sYrGc@(_Z zFB6{CmT@v&ITz+UJ4<<9JH|;qCu}rkYl9Yv$jpXa;R{;3_ZgY4Y_#C%3B-9(n~!A3 zHke~T3bYy|B}nFItrjz{d}Uz^k&8m@0Fs?m@Jkf%D$<+}L|e>;#d$?5<|JQ)JFE=8FpV;qCJM>Ifx-hE+^Bu&A&iPH26?6v?<>@dq<0L zGK;@qdl()nyrXUYNVL_hH9XT?2T#eh(@3srl%_<1ys!0NA#8dAv4AYrayfx-DI@tn zdxw)*O3lSWjZ3vPoJ?1az?^3}E!CQ=WN~18z=mnd5-k@A`*j2B`%B^f(R%o#`%nQzTVAh=jy;!MDL~^Jb zJof~$T1&1IHjNVS-z9*o(^?_92E48WvReca2O_ z9t5&o>#|XJF;$-lWS2Gx$-NLK56Cxxz45o&5nZ zAr2#Zv|J?JK}8FJRBN?A6JF2X0BZuscUmcu3v1vU4#>Vh>py6jmCUP9sSP7v0yaNr z<31N;*sbuZLr};AS~U{3Pgn{z2esOpgbiCej2zZla034&uywk!4#+QBHj*ozgZ~}{ zx$rL|fc&H7_{eWS z&S+Igo}Qkj{0~U&u(4TqF~Ypm@K7Xw0b!A&;UXVNgI~7j;eANnfwpuY$#9!5MI1)z z0jVF(MY0a!GzHQ)yxB*XSJQCAuY}i1u(=q>h2g$FaygI|;XEYkuwR#i*Z2tQ*Ja`3 zNIr)+tY00%O}2>0jIe%P74CzCy@$_!vC}C$)JLub(lz`r688TqZvfIg`~;FlFr)ed z$qMHosk;Q8_5isiyv9dH0l7AO3Q0G(<_SQ0g_~E2>tSRvkUrr-Nb>SQdx6{-o`&SQ zx8N5~K>CGuBl+QCcpm`BfUxnkh?4`m3+6Q_+yx0+Uvq#A2~YA7HmbwIi;!eP>vMsO z2v_?^F_6*W*j5pFB-GsZf!rR>KvL@&cux<=`0xlM@4?fzWk4o`=laNcAa{q4B54OR z^GhK2hcmW`$XmaHxeDZw@I)Uu2xNM=7|F|!FGijW*C4qbuK9N$&xS{A7jc%tX#4}@ zh45@2sZ|F3510E$49Lsj<35rE@>;mn4iTr01E)Pe-U^TLk)}Z24j21KD9tQGXcqo!|*dNUTQY$jsNAiKFkt!sY zL6+wMNkkg%5pftP0b)faA(;f)yA(*>NU4u7ulkYGNIn6ZSwI>^GO9%!Mp#=-Bh!$) z4v{|w(jrpjBO8FUjx_&Hcs&DNUjn%-GSNqvSNq5sBu{`1Tkls!j`_$Au*rsO!1aU{2ZChP-pW2D_)5!r-Qc^Jse5pnt? zPnP;e`k@W04#&Wzf20fvQ*}lLMY`-0ahUf04P;1Uk&mQ*0=f}t^MkOtvm{N40~r=o1IU!fJ|yG7=6WFaMcVx+S|?q-KQayp z(^VFEYNW_V27uQ?ksYLP*c$EMtjny?`*AMUi7jn1(L_QW|M?RCqB> zU^8J^WYI5@tOoK?WW;ZRFa_8M-{|Z8LH4$y{pCB|>?dT#TG*|0J zoioCQ=4ylJG$b@v8%MVzp}Bf~R8!!QHtgqVu3iKm@R5Yg)fUmAwFRNM+B#b8BW$j= ziO#4aY-p}t5p5C@gy!m%(fK~Y=IYhaE~>Dhx!O7UFcO-XU81QP-Zff)HZ(K4Mq6nj z4$aK0=sqMgGp~(K4GSAa*v#x1Z5I)QX6E(LdQm}WX5JL-goHG_U-Tv@3C-RC(FsUM!v{nsBcb^`AUYoj&F7)fawMeTw?=D_&icZr- zWYX|^qEk#kXk9!IEwv*ArP;Rr(OVp`O21)+8EWV8ket&66DGHjM?L zRj@c(=_70vltyPX5jM06mPN~ukYX>7{)2?p#Ycg4u_9XUJQ0W1#foUTkFZhwI9k$F z*w9KTi%w-PwSWRJ!fZA~=Qb0B*3ReA>7dZ-o*kF`QV>tbYV8WO4nqhi~U&`KE{ zi}e(7Xr+veW%>wPDYwTaA)%ErAvPBY)q;t!N+h&)?u;EpLbc$on9)nLMXTxVSXOUI z*dFQLSmpJC&}y0*>(^HjmcfT(v6}>;)igae^kzY5HRZ-){RE-a^mOb15?W2q#!mMa zHnf^vh~*9tgjQ2w>=+VSO|Qg;4iq-DnqH61MnbFU%~<6SVMFzzIM#QBAheoFV$MiO z*lKz&R&SIbw3?R0YL6C#R@1UrrH`=H^igch7-2)J>EqZbBvda}$1Wc$Y-oM039PTR zvHoa7^LcITJ|r}I*T)_~LUVO}EEfsQ!}YO6NNCo55>svytyG1x5iGR4fShlY|;3$`?VwBwJUb<9m0nCwJSCX z3H9rn*aRfhuWw>gkWjzAi4`HCe(i}JMMC|mj@6qW+M<4a7t2IK{rWy|g?nRD(Pri* zc)AT0ZEtKlk_eE7K=uW^eu%Z2$l8)`S^N;|%Zd2K_XXhfLu?Eu6=8L^_!js6*aL#3 z{oNkEs0lXvV>1NtzTUY%whRfqq4Z|Z2pzku^{@H!Z)b0@oIc|8YX7LwAeG^Go-X()(yJqKeWk2gu=AMHfN-h~*-AC^KD|0yZaOE0Amhn`uB!#mar;X(0c^vL=Z*t>Fak zB_L;FrAP)}4Nv5Oq{TOL0$-$WD%whqm)*m>UR2(0BuFS;a<3$dz$+4;HkpxpZnF+Z zB0gq{u(7aTPW%*-|Mg8*c7shaUVfjnISk~S_?r7g9Om^mkcM%wYm#rUH;$J*z-$VY zia+6iV(rrTn=0qU_wzXL4fg+F zw+J>(Xt^L#ZbLz|Ec}NOorYX0BO}ltClDB}|1LTT$ zy9aCWYi6@02gsH2nMhXmgy&5_u8J4<$g@DMrV)z|x&yux0i<*M#)oRLIN=kY3zg^` zAB^PD@o>J#ZAK!w|4t&~kxY3*yqnQEeh-rIUl4f^$y?B`9B89+d^#uPX_H}87xKvS zkYv||U)BTZ5?|ya?*r)?ulH~*-c$A;Hdg@2ia#QVr%~6$pFu(z)x*oq9WXxYz^h06 zGmJBCc$!iPBs*S(!kz+U|UVA!=Q=zaG z$JW<<@o}8UQJosE_c*heu5@|;ej5mJ9*UQ8vZ2=0PH9SaAP>itCwQFj+&jg0avqLn zaw2lki`xwHkpVy+i%<2DaX@Cqi+tpMAkW16&R~&6FP;YSV*F!HWOiPS|IUfb&a3gX znarzPq4hpDUYC;!jdC$J-dGTYaxpjFnG>0d*W$f=gymv>d?3c5EEi+sS(^2{*l!fa zhjW`*$^%f};b#a+aeRs(+J{iZ*{Up#=O8(D4v`s1^3Nk8*842&?tC%FigCTq(sn&f z1cJd|MIE-oXYXPaduns6M*N0F66(80>ae?GmQzVu!gCp>KMN>M9rh*$vyp_oKgP&H z&xXC($jI9sVegNzI3*ro`|z^~do$#0@}@`f_-Isw=^f6J_{&I!!4kv{^T$E33d} zX}l$p2s{U2t$!H5QV>rMKa5|CHcT_iz-w82EZUGlE|1@fguYt8JU$)0=>7TSSgFOF zhZne%-~KY)a0%bIvNmyaQT+mOwTwedDc zC_C%oxkxBGpTsYIN_f$XDv$R^LNjV(JQoSgsEzSbB$U&Qaph?dhjRK^ybuY^y3gY) zk>q-{ygp=S-uV4mIAUVzVbO{Q=WDlp8c`+MZb(6MUsC=yqmfu z-spK@W1c78aI1=ULNc~Wkgww-kkC7>TjRw@y0;c@qHc>XLoy217kg7~N4!bCi2OdR zO4j<$cyCVRo5Q=~_X?86=HU^z=5OM&(T3*XxA9_5#QgakY`%@(^a6`4$Y~&ZQJU2=`6#JWeV!T9pUmFC(EO zN8(C>h)gr{m-t*HG&7II#s2}XP-tfU9$$erG&6sX|A2&M=I`;NNN8sM8J{vov_)!j zBEA3#&DE3fEl6mto{ay)$t*1m>N2Y-Cvn7NB{~_eRmgMd)t!^^I1;KmC*#eKP~ABh z&*VhTsFU$Ag76u24vhR?@ek34X4I+pc1{YEI@{BfCSY?aKK3Qny3nzUf&4E%l@p;+ z89@GxmvAyuc?Nc{Ojpwr-~xZ;b^1fU1liARW+@lLE`{x%(-XgOQW4IqC+-5I*IRAV z(B?00Qyykt+-KvHo=6n&aSkt-FDg-bq5+cWZxCsYWEGsf&*yDjf#gSzWFcAXk={sl zd!(NrY3cChFsmTxiAhN6!ua%pzSl~KI5V|P=v6Br;>^^Jd*p5IHB)Qqd40f1dD^=W zl~spYiE@nmF%ULlwGyY0tUXtZMy*5_{_mbQ)MDgD-ufGyl&4({qk0RF+KJ7a%+kif zeF}>cO8kK2$ubc+lsGJia(*Qd>lHq#X{9i#EOIDuEs{JKRYufAjv!vG)Dn4U!!+tP zun8xoyvpM!G@~Mk%}A(LMiMvA6>U+ijNojksKW?*Bbvy@_zR$!tQS$whSjee$f+bu z6BvnkHf$}kITlZh!M3hy1Yd4|D~x+K>%WG##la@w5vC+lz$TG+1-+Wr7m@Wu36ja* ziO5D`2`BOt%Sf!_M0`h)trR2ig^#e6;v}j?9R9!9SWnMMOnt2u?z{ z#WhI0>?15r<3tH38#NlAW{H)YlqU`o4hWmH=i$`oEoi-WqIfCy zN_!P{x$kf?{zFD&mir{`^AVQizKK#!WS09S*86Nq!Det`6DKn7w5+QqbGbYc+__H0X#ok%uh zh`KX6QG?_Ic=L+=N@8@P-6tYWU6_ZgHjPP44NJSo6tUG zUelHD;7!y`KyFK9ax%-?;oqJxHZU9bPl9kgRbX>_qPLHH17t!XkCRyn+anzWa!;a~ z6Zk6WH}E?bPP&wfI3pkq^O};#MbZMEI5YB4qKXsvFBRL;l;c3ACF*SyUTiI&2J(0! z%SY4-cqchA3CX68X$m9HC5n+;4ZnDDfy_zl<7Ac=#xZ;)aTINie+3!_Hm@YQSFpBb zdArKj6C*f*Ujkm7t~3Xm*Asb2*l$MK0C^*^5=j%Nuo*y#6S2=koY9ZMyXrvRNi_dl zkn=#*8CjI5{e>VqS_$$&V%nF2u$}o0V6!w)iiFhy=Cv%5yG7XC4>p53SZLPVI$PEqx7=tF9Mbwe=bwVP0W9cc+MRW`wxHh`!86 z)~g z9@@~}rk=iqlUWLTXMnB2dinvhq1{eBeZ;r?dc0q()YHRz7!f+Q86wxy>v2+%Mp}1{ zeqoADeZ75(O#?j(37f0iAWlOa!opv9otq$oj5N}7n=m3zA)4s3xmUSDHcj;3d~Jom zx+%t~s6&yP>Zek?n&~CgtQX~J>);HZ>EVTeI2Y;5xlKj5{qyi&A>ev0($^yC3S{O6 zMk>!l3x&9TBkwBQvH`jM@B1Vi|VGF&6lR{-HwEh!BZlNc>W7kutEQNFaUw~Y! zH%HROg#WAxq$Q4qjMG|g@jdgBySUbRdrpLn@)^7duaDzIj@YI8L7xq~p0@gLK5|ZH zMzp4}(e# z@8RE~FY^)h+vK78ZX{p-2u}~d>(;<}AEBQXHlF^B(0l*PBFp(aLa*Xvx^it}_>wck z8KpZ%MeFT>%mQ+IAn$kREq>uPUgSIU_MC{BPyk+c=pB);neZwnLXqSeoS_;1T^bB_$EIgum( zhWg%VB{(NcO+~l%zl57r`P+P^{bFS z73u-xIlV6u2hMVt&GULL5?13_oP7OVBm*&Wf&Lv5c2~l@UeZq^VY@*_Ue@RTA=(-b zzrFniviz!E`%gjGUW?hhrZ-1274~EMz-FF43JJS6XRW`fPeJkkw!T20gM{5Tu{b6A z8cy<+=;Pvd9PjGJan=_6*OglZc`u-li}W$V##^V0^ba`^GlAU`Ez*DY5mwRO*K40( zk;Q4oVYue^b(@n4jn0G@>rIf*x$$DXwIJSpezD#O37rxz)~`b^IwfAL--Lwb&tiQ9 zdePI0#rkX{bSC_Pz7h$Y34fs1AYnOWCj+H=y_2jL75qCMj4aXnA))i$rFsq$I`3Vo z7bBsQ+ogIH5<0nEs&D*DL}q7S_d*+I6ZYijLw%dD;d{v6U<{Y(zoQrJA(!jXQ#^xS zc9!dPIT6`mr!>p;)Ki+3dg>|78vT6kCGXZh(K9%acjBMu%0J?o=}!Dp{nTke=uZ4o zJ?mdV=uBpVJ{}3(n{UwPb0U>wgKquDyrhzB2q?)0{Tyxszv-MKG^$*0B8aCX<$7}@ zG!x48c7k|Mc+2%nPNb4-)UWlCz8m1)O7F*sRFcj52u|dvZVrsbH7dw4qV`R-eI%9My02NNpBJj_S98QT`W;9}pU>z|AR&EDH!^Rs(NPEM^VnICZ4IAr`koLky4$zCVH*9P} zLUSW*>_aco-mqbW*)>=2v!?kl6Cy?i64Ks?F%Ai7Z`3G4LeJV_#&#s6y>a6-64Ktd z(JUg`BJGVEeUXs%#*Lv-VME$`HYqEIGkoI?VZ*ieBxtX0Cp;3ix(Rp}7qbMP+nN;FjW40j(sl>TPs`fTAs?mm2qLE>k z%uA|7BcqTLsS=Hh)LmR7<27z0Rid#`EQqHPjg3V}XeKl^Qnk0Sv69IK+umiHi)!V!bF-NF^>dZbw2Y(b_0L!uF7C7k8;qiG)<5jiJ~g4ynXt zMl&R&677xqkdR7b7zId3C9X1lKtd{!Y1DH>WKxMvMkW$ci7v+dNJu5R8_y#lmFQu7 zf`n9}XFw&cGmdc^IbzotU0j)ErV`f~kNOBxiQYy&CsHMP8}m7lD$&Py9|@^MALC;| zJeBBUe1U{iqK~l~y+|ec7<-Y>+~{K*MK4l`K1RbNyJo2p*Be<#NF}Z}rXV4exWOn! zLMqYM*oTBv;zmQOD3eegTyj7*L5J#t`l$RbqrO3ELu-7-3{I6xU2DG16$$ zNDxwqkpYz$W#pg@sl+IwloP2Eql~7FSsbYnqXH^1%4orDq)Lo7+6dyQ#AqV}3C)Dj zMwTGnUShP-n-i%LV~l}5!c^jRV+<#9R3{h@b0Sq@f>DBmRN^kkmNMgbC1iTjO}NJu3fG{WbJIHVFeMsp;j5|0}9At9BRW-LNND)G2cg@jaM zh7oBhB9lryX`GLQRN`r)KN3=jX9FtnyfK5@$Ps(q*v^T_GE<4?4eNZ?mdyKX;{r~k zO3XIeaUxYB-{^{jR3hKFUJy?u@{Qq0NG0-(iReWtk#9^!LUSYEn1)`Y68T0c61tCj z!Pt$2RN@6gYsPvZo{6)&wik^IB%~4r#uOx^5_62XNJu5-80APvCFU5%kdR8uG48og zv_&d$Heo7JXgnrtxJuN9cP3skUPCY1OB5L^IFZ>YGB$7`RiY@M60ZhSVxF;udr6fj zHV$B0q!Pu(q88$sNhKB-<5~(rDzPA-5(|xGXhSNo(5T@=&X$G7U9DIgsS*nVDzVVG zkK0I-S#FF$LVJl7MiCNHiIqkb5>knejpIm2CDt0(Tp}WqN|YI6 zkdR7zYLs0nY)B=_jf^&ekV;e-Ly?e5R2qdyNF}~7N|2CBd}Vx#gjC{dLutz*%M+n( zMn5EUBD6iABs+`}VdI@S>@fbviBysuMu*E-WH~o>8ofA?O0v@!%!yQzUB+!lNJ(}X zlLhgVWS21m2`R}gBOkp;Np=}UNNE1-GK$fQlw_B&9SJGPZsRl(Qj*<9tIJt0q>_AN z3`Igp@~u&Xgp_2DQHF$+WRFpUgp_2D;j|NxNlEq?-yk6+Ih&M~!&mr>L&AnDNfeai zJEKl}5r>rId!sQYa?XEmwB$r8$@c*z`5~Yr2aOKgODf3`qc^riN^-<-GDPd7BtILm zs{|n>`8l8@M~y*fLrQYg$m2xLmZQdhoJb`(8c>p>MxCp9Ti%J#FGfrdPf30;93(Uo zeleN|;wi~5MsrT2lKg61?juY|emA;sB1iRvF_06fBqxj+NJvRe8M~0se&Zjbb|$-K zx!?HL$Us6$@}DsY2`PzU79b%dsbwBSLP`=cYj+fpNl7&GMkJ&p5i=JFDM`#+goKnN zVg7`Kl*Ba8AR#4j%(k6GTcjj)&D67tbIcLkMvmAy<`Pb%N}OZ<<|FK`q`sNnnMIZ= zQQtH|2)~po7Q;D`_6%v{WZOv*yJe6o`9^gc(#AW7hKEhO@y?L4wIjUEhc2Cv| zsS;P38AwPaGRko2<~}5(5;vLk`v@;miT-9QB%~69%v+I=N(?b)a3c2`!^|2a zwBNWjpd`c1-q*9X!@~BqPmCBs70Un%U?@N;1-%iiDJ8lsO*>Dak0a3JEF6XjAFS zuh4q}HO9n(@n)BsSX=qZ@fYDskU%DxZzB2o74g;I z`^;)2^Wb+kUBKo+^R}D0m$%Q%G4JI>YE(`@qaF)r)Dz~T+)HXyu35l|)Tmr@=m0Sq zq)|_q{RRm_8ue5_qnVZl94CmUQO}r@IFTBaXFlvBOrxGRb2*W#=|yuMCsLzcG&dt5jVd%7-@2ti1H&L&KM)|sWkhU-r+(1i8oSLj9hQ)bq1BC}Iw9_K`=L|H&3HUw1SGgBGK zu1BiGX4BzBs>EiqdbGG^Qi(6kqOpRIN_-hmiLcB9XhSOTm09mL<|Sv#SLW-SNR{|1 zpb}r13%HF`i7nxplGL)+AR#5GWz`@dC8=dCzFV|KN^&+SD~I2;S!;w1SCSh+ zN$ObNq8BMi$U4r6%udKsCdpi|cWFXa>OE1|O1&qFTQTk>mBg}|a3Yn&vTE)X*Gx)c zTl=O6LP}y=srN*V)#^TBLrUUUBRG+>#j$?kL@J46rQQ=c)-NKCcTeP6#|80}#I;T% zp_$-X+Wn$+ww7H`3D+_>kxG)Z8u$oPl5?!)oXAl<*XqoPRFZS8iAXx&+iOj%^+-rb z&bMlikdjC+e zu!uvtk!fXcB6XvawG0XAMrSMaETxOpCWpn5W7x%d zoD-=VU92)6VRt}XtsR_5-RNo^;6&<1H|tL%q#NC=^ha1*6`pQ%vuq@!8{Mp?f_UE$ z=w`J*LbIitm4RNQ8{MplNJuxjTLnl+H@aJuNazkI%Q}sObmJN;^HFhyq#He~F-S-^ zdRTc#NH=;|E0K_H^st<1A`a=s*@WrFwN_JM!*yd2=tj2H4ZTP=dRoIck=f~KjpsyU zhv`PofNt~-=tf`bKJF!Tqra7hZLu+AzhdieO?^UKGwH?vD`%!4q#FYQx-rnIL>tnL zf!1kGq;3qf9-qbHNZlA1(2arCQ`|=GKn7W}1@UxakX3|)X2Kw=SP*XqGRRuQiPVk3 z)(RhCx-rx$=R}U`2&kiLq805>koVtfNRsCB|7su82b_ zF~MqwgjC{As~E{;@Jl8374*BU+D{2DQi(}cb0nk^_gZ6+kV@QV6(b={m}+h3q(JG6 z?-D;`#hzx73zV_=4)7xZO?b@8qQ@7nlQ~O;Y4b}G;0MXQWK_I z6-Y=ErdvA%@ibw&^%D}(gz44^^rF4Qbn7${nhDb_?HSfDQ3tOohu<+;nMgCgfUeIg#1PwK{SlH6b^k3C{#H;d!ek_mY}WV2!}GND~UI z?AfAq(u6ry-xmZSO_&qVghFdB+K?s`T2-8g^>rKctI+xh39HMDylfdSvdCh^HHK9% z*E$agTXF2aLcDIZLBhtF+03){Az>M0ao(_M7l=3mF>$gN zw<pl1_=M?uDO+fK!t~{?E!O{p zSD3!jwZ%Gg0Gz;!zLz2ieJ^E;^)I$Xx^XsPx>03CU*SFFx-kdx{4^D zV87Lx+en2xWMy$8zcX;in#+m&&cGq7O4#sKz;;%Ltc=%rcD(Nl)L4V&2|_AbV<~S4 zLYjHl8p?^x*J0~NPGr6g2l92;IwInD`8qgDT5AYVtUKe(67*U#3!KEm?#D~+?4 zuRkcVm#;qp`T8S}uRkb`moG^uUw>GUH)VF%F87Z>zD@-4^*<}gy=1=rvs!T?^Yx!K zgA>}#R+9y1=j)8sW#QTRI%CzmeRjSSyL$;Evc@U)Xe3nQYS}L#VS31P zK4dROLN!ja%aBlw3)_?45s|6JMePD4RO1r%N+eX{OuOH^!s`J|)HvIokA!NRYd3sP z*ienDYj;6HHSQdH3=*nw4eWVHsKzz2mvK^{jDyNJ7xbsG-E0wyEUR7<+xb8cs(R9UA@V!;za7|O?LBTYz(EY-eeEuM4n9EWS4&=W)$5` z+-x6MAqdsMo9(<+f>0goXV-8d^VQG3=VN9g^VKhquYNR!UUvEiveVz5%HzoF46vW@ z5tg07_H0gM-iJ{xynGF#w!D0KHeSAl1@bj4kgs8Zd=0aUc!vgsl5y;mVyO?{) ze2uqPVlU|XNaJl|H5)^jukm&kCo*5-?L})vE+}7j*qhf0LixJGo>C?V-?b@FTFRFtN+Rc$r9n7(v z4Z>#o08s}YwfiBVIylX)LPB-$ar-zDs)IA^dgUSx)xlZzO-QH?K4p*LMApHl?J6Yf z1cvqf8GF%ZERMYUd(IwLDG1fU7Xo##z+S*@WF0K9*K#7}2CIVw_TN6j>fjtZ{yB>* z>);%_At$m97TPV4P#r9^uMotmgN63BNT?1L+WpXr>R_Qg1PRr_LVFB)Q5`I_3y{$L z;7frz_>#Q_ZKw_w1?u3-_EEHOq;C#F9CN>%s-u>YGKpmWKPemK5gKyfK zkx(5hwof6UI=H}Y@`Z>@b#Q^Vy6Jv!0gaER64Hk1-~#&^5y#sbFR-(bP#s)gUx#f` z9Xy+`I=IjtENplkdgB5}kgqa( z4fm4y`o#XsM_9hfDHmS8Dk-v;uS&A<@>LngS7jhym4SR!+S_^SGGCQ}e0>qf*A{yp z_mcVAZXf4F=4-p%dm9^7SsAz6(>Rfpal2i!L*#<;wZqnS2}1eWVVCX}gz~l1j(x+3 z%-2r)X-;Imb_Vjb)6VBMGGDuBRK0xd3gl~-{WABG`Pyw4`v}X|9?FH6ue}u6%hz7A z@$$7dkgvUgeC-Y73%q#iGGBWG`Pv`I*H89Z?j`f}v%Q@YnXjMiR^PHwmHGPF9>Iys z*Uxr&wa5kK>!@A%ogkF2qxR6ff>6GGvFVJO)h|}Nf3a6`8@ZD?W=HoiFL`SHr`;S0 z-O-=0Gmy|u=A?ZT3GHM~*~Skd4((+AvD+b`oy>psJ|xxfoQR!TD^9ch!i#n?>CPe~ zw3DgrR3V|AOvpKogmyBTlX_|$b=v&MBFmjj%qd5*7ykDUJG+QG%?}70+S}+(-a$bQ zmBKuSE3}-4eiDTCHc2P-9>1RR7Pk>|gY9JMIs1Hs?PShz{^UgNWX^HY53$H{CsW_i zk38`{YN-&v#Pq=$kq1YIxtholG+)^^U%oGZbxTCv%}wiiCDD z&7Eo_w3BJ!)IKaC(@v&^LwD=6lW9TY(;C~N zoy^&!tQ<~qoU4Tm-^rB1jB4o&MlagQv~nhKB6YQu^EW3_S6ex$cl52Cv?IKy-W`2w z>X)aht(~y2@%AmP9g`EOtCu(peT3<1Tk5-~tL-VWH)8Fb)RXP@fiY}PalGB2Bs7NL z#aoxU+TKaMqt9?s@8~m~_S{SAYFDQ>CsJ3tI>n-2-oB-)vs>7B`89USGXK|*zKw3ByA#GyJk)+t3ob#R=s9SPOJ3C^Pb2`~1(1gnF0 zI>(Vv9lYDg{zuqQ9lXbxh=l6kWM?)Ks)P4An~=~Q{Zyx#6IllzbS9o=kqZ>6gAX}X zNT?3xIPLxuHdF^6bCffJP#t_CPzPr^*K!*%H&`8<>CEsERtIM}FL5I4;4Eh$C$bJc z>3oQU>fn=3nIK*reA4+E3Dvfn>kK_pZMpLC9*7uCThorX#sxGs6Jog1iw zxlR_^P#t_KPzRrOrl1Yg!Dj$<~zI5i%z!l19dRpQPRW}QXPEJ>4${s;2dWf z5~_oRP6-mKgN1=QSV-gJsYIdkrSS6VU|~QLBq2>GbiT&6s1BY@SRH)H*(+>#9b5r( zzR39(y{Hbp>^SMHr&3p6cAn-$>gvk@U47X}y`z7H`sL~BD^5O-Q{mOYSDcqQk-GY- zQ|u#5S6_FQ2ro~u-y{|Fl=e+(%Ns+_#=GNqGcc-e21Zp98r3(QRlIenv~LEKc0oXC z-*Gl_FR8SPooeg_ot-Xr+SOv?EbllLJL5Q!cN~kIHFdFA&%I;@mpX%egk^9!jkA}p zRTSCF*DA`Xm#301}&PRtZGR2g?W$C3QiQ&h%polHyEP-U!k zN^L=?GJfxDM?#fxpK}TcRmT0!WsdNo%6QPp=0sM;pPb!Ds4^aMGF|2+p8_9t<|hTA z%6Qb7QCASEjK>0%@ek(;5lL8UJ%;pbb?<#odjBDr34^yS|7+m9duF3JF!l zT5jqcVl5ZP$5V+~?v29BtBkeW)H_5;NE2$ggRm{CjAs*88Ed<@2^(G+*Fj~hzCBkkehmk7;;l9qv|%~UQ%gQ>Zzx+s@qK1c(qb>TX7;oJgh3bPFzIk>x!| zN7uPX5V{BH?B=!*gx=k7)ZU(M?Ut-9slB~i6A5W=FSn5(p7!=~FGWJy+sn;FFVfy#Zg(W4y}jJt=tbJw z%gsST+IyXwdOCNVTZ}fOy}jMk)44wGcC;bw?dztV&fV;$p3e1iGg|S!d#7{#+|<*# ze(nggA?+RDE<-}vJILLKgtT|CtF;!9NqYyosqfnirt$G~W3by=czN18*rlh6^sdNY zw+-5mN(^?}VOylVXA`Eqx47Me4cFd{uqubRBhZVqcc?p+6REvJ-CsG8+B-C$y+Z@q zJIp;HB71ie!>Fg8_6~FZ#n#z+XTKvG=GM7{jhNKlTV2CPnD&k&UG;XkV=1yXhGRWl zr8jWK21a#kU{uEjMs=)vE^l3G@7RF$jtgk-M7IU^lG=NZ+l3RUz4y39qF6Gw1R?Fc*R8x<5YpbsZnJib$P7+)-{M4OaB?7nlihc@jjWYZ zXjHv?O$p>{io2A1$$Z`CuJsX?uc?#^FJCzn*~?cB*?6@wCy=k4K)!MU`O0xO@z!O& zasv5!ERe4!+@0J@<}24d%8ATZuA9}KjjFth%yp-7BJUz|-Rce^7nHB3+
    P`;jW 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�HRZ}0D(Zo!CX{t}XK&va)-oNert9-s(pWAF3` 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 VEY|klMG^n!Mex68{NH#5{sU-vLLmSE literal 0 HcmV?d00001 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/BouncyCastle.xml b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/BouncyCastle.xml new file mode 100644 index 00000000..d27354a2 --- /dev/null +++ b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/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
    +            
    +

    +

      +
    1. 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.
    2. +
    3. 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. +
    4. +
    +

    +
    + + 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 + ECMultipliers 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 SimpleBigDecimals + taking part in the same arithmetic operation must have equal scale. The + result of a multiplication of two SimpleBigDecimals 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 ZTauElements. + + + The αu's for a=0 as an array + of TNAFs. + + + The αu's for a=1 as an array + of ZTauElements. + + + 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 ECPoints. + + + 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 ECPoints 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 ECPoints used for a Window + NAF multiplication. + + + Array holding the negations of the precomputed ECPoints 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 = &sum;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 AbstractF2mPoints 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 X509Certificates. 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 X500Principals. +
    + + 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 X509CRLs 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 X509CRLs 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 + X509Certificates. 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 + Stores used for finding CRLs, certificates, attribute + certificates or cross certificates. + + @return an immutable IList of additional Bouncy Castle + Stores. Never null. + + @see #addAddionalStore(Store) + + + Returns an IList of Bouncy Castle + Stores used for finding CRLs, certificates, attribute + certificates or cross certificates. + + @return an immutable IList of Bouncy Castle + Stores. 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 TrustAnchors. +

    + 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 + Strings with the OIDs. +

    + + @return Returns the necessary AC attributes. +
    + + Sets the necessary which must be contained in an attribute certificate. +

    + The ISet must contain Strings 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 + Strings with the OIDs. +

    + + @return Returns the prohibited AC attributes. Is never null. +
    + + Sets the attribute certificates which are not allowed. +

    + The ISet must contain Strings 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 Lists + 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 Lists + 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 X509Stores. + + + + 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 CU5/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.dll new file mode 100644 index 0000000000000000000000000000000000000000..9c63974c66f2c3ec06466943969cec41249ad7ab GIT binary patch literal 21504 zcmeHv3v?Xik#2R*sOKSRq#4<=Ez9=!J(i`h{6cmxU|A1a*z!xVjfsOj(zNBlGt+YS zjIr#PNDz{RkOY#&3E7YU$?nD{mnW_nw=vr@E^C`s=U1s{Tj+-J{-X?;sx$`SE@0Eux2U<^6}1Hees-?Hj~xW z;U%u>-CaaGG#|wZr?2x`d!81>E45altHB8>?n}pTjpI9tFHx=Fy0V)Y1_S;)iZA&5 z@zIf6Sd{;luP(_fd_D=iyBHZI+Qv?p{JEE?3cMpjM2(Zn-j0r!Oc$vj=xyWVlLhls z0racPM49x}wHuUt;%GK$JN6(bv27FxcXS87<35`auB2^dEeNu$bT7WFYcIazKAVZQ zj3Wj8KKm6PHbbWh`td5FXD%bsgiG{=qvf1%S#Nu}Nl(ln3hTbJ(BRkgiv|oaoCfd` za{-zju~9Ibr~y~k6L4wxEF}C8L>d~-JTUy$d=_5-u&fEK&29Bbmr*gQ`wFvRT>_yp zE?g0|-vedF(iZ=+87nKSI9FT9U?vyO*UzwOYY{jux|q=!(&EpWG&i7;2rZZer4Xi; z7DD6PrXP7JZjAb@C8%aC1$ftL@LYNs(+fe*2>Yz%ASz>8B7tjjU723NLLY`gRjIk! zt&Dz!TYNKC){djCm0(r{n;U{wGqC#A(V)`;B#{INU+^uvKt@a7+z)SttxN0eR*i=5 zUplMQ*2Q{wUK1zWzjU^JofOXr-oLcLKF4?hp$#YM;F+dUodnwl=b#sU3%O$$7RFt; zxlOSq6s$&p&#Gq6Zm6~&hsuz(hE*X%)Up4@lXfYks^LQ5nx6l2-vhnKf^o+dW@zz z#O!5uHS$ENhE?UndT6zf)Zs)MKxJU#w;^Q&?El3Lp^dQhF3=m#gRArzRwWn)hrt*{ z%l`SE)9ZcWbi+bSjH;M^u^y6o$?5y0c#e3{sE+wA*2Ae@af5xo6wfu-Z&QjJ?U$r@ zp0Yv0!JQA+`D6YBEDXCLjG}UrUGInS>~-|pM}G<1F(#su`WiM`7TDLaWXT8i158SA zBo~ab8!C0@ax`-miv0Q+h5_-IwFz9sSWs(SQ6d6~D}h^Al^7VsAz0*WW_J7Z>@6ks zEUN=}Q@8yKwupPBV%v0^p6Fz$1Qv&|(+zMI(e~>ObI+m$e-n?-6&SD;JSUuCR=B>> zzyRFJ70@cjWf!9@R z(2-5Cio|xNjHpp|opJ_@GU@`+Kw<|3T0%g28EGpG%q;X`U`7r0o55r8^TL@E4e(%m zf(bPkIeY{Kn4yei7naq9?3YmJRnc}nh*c)`Gg=j`niZ=~ zz|||8E27mi*VfygXM3ycmvJfQXDC{2U4sg!cMzABZ^M?#i}h&IwI#G*p>-{n1Q}yd zJ!HKbm$S$X|Ala%*)S4^K>rMLF15cG03V(KFtF(#f7UmIVy!2(F?jpyFke3jJ0JWmQJd8eo|j!DgTm zQv-fdn9^7sDpj(Z0|*Jv-=SGC2X~s>c4Ra z0?|;}80(lYN+zp*)S8nmJf!eYv*BXwZzPaT)l?T({?_So3Uzw8 zLECnE_@7YIchz=FrzKkDDh)F|*L{PwT<+nA>3?q3B>Z!+T6=kLA)xbYCkd(Ii+VbT zlxUG&pFqfsru>Z%_cyGG*hSrgR97tJUa&E}%n_?!-u!_K^>^+rY-m@M-`*081mjxnf zKNc#reiB8eb>{|L!iIB-6kL4krQUv%YuIzb?u@8(2QW*NM{BT2@^^Sf z#pY}8BsLO^hD!zmmQC$JbJTtXCcJGAZd5%uRW(u0V*Wem0q!d>#QYeBzO#aWG1FrR zvftgn`1pRn(ESOF5CiFX2IEiF69f#5XT=Z%jM*MT5HRL=3_-wX@EC%Cf%__@Ly&)R z+n$qX;kIY-PQ$>2v07c$^2K={ddmA6preeo0d0Cof5)SBRy9VeGv;Y&lC|wah$+To z)F=7g{61geCJ2O|!Fs92u5&YJ!+Jkpk(rf&7Jq%!g=_SH?6j4^0ok!Bs{^vlP^JfD zf596A1M=%|Q5^`#-c5QitLj2kd0^BxVF6WRqlWTl)!5*1iG3kvc(xPW#_(&=>zjM&bjwF7r7b#HCVC6mb!=1G@D`zysE;faBNJS?>5-L=Br%8wg3G7ZO3hnCCGB z0b{<$5X3Ge%oW@}e*$}IL$64*4-tk3S3w5=|~N&K@$cQ zE8bs;?X3Fo=k$v}iYS9K7n5RAMSjnJ2C z4pNLhMK#eFy%73j%%F|*K5*_8d*^>lm1n}K@zr12*B7ySQTWzg&38}xNQd**Z%_r<7sJRG63{$;@kZL3%o zY@qd#cvS=S*T!oN>Vbs~^iXvib>9j}kE#zMN`Gb?uME?-s<^*fqTH{43ACZt-v~0a z0^IA@bt|}t9*REa3)8l!1^u_z9u6AxWQ;xk(*WDQmTn3~$f`Yv-SW@SmO)>r=2mLZ zUxWTQ!rC5y#|-+Ik4u|;jE{sFUo8Hqh_T21qoyWWPd|&k3Hil-mbna)4b*{NG|+8T z4}*WMlKZm1>Iv9zMEbSAssWOkwDn4m`_&LR4%=RfvHqCY^HcPfKf49;SkW+9v_=s4<6udRI(u)0$BX|!M9Kh^|*_r#*UdfF76;fvCzt7ZZE z!;OHO{R@4DF-S9f`$t#OGQe&?kMjv%6F9#>+%&pePXfNGtpQx6&0w9{GQj&aF8!Xs z<60Z=Mfz2Mw`tn|gF3?+;Jf1-f)C72N4A4=LZ~sE%9GpJ)LxaJDEu zech$*41dU1LywfGJAAeDj7trmUW|THqVDk3(Z9GQQ&tpy?%V7VplbPl@EmgD0y#2c1v4RKkBA z)DK*0o&PJKek{~EN<{w3*GSi_RCaC(eaknG{z0g7l#e~`n@@#iE;~nuK`oeIC-$-} zT=s$Bf#_4dIBjyNO!R3`T`pBw{SUr{)az39)z5+2uP9jkf^QLJ-LkIW2rZ$4OYOx< zvV_jM)I*_{d`syTm->F_6;K~>sUL-3_bsDyF7@m1Z$W+5rIu8_?pscO?owA&{ub0% zU20L7{0Vy4rPhT*pdNFn$7|~RE9fbgdb(yFsJ~Z~__~RzlG1m&8c}JYZ7%fyC2*tl zs!LS`68@FckG&mx=}>q(W`aX5H59G|WxCXf$aZR>oJ-vpsReb?rLOgDrzG9zQaR*f zazY$d(Fau-ENk(vqR$KUB;^9zv64Ta%IFniouAiro^Kd_OUK@hlDMDMXe3mIby(#l zmbQw_0BY&34-*AKm)s;bRNai1@;KsBk-WW6yQwC z2!2BF5y8g<-YW1xnUzu+>(2;00oXtzf{zKj4=_$Y5&TZnGUx^1%Q2@sqqop6wMDUY z^ef?xA2Q4lK{&jjB@V^UuxOOJ`#U9wB@Af|hZRyD0QA*b%6*$P*fE`js?3_XSBQx*- z<0H{!nx@C}WHb~BirD;UZ!aqwyf3s*M9&`WkM&yGqg{+u==bUK zf_3_Ntif{tzZ6@f-wK(8{w(aQrEloJs%_IB)XqfP^lzZ=SLo+ax=nwOBL2PlQ{s(p zfKyA)0zaZZtNWuv`V0D%Rmb(8=tnspw9oj{bYARRd%)hBU-5ivCH{qJxH7BWx#EM z?*P7n{+jObCvoag1gxVQ0p|*5G5s0vmGlJQT6!7qa(V->gQ_c%w4LIBeY6Ac-2w+` zFYx1nJM>=QXXt}~H`B)|dZd-_(8tl@ivoQb)y0 z6Zn|G7X)fP<}Vc3E-)o<)b}Ugj|qOCz{dnW?`L_cU>Fy;S>UL^dj&o!@Ogn`h@`;H z0*?qB6?m_}M+H8w_yLx`SKy-ppBG3$(Ic>%_R+ocSM(fxK>N5B(OdOv5XledpVvc} zFRL-jMX*P%;nOGFiEPB&yUl+UU@qDP_}=QP0rv-Y13nY#2mFulLBRG(hC9R80sg#Z z2=I9L1mH~(h9`U{{5mawZk^(?8(#>hV=o*)n+ZT2Gbp#;1gK;6s|4Nxh;;}yVP6WU zQ>*OOR|D!;zoOu;1=MLB)d61*sMBRM6L=e-j!c^c{0cywuEb2O(N%yta*ucR?SOvl zx)&oesK>TDSn8^;qA~iPGnr`f}F8hc%QnPny}OC4HHpJmlK5thaD1H&sIQ$mzFO zbZT*@l}lx&;j3yLsl1iX48qFODR%tS`dh5@$nTcowoQ9#?LLzuU`~f}7Q3YLD zGiT-tQ;Iu}XL2QHY|rG=#GJ_nN`WIb_2ivGDnDqFgMjo|MH}e2IJuGQI*G>IQb!4K z0Nqka4WvXlyk0?XCTDth7aX1S2o-*nt{#t_~eNso+)C=m|UF`q0F1qm2v@W z-JfwX6NK9x$IK06NBT2}Ygx44bPC;>Q|#k1vm|R{I?Sc)OY3{2FX6;G2GUZuGhH) z!{|WD=B0r!^ULY`CC6sJoyud9u?xw)R?!;!d*w12fro&~cfY$(yox$xtg+GM&wO>W~hk zT)*40vQvG*JBB_d%hMUpcD#9j6$0?zj-Ls(1u1L5eFICAH{b*-6Rp_cjr- zW^%nrY}U(cq)2IvEvcBmoNm!ASK-Ycd2@JgDvt#hD{wX|1H0ckZsw(T6Lv1r&O{E6 z)*j@}L@pbt_6SnNMbom)kp$d@sUV|T*kKJyo19cV`J2#&$#I!5VdnC3Vk@3g zl{QD?jGnyV7-#*IqGJdsmV-$TZH1 zO?O&_ZY=+4c)*lt7{hT0i*~-St611|bT4mz%Vpi-u`+$B)gMDRhu144>-#ONq{Ab8 zQ7bz;9;>vwoe*luDCn?9h6|{XHB+{DhDU*ElNvQHfl=XN{dfi1MI~p=JPR}GEwIQs ztgbd~$sq99l>U{eCr*VVFbkEBW_)`jW=nwng#c^68k$!@_hxMTvQgQdky7h z_r?Q+%k9OD4%cu4)tO0QC+QS2gO11YmRU|1+Y-YwgXWZCFSOjT3FY42t`y1f(+f5) z@V!j*UXD6=_1@hMVq3tQM+AcxLFad9Kq_PHF$=twJG5^&jm>C@lyojpoIxc*R+6-P z3nJNz!S77YXyLI#Ra!aXPY*{7JTxs+u7lB@FW?pvdStfPCDV!{iSN$bWM(lXW3%ef zml*%aQqDPi^FKZbh2ieAI_$#4qVbsrLAA-jEj`@p5HFM-&b{KBsqr-Ds7E^}@5=KY zd~XWd>->;7Y5H)mXSoE&7^<^!Mo|=hVAYXzeAmGBxQW94Bxi2V6j-=`NFPmMVx$h6 z4;9*nF!h$!W3=d5FMQdy>@^27!x`c z8xiBYjX&Gfb;=x+ZE}g}O~I4G)1BhE2Q5e>ODmjO2D|tsm)9JH^f)_<+3YU6D>qyi zA$s>#vhbE+obqJS4Y=lT#Ym$R4FPKgXONBo8^mdH22w-dWaubhkCdgri$gwx62>yn zmXv=q`fQ)e_9~_zkb~+BUfxlnCg?aggZO8WO=*;=Mhc+g)QQ9G9_j^l)U9ViCJs}% zp<_~)n>FbaG?+9DZU!~;Fd>fPanJO)NSokgQ92}@V?9&raZ7AT9POB>rL1+J56{$E zdZ76vcv-Z<^^Zc*a{G`5$3`7?Uz}fZXj_geJBTH@U*l``p;iI*;vw1OdMlTU^*f=N zL*qHu^9=h;S(PMhbqA!1u!q~oPpUCFobQ4RZD+mQ^E|ZMGywHtcfKC6`Bo^t;=)_u_KpcNJ6iK!Jw3+!bJ+T+wuJMj{FH!#%} zx59}O2Y)&*;2H8&91G5Z3}iVTr}0&}(<#ZCL;ET%O=+nQcG!qPMlyxwIG_tspKEc1 zPoZ~st?a5U$);n_%O#vOZmq5$~l!slsN}^ z)Ud7PaWvHroGn@C=8>Z9DeEZbCHs=K@hIn!G6;&ZfbGshKWE7JF*OVxk8<&9TNv@2 z7%`p)SVB!vYRq!>rO-#VBn?~WK&RAFt*P1L(zdJV&Wk(e-(J-Adav@!o!(ZBA0zzu zP34-BnHo)M>zCOmjxldTmgfQ<8FA#QSsI0^59Nqpye?3^bl@Qsi}Gk?zi3O@${yqn zkABvy#=!Wv!VBBW@$mF`z50DE(kdh#LuHNS2y^Qb$0YZ#7d(#bb}8f0#EZ$~@j3l0 zLtA^GbNtMy@S^z6tHbkrc`T{5!<#qRTFg^dsachypk}Cvb$CU|;$K|G2hU=jM^zqa zt9GLW++m!ed6(&PRx;8@bGf08WD3Z zJx@`n8@6&DQB5C4{QzALTY0=uML+obix8E6G;^ZeEy$%#jNi$+lhZ~miI)$#ondIV zp*@2u&!jwR9Po?a^16&Sa`$-oU(R~UM-ey9oCvr$sw@`+aRM0z z)92E4X_dE(^Q01=F#M*oltw@3DVr`7WuwY_gXx_y02i@qdG|2cjh@4J&S!UUcR24j ztJN6AY&rVbcV>vE#6g3+`Q%J-;62_-Wo0_%#fOKxS~5JtcGh?H-=#khuSfJMt8mZH8As;kF!hwp|hDfwI z+6rl?nCVBIh(Ca4#I&)6V$|4DDP0kUg)?JgEl|)Dh&1Za(OaSY!&>xgw0UN9^iD0d zDYhvR8@(&`p4fYY5s5_c8(Q?PRu711Y*Q#sQdCC)w+`&C!)qj(9tn`2&58u$KDgoq z&q22a;GjCH)07UV6kQQRwGpb-e0oH$osajsVGFyuj^KxRqE&0G3iujz&kgeem9f#g zW25(Y|L==LNB^`Dj%Fr%Z}c8C7Y;|q+EqmEsUlx&^gi&>;Xkd5`(fH$a6=dOdvpx{ z#pgX}7rpfxv9aDNwtuV_RZxRFgEqbtC{<^2{~~a|5zrfB zqdyU5DvWx1Y%GQUA(X=(_%B8K0s&a`^TtLMogAXwCY=i^MiTAcA+madgJP7K91*5aqj^D(Q=Izae))Z zx#a*qn~9q({2b4T7x@S>&Q)>ZOs?sJGSoL5nmf07>V~4aQv8$qXI5C=8ivpKE9@P4SttZ!TCii@Pd1H zduwOgWotIHw6(5jZ&|l){g#%E9c>$0Hf(6y(6(;Nn$>HzwBuJ}8daG27W~Rf(6z}m zN&K{~SEI({&aVE_t#bgH8ikC{_BE1=}*_EDS zxku&6emtFZl6WX#<%jUL1Ku!6dnf8!ikU2)1O@mfYxu_d0WKri93}qTlM@I&9Q=Ho6XP{AxI&F4_>zAM^^E4RfTzDX?Lwx9RkN!)$0 z9jn}<1TMc;-c^=rr#sk6;_iX(Dfu&uzn-GuFM;7bK+(h= z8isGUXG8Eu0Ww?BN)g`O0cR$fRb&}#I&j)|F{y*q}Bl0&J Q=w + + + + + \ No newline at end of file diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/ExchangeDkimSigner.pdb new file mode 100644 index 0000000000000000000000000000000000000000..4d99757841daefd074b8ff7cadffa861363d97b8 GIT binary patch literal 52736 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 literal 0 HcmV?d00001 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/MimeKit.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 CU5/MimeKit.dll new file mode 100644 index 0000000000000000000000000000000000000000..8a58db8f417200e02657d58a50307cea7cfa6612 GIT binary patch literal 800768 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%0DXHCd!LSdnAqhy_5`tKbu4xgup~Z#@Cw9+ zb!?2-kveuRu@CFm4a9EMu^$twN$(59Uen#BPo9ir>R>%}uzq4SyxN)AB76dAJC@i< zI`(m5HT~8##BR{t-A(L19eaUT&6$K>5vv^w5PMtqJG%sI0G|MT`x1Mfj-5(uqmJE3 z>~c7KUB@0E_CGq7I0IPCI#QZg4Skt9*z7vkAhG%Q z1k!ONv2{9j90@%HeJ`Awy@_XyaUW;4fvW?HaX5H` znaRuZH1Vkkt35wcou4Q7G5g)j+6sGuqMV5UPp0yn^qfRpd=-(-NdKO3T@lG!U_d84B376lVXu>N& zC0sX-J8$5l?k|b(1&Z$c@4i<}5x5YNt3}?`mm_f8x(vzRr#LwTQo0DA0Ci^C;f+na zm0PChKcNnXp?NoY8EF0@X!dVrWLo4(Mm*CYYQl25a2Q-3DYWH+Mnm~|6bLy|Z>OSi zOGDll;zPW=D^fZNr1X8e=ACJWw@|CMio~V5R8%^e?s1_eK{oP2jcDF9H$sMYxWC_Y z2H+J!QcR}>!HcwGg+U%2tu9&T{07PdohwiNId2?JS9gz`!C>s6+-!O0Ae3?z0LOiZ zL&0W|8yRR4!R(jj7}_S`|6U zV#uhbeP=kUaK4iEbe**GS~bqxGbBlS!0eYGq`lEkyJ#j~e3B}HvK2OPZ@_>o-lV)I z5l>NWZFv4Y08!m=2g-W{Lqwz|!wGli5H1iM%wo^0Ik`E$5geMT`JlXnL<*OXaAgwr zM%61DL*Gq?@y??T4mA6Ls4#z?4BL=50Xb_sKn}sEsot+h*MuI0lPDvA#HJQ2METtp zu+^d$#H!+3vKMY=A|O1g8c2+K%tPvyW#C?(@nxhxa1kDyu>~L7fCGSO6f+Z{Y~n@=h6qknABib z#r6Po zC^{tTmc)4#*r6ZX2vf=MoT_$U!TZ6T?F3fbo1AO2imZ<+P`tUvf+D=5L=|$%$Ao*3 zC=$dZ88QDdl*h&GUxv~=S6P^}bBpkvpY-N)J&odGZ_uRJ7}X#}03KF^kY&ZkS$H=Q zVzm?>+w0yb^B)sbD}N4h(>hQK3KJ90!bszzY#89ddS} z3B#I2v;1MrEHmXCM0A$fp)`}bs4VT(T`+LTxP@(D={|tDW#fw@91;X1L;nG7AI7bl zX`R9~+)lJ@<-c0pEvpX*1;3^eMd>gP6u9gnz5FwTs~*Jr;LMxUtD0 z=jr{ZjSxd0g%}$l*vIq08+^kqFf>MUJ48!pwdIM7N&b@I)5TRR*Afer9)h!+9dizZ zio30lvzi*Xcq%zI1|C&8Mw2%X_! zCNGp+sULanYsZfCk{X<8N-#a~_Iw<2-<-XGLJ|a?7+6mGxCcVI9OgsZm4WNjEQ|;)qFV2&SlJ8j-wH^8}vx7$eUFvmcV0Gblq3$wDb|6 zy?v7l;Vimd0Gi3Nc9F^?WzsbM4nEwDya-Kopp8RN0T+!``w=SrgHSqD`Y<@I3gb*r zB!v+YhB3=1LK=!;+EU0c9isdBn*mw5j;JsuRQd?~ijVmhkmr4PeijV#1g(!NlX&dk zJz7dtt)?oIaxnf;gwp8lWI6#CyC{?90%I8lk1M;m&fHOUl93sEXYv!3IH2WAM==7b2y(l zcTTgXebPAv;llO3x@&LZ&7g*USkpCxof7;Yuh)?z(sL!tth80=72>4lV#}w8o~zV_ z<)ym%)M2pfQ|D>ll{yvF&<`nyB+zk%oD)c0L=hQQM0$Mt%p^MT8jZ)d|M%&94RqEc z7E?ONUQ$zU(JV7JHUp41E_S2MQ3{~&4ouH!XF8jh8SvUf2d^rX4npz-hKZE>Keo#g zbmj)dl~hA$VF6y1$Pt3@|7L372A^CQMS%Y4##ni`ggZzD#udwl0vXljV2^X<`& ze0!*bDJUc*ggX;%yd&XSP|c1+Q+Vnsm8I#?h5s zp5%N}BF(`Wv?Qdz6=Iz+AL6_S5_97&tVG_l3U}!1h<(Q<$dl|vKU9en?=sg$>yJs; z7vCXi!K`>*$i7?=F%7yW8=_wHoqf?j>}DW#2;su~*bYZVhwiJ?;Q@pR0RWW4op5(B z?Jb#e(Hq-aDxpy?sWH=W@gExcsr1XHaU%R?eZRY!wpVW;f?8>vQ^AGYj#gSpfpoh( zJZoUsh&O|M-0V;xd%`yEq}-BpKI$fA^4FKW6>~u62~_F65c1SE8c~GqM7&Lu(-2vS zp-fYBU>``-hrx2j5vfS}nT0ujVdo}DfgnD92?9{8Zi)~X9ZB_Rma77IREd(0L)rq} zrc3{YZlodF6diP}^x*91iPnjSI-7y5>q(>slNM~o>_b(8FqZp)jOf1CWa0JZ=m6fy zj*19wFEqfZbm?M-h`>{G8bjs8nO;|&TLs&wa~cyt0hEQAO)+5uJ$cJ&QeLXWCawPI zlN<#S0~w^>_$JP7PsBn~cKOz>jM9)C#9nE)}oEoQsSq zegYa$)1PUIg~~I?3gmbk5qaWXWYD$BZS_-Gv8bfdlg%AB?nBXnEE~wTW3|I;Mb61! zrQdRedNCI}9e^7-hfSEO+NN_nAgOiJN5|ql&d*^?lrCWgS<|KP%A#i@UPbC$-8m`- zKEBDIOP9h~TV(uBa7-Rrg0Qb}W>`I2ABn6?kB)?F3h0dB_2*D)7|%dEXTV<@mRBm# zCKLV0i7Dw($Z}Rs+>b&EX|(@zyvr29BiSc0oMgkO*Az_y;njt*a3`X8jZTPk@q@nZORm%vWY<$COuTl*i7e5JsA&udcc+d7J#1aZa z3*qI+Ff1Q%2*78t&>ZdrQU7eo`Ws-Jl}8!Q99EDw$T>V=o0x8kq#>g9l%%biwy9jF zsj)mL6keGgb1p+^$#uojlViK41JdO}2r8CJ+SfEuiKuo5(vGa&PJ9h;XEcGrgwXMc zH-*vgSk74>E(c;GV+o`I$_Q-H3L$OYnq-#CL=mic+G*$g=xrb`sRc=f#HW@!z$NgZ zZBEqa0e`;vFV~&8rRs^LDoU!crqoAP1`0Ty1YQn~j%MPcUbUey6PE`&{+(i7-T}>o z7XdZ~;=L%mf%rN`M@PI0+8VNKv~ky>IY3{5EZD%>7iM7(kB-Cw;$op|Nie8$O z_#{rI!L>?bfkwi6Y5Bc32RfH30SU9J?L@U{@YdoX(@Nqm4+z)U?nzfF4YRC8V`gPw z_=|mxR`!Sh&n6nR9h5LPZrOzw6#qgZHoey03Ge1_y^0~{#blm? zQAoUW5aNefEP{P8KU=jMC!Uka$cGVR|AWA=y{vHOjv9aaa#M z*^cEp^qeR~7sI8tvL-YN%^!!A7q5eO@17K|M3krYC~IIRv~b z3Rk7Mph^}C3%ziTMmYRqj0F@{Zwl>YoD^~99@b8l(Drqdn++j6>v=8cq!9Xe=^W_% zjHdfg>67rFVhWW$MZI$!Q-wYyWMGZRz}6K?qfl}stmAG6>i<=A7!3DZ_yPWD;QcQ^ z2CcCzg$0MoQ=sDgYI+h{OV?1VB2uzx8;qVoX+jJsmBGZ(FQ)DA!8Kqpg-h4cC}nh| zaAY!1l(*~PjwMCs0;vshq4ZfegP267+*>l9Ou_XMrNnu*ALn)oHA_%109LH9)Do#( zTK-g$^f`pDh*D0&k~Mt!yC(Y--&p3EKT@u?Lx-QQtfX;E3rVp+G3oP_n6Z-w76jQr zG0Vyo1M$is3f8;ETU&#w0mQ8^=F2J?l}xYQa8%Mg0&YNDR^i|v7A}1Opo@9>yK}Q@ zs~8vzLnUl7BkC~OFK9QCH;UuS6(>rp2Af&B`zU)5t1*-7NYbk#()*Rp4pfd;Ybys> zD&rLs;vBpCR2`Uxx&8Zq|2OKM+D8sVop5JDKq_lsgH_&wdaeed5CjdHyiq9}NL74V ziG!|I#mZK#7iX)HU#j9{d8+nvSnsdX&k=q1ey-{-*w0P!heH9<%Amia9s4_~!Tyf) za9kn%&q};n6AH<6V`X?CVTM+E^Y&kdR$ALk@{oD)4-7!CCX!4wwt8avnj%wIsUZjk zDzjJIU^mOcOyF@EKQ>E8$f(<>!e`P_fUHwh>#NH_kw@wbLCN%$ku z4=JCGlAcBR9m6aCdD{Qo2*WGmp|*&`G^^0AlDr)G*Bf4GjV07>cG5L_(067H3wVXUDTBE_E*C5)>}OPOR#C4!;( zq5MvTl79ts2JN>S8-rtv5+XxVbPN}6#$;>*YBB|9Ua~HcisN;ND1>5S?*MT>*Ay8y z6BHaf5rqut9-Ppj5}SxqNk%3TqFNITqJ}3Lp%j0(#46g4kpSVu@8>&}LdT(!)xzD#Tf(tWiwE z`W0pE-ivs+w!}$XB6L9iNThX&g~LCeLzd;{n9*|KEG&b(3e&2Pc|hqVaA4KepcVcwoVv=g#~N|+;C8G|c*_>yh|O~bcW{L#bN~dH#+t0s%^rtkPK-J%c+yJ2 z>Wj+C!gN&D(EPb$m(ej~bYQP@$~4R!e-JW^?;uTT?ENM9iI0C7-$cFUC9)97_sUcu zs!EUhGmdkc!mVNFdZb!LBw90&44=)+6S>#9U2&jiBl8r;Wxj%Fa&bI_Qo02?H!tyG zf~*`wOSb}r1bMNoxQhA+%i3I3yz?{B*i9?X1LwmltF2vlWwp6ev=&{=r&03GWA=>S zLQdMH+Yn7#L>^&ljX1Z{WMS1TX>DYYqy+elETVW0+SQO{uo#A~wv8DBc0S1F#o*#i-(_7*$LaBdbNOoNP{y zMoV9Z?}4eX!XZoviI!L_!8%l1OET6mv;*F}LHVCm=%NNs$OXS=i9>+=a^oM$r$+m<$!r%t{;CfBvTn?zUwI-XAtFeOAn@!>r)wE<&(6Q!%gty_fW|fj9zrmW3@>;wKr3)OC#CEqPD)gm=ytXEA*o$Pm zDRO|%>kC2pf>+_Sy{(P(Wp4ThT5p;~h4Pfg;;d7>{_ovM2Wz3zKF0&--2@$f$4nN2T04^u;8Xs7Y0ajR8%wo zrul$q0AzeXGyt+bAQ}KOeLyq-X8C|<0PNrcqIuOEzX#DzOb6<%Kct*n$%~Y8yHdVJ zMb?|0yA<+uC~E$=8T|Y%O6xcnjPn$xa|_fG{X@_GyTm}C|0?wi3Hm#zXBg1mNxcNS zktCG<8^oyb@3*0AumnZNaxY9!z5}K7UFxSe--FWcjeoI#;^n>Ny}h%akw3dS?!5tY zeh+kVUVUFBd%{zl`w$3bYdkjL@BCt%8gH3`!SUlWP>7uC&;yq4XIyiw$8$O|%X%Cm z>Y$sJ@{bX`3U38`ZU~<iIWi@gcz5Xgu;y5odw)E`b028N z&ek$)J^cVyB7Yh(r}MrU>vx=$_i%WGx-@y05`BGIZJe2#@%|q~?8k}3+72D*PB%Fri;e;ZsVy)rQ!?4Yz zv1xTN7i4=<*7c=F0G*ZvgZiTKR-QVWVWCdi&YgHVgM*^%@_W9&_s+f0q)yt$9KIHb zhJNLmi!%Aup6xJ)aK*=z&Bu?O{n*ZF*j#nSz7OP=LqjCLPw`e||8iUYnS2xAP3B8~ z%I{wM6kxmDh{NX+d;i+vhXi@P(MLwy57^~hn|k_+2s`#<05yZUFMU2 zDzv;iY?lwI*k;_EHU2!sn_J^Qp@Pbd0^Xmp#;1V6zR|YE-=b|)j-g6Oxsz;l+6yC+ zc>gZ89BWc>%(3Ncg);Qn(IX z!F~4Wzx-twJEhcLc>3XQ<@bf=%oEQ0dw!t!8eqG8y3dLQU!gzjhyc8@0t%g&VgvkU z1-ytZZxZmQKG=U|@e_jlxq_Tjl=C6w_OpEkAL^cNmj^4xgWTin^4=BW?(QMTnu>9u zyQf_~t77bT=i6n%g6dK+Ca75Jr{gHi;Xkl4yc-wV!vcZ>}M95BA0ai5z z-}%G4G$7G5W*PYdRGMXNyLuc7)lJSPJxs#5-i4#X#t$aZ#OlZb>#g<&$|Qrri&pS1 zhcIU|Km%#PT7j&+VYg?-IlChBy(eUz zymTHC)w5UVxF^;gq_%ow_jBlHsx4vD%{9A7ZY8`<6|a`>=LqFPj`j?_4EyQ9pnX@h zAwSy(mtFN-df|CzYn~71T)51rI4=*c&9&5zo~3f=r=&M*pg$IRvji_@+BPw@sdy1* zz6>jK?!t$WA}f;}NNRy)S`c|AJE%v|MR4X&#L6rjY_>9ssXJ#7pKL*AMRpTHr{g(v zGJkNYl{u2S4TEtjv+GdG%B-GK6XCKt&W}^hJFU#}IW-X&Sw^7IoIc_pw}>PaS|`DJ zGCFEJN@8&yz!EMkc@?u!2_X~n@+`|)yXPsBt$?ViM;uhX5RGJ()isrJ9!F^`UkaeZ zH{2z*QNzfzc-9Z#re>CJhWbvPfs;%&l~%rK-QhgOfL@{BO~@Z*w9he4=~CK$XfsQ_ z0QzmV?*xaj}UArGv57NG~gKDjL zkgXcZsa`0T*E(yN9Sr5OwbpAj>#x^Z|L!69&cuBpe(c5aM^QV<&F7N#&ax|NS9y`B z)5amDHvkxZ-0kNqrhmM(u-)QGBfK+gi`txwYPM_rqJIbbYvLjWRzCV}MrFaxCs+Z1x2DxZZSpYor(J z<>=c`Y&jIbUm{^dFe1QtA9Wre3-=-C1r*`_P}rRk;xW)BGh$z5m7YWukQ1L+cOUvK z0^ywcScJiP#e3d?F+u4mI7ZutMG0e0tCeL6^V5|%--W??wjadjQ&x76>QuL*O#1tz zRP_b*X6Z)=N~X{tThi4IRgF1iEWpm3Ni)5qRnpefWJC^;v_*{P;0Kw5`#a0Qi|GTn zr(&uTUp=Wz|1~}7%-U;8KNh0f3$}6*MF(Wzva&hnSwVOr@O(49MF zM#4){fpmHYbNllNU%R%zGn*d*LzAKYG)=cyA#&FQH`c9?)T==;3NO^E>_>igN7? zhOM)jI$F|~fb%@}@d&8Js7LBSbp$8=t1@x|4Y zqUk&hv@xdYjyR2}!v75L{$v2LN~qrPt@C=@<6DQY1kL*07_cvG&qstl3`K@=)SwJr zi1BC+^Tmr0+;dp>b3h>8mMEO8+6coq&B$G+^rn$AzW5zAMrYfx3@*Wgn)GuB{RH^# zkHcSKhVT{+)^c#pX8fm6;-T@MK}jH9cE+gW+{+(Ec>lxj9Qq-DlI52W63)|sxbbJ{ z-%EI6Ygtw4E2FpT4&vTql)N?}kK9hj;# z*q~_?zioCj2h4(H66*!nt-u)6K zy^j~cEVbJ9UtYPfLeBP|@8@|qHDrZDm#o7Hwqb$`!Osnm)KD}6Fgyl$RR!j{DcX@= zg9xnep>}}tir`evsFA3pUiA$8CA;w#0F4 zRwnIMf1}C0#HNTu)@ON!-@*|xo9`&16*FSZ{(KzzRwHzT*Ovs-UG4M!uhY%g{d6Df zZ5@Orumc#z#h4XPc)^Co@!!K`kGYYUvcN8cIC!1iaFzKuL1=|cVgA|*mysjUFu)L* ze^LcTx+&*lB~qSc{lFQ4HxUhPhs1HaWWYRU4-z8LgzPOxX8!?)Yd@}l?xR@?jI~D! zHPU%lL;vH^^gYe%yLt3H>|&~9s-&Hqm09LrSaTl#dgTRZQo}8t1F2FPh-d&D?b}e297OU(g zvV!xX6c*W(YfgTqV3Ez4f_2A!+jLB>Kc;zZc0S5A_P+jxxNsfp9V#K`Ehy-}ZDT(S zD=?lm?+MLR`KMx+F8^HAj`FWW?JWO6)UNXX ziaM=43}{H(9ecGdkUt>p1T2>8>;4cHRdHW z--OLd&;5!T^ZqpNUbR1@#=Ms17vHJ)e?QEbW4yplpe5Fo49{GmIfwS&Gmq1JS=Iaj zn*UTaZ=`t?b576wxisHXHD5q;7K38X{=+nXuxkDKdn?TWPJWH%0O#(a`Rpnu@20t< zYQC4|JKnC)b05tIRL$RqS(T1Whoj7>3XcJRxoItoYLw3V%C93oY|Qkh+F0pnw$gSc zJNm>mR?2?j8W)Bmhwz5%hB=J@GTAX$q+wBh7=hbQIOwRzBJ$J!2f8lmLcOP+}G^4_cB{uR> zqRuSvNnd)zfeLXwL|P#q?AJkQ+r!2>@b7W7E#cINS=xpc2hyZUZ$s@I!1BCAWhBzhcJcqR#vqJAIY9wsqJd=}XA-Ju_y@fG`)QbV z4jZ{@8f?x&Dyg6yQt>QO!FX5y+iA!gGmyqHA*5sZkexjd&AJ=OJ`M$!ELLW55XnpCvyd_Sdzr;6wAhQ*i^*AGL!1xB?WOBEJV4S zMh!0INh!n0$W{zty-0EQE*X|+S4uN96hlUw88Hl1&W(K6T*@PLOA9zB|LQ;f|G|#$t*St#4sEvHBL_)<~=6#H*Gb zDIq7Ju*O*Cm^E!Nd=G7lw1 z;Lo)lF*;s0tYcwIUc80=4mas=vRgd>-a5rou`RSe*wq?RD&&2o+9HrVgyV7G8|FF) zxR`)%TzTBdOg0Fms>SN^jiJ`K;$bx17A;~vX<(J+PiUzy@JiZ8zRq2^Xon#pA2 zsN_nr0TrSl*`Vsml3!v-=XuDrdQs;vJyS8nyjq9)6zh+rdaxDV7HJE6+{yJqgQ-NE zCB3DhKeR20@}5j$H-+WhjkP9H>z!XfYv4esctAw-hiItOsSS<2e#~vHQYl(xFB3N% zOvpWefOEC}z&`j#C}i86s8wgl+C*&?hS+NI%mZ$XC&@i`-_nD{gcyc zrVw~FSfnCU36^?4STqo9YEqoxIaB>K?2R-$?WLj9@K+jSZ`_paT*xw_xW@{Y5;nw} z_*|mCZult`zHJPnDn5hoDFY#er5(S0iWYB>YNBofV;i!84f??>PV)z?@t2Vw8!E^g z9EJ^f*0>;z61VeIeD};R!*}2Ojzsc(?g3Cw$`|n+&o9LHtis}0CcYYnYa89UkmM)Y zwy^6YBc49uPPddc?qa|z4iauOs&xKg+^Aa29q7bCdKth`#Gyy*hNYYw*wM_wLvedJ zvv5s=Wm6x=cTGY%RwhH1b#2wbhR{&*wm$j>e%7dpf^*|Z2+ND6$6rC(+Y+cmmh&pK z95dOJ9ccUnd@L`=KsOWfjKWtjvz<4`1i7q^Uc{1P+6=tru+w)IA+=Z)$xU#nf%Fx{tz{ z_AMtLfi?=wCiW4!hko)>?8_{^8Zs&|UTiR1O*`eN zJ493aqV^C4gW)Lp!a`iGVkm%)a9v;=$8{(HSoiPc(cM`P+Y!bUP|0A_W^RMzK z6W|ffr5eu%cr=bfpIABTInYJfwQoDOyTbq_>68$XQ440m_P^q$E#Z$TGbw57o&N>7*ZA%`{k^f_d{fYC?)z3MDr?w{F?BQ- z49(7bvhfrg%?)SY=e*rC%yAg>m%Pz5FpR=PJssp17TJoxbp4q>`4o=khO^K7`H7F_ zkMxkdTl}1|f9J#tpU>w2f9vG^-pCIXHv^89qrKh^RsUh`M6BFeF&^li94k++825D7 z#>#ya<6`%KSh-j+&UJTT8rfV_t7rjq`|+LDQl?GZtUt@t(Jx0m;$9=5ZXQJKT?ZSF8qvjWGPyoNjBF0gae zbl8}`B;46{uF>)(Ou&6Q3b+ByyBDGFS5AGZbS^msow}F2{P<3&2Aht=6d8-qSQ(3( zSQ(3$SQqOvWgLk4m+aez`Xk|fj2%O{5LB!Z$Y4Q9ykd)h!(mxZD4WxVFg+1yqNlwa zXH%Yro{{<+5;;&WBGKFt89^R;_W%<1Q*jH@0Gzjxy`%AL1pD|6(MHJLa0jB(j*5<= z!DJLiHlXPl-3#OPTqZW{s8|I@%iQr)$7<=-Xx;zAXe@i|e~qqzh?n)=!g^-u#eYN3 zJaIIVZaPD346p}q3>ks8#WZGm={7gg1$IFOr}Tv~OGY!_SsORcCT2M(qps?k!p0R9 z_s7C6H8cn@4iff8nlD$|AWs&$bkxA^$l5Hwg*n*Gpwo^~2SpBd=*73fcsy)^mR8n4 zTNOG23z^e`AzjL}^z0?JqfZ=!pqP^M=!7I_vDq%Z&6G0xXE?B=gt4pJ;gM=psN@`h zajMt{U+~tpK7cg-+{>^3t&FFU*hXylFs4zpfft$L&p{xhzR_KzD2-j-jqM)-(tR4GFHqA-6-uld6Yw}*4;e^1O1*Ajyp(Jc(^_0yn|xtWmbAj7>koH zUPdXi&;K#uH;+Jr_K?W$uF#HKmMYu|?Ue7~V?L{toFJd*N80>2>?;^5=f1ah@usqU<-XTG$)C#8Wnjg`H7t#oaMXq7>a8qEQe7@?CL%$#&Wki zL^+d#K7%l<@!Tjp`ra9&_+uIvx2k)z+fPr!zn+?!l=Lk~jd!X+=}sJmV$XhcK-&2cq&>^BggeZs5%i*v1CW_B zmWZs(KJv&T4XiJowqV&a#E8Y=_-Y%s?kmy*T9mJ$sHpP?zokS7ubyX?K|VyCaZZ@R0uR;VJqpyDe8 znF%VjPX1p1t^?O@Fjrw(Q$F!K`oyb#yV>qXWMJ{ELfCEeT_LogXR1NY$_p8Xp=+#9 zhDu(geR)?NKQ)=h@9O@i0r%H?q>?`ohvEV-n1-APhKYR@Fl_}fZsd@+9UgCy2gnm^ zOTq6?&^-*jp2E2c%lIwayaFDnky2=7qRGPS#1FJz-Kf43DQ}9{Dhp1-G|H}KL1<;; zlGt4YVLR02esaIivR(ohKVzyt6@G z-2*<%03XVyd>EbPu}C8eEu@W(jzmSMD7mW&Xc8-4E4Qc-UA15nxio($8VuXS@m? zVg4GP!7UI>XFJB?p@dAfR%8|xx;@)!h;_U{!zSSo+ZQ>-f}!(pZqnc|3A5CSSF_Jf20rhJ4^$WesNE zud(e3k2XZ{yvX?9Fpl6z@Y53kPM-e{VQFEF2(nvf^xYe zKX*ISPDct3AlDvtxgEy@Fi}#3ejoL+Du$O{V%SPMh)I~0jP&CMJ)i2pJ^F3P6lg5b zKy+jAI`BucwN*|eV=5DH$uG&N-NamsT`E4&a=Gg?Z%ozpSlkKb5DD*cohGW zsG_mm@57#of37c#iPJwRYdDbfZL zzm<9s=UwATJ9X(J>@u#rnlWRFbFCyzw@8=Ik?L@vTCiKJeP zyHPJga2fI`j0s1;hz4G@k2gk3CKR+x2Y}cRwUkOjCg&DYh7ENkG#wD~?;F#l2+VHA zH@De6Xe2HAg|KMSUb108c$o3T`)`COrwBwjMU*HftRBQlQ96#fc}Pi)Q5(m$f1G~8 zgIyJ^h-Bs%5D1P9#7E#75AVhMe+WS)v2Cd{!3Pzl39(X7MVv#BESy=uIbYLQZmjtn zmnEtHmNEQiS-iveBx0Nk?APGi%)V2Ee0>I*GgWq zeC`%9jNhPq;yxA@&868@3%9tI!+q=O8Z$;B&!bZhp=znN)o*3C$Z&lAhg1{G)*Y?# zZaC?Kw+Hh(Tc!7-UN(p^hWWV|8!ejEP+Dx_g=ng$u>tFLvXkP!rlq%bqeEY`7aRl{ zAjBH-o!MF~+#SXWjp;;jF0H*rAMF+NrHqVJA)8B@%u%!+Jd8Lx!+Vl%aAgc{E#VX+ zHbkt_)ogL2u`wNHXT7lCz!4r4g+o8y&jKo$rT=r&7V1 zxX+q6dMq4%@N7LwMu(oOq*w~7yU6#R5bp`!djj4Q5O!4)UyXMbDY*foI>8hMv*-a? zbRi7u3s5rgy#D;694b_uq#PJg`;J3idmpafBT6%DJ;i4k9lzp+oui~WqQ8jBCMniG zaHtQnDc(~_g_Xc|8T}+81b9saW2N{A?k91bU;uGu;RkD43Ab6^+ZdFmJY{x?+1}7^ ztP{gQ3HRo-zAh{ps#`|6`*E?T$us0(kXbguWM6=DKF05a9`XW$1=W2S-j%_lfQ_hv zA)N8VOy(G*p>bh<=VL*UaE5^5SoR>Kj z4`O2W^8*+p&28Z*y`dsM1gOn2rH(223&}{JX5n~=i}P%lL-|>c^i$q`(i-}u8K_65 zzbyS{hh@ucQ(90ek$% zA=;y9jn9>LA)={d^coA_NzXzA*+RN8f0+=~V^h*neDVpQStYka*lOaqjB_%WH~+&( zE#_P*cle?N>ZHd`wAqUJ>aiMCB`_!OScVrTDsf8KFpG*RjZpmZzzH35M>3{TIAT?- zQc{w(8r&@TkStbs1xw_1vS3y2dwzLJ^W9UtH!MQNZYYp{U|mCt*8*p8Ya@$Y#QTyf zqu33R(Ckr5)X|2BlqO5Qqm2LB zTFLr?FkYJItW-bGrhhke0=kLkwxVt}jEOKQme6wYpvbh!%Q|q8jD|}|*bhXKcIVI& zc=ZQsjVh8f-GCiy9GcMO=}K4~Y~tZ+)mrG!%qa+oDNAUy~C592`@ri7C|NzHs4sHaax z1zP$ia1MHA4s1L{We-*fBwwsiIA9s#2>@FX27v8=q%Q%CwI3LjQ9REgSq8JTepsgS za%LAh*KVf^vxE)Fa8&q!j;vQ05dhjz5u(Bi*rNT2p$TQi`+OPLmD5;7ZB$wc3{l1C z6@C&T3G);0ttYp|qm?w%5lcI(1}}MI zO(m9wkc}N}8TcY8mOT5@>vr2Br7VCn*rBQ^X``k=ZX1R>3%Is~1sdE70)i#M_;a?5 z#neC#Hz^>x3U@>xS~)I*?kBHKdby|E4gG?$&U`tt4!E%=vg8!}Wbp;&CnqnoR7ELJ z{#JF_1(}_8%3vO35n)({)e&c$rhghlbvBP6QZ+%G&LFD$$RG*(ARIgQh7f?sGl$RfOxJG(un&u2S(1ocF}!tim!5``uZ1fs}`R zF+gdPd4THq2I69?&MSJ5<2#*Ic*va=bll|GC`w;}?C}P?8a9}Ytc-dOEDd6h(fI(< z+#5-cn0Px%l~lY56dfJ0v6m!=g}jKkFG!lagOPaCg+2a2n`I9+<6N1y9>90WMm)PE zJD|F%G)IhskWe)7NmHa+Ntu~Ap37P(xy?SYj(X>O%o5IdKeQ=xBW+V+zbo!Ushsyb|MfaA}Kji@iw*4$mLw1rxCEKI#a~ z$!?RKWLj$6Wa_x-2)Jp&N<2v%!CWkc(_hr5Q9uQ>GQLx_ZyzxrVZ`_|(yZ?Cn;X}| zc|VpBaShKr8vi(8z^o)iU!m>UtT*%@%(SqYoDHrY>?a_ek>$Lv0BL*;eI#zt!CkI3-e zChn;!!p)7RA(%0FR7|}hJ%S_=!|Q^h6QaSzRit+#)1o|$QCc7bCEH`s(MB^SA6d1A{}@nPzW=f3xqsCZ1Yh#A>AW# zwW>&^r1+mPxSuOt6VH{Xl_ndIf{gzjL?e%#LSJw3Oz=3)$xaLrTU~BDWw9{~u0>gbi{YdadyqzNT+yCigpQHRZZcDv?-Q~vIa;qA zKRA~Y)HhIvd8W`K-$I)uiBkbNX+)UA3{Ay_b!wqQQKKZ|T0)E>34K@D6zS4R8uFhY zr`Rmp7vU&A9`EtTD_nR%Ex_92TWA~O#b1K1sfno&SX<=&DHg{8;~r$#`7t$=6Fy~* zVa%c6?{*Bp@~(&EPbz*C9$*T=K7Twk+vY=a3N%@aaq|n^6Rpxi3Q8q0%v;84i_>6U|W689{N#K^E{M2%*89>1#S-%BDpDjV^W@=%mpqeG|%p zVT>g(Yg4ZJ8?i$@{w>_|DSZqdyaYfejc_8exGqD>_`d;OoC&jH0P7NovC znwghhrwqfm*=!W|f!k;{2Fu|OAu-Wx8?~!o70vDp?NV0@>}QBL)17ax1}{ivDO+cp zn`aVAWu(3MM+8yhs-8a-!iv9j^mlhXf8ZbUlgUx>69H9V3MF115zl|D}gvI;BwDs`abV)UOwh27eL zGXtL0KJZqqg$dJT^QDvmLb!_rD=#0D*^b*dqg_L;NriSDy#<@<=H%o&Qx(8 zrqVU&rz;5oSi<-pz+OemwG_nbo-!%Y*)>R}HZz5lg?Z&^l^D^xsu=gE#2A|#qe`h) zd?(OC_o@BnJ*TACPLU~(Y0R54_XMTq`s?c$aQ+SDHXR=y1N#%IE~5&YrPq)V9ZMgF z1GDryW(sJ?wrvU-b9REJWz!U6cmS5rw*nl-gAmly!7#)l8pZ!omdQ<)F=qyBnxPra zR>9$B=!;n0r#JI53!4hiM5t*k;!KwTn*NHy(^$j>JtMY&TaU$EppB}Ah1>GduwZzg z8kQN*WSdZTo_=SzYoCtG5ok`GwflXgT8nZ46 j(OpCnM)2JM2)wRRf;D7P#}X(x=5oda`m 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 + + + 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 c1299ef0b148bf3f4a0c2dd80e8d8eb450e59dc2..24a78bad1c721422271f8c1f931edd35e9f38e46 100644 GIT binary patch delta 3928 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 jikC$x6HdUSP9#2^|Dm7 z`$kf)29T43wp9}S=`tdgw&^M>%D2zvR09pqOMRGjylSRPv7(81SOPvdy=@H2Z z5E(%hE5Um_^qr2$q-`jeo)q`llS|>3i_D1urBj}yG?Hb2*A>rqB_|@vPMEH)ID%L? z;5jEIoFl!wDSTHpHd~zCIf+rnf#RI>Vtsiq4;1HieqXtHt^>vSodYtCRmc({Tz}c6 z`$7w_doAguX{75(^wtxfmi9(RBQ>5u6e-i zF08}5YOP=Bh2DCVEuG|i>#SZB#z)z+NhI+h){~8hLyjtrjs+dDCab_1@ifCLcbm>w zi&gKO!mhA3IZIi>I_PX>iJ=djKVhui+Tng3T;XY8lZPJl2*xH`k7ev;wN|zF5q6_> z)|(6GQ*SemMXUwB9HT|nG&_gg)WLDn*8AEWJJ6sEYs8z0%#VB%z_*NiKQlFy{(}EYlR-cTY@{(W_2xy=$!woJ~e8+Df zZVcv%Y?|o`3zP2mjs-Q(c(6u`30=RQ!eVL9L@EdC!Ec?tA_3>Glt6_U{CnVstQxFj z;gl@O%E1Fn4!@+hhRsG?$m_vfYys%vl77Ss(Ho*2x$VYcIO~+^rGL^@g401;-D|c9 zjl5Br*-JOOR|*GhD3nUh(@CepO1(&_B6E$<>6nte)aKX8Nq6JuK`M1CwFGC7EHg}< z!bvNYN|$ld&a|Sn{*A&-GjR~fd2jkt!b3f_$`-qzs&Lj2oum?{PF`wLYJdh)&OO3Q ztG|`by~0P^ZPoADBmA^`RP7Z3+Hb2LU|x_0N7Y^tqGxP%g|SCu(aBM@7q{$nrTWPo zdO+lo17}{k7b%^>Yoo)ZOBfK!;LpJuvGiZOJLQUi2L@RS%!aU9G<19UCa zxJ$Mcq4R2NhpW|mO+@HjTdg+#40XX)8NRnfl)kW4wr@nFqQr5~rH7kQ@ zB`I2N%R-M+i&49+rg{QUYi;$sKVK`QTW$5KzX@j@rChdLcV4Zsp9Y@WyzfX-mL}y5z2Bj(ftKbnT<=fDb1V1631iu#hFzs=3BaNt} z5qi}bKzzaXEJhC_XN3Od3s57LEJ6Gfy#T(fcr1`bN7bxFe4+Ld>a-iL(RG{~I`dMM zSEto#qnWhS$ihGJ)NZqcF&+%X**gASAddK}KtgdED`oA*<=~y}224Im3os!s*hU-q z&FE8+S|+XvO(j|96kD&YWktyBW>ZyW5&g^Ghs@UC7Iq!aF?X^AYRVp;bsb~X?DLfK z*LeFT<3%=1U&2bT&k)aHN9Yx>)$=B(1>R@lAy$eeio#{IKG1O1+)e{YtWj)J>`~mWctY`f z+IPzQ{fZ|P&nuEEr3$$u>uC`^N>9^UbQimqW$|hJTE2nb#Se2go^gF7$iPn$KW+sc ze!VpsQG-?wt~Fc0Zr>tssjC%y&3z5{sizH`lOcJfXC-*ne+#(AvjN;Te`#UHT#NzQ)*5iZy1 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 Preview/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 Preview/ExchangeDkimSigner.pdb index 9b98a4852976763710e82daf1d346e4cc0cc0ba0..1cb9fd0ae78606fd527c052adb752d8f135c1b54 100644 GIT binary patch delta 9257 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 diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 RTM/ExchangeDkimSigner.dll b/Src/Exchange.DkimSigner/bin/Exchange 2019 RTM/ExchangeDkimSigner.dll index 96c61fb4963c020eafce71bc565d9f620c2700cd..158c0db90715bfdff583deb653805ee3e8509bb6 100644 GIT binary patch delta 3928 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 delta 3816 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 UpS9o>#viH}3M~4N^-i+?8y@`GWB>pF diff --git a/Src/Exchange.DkimSigner/bin/Exchange 2019 RTM/ExchangeDkimSigner.pdb b/Src/Exchange.DkimSigner/bin/Exchange 2019 RTM/ExchangeDkimSigner.pdb index 2a3e558997566b8bd230cc7196fb4bbc40fbed8b..7efb1fa7e8523ed490ee4dffda668e1f0ba8ce9f 100644 GIT binary patch delta 9257 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 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + diff --git a/install.ps1 b/install.ps1 index d98d566f..1c66befa 100644 --- a/install.ps1 +++ b/install.ps1 @@ -46,13 +46,15 @@ write-host "*** Exchange DkimSigner Install Script ***" -f "blue" # Exchange 2016 CU12 (15.1.1713.5) # Exchange 2016 CU13 (15.1.1779.2) # Exchange 2016 CU14 (15.1.1847.3) -# Exchange 2016 CU14 (15.1.1913.5) +# Exchange 2016 CU15 (15.1.1913.5) +# Exchange 2016 CU16 (15.1.1979.3) # Exchange 2019 Preview (15.2.196.0) # Exchange 2019 RTM (15.2.221.12) # Exchange 2019 CU1 (15.2.330.5) # Exchange 2019 CU2 (15.2.397.3) # Exchange 2019 CU3 (15.2.464.5) # Exchange 2019 CU4 (15.2.529.5) +# Exchange 2019 CU5 (15.2.595.3) write-host "Detecting Exchange version ... " -f "cyan" $hostname = hostname @@ -154,6 +156,8 @@ if (($exchserver.admindisplayversion).major -eq 8 -and ($exchserver.admindisplay $EXVER="Exchange 2016 CU14" } elseif (($exchserver.admindisplayversion).major -eq 15 -and ($exchserver.admindisplayversion).minor -eq 1 -and ($exchserver.admindisplayversion).build -eq 1913) { $EXVER="Exchange 2016 CU15" +} elseif (($exchserver.admindisplayversion).major -eq 15 -and ($exchserver.admindisplayversion).minor -eq 1 -and ($exchserver.admindisplayversion).build -eq 1979) { + $EXVER="Exchange 2016 CU16" } 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) { @@ -165,7 +169,9 @@ if (($exchserver.admindisplayversion).major -eq 8 -and ($exchserver.admindisplay } elseif (($exchserver.admindisplayversion).major -eq 15 -and ($exchserver.admindisplayversion).minor -eq 2 -and ($exchserver.admindisplayversion).build -eq 464) { $EXVER="Exchange 2019 CU3" } elseif (($exchserver.admindisplayversion).major -eq 15 -and ($exchserver.admindisplayversion).minor -eq 2 -and ($exchserver.admindisplayversion).build -eq 529) { - $EXVER="Exchange 2019 CU4" + $EXVER="Exchange 2019 CU4" +} elseif (($exchserver.admindisplayversion).major -eq 15 -and ($exchserver.admindisplayversion).minor -eq 2 -and ($exchserver.admindisplayversion).build -eq 595) { + $EXVER="Exchange 2019 CU5" } else { throw "The exchange version is not yet supported: " + $exchserver.admindisplayversion }

    72WgkSIV(Gc_udbGq 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

  • 72WgkSIV(Gc_udbGq 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

  • pU2vjfyM6F>*{8 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≠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%0DA>%{L`6)rRMTGS!?`8 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�<3 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

  • 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∨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 literal 0 HcmV?d00001 diff --git a/Lib/Exchange 2016 CU16/microsoft.exchange.data.common.xml b/Lib/Exchange 2016 CU16/microsoft.exchange.data.common.xml new file mode 100644 index 00000000..a086b7a1 --- /dev/null +++ b/Lib/Exchange 2016 CU16/microsoft.exchange.data.common.xml @@ -0,0 +1,9082 @@ + + + + Microsoft.Exchange.Data.Common + + + +