CodePorting.Translator.Cs2Cpp.Framework
System::Security::Cryptography::TripleDESManaged Class Reference

Managed TripleDES implementation. Only supports ECB and CFB modes with None padding and CBC mode with None, Zeros and PKCS7 paddings. 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. More...

#include <triple_des_managed.h>

Inherits System::Security::Cryptography::TripleDES.

Public Member Functions

SharedPtr< ICryptoTransformCreateEncryptor (System::ArrayPtr< uint8_t > rgbKey, System::ArrayPtr< uint8_t > rgbIV) override
 Creates encryptor object with explicit parameters. More...
 
SharedPtr< ICryptoTransformCreateDecryptor (System::ArrayPtr< uint8_t > rgbKey, System::ArrayPtr< uint8_t > rgbIV) override
 Creates decryptor object with explicit parameters. More...
 
void GenerateKey () override
 Creates random key and stores it in algorithm's internals. More...
 
void GenerateIV () override
 Creates random initial value and stores it in algorithm's internals. More...
 
virtual SharedPtr< ICryptoTransformCreateEncryptor ()
 Creates encryptor object with parameters defined by algorithm object. More...
 
virtual SharedPtr< ICryptoTransformCreateEncryptor (System::ArrayPtr< uint8_t > rgbKey, System::ArrayPtr< uint8_t > rgbIV)=0
 Creates encryptor object with parameters defined by algorithm object. More...
 
virtual SharedPtr< ICryptoTransformCreateDecryptor ()
 Creates decryptor object with parameters defined by algorithm object. More...
 
virtual SharedPtr< ICryptoTransformCreateDecryptor (System::ArrayPtr< uint8_t > rgbKey, System::ArrayPtr< uint8_t > rgbIV)=0
 Creates decryptor object with parameters defined by algorithm object. More...
 
- Public Member Functions inherited from System::Security::Cryptography::SymmetricAlgorithm
virtual int get_BlockSize ()
 Gets block size of cryptographic operation. More...
 
virtual void set_BlockSize (int value)
 Sets block size of cryptographic operation. More...
 
virtual int get_FeedbackSize ()
 Gets feedback size of cryptographic operation. More...
 
virtual void set_FeedbackSize (int value)
 Sets feedback size of cryptographic operation. More...
 
virtual System::ArrayPtr< uint8_t > get_Key ()
 Gets key of cryptographic operation. Creates new if not created yet. More...
 
virtual void set_Key (System::ArrayPtr< uint8_t > value)
 Sets key of cryptographic operation. More...
 
virtual System::ArrayPtr< uint8_t > get_IV ()
 Gets initial value of cryptographic operation. Creates new if not created yet. More...
 
virtual void set_IV (System::ArrayPtr< uint8_t > value)
 Sets initial value of cryptographic operation. More...
 
virtual int get_KeySize ()
 Gets key size of cryptographic operation. More...
 
virtual void set_KeySize (int value)
 Sets key size of cryptographic operation. More...
 
virtual CipherMode get_Mode ()
 Gets mode of cryptographic operation. More...
 
virtual void set_Mode (CipherMode value)
 Sets mode of cryptographic operation. More...
 
virtual PaddingMode get_Padding ()
 Gets padding of cryptographic operation. More...
 
virtual void set_Padding (PaddingMode value)
 Sets padding of cryptographic operation. More...
 
virtual SharedPtr< ICryptoTransformCreateEncryptor ()
 Creates encryptor with parameters associated with algorithm object. More...
 
virtual SharedPtr< ICryptoTransformCreateEncryptor (System::ArrayPtr< uint8_t > rgbKey, System::ArrayPtr< uint8_t > rgbIV)=0
 Creates encryptor with explicit parameters. More...
 
virtual SharedPtr< ICryptoTransformCreateDecryptor ()
 Creates decryptor with parameters associated with algorithm object. More...
 
virtual SharedPtr< ICryptoTransformCreateDecryptor (System::ArrayPtr< uint8_t > rgbKey, System::ArrayPtr< uint8_t > rgbIV)=0
 Creates decryptor with explicit parameters. More...
 
virtual void GenerateKey ()=0
 Generates random key for the algorithm. Overrides existing one (if any). More...
 
virtual void GenerateIV ()=0
 Generates random initial value for the algorithm. Overrides existing one (if any). More...
 
bool ValidKeySize (int bitLength)
 Checks if key size is valid. More...
 
- Public Member Functions inherited from System::Object
 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...
 
Objectoperator= (Object const &x)
 Assignment operator. Doesn't copy anything, really, just initializes new object and enables copy constructing subclasses. More...
 
ObjectSharedRefAdded ()
 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 TypeInfoGetType () 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...
 

Additional Inherited Members

- Public Types inherited from System::Object
typedef SmartPtr< Objectptr
 Alias for smart pointer type. More...
 
- Static Public Member Functions inherited from System::Security::Cryptography::SymmetricAlgorithm
static SharedPtr< SymmetricAlgorithmCreate (const String &algName)
 Creates algorithm instance. More...
 
- Static Public Member Functions inherited from System::Object
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 TypeInfoType ()
 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...
 
- Protected Member Functions inherited from System::Security::Cryptography::TripleDES
 TripleDES ()
 Constructor. More...
 
- Protected Member Functions inherited from System::Security::Cryptography::SymmetricAlgorithm
 SymmetricAlgorithm (const std::vector< SharedPtr< KeySizes > > &block_sizes, const std::vector< SharedPtr< KeySizes > > &key_sizes)
 Constructor. More...
 
- Protected Attributes inherited from System::Security::Cryptography::SymmetricAlgorithm
int m_block_size
 Block size. More...
 
int m_feedback_size
 Feedback size. More...
 
System::ArrayPtr< uint8_t > m_iv
 Initial value. More...
 
System::ArrayPtr< uint8_t > m_key
 Key. More...
 
std::vector< SharedPtr< KeySizes > > m_legal_block_sizes
 Allowed block sizes. More...
 
std::vector< SharedPtr< KeySizes > > m_legal_key_sizes
 Allowed key sizes. More...
 
int m_key_size
 Key size. More...
 
CipherMode m_mode
 Direction. More...
 
PaddingMode m_padding
 Padding. More...
 

Detailed Description

Managed TripleDES implementation. Only supports ECB and CFB modes with None padding and CBC mode with None, Zeros and PKCS7 paddings. 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.

Member Function Documentation

◆ CreateDecryptor() [1/3]

virtual SharedPtr< ICryptoTransform > System::Security::Cryptography::SymmetricAlgorithm::CreateDecryptor ( )
virtual

Creates decryptor object with parameters defined by algorithm object.

Reimplemented from System::Security::Cryptography::SymmetricAlgorithm.

◆ CreateDecryptor() [2/3]

SharedPtr< ICryptoTransform > System::Security::Cryptography::TripleDESManaged::CreateDecryptor ( System::ArrayPtr< uint8_t >  rgbKey,
System::ArrayPtr< uint8_t >  rgbIV 
)
overridevirtual

Creates decryptor object with explicit parameters.

Parameters
rgbKeyEncryption key in byte array form.
rgbIVInitial value in byte array form.
Returns
Newly created decryptor object.

Implements System::Security::Cryptography::SymmetricAlgorithm.

◆ CreateDecryptor() [3/3]

virtual SharedPtr< ICryptoTransform > System::Security::Cryptography::SymmetricAlgorithm::CreateDecryptor ( System::ArrayPtr< uint8_t >  rgbKey,
System::ArrayPtr< uint8_t >  rgbIV 
)
virtual

Creates decryptor object with parameters defined by algorithm object.

Implements System::Security::Cryptography::SymmetricAlgorithm.

◆ CreateEncryptor() [1/3]

virtual SharedPtr< ICryptoTransform > System::Security::Cryptography::SymmetricAlgorithm::CreateEncryptor ( )
virtual

Creates encryptor object with parameters defined by algorithm object.

Reimplemented from System::Security::Cryptography::SymmetricAlgorithm.

◆ CreateEncryptor() [2/3]

SharedPtr< ICryptoTransform > System::Security::Cryptography::TripleDESManaged::CreateEncryptor ( System::ArrayPtr< uint8_t >  rgbKey,
System::ArrayPtr< uint8_t >  rgbIV 
)
overridevirtual

Creates encryptor object with explicit parameters.

Parameters
rgbKeyEncryption key in byte array form.
rgbIVInitial value in byte array form.
Returns
Newly created encryptor object.

Implements System::Security::Cryptography::SymmetricAlgorithm.

◆ CreateEncryptor() [3/3]

virtual SharedPtr< ICryptoTransform > System::Security::Cryptography::SymmetricAlgorithm::CreateEncryptor ( System::ArrayPtr< uint8_t >  rgbKey,
System::ArrayPtr< uint8_t >  rgbIV 
)
virtual

Creates encryptor object with parameters defined by algorithm object.

Implements System::Security::Cryptography::SymmetricAlgorithm.

◆ GenerateIV()

void System::Security::Cryptography::TripleDESManaged::GenerateIV ( )
overridevirtual

Creates random initial value and stores it in algorithm's internals.

Implements System::Security::Cryptography::SymmetricAlgorithm.

◆ GenerateKey()

void System::Security::Cryptography::TripleDESManaged::GenerateKey ( )
overridevirtual

Creates random key and stores it in algorithm's internals.

Implements System::Security::Cryptography::SymmetricAlgorithm.