IntegratorHelper.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291
  1. using Microsoft.Win32;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Drawing;
  5. using System.Drawing.Imaging;
  6. using System.IO;
  7. using System.Net;
  8. using System.Windows.Forms;
  9. namespace Optimizer
  10. {
  11. public static class IntegratorHelper
  12. {
  13. internal static string FolderDefaultIcon = @"%systemroot%\system32\imageres.dll,-112";
  14. internal static void CreateCustomCommand(string file, string keyword)
  15. {
  16. if (!keyword.EndsWith(".exe"))
  17. {
  18. keyword = keyword + ".exe";
  19. }
  20. string key = @"HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths\" + keyword;
  21. Registry.LocalMachine.CreateSubKey(@"SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths\" + keyword);
  22. Registry.SetValue(key, "", file);
  23. Registry.SetValue(key, "Path", file.Substring(0, file.LastIndexOf("\\")));
  24. }
  25. internal static List<string> GetCustomCommands()
  26. {
  27. List<string> items = new List<string>();
  28. using (RegistryKey key = Registry.LocalMachine.OpenSubKey(@"SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths\"))
  29. {
  30. foreach (string command in key.GetSubKeyNames())
  31. {
  32. items.Add(command);
  33. }
  34. }
  35. return items;
  36. }
  37. internal static void DeleteCustomCommand(string command)
  38. {
  39. Registry.LocalMachine.DeleteSubKey(@"SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths\" + command, false);
  40. }
  41. private static void CreateDefaultCommand(string itemName)
  42. {
  43. using (RegistryKey key = Registry.ClassesRoot.OpenSubKey(@"DesktopBackground\Shell\" + itemName, true))
  44. {
  45. key.CreateSubKey("command", RegistryKeyPermissionCheck.Default);
  46. }
  47. }
  48. internal static List<string> GetDesktopItems()
  49. {
  50. List<string> items = new List<string>();
  51. using (RegistryKey key = Registry.ClassesRoot.OpenSubKey(@"DesktopBackground\Shell", false))
  52. {
  53. foreach (string item in key.GetSubKeyNames())
  54. {
  55. // filter the list, so the default items will not be visible
  56. if (item.Contains("Gadgets")) continue;
  57. if (item.Contains("Display")) continue;
  58. if (item.Contains("Personalize")) continue;
  59. items.Add(item);
  60. }
  61. }
  62. return items;
  63. }
  64. internal static void RemoveItem(string name)
  65. {
  66. try
  67. {
  68. using (RegistryKey key = Registry.ClassesRoot.OpenSubKey(@"DesktopBackground\Shell", true))
  69. {
  70. try
  71. {
  72. key.DeleteSubKeyTree(name, false);
  73. }
  74. catch (Exception ex)
  75. {
  76. Logger.LogError("Integrator.RemoveItem", ex.Message, ex.StackTrace);
  77. }
  78. }
  79. }
  80. catch (Exception ex)
  81. {
  82. Logger.LogError("Integrator.RemoveItem", ex.Message, ex.StackTrace);
  83. }
  84. }
  85. internal static bool DesktopItemExists(string name)
  86. {
  87. try
  88. {
  89. return Registry.ClassesRoot.OpenSubKey(@"DesktopBackground\Shell\" + name, false) != null;
  90. }
  91. catch (Exception ex)
  92. {
  93. Logger.LogError("Integrator.ItemExists", ex.Message, ex.StackTrace);
  94. return false;
  95. }
  96. }
  97. internal static bool TakeOwnershipExists()
  98. {
  99. try
  100. {
  101. return Registry.ClassesRoot.OpenSubKey(@"*\shell\runas", false).GetValue("").ToString() == "Take Ownership";
  102. }
  103. catch (Exception ex)
  104. {
  105. Logger.LogError("Integrator.TakeOwnershipExists", ex.Message, ex.StackTrace);
  106. return false;
  107. }
  108. }
  109. internal static bool OpenWithCMDExists()
  110. {
  111. try
  112. {
  113. return Registry.ClassesRoot.OpenSubKey(@"Directory\shell\OpenWithCMD", false) != null;
  114. }
  115. catch (Exception ex)
  116. {
  117. Logger.LogError("Integrator.OpenWithCMDExists", ex.Message, ex.StackTrace);
  118. return false;
  119. }
  120. }
  121. internal static void RemoveAllItems(List<string> items)
  122. {
  123. using (RegistryKey key = Registry.ClassesRoot.OpenSubKey(@"DesktopBackground\Shell", true))
  124. {
  125. foreach (string item in items)
  126. {
  127. try
  128. {
  129. key.DeleteSubKeyTree(item, false);
  130. }
  131. catch (Exception ex)
  132. {
  133. Logger.LogError("Integrator.RemoveAllItems", ex.Message, ex.StackTrace);
  134. }
  135. }
  136. }
  137. }
  138. internal static string ExtractIconFromExecutable(string itemName, string fileName)
  139. {
  140. string iconPath = string.Empty;
  141. if (File.Exists(fileName))
  142. {
  143. Icon ico = Icon.ExtractAssociatedIcon(fileName);
  144. Clipboard.SetImage(ico.ToBitmap());
  145. Clipboard.GetImage().Save(CoreHelper.ExtractedIconsFolder + itemName + ".ico", ImageFormat.Bmp);
  146. Clipboard.Clear();
  147. iconPath = CoreHelper.ExtractedIconsFolder + itemName + ".ico";
  148. }
  149. return iconPath;
  150. }
  151. internal static string DownloadFavicon(string link, string name)
  152. {
  153. string favicon = string.Empty;
  154. try
  155. {
  156. Uri url = new Uri(link);
  157. if (url.HostNameType == UriHostNameType.Dns)
  158. {
  159. Image.FromStream(((HttpWebResponse)WebRequest.Create("http://" + url.Host + "/favicon.ico").GetResponse()).GetResponseStream()).Save(CoreHelper.FavIconsFolder + name + ".ico", ImageFormat.Bmp);
  160. favicon = CoreHelper.FavIconsFolder + name + ".ico";
  161. }
  162. }
  163. catch (Exception ex)
  164. {
  165. Logger.LogError("Integrator.DownloadFavicon", ex.Message, ex.StackTrace);
  166. }
  167. return favicon;
  168. }
  169. internal static void AddItem(string name, string item, string icon, DesktopTypePosition position, bool shift, DesktopItemType type)
  170. {
  171. using (RegistryKey key = Registry.ClassesRoot.OpenSubKey(@"DesktopBackground\Shell", true))
  172. {
  173. key.CreateSubKey(name, RegistryKeyPermissionCheck.Default);
  174. }
  175. CreateDefaultCommand(name);
  176. if (shift)
  177. {
  178. Registry.SetValue(@"HKEY_CLASSES_ROOT\DesktopBackground\Shell\" + name, "Extended", "");
  179. }
  180. else
  181. {
  182. using (RegistryKey key = Registry.ClassesRoot.OpenSubKey(@"DesktopBackground\Shell\" + name, true))
  183. {
  184. key.CreateSubKey(name, RegistryKeyPermissionCheck.Default);
  185. }
  186. }
  187. Registry.SetValue(@"HKEY_CLASSES_ROOT\DesktopBackground\Shell\" + name, "Icon", icon);
  188. Registry.SetValue(@"HKEY_CLASSES_ROOT\DesktopBackground\Shell\" + name, "Position", position.ToString());
  189. switch (type)
  190. {
  191. case DesktopItemType.Program:
  192. Registry.SetValue(@"HKEY_CLASSES_ROOT\DesktopBackground\Shell\" + name + "\\command", "", item);
  193. break;
  194. case DesktopItemType.Folder:
  195. Registry.SetValue(@"HKEY_CLASSES_ROOT\DesktopBackground\Shell\" + name + "\\command", "", "explorer " + item);
  196. break;
  197. case DesktopItemType.Link:
  198. Registry.SetValue(@"HKEY_CLASSES_ROOT\DesktopBackground\Shell\" + name + "\\command", "", "explorer " + item);
  199. break;
  200. case DesktopItemType.File:
  201. string tmp = @"""";
  202. string tmp2 = "explorer.exe";
  203. Registry.SetValue(@"HKEY_CLASSES_ROOT\DesktopBackground\Shell\" + name + "\\command", "", tmp2 + " " + tmp + item + tmp);
  204. break;
  205. case DesktopItemType.Command:
  206. Registry.SetValue(@"HKEY_CLASSES_ROOT\DesktopBackground\Shell\" + name + "\\command", "", item);
  207. break;
  208. }
  209. }
  210. internal static void InstallOpenWithCMD()
  211. {
  212. Utilities.ImportRegistryScript(CoreHelper.ScriptsFolder + "AddOpenWithCMD.reg");
  213. }
  214. internal static void DeleteOpenWithCMD()
  215. {
  216. Registry.ClassesRoot.DeleteSubKeyTree(@"Directory\shell\OpenWithCMD", false);
  217. Registry.ClassesRoot.DeleteSubKeyTree(@"Directory\Background\shell\OpenWithCMD", false);
  218. Registry.ClassesRoot.DeleteSubKeyTree(@"Drive\shell\OpenWithCMD", false);
  219. }
  220. internal static void InstallTakeOwnership(bool remove)
  221. {
  222. if (!File.Exists(CoreHelper.ReadyMadeMenusFolder + "InstallTakeOwnership.reg"))
  223. {
  224. try
  225. {
  226. File.WriteAllText(CoreHelper.ReadyMadeMenusFolder + "InstallTakeOwnership.reg", Properties.Resources.InstallTakeOwnership);
  227. }
  228. catch (Exception ex)
  229. {
  230. Logger.LogError("Integrator.TakeOwnership", ex.Message, ex.StackTrace);
  231. }
  232. }
  233. if (!File.Exists(CoreHelper.ReadyMadeMenusFolder + "RemoveTakeOwnership.reg"))
  234. {
  235. try
  236. {
  237. File.WriteAllText(CoreHelper.ReadyMadeMenusFolder + "RemoveTakeOwnership.reg", Properties.Resources.RemoveTakeOwnership);
  238. }
  239. catch (Exception ex)
  240. {
  241. Logger.LogError("Integrator.TakeOwnership", ex.Message, ex.StackTrace);
  242. }
  243. }
  244. if (!remove)
  245. {
  246. Utilities.ImportRegistryScript(CoreHelper.ReadyMadeMenusFolder + "InstallTakeOwnership.reg");
  247. }
  248. else
  249. {
  250. Utilities.ImportRegistryScript(CoreHelper.ReadyMadeMenusFolder + "RemoveTakeOwnership.reg");
  251. }
  252. }
  253. }
  254. }