mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2024-11-08 08:47:17 +01:00
70e5f0ba21
Also enabled the latest C++ revision in the project. Replaced the Random library with the one provided by C++11. Implemented a simple AES256 encryption class. Various other fixes and improvements.
201 lines
6.1 KiB
C++
201 lines
6.1 KiB
C++
#ifndef _LIBRARY_CRYPT_HPP_
|
|
#define _LIBRARY_CRYPT_HPP_
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
#include "SqBase.hpp"
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
#include <aes256.h>
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
namespace SqMod {
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
* Simple class to maintain the state of an encoder.
|
|
*/
|
|
template < class T > class HashWrapper
|
|
{
|
|
public:
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Default constructor.
|
|
*/
|
|
HashWrapper()
|
|
: m_Encoder()
|
|
{
|
|
/* ... */
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Copy operator.
|
|
*/
|
|
HashWrapper(const HashWrapper & o)
|
|
: m_Encoder(o.m_Encoder)
|
|
{
|
|
/* ... */
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Destructor.
|
|
*/
|
|
~HashWrapper()
|
|
{
|
|
/* ... */
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Copy assignment operator.
|
|
*/
|
|
HashWrapper & operator = (const HashWrapper & o)
|
|
{
|
|
m_Encoder = o.m_Encoder;
|
|
return *this;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Used by the script engine to convert an instance of this type to a string.
|
|
*/
|
|
String ToString()
|
|
{
|
|
return m_Encoder.getHash();
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Reset the encoder state.
|
|
*/
|
|
void Reset()
|
|
{
|
|
m_Encoder.reset();
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Compute the hash of the specified string.
|
|
*/
|
|
String Compute(const String & str)
|
|
{
|
|
return m_Encoder(str);
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Retrieve the hash value of the data hashed so far.
|
|
*/
|
|
String GetHash()
|
|
{
|
|
return m_Encoder.getHash();
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Add a string value to be hashed.
|
|
*/
|
|
void AddStr(const String & str)
|
|
{
|
|
m_Encoder.add(str.data(), str.length() * sizeof(String::value_type));
|
|
}
|
|
|
|
private:
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* The managed encoder state.
|
|
*/
|
|
T m_Encoder;
|
|
};
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
* Simple wrapper around a the AES encryption context.
|
|
*/
|
|
class AES256
|
|
{
|
|
public:
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Default constructor.
|
|
*/
|
|
AES256();
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Construct with an explicit key.
|
|
*/
|
|
AES256(CSStr key);
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Copy constructor.
|
|
*/
|
|
AES256(const AES256 & o) = default;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Move constructor.
|
|
*/
|
|
AES256(AES256 && o) = default;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Destructor.
|
|
*/
|
|
~AES256() = default;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Copy assignment operator.
|
|
*/
|
|
AES256 & operator = (const AES256 & o) = default;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Move assignment operator.
|
|
*/
|
|
AES256 & operator = (AES256 && o) = default;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Used by the script engine to compare two instances of this type.
|
|
*/
|
|
Int32 Cmp(const AES256 & o) const;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Used by the script engine to convert an instance of this type to a string.
|
|
*/
|
|
CSStr ToString() const;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Used by the script engine to retrieve the name from instances of this type.
|
|
*/
|
|
static SQInteger Typename(HSQUIRRELVM vm);
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Retrieve the associated key.
|
|
*/
|
|
CSStr GetKey() const;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Initialize the context key.
|
|
*/
|
|
void Init(CSStr key);
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Reset the associated context.
|
|
*/
|
|
void Done();
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Encrypt the specified string.
|
|
*/
|
|
String Encrypt(CSStr data);
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Decrypt the specified string.
|
|
*/
|
|
String Decrypt(CSStr data);
|
|
|
|
private:
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* The managed encryption context.
|
|
*/
|
|
aes256_context m_Context;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* The key used to encrypt data.
|
|
*/
|
|
Uint8 m_Buffer[32]{0};
|
|
};
|
|
|
|
} // Namespace:: SqMod
|
|
|
|
#endif // _LIBRARY_CRYPT_HPP_
|