コード例 #1
0
        private static string EncryptData(string key, byte[] cleanBytes, ObscuredPrefs.DataType type)
        {
            int num = cleanBytes.Length;

            byte[] src  = ObscuredPrefs.EncryptDecryptBytes(cleanBytes, num, key + ObscuredPrefs.cryptoKey);
            uint   num2 = xxHash.CalculateHash(cleanBytes, num, 0u);

            byte[] src2 = new byte[]
            {
                (byte)(num2 & 255u),
                (byte)(num2 >> 8 & 255u),
                (byte)(num2 >> 16 & 255u),
                (byte)(num2 >> 24 & 255u)
            };
            byte[] array = null;
            int    num3;

            if (ObscuredPrefs.lockToDevice != ObscuredPrefs.DeviceLockLevel.None)
            {
                num3 = num + 11;
                uint num4 = ObscuredPrefs.DeviceIdHash;
                array = new byte[]
                {
                    (byte)(num4 & 255u),
                    (byte)(num4 >> 8 & 255u),
                    (byte)(num4 >> 16 & 255u),
                    (byte)(num4 >> 24 & 255u)
                };
            }
            else
            {
                num3 = num + 7;
            }
            byte[] array2 = new byte[num3];
            Buffer.BlockCopy(src, 0, array2, 0, num);
            if (array != null)
            {
                Buffer.BlockCopy(array, 0, array2, num, 4);
            }
            array2[num3 - 7] = (byte)type;
            array2[num3 - 6] = 2;
            array2[num3 - 5] = (byte)ObscuredPrefs.lockToDevice;
            Buffer.BlockCopy(src2, 0, array2, num3 - 4, 4);
            return(Convert.ToBase64String(array2));
        }
コード例 #2
0
        private static string EncryptData(string key, byte[] cleanBytes, ObscuredPrefs.DataType type)
        {
            int length1 = cleanBytes.Length;

            byte[] numArray1 = ObscuredPrefs.EncryptDecryptBytes(cleanBytes, length1, key + ObscuredPrefs.encryptionKey);
            uint   hash      = xxHash.CalculateHash(cleanBytes, length1, 0U);

            byte[] numArray2 = new byte[4] {
                (byte)(hash & (uint)byte.MaxValue), (byte)(hash >> 8 & (uint)byte.MaxValue), (byte)(hash >> 16 & (uint)byte.MaxValue), (byte)(hash >> 24 & (uint)byte.MaxValue)
            };
            byte[] numArray3 = (byte[])null;
            int    length2;

            if (ObscuredPrefs.lockToDevice != ObscuredPrefs.DeviceLockLevel.None)
            {
                length2 = length1 + 11;
                uint deviceIdHash = ObscuredPrefs.DeviceIdHash;
                numArray3 = new byte[4]
                {
                    (byte)(deviceIdHash & (uint)byte.MaxValue),
                    (byte)(deviceIdHash >> 8 & (uint)byte.MaxValue),
                    (byte)(deviceIdHash >> 16 & (uint)byte.MaxValue),
                    (byte)(deviceIdHash >> 24 & (uint)byte.MaxValue)
                };
            }
            else
            {
                length2 = length1 + 7;
            }
            byte[] inArray = new byte[length2];
            Buffer.BlockCopy((Array)numArray1, 0, (Array)inArray, 0, length1);
            if (numArray3 != null)
            {
                Buffer.BlockCopy((Array)numArray3, 0, (Array)inArray, length1, 4);
            }
            inArray[length2 - 7] = (byte)type;
            inArray[length2 - 6] = (byte)2;
            inArray[length2 - 5] = (byte)ObscuredPrefs.lockToDevice;
            Buffer.BlockCopy((Array)numArray2, 0, (Array)inArray, length2 - 4, 4);
            return(Convert.ToBase64String(inArray));
        }
コード例 #3
0
        internal static byte[] DecryptData(string key, string encryptedInput)
        {
            byte[] array;
            try
            {
                array = Convert.FromBase64String(encryptedInput);
            }
            catch (Exception)
            {
                ObscuredPrefs.SavesTampered();
                byte[] result = null;
                return(result);
            }
            if (array.Length <= 0)
            {
                ObscuredPrefs.SavesTampered();
                return(null);
            }
            int  num = array.Length;
            byte b   = array[num - 6];

            if (b != 2)
            {
                ObscuredPrefs.SavesTampered();
                return(null);
            }
            ObscuredPrefs.DeviceLockLevel deviceLockLevel = (ObscuredPrefs.DeviceLockLevel)array[num - 5];
            byte[] array2 = new byte[4];
            Buffer.BlockCopy(array, num - 4, array2, 0, 4);
            uint num2 = (uint)((int)array2[0] | (int)array2[1] << 8 | (int)array2[2] << 16 | (int)array2[3] << 24);
            uint num3 = 0u;
            int  num4;

            if (deviceLockLevel != ObscuredPrefs.DeviceLockLevel.None)
            {
                num4 = num - 11;
                if (ObscuredPrefs.lockToDevice != ObscuredPrefs.DeviceLockLevel.None)
                {
                    byte[] array3 = new byte[4];
                    Buffer.BlockCopy(array, num4, array3, 0, 4);
                    num3 = (uint)((int)array3[0] | (int)array3[1] << 8 | (int)array3[2] << 16 | (int)array3[3] << 24);
                }
            }
            else
            {
                num4 = num - 7;
            }
            byte[] array4 = new byte[num4];
            Buffer.BlockCopy(array, 0, array4, 0, num4);
            byte[] array5 = ObscuredPrefs.EncryptDecryptBytes(array4, num4, key + ObscuredPrefs.cryptoKey);
            uint   num5   = xxHash.CalculateHash(array5, num4, 0u);

            if (num5 != num2)
            {
                ObscuredPrefs.SavesTampered();
                return(null);
            }
            if (ObscuredPrefs.lockToDevice == ObscuredPrefs.DeviceLockLevel.Strict && num3 == 0u && !ObscuredPrefs.emergencyMode && !ObscuredPrefs.readForeignSaves)
            {
                return(null);
            }
            if (num3 != 0u && !ObscuredPrefs.emergencyMode)
            {
                uint num6 = ObscuredPrefs.DeviceIdHash;
                if (num3 != num6)
                {
                    ObscuredPrefs.PossibleForeignSavesDetected();
                    if (!ObscuredPrefs.readForeignSaves)
                    {
                        return(null);
                    }
                }
            }
            return(array5);
        }
コード例 #4
0
        private static byte[] DecryptData(string key, string encryptedInput)
        {
            byte[] numArray1;
            try
            {
                numArray1 = Convert.FromBase64String(encryptedInput);
            }
            catch (Exception ex)
            {
                ObscuredPrefs.SavesTampered();
                return((byte[])null);
            }
            if (numArray1.Length <= 0)
            {
                ObscuredPrefs.SavesTampered();
                return((byte[])null);
            }
            int length1 = numArray1.Length;

            if ((int)numArray1[length1 - 6] != 2)
            {
                ObscuredPrefs.SavesTampered();
                return((byte[])null);
            }
            ObscuredPrefs.DeviceLockLevel deviceLockLevel = (ObscuredPrefs.DeviceLockLevel)numArray1[length1 - 5];
            byte[] numArray2 = new byte[4];
            Buffer.BlockCopy((Array)numArray1, length1 - 4, (Array)numArray2, 0, 4);
            uint num1 = (uint)((int)numArray2[0] | (int)numArray2[1] << 8 | (int)numArray2[2] << 16 | (int)numArray2[3] << 24);
            uint num2 = 0;
            int  length2;

            if (deviceLockLevel != ObscuredPrefs.DeviceLockLevel.None)
            {
                length2 = length1 - 11;
                if (ObscuredPrefs.lockToDevice != ObscuredPrefs.DeviceLockLevel.None)
                {
                    byte[] numArray3 = new byte[4];
                    Buffer.BlockCopy((Array)numArray1, length2, (Array)numArray3, 0, 4);
                    num2 = (uint)((int)numArray3[0] | (int)numArray3[1] << 8 | (int)numArray3[2] << 16 | (int)numArray3[3] << 24);
                }
            }
            else
            {
                length2 = length1 - 7;
            }
            byte[] bytes = new byte[length2];
            Buffer.BlockCopy((Array)numArray1, 0, (Array)bytes, 0, length2);
            byte[] buf = ObscuredPrefs.EncryptDecryptBytes(bytes, length2, key + ObscuredPrefs.encryptionKey);
            if ((int)xxHash.CalculateHash(buf, length2, 0U) != (int)num1)
            {
                ObscuredPrefs.SavesTampered();
                return((byte[])null);
            }
            if (ObscuredPrefs.lockToDevice == ObscuredPrefs.DeviceLockLevel.Strict && (int)num2 == 0 && (!ObscuredPrefs.emergencyMode && !ObscuredPrefs.readForeignSaves))
            {
                return((byte[])null);
            }
            if ((int)num2 != 0 && !ObscuredPrefs.emergencyMode)
            {
                uint deviceIdHash = ObscuredPrefs.DeviceIdHash;
                if ((int)num2 != (int)deviceIdHash)
                {
                    ObscuredPrefs.PossibleForeignSavesDetected();
                    if (!ObscuredPrefs.readForeignSaves)
                    {
                        return((byte[])null);
                    }
                }
            }
            return(buf);
        }