obfuz/Runtime/EncryptionService.cs

125 lines
3.8 KiB
C#
Raw Normal View History

2025-04-23 18:43:14 +08:00
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace Obfuz
{
public static class EncryptionService
{
private static IEncryptor _encryptor;
public static IEncryptor Encryptor
{
get => _encryptor;
set { _encryptor = value; }
}
2025-04-23 18:58:44 +08:00
2025-05-11 10:37:42 +08:00
public static void EncryptBlock(byte[] data, int ops, int salt)
2025-04-23 18:43:14 +08:00
{
2025-05-07 19:39:09 +08:00
_encryptor.EncryptBlock(data, ops, salt);
2025-05-07 10:14:15 +08:00
}
2025-05-11 10:37:42 +08:00
public static void DecryptBlock(byte[] data, int ops, int salt)
2025-05-07 10:14:15 +08:00
{
2025-05-07 19:39:09 +08:00
_encryptor.DecryptBlock(data, ops, salt);
2025-04-23 18:43:14 +08:00
}
2025-05-07 22:55:07 +08:00
public static int Encrypt(int value, int opts, int salt)
{
return _encryptor.Encrypt(value, opts, salt);
}
public static int Decrypt(int value, int opts, int salt)
{
return _encryptor.Decrypt(value, opts, salt);
}
public static long Encrypt(long value, int opts, int salt)
{
return _encryptor.Encrypt(value, opts, salt);
}
public static long Decrypt(long value, int opts, int salt)
{
return _encryptor.Decrypt(value, opts, salt);
}
public static float Encrypt(float value, int opts, int salt)
{
return _encryptor.Encrypt(value, opts, salt);
}
public static float Decrypt(float value, int opts, int salt)
{
return _encryptor.Decrypt(value, opts, salt);
}
public static double Encrypt(double value, int opts, int salt)
{
return _encryptor.Encrypt(value, opts, salt);
}
public static double Decrypt(double value, int opts, int salt)
{
return _encryptor.Decrypt(value, opts, salt);
}
2025-05-08 08:54:18 +08:00
public static byte[] Encrypt(byte[] value, int offset, int length, int opts, int salt)
2025-05-07 22:55:07 +08:00
{
return _encryptor.Encrypt(value, offset, length, opts, salt);
}
2025-05-08 08:54:18 +08:00
public static byte[] Decrypt(byte[] value, int offset, int byteLength, int ops, int salt)
2025-05-07 22:55:07 +08:00
{
return _encryptor.Decrypt(value, offset, byteLength, ops, salt);
}
2025-05-08 08:54:18 +08:00
public static byte[] Encrypt(string value, int ops, int salt)
2025-05-07 22:55:07 +08:00
{
return _encryptor.Encrypt(value, ops, salt);
}
2025-05-08 08:54:18 +08:00
public static string DecryptString(byte[] value, int offset, int stringBytesLength, int ops, int salt)
2025-05-07 22:55:07 +08:00
{
return _encryptor.DecryptString(value, offset, stringBytesLength, ops, salt);
}
public static int DecryptFromRvaInt(byte[] data, int offset, int ops, int salt)
{
int encryptedValue = ConstUtility.GetInt(data, offset);
return Decrypt(encryptedValue, ops, salt);
}
public static long DecryptFromRvaLong(byte[] data, int offset, int ops, int salt)
{
long encryptedValue = ConstUtility.GetLong(data, offset);
return Decrypt(encryptedValue, ops, salt);
}
public static float DecryptFromRvaFloat(byte[] data, int offset, int ops, int salt)
{
int encryptedValue = ConstUtility.GetInt(data, offset);
return Decrypt(encryptedValue, ops, salt);
}
public static double DecryptFromRvaDouble(byte[] data, int offset, int ops, int salt)
{
long encryptedValue = ConstUtility.GetLong(data, offset);
return Decrypt(encryptedValue, ops, salt);
}
2025-05-08 08:54:18 +08:00
public static string DecryptFromRvaString(byte[] data, int offset, int length, int ops, int salt)
2025-05-07 22:55:07 +08:00
{
2025-05-08 08:54:18 +08:00
return DecryptString(data, offset, length, ops, salt);
}
public static byte[] DecryptFromRvaBytes(byte[] data, int offset, int bytesLength, int ops, int salt)
{
return Decrypt(data, offset, bytesLength, ops, salt);
2025-05-07 22:55:07 +08:00
}
2025-04-23 18:43:14 +08:00
}
}