private async Task <bool> IsUrlAFolder(Uri uri) { //todo: replace with regex? try { IEnumerable <INode> nodes = await _client.GetNodesFromLinkAsync(uri); return(true); } catch (Exception ex) { return(false); } }
internal static async Task <(bool success, string downloadedFilePath)> DownlaodWithMegaFromFolderAsync(string url, string downloadFileRootPath, string fileNameNoExtension, IProgress <int> progress, CancellationToken stop) { var client = new MegaApiClient(); var downloadFileLocation = ""; try { client.LoginAnonymous(); var splitted = url.Split('?'); var foldeUrl = splitted.FirstOrDefault(); var id = splitted.Skip(1).FirstOrDefault(); var folderLink = new Uri(foldeUrl); //INodeInfo node = client.GetNodeFromLink(fileLink); var nodes = await client.GetNodesFromLinkAsync(folderLink); var node = nodes.FirstOrDefault(n => n.Id == id); //Console.WriteLine($"Downloading {node.Name}"); var doubleProgress = new Progress <double>((p) => progress?.Report((int)p)); downloadFileLocation = GetDownloadFilePath(downloadFileRootPath, fileNameNoExtension, GetFileExtension(node.Name)); await client.DownloadFileAsync(node, downloadFileLocation, doubleProgress, stop); } catch (Exception e) { Logger.Error("MinersDownloadManager", $"MegaFolder error: {e.Message}"); } finally { client.Logout(); } var success = File.Exists(downloadFileLocation); return(success, downloadFileLocation); }
public async Task <List <INode> > GetNodesFromLinkAsync(Uri folderLink, CancellationToken cancellationToken) { await Connect(); await RetryHelper.RetryOnExceptionAsync(async() => _allNodes = (await _client.GetNodesFromLinkAsync(folderLink)).ToList(), 2, TimeSpan.FromSeconds(1), cancellationToken); CurrentFolderLink = folderLink; return(_allNodes); }
private async Task checkOnlineVersion() { loginhelperPlugin = null; if (loginHelper_installed) { loginhelperPlugin = new Modpolice.pluginFileInfo(Path.Combine(plugins_x86, "loginhelper.dll")); } charselectPlugin = null; if (charselect_installed) { charselectPlugin = new Modpolice.pluginFileInfo(Path.Combine(plugins_x86, "charselect.dll")); } //Hotfix for missing use-ingame-login.xml if (loginHelper_installed && !File.Exists(login_xml)) { File.WriteAllText(login_xml, Properties.Resources.use_ingame_login); } Dispatchers.labelContent(loginhelperLocalLbl, String.Format("Current: {0}", (loginhelperPlugin != null) ? loginhelperPlugin.modificationTime.ToString("MM-dd-yy") : "Not Installed")); Dispatchers.labelContent(charSelectLocalLbl, String.Format("Current: {0}", (charselectPlugin != null) ? charselectPlugin.modificationTime.ToString("MM-dd-yy") : "Not Installed")); try { var client = new MegaApiClient(); await client.LoginAnonymousAsync(); if (!client.IsLoggedIn) { throw new Exception("Timed out"); //Throw exception for not logging in anonymously } IEnumerable <INode> nodes = await client.GetNodesFromLinkAsync(new Uri("https://mega.nz/folder/4EUF2IhL#Ci1Y-sbbyw7nwwMGvHV2_w")); INode loginhelper_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("loginhelper")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); INode charselect_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("charselect")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); if (loginhelper_node != null) { Dispatchers.labelContent(loginhelperOnlineLbl, String.Format("Online: {0}", loginhelper_node.ModificationDate.Value.ToString("MM-dd-yy"))); } if (charselect_node != null) { Dispatchers.labelContent(charSelectOnlineLbl, String.Format("Online: {0}", charselect_node.ModificationDate.Value.ToString("MM-dd-yy"))); } } catch (Exception ex) { Dispatchers.labelContent(loginhelperOnlineLbl, ex.Message == "Timed out" ? "Online: " + ex.Message : "Online: Error!"); Dispatchers.labelContent(charSelectOnlineLbl, ex.Message == "Timed out" ? "Online: " + ex.Message : "Online: Error!"); } }
private async void installLoginHelperClick(object sender, RoutedEventArgs e) { _progressControl = new ProgressControl(); ProgressGrid.Visibility = Visibility.Visible; MainGrid.Visibility = Visibility.Collapsed; ProgressPanel.Children.Add(_progressControl); string pluginName = "loginhelper"; if (((Button)sender).Name.Contains("CHARSELECT")) { pluginName = "charselect"; } await Task.Run(async() => { try { if (!Directory.Exists("modpolice")) { Directory.CreateDirectory("modpolice"); } ProgressControl.updateProgressLabel("Logging into Mega anonymously..."); var client = new MegaApiClient(); await client.LoginAnonymousAsync(); if (!Directory.Exists("modpolice")) { Directory.CreateDirectory("modpolice"); } ProgressControl.updateProgressLabel("Retrieving file list..."); IEnumerable <INode> nodes = await client.GetNodesFromLinkAsync(new Uri("https://mega.nz/folder/4EUF2IhL#Ci1Y-sbbyw7nwwMGvHV2_w")); INode currentNode = null; IProgress <double> progress = new Progress <double>(x => ProgressControl.updateProgressLabel(String.Format("Downloading: {0} ({1}%)", currentNode.Name, Math.Round(x)))); //Find our latest nodes for download INode loginhelper_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains(pluginName)).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); if (loginhelper_node == null) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel("Something went wrong getting the node"); await Task.Delay(7000); return; } if (File.Exists(@"modpolice\" + loginhelper_node.Name)) { File.Delete(@"modpolice\" + loginhelper_node.Name); } currentNode = loginhelper_node; await client.DownloadFileAsync(currentNode, @"modpolice\" + loginhelper_node.Name, progress); ProgressControl.updateProgressLabel("Unzipping: " + loginhelper_node.Name); await Task.Delay(750); Modpolice.ExtractZipFileToDirectory(@".\modpolice\" + loginhelper_node.Name, @".\modpolice", true); ProgressControl.updateProgressLabel("Installing " + pluginName + " x86"); await Task.Delay(750); if (!Directory.Exists(plugins_x86)) { Directory.CreateDirectory(plugins_x86); } ProgressControl.updateProgressLabel("Installing " + pluginName + " x86"); if (File.Exists(Path.Combine(plugins_x86, pluginName + ".dll"))) { File.Delete(Path.Combine(plugins_x86, pluginName + ".dll")); } File.Move(@".\modpolice\bin\plugins\" + pluginName + ".dll", Path.Combine(plugins_x86, pluginName + ".dll")); ProgressControl.updateProgressLabel("Installing " + pluginName + " x64"); await Task.Delay(750); if (!Directory.Exists(plugins_x64)) { Directory.CreateDirectory(plugins_x64); } ProgressControl.updateProgressLabel("Installing " + pluginName + " x64"); if (File.Exists(Path.Combine(plugins_x64, pluginName + ".dll"))) { File.Delete(Path.Combine(plugins_x64, pluginName + ".dll")); } File.Move(@".\modpolice\bin64\plugins\" + pluginName + ".dll", Path.Combine(plugins_x64, pluginName + ".dll")); if (pluginName == "loginhelper") { ProgressControl.updateProgressLabel("Searching for use-ingame-login.xml"); await Task.Delay(750); if (!File.Exists(login_xml)) { ProgressControl.updateProgressLabel("patches.xml not found, installing..."); if (!Directory.Exists(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments), "BnS", "patches"))) { Directory.CreateDirectory(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments), "BnS", "patches")); } File.WriteAllText(login_xml, Properties.Resources.use_ingame_login); } } ProgressControl.updateProgressLabel("All done, just tidying up."); await client.LogoutAsync(); } catch (Exception ex) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel(ex.Message); await Task.Delay(7000); } }); ProgressGrid.Visibility = Visibility.Hidden; MainGrid.Visibility = Visibility.Visible; ProgressPanel.Children.Clear(); _progressControl = null; //Check if loginhelper is installed loginHelper_installed = (File.Exists(Path.Combine(plugins_x86, pluginName + ".dll")) && File.Exists(Path.Combine(plugins_x64, pluginName + ".dll"))); charselect_installed = (File.Exists(Path.Combine(plugins_x86, "charselect.dll")) && File.Exists(Path.Combine(plugins_x64, "charselect.dll"))); await Task.Run(async() => await checkOnlineVersion()); }
private async Task checkOnlineVersions() { #region pluginloader if ((File.Exists(SystemConfig.SYS.BNS_DIR + @"\bin\winmm.dll") && File.Exists(SystemConfig.SYS.BNS_DIR + @"\bin64\winmm.dll"))) { pluginloader = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + @"\bin\winmm.dll"); } else { pluginloader = null; } Dispatchers.labelContent(pluginloaderLabel, String.Format("Current: {0}", (pluginloader != null) ? pluginloader.modificationTime.ToString("MM-dd-yy") : "Not Installed")); #endregion #region bnspatch if ((File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86 + "bnspatch.dll") && File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64 + "bnspatch.dll"))) { bnspatchPlugin = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x86 + "bnspatch.dll"); } else { bnspatchPlugin = null; } Dispatchers.labelContent(bnspatchLabel, String.Format("Current: {0}", (bnspatchPlugin != null) ? bnspatchPlugin.modificationTime.ToString("MM-dd-yy") : "Not Installed")); #endregion #region bnsnogg if ((File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86 + "bnsnogg.dll") && File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64 + "bnsnogg.dll"))) { bnsnoggPlugin = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x64 + "bnsnogg.dll"); } else { bnsnoggPlugin = null; } Dispatchers.labelContent(bnsnogglocalLabel, String.Format("Current: {0}", (bnsnoggPlugin != null) ? bnsnoggPlugin.modificationTime.ToString("MM-dd-yy") : "Not Installed")); #endregion #region lessloadingscreen Dispatchers.btnIsEnabled(lessloadingInstall, false); if ((File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86 + "lessloadingscreens.dll") && File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64 + "lessloadingscreens.dll"))) { lessLoadingScreen = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x86 + "lessloadingscreens.dll"); Dispatchers.toggleIsChecked(lessloadingToggle, true); } else if ((File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86 + "lessloadingscreens.dll.off") && File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64 + "lessloadingscreens.dll.off"))) { lessLoadingScreen = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x86 + "lessloadingscreens.dll.off"); } Dispatchers.labelContent(lessloadingCurrentLbl, String.Format("Current: {0}", (lessLoadingScreen != null) ? lessLoadingScreen.modificationTime.ToString("MM-dd-yy") : "Not Installed")); #endregion #region simplemodetrainingroom Dispatchers.btnIsEnabled(simplemodeInstall, false); if ((File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86 + "simplemodetrainingroom.dll") && File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64 + "simplemodetrainingroom.dll"))) { simplemodeTraining = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x86 + "simplemodetrainingroom.dll"); Dispatchers.toggleIsChecked(simplemodeToggle, true); } else if ((File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86 + "simplemodetrainingroom.dll.off") && File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64 + "simplemodetrainingroom.dll.off"))) { simplemodeTraining = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x86 + "simplemodetrainingroom.dll.off"); } Dispatchers.labelContent(SimplemodeCurrentLbl, String.Format("Current: {0}", (simplemodeTraining != null) ? simplemodeTraining.modificationTime.ToString("MM-dd-yy") : "Not Installed")); #endregion #region highpriorityplugin Dispatchers.btnIsEnabled(HighpriorityInstall, false); if ((File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86 + "highpriority.dll") && File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64 + "highpriority.dll"))) { highpriorityplugin = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x86 + "highpriority.dll"); Dispatchers.toggleIsChecked(HighpriorityToggle, true); } else if ((File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86 + "highpriority.dll.off") && File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64 + "highpriority.dll.off"))) { highpriorityplugin = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x86 + "highpriority.dll.off"); } Dispatchers.labelContent(HighpriorityCurrentLbl, String.Format("Current: {0}", (highpriorityplugin != null) ? highpriorityplugin.modificationTime.ToString("MM-dd-yy") : "Not Installed")); #endregion try { var client = new MegaApiClient(); await client.LoginAnonymousAsync(); IEnumerable <INode> nodes = await client.GetNodesFromLinkAsync(new Uri("https://mega.nz/folder/WXhzUZ7Y#XzlqkPa8DU4X8xrILQDdZA")); INode lessloading_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("lessloadingscreens")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); INode simplemode_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("simplemodetrainingroom")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); INode highpriority_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("highpriority")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); INode bnspatch_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("bnspatch")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); INode pluginloader_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("pluginloader")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); INode bnsnogg_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("bnsnogg")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); //This seems dumb but yeah Regex pattern = new Regex(@"^(?<fileName>[\w\\.]+)_(?<date>[\w\\.]{10})(?<ext>[\w\\.]+)"); DateTime highpriority_date = DateTime.Parse(pattern.Match(highpriority_node.Name).Groups["date"].Value); DateTime lessloading_date = DateTime.Parse(pattern.Match(lessloading_node.Name).Groups["date"].Value); DateTime simplemode_date = DateTime.Parse(pattern.Match(simplemode_node.Name).Groups["date"].Value); DateTime pluginloader_date = DateTime.Parse(pattern.Match(pluginloader_node.Name).Groups["date"].Value); DateTime bnspatch_date = DateTime.Parse(pattern.Match(bnspatch_node.Name).Groups["date"].Value); DateTime bnsnogg_date = DateTime.Parse(pattern.Match(bnsnogg_node.Name).Groups["date"].Value); #region checkforlessloadingscreens if (lessLoadingScreen != null) { if (lessLoadingScreen.modificationTime < lessloading_date) { Dispatchers.btnIsEnabled(lessloadingInstall, true); } else { Dispatchers.btnIsEnabled(lessloadingInstall, false); } } else { Dispatchers.btnIsEnabled(lessloadingInstall, true); } #endregion #region checkforsimplemode if (simplemodeTraining != null) { if (simplemodeTraining.modificationTime < simplemode_date) { Dispatchers.btnIsEnabled(simplemodeInstall, true); } else { Dispatchers.btnIsEnabled(simplemodeInstall, false); } } else { Dispatchers.btnIsEnabled(simplemodeInstall, true); } #endregion #region checkforhighpriority if (highpriorityplugin != null) { if (highpriorityplugin.modificationTime < highpriority_date) { Dispatchers.btnIsEnabled(HighpriorityInstall, true); } else { Dispatchers.btnIsEnabled(HighpriorityInstall, false); } } else { Dispatchers.btnIsEnabled(HighpriorityInstall, true); } #endregion Dispatchers.labelContent(lessloadingOnlineLbl, String.Format("Online: {0}", lessloading_date.ToString("MM-dd-yy"))); Dispatchers.labelContent(SimplemodeOnlineLbl, String.Format("Online: {0}", simplemode_date.ToString("MM-dd-yy"))); Dispatchers.labelContent(HighpriorityOnlineLbl, String.Format("Online: {0}", highpriority_date.ToString("MM-dd-yy"))); Dispatchers.labelContent(bnspatchOnlineLbl, String.Format("Online: {0}", bnspatch_date.ToString("MM-dd-yy"))); Dispatchers.labelContent(pluginloaderOnlineLbl, String.Format("Online: {0}", pluginloader_date.ToString("MM-dd-yy"))); Dispatchers.labelContent(bnsnoggOnlineLabel, String.Format("Online: {0}", bnsnogg_date.ToString("MM-dd-yy"))); } catch (Exception ex) { Debug.WriteLine(ex.Message); } toggleControl = true; }
private async void installBNSNOGG(object sender, RoutedEventArgs e) { _progressControl = new ProgressControl(); ProgressGrid.Visibility = Visibility.Visible; MainGrid.Visibility = Visibility.Collapsed; ProgressPanel.Children.Add(_progressControl); try { ProgressControl.updateProgressLabel("Logging into Mega anonymously..."); var client = new MegaApiClient(); await client.LoginAnonymousAsync(); if (!Directory.Exists("modpolice")) { Directory.CreateDirectory("modpolice"); } ProgressControl.updateProgressLabel("Retrieving file list..."); IEnumerable <INode> nodes = await client.GetNodesFromLinkAsync(new Uri("https://mega.nz/folder/WXhzUZ7Y#XzlqkPa8DU4X8xrILQDdZA")); INode currentNode = null; IProgress <double> progress = new Progress <double>(x => ProgressControl.updateProgressLabel(String.Format("Downloading: {0} ({1}%)", currentNode.Name, Math.Round(x)))); //Find our latest nodes for download INode bnsnogg_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("bnsnogg")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); if (bnsnogg_node == null) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel("Error retrieving pluginloader"); } else { currentNode = bnsnogg_node; if (File.Exists(@"modpolice\" + bnsnogg_node.Name)) { File.Delete(@"modpolice\" + bnsnogg_node.Name); } ProgressControl.errorSadPeepo(Visibility.Hidden); await client.DownloadFileAsync(currentNode, @"modpolice\" + bnsnogg_node.Name, progress); } ProgressControl.updateProgressLabel("All done, logging out..."); string _BNSNOGG_VERSION = Directory.EnumerateFiles(Environment.CurrentDirectory + @"\modpolice\").Select(x => Path.GetFileName(x)) .Where(Name => Path.GetExtension(Name) == ".zip" && Name.Contains("bnsnogg")) .OrderByDescending(d => new FileInfo(d).Name) .Select(Name => Path.GetFileNameWithoutExtension(Name)).First().ToString(); ProgressControl.updateProgressLabel("Unzipping " + _BNSNOGG_VERSION); ExtractZipFileToDirectory(@".\modpolice\" + _BNSNOGG_VERSION + ".zip", @".\modpolice", true); //pluginloader x86 if (File.Exists(SystemConfig.SYS.BNS_DIR + bin_x86 + "version.dll")) { File.Delete(SystemConfig.SYS.BNS_DIR + bin_x86 + "version.dll"); } ProgressControl.updateProgressLabel("Installing bnsnogg x86"); await Task.Delay(750); File.Move(@".\modpolice\bin\version.dll", SystemConfig.SYS.BNS_DIR + bin_x86 + "version.dll"); //pluginloader x64 if (File.Exists(SystemConfig.SYS.BNS_DIR + bin_x64 + "version.dll")) { File.Delete(SystemConfig.SYS.BNS_DIR + bin_x64 + "version.dll"); } ProgressControl.updateProgressLabel("Installing bnsnogg x64"); await Task.Delay(750); File.Move(@".\modpolice\bin64\version.dll", SystemConfig.SYS.BNS_DIR + bin_x64 + "version.dll"); if (!Directory.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86)) { Directory.CreateDirectory(SystemConfig.SYS.BNS_DIR + plugins_x86); } if (File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86 + "bnsnogg.dll")) { File.Delete(SystemConfig.SYS.BNS_DIR + plugins_x86 + "bnsnogg.dll"); } File.Move(@".\modpolice\bin\plugins\bnsnogg.dll", SystemConfig.SYS.BNS_DIR + plugins_x86 + "bnsnogg.dll"); if (!Directory.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64)) { Directory.CreateDirectory(SystemConfig.SYS.BNS_DIR + plugins_x64); } if (File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64 + "bnsnogg.dll")) { File.Delete(SystemConfig.SYS.BNS_DIR + plugins_x64 + "bnsnogg.dll"); } File.Move(@".\modpolice\bin64\plugins\bnsnogg.dll", SystemConfig.SYS.BNS_DIR + plugins_x64 + "bnsnogg.dll"); ProgressControl.updateProgressLabel("bnsnogg successfully installed"); await Task.Delay(2000); } catch (Exception ex) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel(ex.Message); await Task.Delay(7000); } try { ProgressGrid.Visibility = Visibility.Hidden; MainGrid.Visibility = Visibility.Visible; ProgressPanel.Children.Clear(); _progressControl = null; bnsnoggPlugin = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x64 + "bnsnogg.dll"); Dispatchers.labelContent(bnsnogglocalLabel, String.Format("Current: {0}", (bnsnoggPlugin != null) ? bnsnoggPlugin.modificationTime.ToString("MM-dd-yy") : "Not Installed")); } catch (Exception) { //Why are we here, is it just to suffer? } }
private async void installModPolice(object sender, RoutedEventArgs e) { _progressControl = new ProgressControl(); ProgressGrid.Visibility = Visibility.Visible; MainGrid.Visibility = Visibility.Collapsed; ProgressPanel.Children.Add(_progressControl); if (((Button)sender).Name == "installOnline") { try { ProgressControl.updateProgressLabel("Logging into Mega anonymously..."); var client = new MegaApiClient(); await client.LoginAnonymousAsync(); if (!Directory.Exists("modpolice")) { Directory.CreateDirectory("modpolice"); } ProgressControl.updateProgressLabel("Retrieving file list..."); IEnumerable <INode> nodes = await client.GetNodesFromLinkAsync(new Uri("https://mega.nz/folder/WXhzUZ7Y#XzlqkPa8DU4X8xrILQDdZA")); INode currentNode = null; IProgress <double> progress = new Progress <double>(x => ProgressControl.updateProgressLabel(String.Format("Downloading: {0} ({1}%)", currentNode.Name, Math.Round(x)))); //Find our latest nodes for download INode bnspatch_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("bnspatch")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); INode pluginloader_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("pluginloader")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); if (pluginloader_node == null) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel("Error retrieving pluginloader"); } else { currentNode = pluginloader_node; if (File.Exists(@"modpolice\" + pluginloader_node.Name)) { File.Delete(@"modpolice\" + pluginloader_node.Name); } ProgressControl.errorSadPeepo(Visibility.Hidden); await client.DownloadFileAsync(currentNode, @"modpolice\" + pluginloader_node.Name, progress); } if (pluginloader_node == null) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel("Error retrieving pluginloader"); } else { currentNode = bnspatch_node; if (File.Exists(@"modpolice\" + bnspatch_node.Name)) { File.Delete(@"modpolice\" + bnspatch_node.Name); } ProgressControl.errorSadPeepo(Visibility.Hidden); await client.DownloadFileAsync(currentNode, @"modpolice\" + bnspatch_node.Name, progress); } ProgressControl.updateProgressLabel("All done, logging out..."); } catch (Exception ex) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel(ex.Message); await Task.Delay(3000); } } try { string _BNSPATCH_VERSION = Directory.EnumerateFiles(Environment.CurrentDirectory + @"\modpolice\").Select(x => Path.GetFileName(x)) .Where(Name => Path.GetExtension(Name) == ".zip" && Name.Contains("bnspatch")) .OrderByDescending(d => new FileInfo(d).Name) .Select(Name => Path.GetFileNameWithoutExtension(Name)).First().ToString(); string _PLUGINLOADER_VERSION = Directory.EnumerateFiles(Environment.CurrentDirectory + @"\modpolice\").Select(x => Path.GetFileName(x)) .Where(Name => Path.GetExtension(Name) == ".zip" && Name.Contains("pluginloader")) .OrderByDescending(d => new FileInfo(d).Name) .Select(Name => Path.GetFileNameWithoutExtension(Name)).First().ToString(); ProgressControl.updateProgressLabel("Unzipping " + _PLUGINLOADER_VERSION); ExtractZipFileToDirectory(@".\modpolice\" + _PLUGINLOADER_VERSION + ".zip", @".\modpolice", true); await Task.Delay(750); ProgressControl.updateProgressLabel("Unzipping " + _BNSPATCH_VERSION); ExtractZipFileToDirectory(@".\modpolice\" + _BNSPATCH_VERSION + ".zip", @".\modpolice", true); //pluginloader x86 if (File.Exists(SystemConfig.SYS.BNS_DIR + bin_x86 + "winmm.dll")) { File.Delete(SystemConfig.SYS.BNS_DIR + bin_x86 + "winmm.dll"); } ProgressControl.updateProgressLabel("Installing pluginloader x86"); await Task.Delay(750); File.Move(@".\modpolice\bin\winmm.dll", SystemConfig.SYS.BNS_DIR + bin_x86 + "winmm.dll"); //pluginloader x64 if (File.Exists(SystemConfig.SYS.BNS_DIR + bin_x64 + "winmm.dll")) { File.Delete(SystemConfig.SYS.BNS_DIR + bin_x64 + "winmm.dll"); } ProgressControl.updateProgressLabel("Installing pluginloader x64"); await Task.Delay(750); File.Move(@".\modpolice\bin64\winmm.dll", SystemConfig.SYS.BNS_DIR + bin_x64 + "winmm.dll"); //bnspatch x86 ProgressControl.updateProgressLabel("Checking if plugins folder exists for x86"); await Task.Delay(500); if (!Directory.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86)) { Directory.CreateDirectory(SystemConfig.SYS.BNS_DIR + plugins_x86); } ProgressControl.updateProgressLabel("Installing bnspatch x86"); if (File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86 + "bnspatch.dll")) { File.Delete(SystemConfig.SYS.BNS_DIR + plugins_x86 + "bnspatch.dll"); } File.Move(@".\modpolice\bin\plugins\bnspatch.dll", SystemConfig.SYS.BNS_DIR + plugins_x86 + "bnspatch.dll"); //bnspatch x64 ProgressControl.updateProgressLabel("Checking if plugins folder exists for x64"); await Task.Delay(500); if (!Directory.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64)) { Directory.CreateDirectory(SystemConfig.SYS.BNS_DIR + plugins_x64); } ProgressControl.updateProgressLabel("Installing bnspatch x64"); if (File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64 + "bnspatch.dll")) { File.Delete(SystemConfig.SYS.BNS_DIR + plugins_x64 + "bnspatch.dll"); } File.Move(@".\modpolice\bin64\plugins\bnspatch.dll", SystemConfig.SYS.BNS_DIR + plugins_x64 + "bnspatch.dll"); ProgressControl.updateProgressLabel("Searching for patches.xml"); await Task.Delay(500); if (!File.Exists(patches_xml)) { ProgressControl.updateProgressLabel("patches.xml not found, installing..."); File.WriteAllText(patches_xml, Properties.Resources.patches); } ProgressControl.updateProgressLabel("pluginloader & bnspatch successfully installed"); await Task.Delay(2000); } catch (Exception ex) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel(ex.Message); await Task.Delay(7000); } try { ProgressGrid.Visibility = Visibility.Hidden; MainGrid.Visibility = Visibility.Visible; ProgressPanel.Children.Clear(); _progressControl = null; //Get the file info and display version for pluginloader pluginloader = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + @"\bin\" + "winmm.dll"); Dispatchers.labelContent(pluginloaderLabel, String.Format("Current: {0}", (pluginloader != null) ? pluginloader.modificationTime.ToString("MM-dd-yy") : "Not Installed")); bnspatchPlugin = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x86 + "bnspatch.dll"); Dispatchers.labelContent(bnspatchLabel, String.Format("Current: {0}", (bnspatchPlugin != null) ? bnspatchPlugin.modificationTime.ToString("MM-dd-yy") : "Not Installed")); } catch (Exception) { //Why are we here, is it just to suffer? } //refreshSomeShit(); }
private async void installAdditional(object sender, RoutedEventArgs e) { string pluginName; switch (((Button)sender).Name) { case "simplemodeInstall": pluginName = "simplemodetrainingroom"; break; case "lessloadingInstall": pluginName = "lessloadingscreens"; break; default: pluginName = "highpriority"; break; } toggleControl = false; _progressControl = new ProgressControl(); ProgressGrid.Visibility = Visibility.Visible; MainGrid.Visibility = Visibility.Collapsed; ProgressPanel.Children.Add(_progressControl); try { if (!Directory.Exists("modpolice")) { Directory.CreateDirectory("modpolice"); } ProgressControl.updateProgressLabel("Logging into Mega"); var client = new MegaApiClient(); await client.LoginAnonymousAsync(); ProgressControl.updateProgressLabel("Retrieving file list..."); IEnumerable <INode> nodes = await client.GetNodesFromLinkAsync(new Uri("https://mega.nz/folder/WXhzUZ7Y#XzlqkPa8DU4X8xrILQDdZA")); INode currentNode = null; IProgress <double> progress = new Progress <double>(x => ProgressControl.updateProgressLabel(String.Format("Downloading: {0} ({1}%)", currentNode.Name, Math.Round(x)))); INode pluginNode = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains(pluginName)).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); if (pluginNode == null) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel("Something went wrong getting the node"); await Task.Delay(5000); toggleControl = true; return; } if (File.Exists(@"modpolice\" + pluginNode.Name)) { File.Delete(@"modpolice\" + pluginNode.Name); } currentNode = pluginNode; await client.DownloadFileAsync(currentNode, @"modpolice\" + pluginNode.Name, progress); ProgressControl.updateProgressLabel("Unzipping: " + pluginNode.Name); await Task.Delay(750); Modpolice.ExtractZipFileToDirectory(@".\modpolice\" + pluginNode.Name, @".\modpolice", true); ProgressControl.updateProgressLabel("Installing " + pluginName + " x86"); await Task.Delay(750); if (!Directory.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86)) { Directory.CreateDirectory(SystemConfig.SYS.BNS_DIR + plugins_x86); } //Delete the current plugin dll if (File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86 + pluginName + ".dll")) { File.Delete(SystemConfig.SYS.BNS_DIR + plugins_x86 + pluginName + ".dll"); } //Make sure there isn't a plugin dll that is in an off state if (File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x86 + pluginName + ".dll.off")) { File.Delete(SystemConfig.SYS.BNS_DIR + plugins_x86 + pluginName + ".dll.off"); } File.Move(@".\modpolice\bin\plugins\" + pluginName + ".dll", SystemConfig.SYS.BNS_DIR + plugins_x86 + pluginName + ".dll"); ProgressControl.updateProgressLabel("Installing " + pluginName + " x64"); await Task.Delay(750); if (!Directory.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64)) { Directory.CreateDirectory(SystemConfig.SYS.BNS_DIR + plugins_x64); } //Delete the current plugin dll if (File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64 + pluginName + ".dll")) { File.Delete(SystemConfig.SYS.BNS_DIR + plugins_x64 + pluginName + ".dll"); } //Make sure there isn't a plugin dll that is in an off state if (File.Exists(SystemConfig.SYS.BNS_DIR + plugins_x64 + pluginName + ".dll.off")) { File.Delete(SystemConfig.SYS.BNS_DIR + plugins_x64 + pluginName + ".dll.off"); } File.Move(@".\modpolice\bin64\plugins\" + pluginName + ".dll", SystemConfig.SYS.BNS_DIR + plugins_x64 + pluginName + ".dll"); ProgressControl.updateProgressLabel("All done"); await Task.Delay(750); await client.LogoutAsync(); } catch (Exception ex) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel(ex.Message); await Task.Delay(7000); } try { ProgressGrid.Visibility = Visibility.Hidden; MainGrid.Visibility = Visibility.Visible; ProgressPanel.Children.Clear(); _progressControl = null; toggleControl = true; if (pluginName == "simplemodetrainingroom") { simplemodeTraining = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x86 + "simplemodetrainingroom.dll"); Dispatchers.toggleIsChecked(simplemodeToggle, true); Dispatchers.labelContent(SimplemodeCurrentLbl, String.Format("Current: {0}", (simplemodeTraining != null) ? simplemodeTraining.modificationTime.ToString("MM-dd-yy") : "Not Installed")); } else if (pluginName == "lessloadingscreens") { lessLoadingScreen = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x86 + "lessloadingscreens.dll"); Dispatchers.toggleIsChecked(lessloadingToggle, true); Dispatchers.labelContent(lessloadingCurrentLbl, String.Format("Current: {0}", (lessLoadingScreen != null) ? lessLoadingScreen.modificationTime.ToString("MM-dd-yy") : "Not Installed")); } else { highpriorityplugin = new pluginFileInfo(SystemConfig.SYS.BNS_DIR + plugins_x86 + "highpriority.dll"); Dispatchers.toggleIsChecked(HighpriorityToggle, true); Dispatchers.labelContent(HighpriorityCurrentLbl, String.Format("Current: {0}", (highpriorityplugin != null) ? highpriorityplugin.modificationTime.ToString("MM-dd-yy") : "Not Installed")); } Dispatchers.btnIsEnabled((Button)sender, false); } catch (Exception) { //F**K ASS C**T } }
private async void checkForUpdate(object sender, RoutedEventArgs e) { bool _bnspatchUpdate = false; bool _pluginloaderUpdate = false; await Task.Run(async() => { if (!Directory.Exists("modpolice")) { return; } try { var client = new MegaApiClient(); await client.LoginAnonymousAsync(); IEnumerable <INode> nodes = await client.GetNodesFromLinkAsync(new Uri("https://mega.nz/folder/WXhzUZ7Y#XzlqkPa8DU4X8xrILQDdZA")); INode bnspatch_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("bnspatch")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); INode pluginloader_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("pluginloader")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); if (pluginloader_node == null) { return; } if (bnspatch_node == null) { return; } string _BNSPATCH_VERSION = Directory.EnumerateFiles(Environment.CurrentDirectory + @"\modpolice\").Select(x => Path.GetFileName(x)) .Where(Name => Path.GetExtension(Name) == ".zip" && Name.Contains("bnspatch")) .OrderByDescending(d => new FileInfo(d).Name) .Select(Name => Path.GetFileName(Name)).First().ToString(); string _PLUGINLOADER_VERSION = Directory.EnumerateFiles(Environment.CurrentDirectory + @"\modpolice\").Select(x => Path.GetFileName(x)) .Where(Name => Path.GetExtension(Name) == ".zip" && Name.Contains("pluginloader")) .OrderByDescending(d => new FileInfo(d).Name) .Select(Name => Path.GetFileName(Name)).First().ToString(); if (bnspatch_node.Name != _BNSPATCH_VERSION) { _bnspatchUpdate = true; } if (pluginloader_node.Name != _PLUGINLOADER_VERSION) { _pluginloaderUpdate = true; } } catch (Exception) { } }); if (_bnspatchUpdate) { bnspatchLabel.Content = "BNS Patch: UPDATE AVAILABLE"; } if (_pluginloaderUpdate) { pluginloaderLabel.Content = "Plugin Loader: UPDATE AVAILABLE"; } }
private async void downloadClick(object sender, RoutedEventArgs e) { _progressControl = new ProgressControl(); ProgressGrid.Visibility = Visibility.Visible; MainGrid.Visibility = Visibility.Collapsed; ProgressPanel.Children.Add(_progressControl); await Task.Run(async() => { try { ProgressControl.updateProgressLabel("Logging into Mega anonymously..."); var client = new MegaApiClient(); await client.LoginAnonymousAsync(); if (!Directory.Exists("modpolice")) { Directory.CreateDirectory("modpolice"); } ProgressControl.updateProgressLabel("Retrieving file list..."); IEnumerable <INode> nodes = await client.GetNodesFromLinkAsync(new Uri("https://mega.nz/folder/WXhzUZ7Y#XzlqkPa8DU4X8xrILQDdZA")); INode currentNode = null; IProgress <double> progress = new Progress <double>(x => ProgressControl.updateProgressLabel(String.Format("Downloading: {0} ({1}%)", currentNode.Name, Math.Round(x)))); //Find our latest nodes for download INode bnspatch_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("bnspatch")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); INode pluginloader_node = nodes.Where(x => x.Type == NodeType.File && x.Name.Contains("pluginloader")).OrderByDescending(t => t.ModificationDate).FirstOrDefault(); if (pluginloader_node == null) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel("Errorr retrieving pluginloader"); } else { currentNode = pluginloader_node; if (File.Exists(@"modpolice\" + pluginloader_node.Name)) { File.Delete(@"modpolice\" + pluginloader_node.Name); } ProgressControl.errorSadPeepo(Visibility.Hidden); await client.DownloadFileAsync(currentNode, @"modpolice\" + pluginloader_node.Name, progress); } if (pluginloader_node == null) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel("Errorr retrieving pluginloader"); } else { currentNode = bnspatch_node; if (File.Exists(@"modpolice\" + bnspatch_node.Name)) { File.Delete(@"modpolice\" + bnspatch_node.Name); } ProgressControl.errorSadPeepo(Visibility.Hidden); await client.DownloadFileAsync(currentNode, @"modpolice\" + bnspatch_node.Name, progress); } ProgressControl.updateProgressLabel("All done, logging out..."); await client.LogoutAsync(); ProgressControl.updateProgressLabel("Peepo berry happy!"); Thread.Sleep(1500); } catch (Exception ex) { ProgressControl.errorSadPeepo(Visibility.Visible); ProgressControl.updateProgressLabel(ex.Message); Thread.Sleep(4000); } }); ProgressGrid.Visibility = Visibility.Hidden; MainGrid.Visibility = Visibility.Visible; ProgressPanel.Children.Clear(); _progressControl = null; }