diff --git a/BUILDS/net6.0/PluginManager.dll b/BUILDS/net6.0/PluginManager.dll
index 809d3de..8c7315b 100644
Binary files a/BUILDS/net6.0/PluginManager.dll and b/BUILDS/net6.0/PluginManager.dll differ
diff --git a/DiscordBotGUI/.gitignore b/DiscordBotGUI/.gitignore
deleted file mode 100644
index 8afdcb6..0000000
--- a/DiscordBotGUI/.gitignore
+++ /dev/null
@@ -1,454 +0,0 @@
-## Ignore Visual Studio temporary files, build results, and
-## files generated by popular Visual Studio add-ons.
-##
-## Get latest from https://github.com/github/gitignore/blob/master/VisualStudio.gitignore
-
-# User-specific files
-*.rsuser
-*.suo
-*.user
-*.userosscache
-*.sln.docstates
-
-# User-specific files (MonoDevelop/Xamarin Studio)
-*.userprefs
-
-# Mono auto generated files
-mono_crash.*
-
-# Build results
-[Dd]ebug/
-[Dd]ebugPublic/
-[Rr]elease/
-[Rr]eleases/
-x64/
-x86/
-[Ww][Ii][Nn]32/
-[Aa][Rr][Mm]/
-[Aa][Rr][Mm]64/
-bld/
-[Bb]in/
-[Oo]bj/
-[Ll]og/
-[Ll]ogs/
-
-# Visual Studio 2015/2017 cache/options directory
-.vs/
-# Uncomment if you have tasks that create the project's static files in wwwroot
-#wwwroot/
-
-# Visual Studio 2017 auto generated files
-Generated\ Files/
-
-# MSTest test Results
-[Tt]est[Rr]esult*/
-[Bb]uild[Ll]og.*
-
-# NUnit
-*.VisualState.xml
-TestResult.xml
-nunit-*.xml
-
-# Build Results of an ATL Project
-[Dd]ebugPS/
-[Rr]eleasePS/
-dlldata.c
-
-# Benchmark Results
-BenchmarkDotNet.Artifacts/
-
-# .NET Core
-project.lock.json
-project.fragment.lock.json
-artifacts/
-
-# Tye
-.tye/
-
-# ASP.NET Scaffolding
-ScaffoldingReadMe.txt
-
-# StyleCop
-StyleCopReport.xml
-
-# Files built by Visual Studio
-*_i.c
-*_p.c
-*_h.h
-*.ilk
-*.meta
-*.obj
-*.iobj
-*.pch
-*.pdb
-*.ipdb
-*.pgc
-*.pgd
-*.rsp
-*.sbr
-*.tlb
-*.tli
-*.tlh
-*.tmp
-*.tmp_proj
-*_wpftmp.csproj
-*.log
-*.vspscc
-*.vssscc
-.builds
-*.pidb
-*.svclog
-*.scc
-
-# Chutzpah Test files
-_Chutzpah*
-
-# Visual C++ cache files
-ipch/
-*.aps
-*.ncb
-*.opendb
-*.opensdf
-*.sdf
-*.cachefile
-*.VC.db
-*.VC.VC.opendb
-
-# Visual Studio profiler
-*.psess
-*.vsp
-*.vspx
-*.sap
-
-# Visual Studio Trace Files
-*.e2e
-
-# TFS 2012 Local Workspace
-$tf/
-
-# Guidance Automation Toolkit
-*.gpState
-
-# ReSharper is a .NET coding add-in
-_ReSharper*/
-*.[Rr]e[Ss]harper
-*.DotSettings.user
-
-# TeamCity is a build add-in
-_TeamCity*
-
-# DotCover is a Code Coverage Tool
-*.dotCover
-
-# AxoCover is a Code Coverage Tool
-.axoCover/*
-!.axoCover/settings.json
-
-# Coverlet is a free, cross platform Code Coverage Tool
-coverage*.json
-coverage*.xml
-coverage*.info
-
-# Visual Studio code coverage results
-*.coverage
-*.coveragexml
-
-# NCrunch
-_NCrunch_*
-.*crunch*.local.xml
-nCrunchTemp_*
-
-# MightyMoose
-*.mm.*
-AutoTest.Net/
-
-# Web workbench (sass)
-.sass-cache/
-
-# Installshield output folder
-[Ee]xpress/
-
-# DocProject is a documentation generator add-in
-DocProject/buildhelp/
-DocProject/Help/*.HxT
-DocProject/Help/*.HxC
-DocProject/Help/*.hhc
-DocProject/Help/*.hhk
-DocProject/Help/*.hhp
-DocProject/Help/Html2
-DocProject/Help/html
-
-# Click-Once directory
-publish/
-
-# Publish Web Output
-*.[Pp]ublish.xml
-*.azurePubxml
-# Note: Comment the next line if you want to checkin your web deploy settings,
-# but database connection strings (with potential passwords) will be unencrypted
-*.pubxml
-*.publishproj
-
-# Microsoft Azure Web App publish settings. Comment the next line if you want to
-# checkin your Azure Web App publish settings, but sensitive information contained
-# in these scripts will be unencrypted
-PublishScripts/
-
-# NuGet Packages
-*.nupkg
-# NuGet Symbol Packages
-*.snupkg
-# The packages folder can be ignored because of Package Restore
-**/[Pp]ackages/*
-# except build/, which is used as an MSBuild target.
-!**/[Pp]ackages/build/
-# Uncomment if necessary however generally it will be regenerated when needed
-#!**/[Pp]ackages/repositories.config
-# NuGet v3's project.json files produces more ignorable files
-*.nuget.props
-*.nuget.targets
-
-# Microsoft Azure Build Output
-csx/
-*.build.csdef
-
-# Microsoft Azure Emulator
-ecf/
-rcf/
-
-# Windows Store app package directories and files
-AppPackages/
-BundleArtifacts/
-Package.StoreAssociation.xml
-_pkginfo.txt
-*.appx
-*.appxbundle
-*.appxupload
-
-# Visual Studio cache files
-# files ending in .cache can be ignored
-*.[Cc]ache
-# but keep track of directories ending in .cache
-!?*.[Cc]ache/
-
-# Others
-ClientBin/
-~$*
-*~
-*.dbmdl
-*.dbproj.schemaview
-*.jfm
-*.pfx
-*.publishsettings
-orleans.codegen.cs
-
-# Including strong name files can present a security risk
-# (https://github.com/github/gitignore/pull/2483#issue-259490424)
-#*.snk
-
-# Since there are multiple workflows, uncomment next line to ignore bower_components
-# (https://github.com/github/gitignore/pull/1529#issuecomment-104372622)
-#bower_components/
-
-# RIA/Silverlight projects
-Generated_Code/
-
-# Backup & report files from converting an old project file
-# to a newer Visual Studio version. Backup files are not needed,
-# because we have git ;-)
-_UpgradeReport_Files/
-Backup*/
-UpgradeLog*.XML
-UpgradeLog*.htm
-ServiceFabricBackup/
-*.rptproj.bak
-
-# SQL Server files
-*.mdf
-*.ldf
-*.ndf
-
-# Business Intelligence projects
-*.rdl.data
-*.bim.layout
-*.bim_*.settings
-*.rptproj.rsuser
-*- [Bb]ackup.rdl
-*- [Bb]ackup ([0-9]).rdl
-*- [Bb]ackup ([0-9][0-9]).rdl
-
-# Microsoft Fakes
-FakesAssemblies/
-
-# GhostDoc plugin setting file
-*.GhostDoc.xml
-
-# Node.js Tools for Visual Studio
-.ntvs_analysis.dat
-node_modules/
-
-# Visual Studio 6 build log
-*.plg
-
-# Visual Studio 6 workspace options file
-*.opt
-
-# Visual Studio 6 auto-generated workspace file (contains which files were open etc.)
-*.vbw
-
-# Visual Studio LightSwitch build output
-**/*.HTMLClient/GeneratedArtifacts
-**/*.DesktopClient/GeneratedArtifacts
-**/*.DesktopClient/ModelManifest.xml
-**/*.Server/GeneratedArtifacts
-**/*.Server/ModelManifest.xml
-_Pvt_Extensions
-
-# Paket dependency manager
-.paket/paket.exe
-paket-files/
-
-# FAKE - F# Make
-.fake/
-
-# CodeRush personal settings
-.cr/personal
-
-# Python Tools for Visual Studio (PTVS)
-__pycache__/
-*.pyc
-
-# Cake - Uncomment if you are using it
-# tools/**
-# !tools/packages.config
-
-# Tabs Studio
-*.tss
-
-# Telerik's JustMock configuration file
-*.jmconfig
-
-# BizTalk build output
-*.btp.cs
-*.btm.cs
-*.odx.cs
-*.xsd.cs
-
-# OpenCover UI analysis results
-OpenCover/
-
-# Azure Stream Analytics local run output
-ASALocalRun/
-
-# MSBuild Binary and Structured Log
-*.binlog
-
-# NVidia Nsight GPU debugger configuration file
-*.nvuser
-
-# MFractors (Xamarin productivity tool) working folder
-.mfractor/
-
-# Local History for Visual Studio
-.localhistory/
-
-# BeatPulse healthcheck temp database
-healthchecksdb
-
-# Backup folder for Package Reference Convert tool in Visual Studio 2017
-MigrationBackup/
-
-# Ionide (cross platform F# VS Code tools) working folder
-.ionide/
-
-# Fody - auto-generated XML schema
-FodyWeavers.xsd
-
-##
-## Visual studio for Mac
-##
-
-
-# globs
-Makefile.in
-*.userprefs
-*.usertasks
-config.make
-config.status
-aclocal.m4
-install-sh
-autom4te.cache/
-*.tar.gz
-tarballs/
-test-results/
-
-# Mac bundle stuff
-*.dmg
-*.app
-
-# content below from: https://github.com/github/gitignore/blob/master/Global/macOS.gitignore
-# General
-.DS_Store
-.AppleDouble
-.LSOverride
-
-# Icon must end with two \r
-Icon
-
-
-# Thumbnails
-._*
-
-# Files that might appear in the root of a volume
-.DocumentRevisions-V100
-.fseventsd
-.Spotlight-V100
-.TemporaryItems
-.Trashes
-.VolumeIcon.icns
-.com.apple.timemachine.donotpresent
-
-# Directories potentially created on remote AFP share
-.AppleDB
-.AppleDesktop
-Network Trash Folder
-Temporary Items
-.apdisk
-
-# content below from: https://github.com/github/gitignore/blob/master/Global/Windows.gitignore
-# Windows thumbnail cache files
-Thumbs.db
-ehthumbs.db
-ehthumbs_vista.db
-
-# Dump file
-*.stackdump
-
-# Folder config file
-[Dd]esktop.ini
-
-# Recycle Bin used on file shares
-$RECYCLE.BIN/
-
-# Windows Installer files
-*.cab
-*.msi
-*.msix
-*.msm
-*.msp
-
-# Windows shortcuts
-*.lnk
-
-# JetBrains Rider
-.idea/
-*.sln.iml
-
-##
-## Visual Studio Code
-##
-.vscode/*
-!.vscode/settings.json
-!.vscode/tasks.json
-!.vscode/launch.json
-!.vscode/extensions.json
diff --git a/DiscordBotGUI/App.axaml b/DiscordBotGUI/App.axaml
deleted file mode 100644
index 49aa2e5..0000000
--- a/DiscordBotGUI/App.axaml
+++ /dev/null
@@ -1,7 +0,0 @@
-
-
-
-
-
\ No newline at end of file
diff --git a/DiscordBotGUI/App.axaml.cs b/DiscordBotGUI/App.axaml.cs
deleted file mode 100644
index 983b886..0000000
--- a/DiscordBotGUI/App.axaml.cs
+++ /dev/null
@@ -1,21 +0,0 @@
-using Avalonia;
-using Avalonia.Controls;
-using Avalonia.Controls.ApplicationLifetimes;
-using Avalonia.Markup.Xaml;
-
-namespace DiscordBotGUI;
-
-public class App : Application
-{
- public override void Initialize()
- {
- AvaloniaXamlLoader.Load(this);
- }
-
- public override void OnFrameworkInitializationCompleted()
- {
- if (ApplicationLifetime is IClassicDesktopStyleApplicationLifetime desktop) desktop.MainWindow = new AppUpdater { Width = 300, Height = 50, WindowStartupLocation = WindowStartupLocation.CenterScreen };
-
- base.OnFrameworkInitializationCompleted();
- }
-}
diff --git a/DiscordBotGUI/AppUpdater.axaml b/DiscordBotGUI/AppUpdater.axaml
deleted file mode 100644
index 939c0d6..0000000
--- a/DiscordBotGUI/AppUpdater.axaml
+++ /dev/null
@@ -1,17 +0,0 @@
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/DiscordBotGUI/AppUpdater.axaml.cs b/DiscordBotGUI/AppUpdater.axaml.cs
deleted file mode 100644
index fcf519f..0000000
--- a/DiscordBotGUI/AppUpdater.axaml.cs
+++ /dev/null
@@ -1,170 +0,0 @@
-using Avalonia.Controls;
-using PluginManager.Online;
-using PluginManager.Others;
-using System.Threading.Tasks;
-using System;
-using System.IO;
-using System.Threading;
-using PluginManager;
-
-namespace DiscordBotGUI
-{
- public partial class AppUpdater : Window
- {
- private string _version = "";
-
- public AppUpdater()
- {
- InitializeComponent();
- Config.LoadConfig().Wait();
- if (!File.Exists("./Version.txt"))
- {
- File.WriteAllText("./Version.txt", "DiscordBotVersion=0");
- DownloadDiscordBotClientNoGUIAsDLL();
- }
-
- if (!File.Exists("./DiscordBot.exe")) DownloadDiscordBotClientNoGUIAsDLL();
- Updates();
- }
-
- private async void DownloadDiscordBotClientNoGUIAsDLL()
- {
- //await Task.Delay(5000);
- string url_bot_dll = "https://sethdiscordbot.000webhostapp.com/Storage/Discord%20Bot/Updates/DiscordBot.zip";
- int actiontype = 0; //0 - downolad, 1- extract
- IProgress progress = new Progress((percent) =>
- {
- if (actiontype == 0)
- textBox1.Text = "Downloading DiscordBot ... " + MathF.Round(percent, 2) + "%";
- else
- textBox1.Text = "Extracting package ..." + MathF.Round(percent, 2) + "%";
- this.progressBar1.Value = percent;
- });
-
- this.progressBar1.IsIndeterminate = false;
- try
- {
- await ServerCom.DownloadFileAsync(url_bot_dll, "./DiscordBot.zip", progress);
-
- actiontype++;
-
- await Functions.ExtractArchive("./DiscordBot.zip", "./", progress);
- }
- catch
- {
- textBox1.Text = "Error downloading DiscordBot.dll. Server is not responding.";
-
- await Task.Delay(1000);
-
- new MainWindow() { Height = 425, Width = 500 }.Show();
- Close();
- }
- }
-
- private async void Updates()
- {
- this.progressBar1.IsIndeterminate = true;
- await Task.Delay(1000);
- if (!await CheckForUpdates())
- {
- //await Task.Delay(5000);
- textBox1.Text = $"You are running on the latest version ({_version}) !";
- await Task.Delay(2000);
- new MainWindow() { Height = 425, Width = 650 }.Show();
- this.Close();
- return;
- }
-
- string file = await DownloadNewUpdate();
- if (file == null)
- {
- textBox1.Text = "There was an error while downloading the update !";
- await Task.Delay(2000);
- new MainWindow() { Height = 425, Width = 650 }.Show();
- this.Close();
- return;
- }
-
- IProgress progress = new Progress((percent) => { this.progressBar1.Value = percent; });
-
- textBox1.Text = "Extracting update files ...";
- await Functions.ExtractArchive(file, "./", progress);
- progressBar1.IsIndeterminate = true;
- textBox1.Text = "Setting up the new version ...";
- File.Delete(file);
- File.WriteAllText("./Version.txt", "DiscordBotVersion=" + _version);
- await Task.Delay(5000);
- new MainWindow() { Height = 425, Width = 650 }.Show();
- this.Close();
- }
-
- private async Task DownloadNewUpdate()
- {
- string urlNewUpdateZip = (await ServerCom.ReadTextFromFile("https://sethdiscordbot.000webhostapp.com/Storage/Discord%20Bot/Updates/Version"))[1];
- int secondsPast = 0;
-
- bool isDownloading = true;
- this.progressBar1.IsIndeterminate = true;
- textBox1.Text = "Downloading update ...";
-
-
- IProgress downloaded = new Progress((bytes) =>
- {
- (double, string) download = Functions.ConvertBytes(bytes);
- textBox1.Text = $"Downloading update ... {Math.Round(download.Item1 / secondsPast, 2)} {download.Item2}/s";
- });
- IProgress progress = new Progress((percent) =>
- {
- progressBar1.IsIndeterminate = false;
- this.progressBar1.Value = percent;
- });
-
-
- string FileName = $"{urlNewUpdateZip.Split('/')[urlNewUpdateZip.Split('/').Length - 1]}";
- try
- {
- new Thread(new Task(() =>
- {
- while (isDownloading)
- {
- Thread.Sleep(1000);
- secondsPast++;
- }
- }).Start).Start();
- await ServerCom.DownloadFileAsync(urlNewUpdateZip, FileName, progress, downloaded);
- }
- catch
- {
- textBox1.Text = "Error downloading the update. Server is not responding.";
- isDownloading = false;
- await Task.Delay(1000);
- return null;
- }
-
- isDownloading = false;
- return FileName;
- }
-
- private async Task CheckForUpdates()
- {
- try
- {
- string current_version = Config.GetValue("Version");
- if (current_version == null)
- if (!Config.SetValue("Version", "0"))
- Config.AddValueToVariables("Version", "0", false);
- string latest_version = (await ServerCom.ReadTextFromFile("https://sethdiscordbot.000webhostapp.com/Storage/Discord%20Bot/Updates/Version"))[0];
- _version = latest_version;
- if (current_version != latest_version) { return true; }
-
- return false;
- }
- catch (Exception ex)
- {
- textBox1.Text = "Error while checking for updates. Server is not responding.";
- Functions.WriteErrFile(ex.Message);
- return false;
- }
- }
- }
-}
diff --git a/DiscordBotGUI/DiscordBotGUI.csproj b/DiscordBotGUI/DiscordBotGUI.csproj
deleted file mode 100644
index 568b686..0000000
--- a/DiscordBotGUI/DiscordBotGUI.csproj
+++ /dev/null
@@ -1,40 +0,0 @@
-
-
- WinExe
- net6.0
- enable
-
- copyused
- true
- ..\BUILDS\DiscordBotUI\
-
-
- False
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/DiscordBotGUI/MainWindow.axaml b/DiscordBotGUI/MainWindow.axaml
deleted file mode 100644
index c011ce7..0000000
--- a/DiscordBotGUI/MainWindow.axaml
+++ /dev/null
@@ -1,39 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/DiscordBotGUI/MainWindow.axaml.cs b/DiscordBotGUI/MainWindow.axaml.cs
deleted file mode 100644
index b7cf17f..0000000
--- a/DiscordBotGUI/MainWindow.axaml.cs
+++ /dev/null
@@ -1,86 +0,0 @@
-using System.Diagnostics;
-using System.IO;
-using System.Threading.Tasks;
-using Avalonia.Controls;
-using DiscordBotGUI.Settings;
-using PluginManager;
-using PluginManager.Others;
-
-namespace DiscordBotGUI;
-
-public partial class MainWindow : Window
-{
- public MainWindow()
- {
- InitializeComponent();
-
- LoadElements();
- }
-
- private void LoadElements()
- {
- textBox3.Watermark = "Insert start arguments";
- if (File.Exists("./Version.txt")) label5.Content = Config.GetValue("Version");
- button1.Click += async (sender, e) =>
- {
- var token = textBox1.Text;
- var prefix = textBox2.Text;
- var args = "--nomessage " + textBox3.Text;
-
- if (!((token.Length == 70 || token.Length == 59) && prefix.Length == 1))
- {
- label4.Content = "Invalid Token or Prefix.\n(Prefix must be 1 character long and token must be 59 or 79 characters long)";
- await Task.Delay(5000);
- label4.Content = "";
- return;
- }
-
- Config.SetValue("token", token);
- Config.SetValue("prefix", prefix);
- RunDiscordBot(args);
- };
-
- commandsSettingMenuItem.Click += (sender, e) => new Commands() /*{ Height = 200, Width = 550 }*/.ShowDialog(this);
- eventsSettingMenuItem.Click += (sender, e) => new Events() /*{ Height = 200, Width = 550 }*/.ShowDialog(this);
- applicationVariablesMenuItem.Click += (sender, e) => new ApplicationVariables().ShowDialog(this);
-
- var folder = $"{Functions.dataFolder}DiscordBotCore.data";
- Directory.CreateDirectory(Functions.dataFolder);
- try
- {
- var botToken = Config.GetValue("token");
- var botPrefix = Config.GetValue("prefix");
- if (botToken == null || botPrefix == null)
- {
- textBox1.IsReadOnly = false;
- textBox2.IsReadOnly = false;
- textBox1.Watermark = "Insert Bot Token Here";
- textBox2.Watermark = "Insert Bot Prefix Here";
- }
- else
- {
- textBox1.Text = botToken;
- textBox2.Text = botPrefix;
- }
- }
- catch
- {
- textBox1.IsReadOnly = false;
- textBox2.IsReadOnly = false;
- textBox1.Watermark = "Insert Bot Token Here";
- textBox2.Watermark = "Insert Bot Prefix Here";
- }
- }
-
-
- private void RunDiscordBot(string args)
- {
- var os = Functions.GetOperatingSystem();
- if (os == OperatingSystem.WINDOWS)
- Process.Start("./DiscordBot.exe", args);
- else if (os == OperatingSystem.LINUX)
- Process.Start("./DiscordBot", args);
- else if (os == OperatingSystem.MAC_OS) Process.Start("./DiscordBot.app/Contents/MacOS/DiscordBot", args);
- Close();
- }
-}
diff --git a/DiscordBotGUI/Program.cs b/DiscordBotGUI/Program.cs
deleted file mode 100644
index 97ded76..0000000
--- a/DiscordBotGUI/Program.cs
+++ /dev/null
@@ -1,25 +0,0 @@
-using System;
-using Avalonia;
-
-namespace DiscordBotGUI;
-
-internal class Program
-{
- // Initialization code. Don't use any Avalonia, third-party APIs or any
- // SynchronizationContext-reliant code before AppMain is called: things aren't initialized
- // yet and stuff might break.
- [STAThread]
- public static void Main(string[] args)
- {
- BuildAvaloniaApp()
- .StartWithClassicDesktopLifetime(args);
- }
-
- // Avalonia configuration, don't remove; also used by visual designer.
- public static AppBuilder BuildAvaloniaApp()
- {
- return AppBuilder.Configure()
- .UsePlatformDetect()
- .LogToTrace();
- }
-}
diff --git a/DiscordBotGUI/Settings/ApplicationVariables.axaml b/DiscordBotGUI/Settings/ApplicationVariables.axaml
deleted file mode 100644
index db6e433..0000000
--- a/DiscordBotGUI/Settings/ApplicationVariables.axaml
+++ /dev/null
@@ -1,23 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/DiscordBotGUI/Settings/ApplicationVariables.axaml.cs b/DiscordBotGUI/Settings/ApplicationVariables.axaml.cs
deleted file mode 100644
index 2559134..0000000
--- a/DiscordBotGUI/Settings/ApplicationVariables.axaml.cs
+++ /dev/null
@@ -1,41 +0,0 @@
-using Avalonia.Controls;
-using PluginManager;
-
-namespace DiscordBotGUI.Settings;
-
-public partial class ApplicationVariables : Window
-{
- public ApplicationVariables()
- {
- InitializeComponent();
- Load();
- }
-
- private void Load()
- {
- ClearEverything();
- button1.Click += (sedner, e) =>
- {
- var key = textBox2.Text;
- if (Config.ContainsKey(key))
- {
- ClearEverything();
- return;
- }
-
- var value = textBox3.Text;
- Config.AddValueToVariables(key, value, checkBox1.IsChecked!.Value);
- ClearEverything();
- };
- }
-
- private void ClearEverything()
- {
- textBox1.Text = "";
- textBox2.Text = "";
- textBox3.Text = "";
- checkBox1.IsChecked = false;
- var allvars = Config.GetAllVariables();
- foreach (var kvp in allvars) textBox1.Text += kvp.Key + " => " + kvp.Value + "\n";
- }
-}
diff --git a/DiscordBotGUI/Settings/Commands.axaml b/DiscordBotGUI/Settings/Commands.axaml
deleted file mode 100644
index 69ef101..0000000
--- a/DiscordBotGUI/Settings/Commands.axaml
+++ /dev/null
@@ -1,24 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/DiscordBotGUI/Settings/Commands.axaml.cs b/DiscordBotGUI/Settings/Commands.axaml.cs
deleted file mode 100644
index 27291d3..0000000
--- a/DiscordBotGUI/Settings/Commands.axaml.cs
+++ /dev/null
@@ -1,136 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using System.Threading.Tasks;
-using Avalonia.Controls;
-using PluginManager.Online;
-using PluginManager.Others;
-using OperatingSystem = PluginManager.Others.OperatingSystem;
-
-namespace DiscordBotGUI.Settings;
-
-public partial class Commands : Window
-{
- private List commands = new();
-
- public Commands()
- {
- InitializeComponent();
- LoadData();
- LoadComboBox();
-
- button1.Click += async (sender, e) => { await Download(); };
- }
-
-
- private void LoadData()
- {
- try
- {
- textbox1.Text = "";
- Directory.CreateDirectory("./Data/Plugins/Commands/");
- var files = Directory.EnumerateFiles("./Data/Plugins/Commands/");
- if (files == null || files.Count() < 1) return;
- foreach (var file in files) textbox1.Text += file.Split('/')[file.Split('/').Length - 1] + "\n";
- }
- catch
- {
- }
- }
-
- private async void LoadComboBox()
- {
- comboBox1.Items = null;
- commands = await ServerCom.ReadTextFromFile("https://sethdiscordbot.000webhostapp.com/Storage/Discord%20Bot/Plugins");
- if (commands == null) return;
- var plugins = commands.ToArray();
- string OS;
- var OSG = Functions.GetOperatingSystem();
- if (OSG == OperatingSystem.WINDOWS)
- OS = "Windows";
- else if (OSG == OperatingSystem.LINUX)
- OS = "Linux";
- else
- OS = "MAC_OS";
- var data = new List();
- for (var i = 0; i < plugins.Length; i++)
- {
- if (!plugins[i].Contains(OS) || !plugins[i].Contains("Commands")) continue;
-
- var info = plugins[i].Split(',');
- try
- {
- if (Directory.EnumerateFiles("./Data/Plugins/Commands/").Any(x => x.EndsWith(info[0] + ".dll"))) continue;
- }
- catch
- {
- }
-
- data.Add($"{info[0]} - {info[1]} - {info[2]}");
- }
-
- comboBox1.Items = data;
- }
-
-
- private async Task Download()
- {
- if (comboBox1 == null || comboBox1.SelectedIndex == -1 || comboBox1.SelectedItem == null) return;
- var pluginName = comboBox1?.SelectedItem?.ToString()?.Split('-')[0].Trim();
-
- if (pluginName == null) return;
- var URL = (from s in commands
- where s.StartsWith(pluginName)
- select s.Split(',')[3].Trim()).FirstOrDefault();
-
- if (URL == null) return;
-
-
- IProgress progress = new Progress(async value =>
- {
- label1.Content = $"Downloading {pluginName} {MathF.Round(value, 2)}%";
- if (value == 1f)
- {
- label1.Content = "Successfully Downloaded " + pluginName;
- LoadData();
- LoadComboBox();
-
- await Task.Delay(5000);
- label1.Content = "";
- }
-
- progressBar1.Value = value;
- }
- );
-
- await ServerCom.DownloadFileAsync(URL, "./Data/Plugins/Commands/" + pluginName + ".dll", progress);
- var requirements = (from s in commands
- where s.StartsWith(pluginName) && s.Split(',').Length == 6
- select s.Split(',')[5].Trim()).FirstOrDefault();
-
- if (requirements == null) return;
- var req = await ServerCom.ReadTextFromFile(requirements);
- if (req == null) return;
-
- foreach (var requirement in req)
- {
- var info = requirement.Split(',');
- pluginName = info[1];
- progress.Report(0);
- await ServerCom.DownloadFileAsync(info[0], $"./{info[1]}", progress);
-
- await Task.Delay(1000);
-
- if (info[0].EndsWith(".zip"))
- {
- await Functions.ExtractArchive("./" + info[1], "./", progress);
- await Task.Delay(1000);
- }
- }
-
- progress.Report(100f);
- label1.Content = "Downloaded";
- progressBar1.Value = 100;
- }
-}
diff --git a/DiscordBotGUI/Settings/Events.axaml b/DiscordBotGUI/Settings/Events.axaml
deleted file mode 100644
index 57c0ca4..0000000
--- a/DiscordBotGUI/Settings/Events.axaml
+++ /dev/null
@@ -1,23 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/DiscordBotGUI/Settings/Events.axaml.cs b/DiscordBotGUI/Settings/Events.axaml.cs
deleted file mode 100644
index 04eb48f..0000000
--- a/DiscordBotGUI/Settings/Events.axaml.cs
+++ /dev/null
@@ -1,135 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using System.Threading.Tasks;
-using Avalonia.Controls;
-using PluginManager.Online;
-using PluginManager.Others;
-using OperatingSystem = PluginManager.Others.OperatingSystem;
-
-namespace DiscordBotGUI.Settings;
-
-public partial class Events : Window
-{
- private List events = new();
-
- public Events()
- {
- InitializeComponent();
- LoadData();
- LoadComboBox();
- button1.Click += async (sender, e) => { await Download(); };
- }
-
- private void LoadData()
- {
- //Read components from Commands Folder:
- //textbox1 = new TextBox();
- try
- {
- Directory.CreateDirectory("./Data/Plugins/Events/");
- textbox1.IsReadOnly = false;
- textbox1.Text = "";
- var files = Directory.EnumerateFiles("./Data/Plugins/Events/");
- if (files == null || files.Count() < 1) return;
- foreach (var file in files) textbox1.Text += file.Split('/')[file.Split('/').Length - 1] + "\n";
- }
- catch
- {
- }
- }
-
- private async void LoadComboBox()
- {
- comboBox1.Items = null;
- events = await ServerCom.ReadTextFromFile("https://sethdiscordbot.000webhostapp.com/Storage/Discord%20Bot/Plugins");
- if (events == null) return;
- var plugins = events.ToArray();
- string OS;
- var OSG = Functions.GetOperatingSystem();
- if (OSG == OperatingSystem.WINDOWS)
- OS = "Windows";
- else if (OSG == OperatingSystem.LINUX)
- OS = "Linux";
- else
- OS = "MAC_OS";
- var data = new List();
- for (var i = 0; i < plugins.Length; i++)
- {
- if (!plugins[i].Contains(OS) || !plugins[i].Contains("Event")) continue;
-
- var info = plugins[i].Split(',');
- try
- {
- if (Directory.EnumerateFiles("./Data/Plugins/Events/").Any(x => x.EndsWith(info[0] + ".dll"))) continue;
- }
- catch
- {
- }
-
-
- data.Add($"{info[0]} - {info[1]} - {info[2]}");
- }
-
- comboBox1.Items = data;
- }
-
- private async Task Download()
- {
- if (comboBox1 == null || comboBox1.SelectedIndex == -1 || comboBox1.SelectedItem == null) return;
- var pluginName = comboBox1?.SelectedItem?.ToString()?.Split('-')[0].Trim();
-
- if (pluginName == null) return;
- var URL = (from s in events
- where s.StartsWith(pluginName)
- select s.Split(',')[3].Trim()).FirstOrDefault();
-
- if (URL == null) return;
-
-
- IProgress progress = new Progress(async value =>
- {
- label1.Content = $"Downloading {pluginName} {MathF.Round(value, 2)}%";
- if (value == 1f)
- {
- label1.Content = "Successfully Downloaded " + pluginName;
- LoadData();
- LoadComboBox();
-
- await Task.Delay(5000);
- label1.Content = "";
- }
-
- progressBar1.Value = value;
- }
- );
-
- await ServerCom.DownloadFileAsync(URL, "./Data/Plugins/Events/" + pluginName + ".dll", progress);
- var requirements = (from s in events
- where s.StartsWith(pluginName) && s.Split(',').Length == 6
- select s.Split(',')[5].Trim()).FirstOrDefault();
-
- if (requirements == null) return;
- var req = await ServerCom.ReadTextFromFile(requirements);
- if (req == null) return;
-
- foreach (var requirement in req)
- {
- var info = requirement.Split(',');
- pluginName = info[1];
- progress.Report(0);
- await ServerCom.DownloadFileAsync(info[0], $"./{info[1]}", progress);
-
- await Task.Delay(1000);
-
- if (info[0].EndsWith(".zip"))
- {
- await Functions.ExtractArchive("./" + info[1], "./", progress);
- await Task.Delay(1000);
- }
- }
-
- label1.Content = "";
- }
-}
diff --git a/DiscordBotWithAPI.sln b/DiscordBotWithAPI.sln
index d88b05a..bccffb6 100644
--- a/DiscordBotWithAPI.sln
+++ b/DiscordBotWithAPI.sln
@@ -17,11 +17,9 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "CMD_Utils", "CMD_Utils\CMD_
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "MusicCommands", "MusicCommands\MusicCommands.csproj", "{B1B4976E-5112-4217-B57B-3A03C5207B6E}"
EndProject
-Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "DiscordBotGUI", "DiscordBotGUI\DiscordBotGUI.csproj", "{7B5899F0-0218-4537-8C74-6210ED2D3690}"
+Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "EVE_LevelingSystem", "EVE_LevelingSystem\EVE_LevelingSystem.csproj", "{EEC445DC-0C4B-43EA-8694-606BA0390B77}"
EndProject
-Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "EVE_LevelingSystem", "EVE_LevelingSystem\EVE_LevelingSystem.csproj", "{EEC445DC-0C4B-43EA-8694-606BA0390B77}"
-EndProject
-Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "CMD_LevelingSystem", "CMD_LevelingSystem\CMD_LevelingSystem.csproj", "{1A4E49FF-9A0A-4C54-AF35-CFFBA64353D9}"
+Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "CMD_LevelingSystem", "CMD_LevelingSystem\CMD_LevelingSystem.csproj", "{1A4E49FF-9A0A-4C54-AF35-CFFBA64353D9}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
@@ -45,10 +43,6 @@ Global
{B1B4976E-5112-4217-B57B-3A03C5207B6E}.Debug|Any CPU.Build.0 = Debug|Any CPU
{B1B4976E-5112-4217-B57B-3A03C5207B6E}.Release|Any CPU.ActiveCfg = Release|Any CPU
{B1B4976E-5112-4217-B57B-3A03C5207B6E}.Release|Any CPU.Build.0 = Release|Any CPU
- {7B5899F0-0218-4537-8C74-6210ED2D3690}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
- {7B5899F0-0218-4537-8C74-6210ED2D3690}.Debug|Any CPU.Build.0 = Debug|Any CPU
- {7B5899F0-0218-4537-8C74-6210ED2D3690}.Release|Any CPU.ActiveCfg = Release|Any CPU
- {7B5899F0-0218-4537-8C74-6210ED2D3690}.Release|Any CPU.Build.0 = Release|Any CPU
{EEC445DC-0C4B-43EA-8694-606BA0390B77}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{EEC445DC-0C4B-43EA-8694-606BA0390B77}.Debug|Any CPU.Build.0 = Debug|Any CPU
{EEC445DC-0C4B-43EA-8694-606BA0390B77}.Release|Any CPU.ActiveCfg = Release|Any CPU