|
| RSACryptoServiceProvider () |
| Constructor. Uses default parameters. More...
|
|
| RSACryptoServiceProvider (const SharedPtr< CspParameters > ¶meters) |
| Constructor. Not implemented. More...
|
|
| RSACryptoServiceProvider (const RSAParameters ¶meters) |
| Constructor. More...
|
|
| RSACryptoServiceProvider (int32_t key_size) |
| Constructor. More...
|
|
| RSACryptoServiceProvider (int32_t key_size, const SharedPtr< CspParameters > ¶meters) |
| Constructor. Not implemented. More...
|
|
SharedPtr< CspKeyContainerInfo > | get_CspKeyContainerInfo () override |
| Gets a CspKeyContainerInfo object. More...
|
|
String | get_KeyExchangeAlgorithm () override |
| Checks key exchange algorithm associated with object. More...
|
|
int32_t | get_KeySize () override |
| Gets key size used by algorithm. More...
|
|
bool | get_PersistKeyInCsp () const |
| Checks whether key is persisted in CSP object. More...
|
|
void | set_PersistKeyInCsp (bool value) |
| Defines whether key is persisted in CSP object. More...
|
|
bool | get_PublicOnly () const |
| Checks if public key only is present in CSP object. More...
|
|
String | get_SignatureAlgorithm () override |
| Gets signature algorithm associated with CSP object. More...
|
|
ByteArrayPtr | Decrypt (const ByteArrayPtr &rgb, bool use_oaep) |
| Decrypts message. Not implemented. More...
|
|
ByteArrayPtr | Decrypt (ByteArrayPtr data, SharedPtr< RSAEncryptionPadding > padding) override |
| Decrypts input data using the specified padding mode. More...
|
|
ByteArrayPtr | Encrypt (const ByteArrayPtr &rgb, bool use_oaep) |
| Encrypts message. Not implemented. More...
|
|
ByteArrayPtr | Encrypt (ByteArrayPtr data, SharedPtr< RSAEncryptionPadding > padding) override |
| Encrypts input data using the specified padding mode. More...
|
|
ByteArrayPtr | ExportCspBlob (bool include_private_parameters) override |
| Exports blob with information on key. Not implemented. More...
|
|
RSAParameters | ExportParameters (bool include_private_parameters) override |
| Exports CSP parameters. More...
|
|
void | ImportCspBlob (ByteArrayPtr key_blob) override |
| Imports blob with information on key. Not implemented. More...
|
|
void | ImportParameters (RSAParameters parameters) override |
| Imports CSP parameters. More...
|
|
ByteArrayPtr | SignData (const ByteArrayPtr &buffer, const SharedPtr< Object > &halg) |
| Computes the signature of specified input value. More...
|
|
ByteArrayPtr | SignData (const SharedPtr< IO::Stream > &input_stream, const SharedPtr< Object > &halg) |
| Computes the signature of specified input value. More...
|
|
ByteArrayPtr | SignData (const ByteArrayPtr &buffer, int32_t offset, int32_t count, const SharedPtr< Object > &halg) |
| Computes the signature of specified input value. More...
|
|
ByteArrayPtr | SignHash (ByteArrayPtr hash, HashAlgorithmName hash_algorithm, SharedPtr< RSASignaturePadding > padding) override |
| Computes the signature for the specified hash value. More...
|
|
ByteArrayPtr | SignHash (const ByteArrayPtr &rgb_hash, const String &str) |
| Computes the signature of specified input value. Not implemented. More...
|
|
bool | VerifyData (const ByteArrayPtr &buffer, const SharedPtr< Object > &halg, const ByteArrayPtr &signature) |
| Checks data signature. More...
|
|
bool | VerifyHash (const ByteArrayPtr &rgb_hash, const String &str, const ByteArrayPtr &rgb_signature) |
| Checks data signature. More...
|
|
bool | VerifyHash (ByteArrayPtr hash, ByteArrayPtr signature, const HashAlgorithmName &hash_algorithm, SharedPtr< RSASignaturePadding > padding) override |
| Verifies that the signature of the specified hash is valid. More...
|
|
void | Dispose () override |
| Frees data associated with object. More...
|
|
String | get_KeyExchangeAlgorithm () override |
| Checks key exchange algorithm associated with object. More...
|
|
String | get_SignatureAlgorithm () override |
| Gets signature algorithm associated with CSP object. More...
|
|
virtual ByteArrayPtr | Decrypt (ByteArrayPtr data, SharedPtr< RSAEncryptionPadding > padding) |
| Decrypts input data using the specified padding mode. More...
|
|
virtual ByteArrayPtr | DecryptValue (ByteArrayPtr rgb) |
| Decrypts value using private key. More...
|
|
virtual ByteArrayPtr | Encrypt (ByteArrayPtr data, SharedPtr< RSAEncryptionPadding > padding) |
| Encrypts input data using the specified padding mode. More...
|
|
virtual ByteArrayPtr | EncryptValue (ByteArrayPtr rgb) |
| Encrypts value using private key. More...
|
|
virtual RSAParameters | ExportParameters (bool include_private_parameters)=0 |
| Exports all parameters. More...
|
|
virtual void | ImportParameters (RSAParameters parameters)=0 |
| Imports all parameters from data structure. More...
|
|
void | FromXmlString (String xml_string) override |
| Initializes object using XML-encoded parameters. More...
|
|
String | ToXmlString (bool include_private_parameters) override |
| Exports all parameters in XML format. More...
|
|
ByteArrayPtr | SignData (const ByteArrayPtr &data, const HashAlgorithmName &hash_algorithm, const SharedPtr< RSASignaturePadding > &padding) |
| Computes the hash value of the specified data array using the specified hash algorithm and padding, and signs the result. More...
|
|
ByteArrayPtr | SignData (const ByteArrayPtr &data, int32_t offset, int32_t count, const HashAlgorithmName &hash_algorithm, const SharedPtr< RSASignaturePadding > &padding) |
| Computes the hash value of the specified data array using the specified hash algorithm and padding, and signs the result. More...
|
|
ByteArrayPtr | SignData (const StreamPtr &stream, const HashAlgorithmName &hash_algorithm, const SharedPtr< RSASignaturePadding > &padding) |
| Computes the hash value of the specified binary stream using the specified hash algorithm and padding, and signs the result. More...
|
|
virtual ByteArrayPtr | SignHash (ByteArrayPtr hash, HashAlgorithmName hash_algorithm, SharedPtr< RSASignaturePadding > padding) |
| Computes the signature for the specified hash value. More...
|
|
bool | VerifyData (const ByteArrayPtr &data, const ByteArrayPtr &signature, const HashAlgorithmName &hash_algorithm, const SharedPtr< RSASignaturePadding > &padding) |
| Verifies that the signature of the specified data is valid. More...
|
|
bool | VerifyData (const ByteArrayPtr &data, int32_t offset, int32_t count, const ByteArrayPtr &signature, const HashAlgorithmName &hash_algorithm, const SharedPtr< RSASignaturePadding > &padding) |
| Verifies that the signature of the specified data is valid. More...
|
|
bool | VerifyData (const StreamPtr &stream, const ByteArrayPtr &signature, const HashAlgorithmName &hash_algorithm, const SharedPtr< RSASignaturePadding > &padding) |
| Verifies that the signature of the specified binary stream is valid. More...
|
|
virtual bool | VerifyHash (ByteArrayPtr hash, ByteArrayPtr signature, const HashAlgorithmName &hash_algorithm, SharedPtr< RSASignaturePadding > padding) |
| Verifies that the signature of the specified hash is valid. More...
|
|
virtual int32_t | get_KeySize () |
| Gets key size. More...
|
|
virtual void | set_KeySize (int32_t value) |
| Sets key size. More...
|
|
virtual ArrayPtr< SharedPtr< KeySizes > > | get_LegalKeySizes () |
| Gets array of allowed key sizes. More...
|
|
void | Clear () |
| Releases all resources. More...
|
|
virtual void | FromXmlString (String xmlString) |
| Reads algorithm parameters from XML string. More...
|
|
virtual String | ToXmlString (bool include_private_parameters) |
| Writes algorithm parameters to XML string. More...
|
|
virtual String | get_SignatureAlgorithm () |
| Gets signature algorithm to use. More...
|
|
virtual String | get_KeyExchangeAlgorithm () |
| Gets key exchange algorithm to use. More...
|
|
void | Dispose () override |
| Releases resources owned by the current object. More...
|
|
| Object () |
| Creates object. Initializes all internal data structures. More...
|
|
virtual | ~Object () |
| Destroys object. Frees all internal data structures. More...
|
|
| Object (Object const &x) |
| Copy constructor. Doesn't copy anything, really, just initializes new object and enables copy constructing subclasses. More...
|
|
Object & | operator= (Object const &x) |
| Assignment operator. Doesn't copy anything, really, just initializes new object and enables copy constructing subclasses. More...
|
|
Object * | SharedRefAdded () |
| Increments shared reference count. Shouldn't be called directly; instead, use smart pointers or ThisProtector. More...
|
|
int | SharedRefRemovedSafe () |
| Decrements and returns shared reference count. Shouldn't be called directly; instead, use smart pointers or ThisProtector. More...
|
|
int | RemovedSharedRefs (int count) |
| Decreases shared reference count by specified value. More...
|
|
Detail::SmartPtrCounter * | WeakRefAdded () |
| Increments weak reference count. Shouldn't be called directly; instead, use smart pointers or ThisProtector. More...
|
|
void | WeakRefRemoved () |
| Decrements weak reference count. Shouldn't be called directly; instead, use smart pointers or ThisProtector. More...
|
|
Detail::SmartPtrCounter * | GetCounter () |
| Gets reference counter data structure associated with the object. More...
|
|
int | SharedCount () const |
| Gets current value of shared reference counter. More...
|
|
void | Lock () |
| Implements C# lock() statement locking. Call directly or use LockContext sentry object. More...
|
|
void | Unlock () |
| Implements C# lock() statement unlocking. Call directly or use LockContext sentry object. More...
|
|
virtual bool | Equals (ptr obj) |
| Compares objects using C# Object.Equals semantics. More...
|
|
virtual int32_t | GetHashCode () const |
| Analog of C# Object.GetHashCode() method. Enables hashing of custom objects. More...
|
|
virtual String | ToString () const |
| Analog of C# Object.ToString() method. Enables converting custom objects to string. More...
|
|
virtual ptr | MemberwiseClone () const |
| Analog of C# Object.MemberwiseClone() method. Enables cloning custom types. More...
|
|
virtual const TypeInfo & | GetType () const |
| Gets actual type of object. Analog of C# System.Object.GetType() call. More...
|
|
virtual bool | Is (const TypeInfo &targetType) const |
| Check if object represents an instance of type described by targetType. Analog of C# 'is' operator. More...
|
|
virtual void | SetTemplateWeakPtr (uint32_t argument) |
| Set n'th template argument a weak pointer (rather than shared). Allows switching pointers in containers to weak mode. More...
|
|
virtual bool | FastCast (const Details::FastRttiBase &helper, void **out_ptr) const |
| For internal purposes only. More...
|
|
template<> |
bool | ReferenceEquals (String const &str, std::nullptr_t) |
| Specialization of Object::ReferenceEquals for case of string and nullptr. More...
|
|
template<> |
bool | ReferenceEquals (String const &str1, String const &str2) |
| Specialization of Object::ReferenceEquals for case of strings. More...
|
|
virtual void | Dispose () |
| Does nothing. More...
|
|
virtual SharedPtr< CspKeyContainerInfo > | get_CspKeyContainerInfo ()=0 |
| Gets a CspKeyContainerInfo object. More...
|
|
virtual ByteArrayPtr | ExportCspBlob (bool include_private_parameters)=0 |
| Exports blob with key information. More...
|
|
virtual void | ImportCspBlob (ByteArrayPtr raw_data)=0 |
| Imports key information from data blob. More...
|
|
|
static bool | get_UseMachineKeyStore () |
| Checks whether the key persists in machine store instead of user store. More...
|
|
static void | set_UseMachineKeyStore (bool value) |
| Defines whether the key persists in machine store instead of user store. More...
|
|
static SharedPtr< RSA > | Create () |
| Creates default RSA aglorithm implementation. More...
|
|
static SharedPtr< RSA > | Create (const String &alg_name) |
| Creates default RSA algorithm implementation. More...
|
|
static SharedPtr< RSA > | Create (int32_t key_size_in_bits) |
| Creates default RSA algorithm implementation with specifed key size. More...
|
|
static SharedPtr< RSA > | Create (const RSAParameters ¶meters) |
| Creates default RSA algorithm implementation with specifed parameters. More...
|
|
static SharedPtr< RSA > | CreateFromXmlString (const String &xml_string) |
| Creates default RSA algorithm implementation with specifed XML-encoded parameters. More...
|
|
static SharedPtr< AsymmetricAlgorithm > | Create () |
| Creates a default algorithm. Not implemented. More...
|
|
static SharedPtr< AsymmetricAlgorithm > | Create (const String &alg_name) |
| Creates algorithm by name. Not implemented. More...
|
|
static bool | ReferenceEquals (ptr const &objA, ptr const &objB) |
| Compares objects by reference. More...
|
|
template<typename T > |
static std::enable_if<!IsSmartPtr< T >::value, bool >::type | ReferenceEquals (T const &objA, T const &objB) |
| Compares objects by reference. More...
|
|
template<typename T > |
static std::enable_if<!IsSmartPtr< T >::value, bool >::type | ReferenceEquals (T const &objA, std::nullptr_t) |
| Reference-compares value type object with nullptr. More...
|
|
template<typename T1 , typename T2 > |
static std::enable_if< IsSmartPtr< T1 >::value &&IsSmartPtr< T2 >::value, bool >::type | Equals (T1 const &objA, T2 const &objB) |
| Compares reference type objects in C# style. More...
|
|
template<typename T1 , typename T2 > |
static std::enable_if<!IsSmartPtr< T1 >::value &&!IsSmartPtr< T2 >::value, bool >::type | Equals (T1 const &objA, T2 const &objB) |
| Compares value type objects in C# style. More...
|
|
static const TypeInfo & | Type () |
| Implements C# typeof(System.Object) construct. More...
|
|
template<> |
bool | Equals (float const &objA, float const &objB) |
| Emulates C#-style floating point comparison where two NaNs are considered equal even though according to IEC 60559:1989 NaN is not equal to any value, including NaN. More...
|
|
template<> |
bool | Equals (double const &objA, double const &objB) |
| Emulates C#-style floating point comparison where two NaNs are considered equal even though according to IEC 60559:1989 NaN is not equal to any value, including NaN. More...
|
|
RSA algorithm in CSP form. Objects of this class should only be allocated using System::MakeObject() function. Never create instance of this type on stack or using operator new, as it will result in runtime errors and/or assertion faults. Always wrap this class into System::SmartPtr pointer and use this pointer to pass it to functions as argument.