This commit is contained in:
2022-06-28 10:45:40 +03:00
parent 861b83cda2
commit 059228ca52
12 changed files with 218 additions and 256 deletions

Binary file not shown.

Binary file not shown.

View File

@@ -121,7 +121,6 @@ internal class CommandHandler
plugin.Execute(context, message, client, false); plugin.Execute(context, message, client, false);
Functions.WriteLogFile($"[{message.Author.Id}] Executed command : " + plugin.Command); Functions.WriteLogFile($"[{message.Author.Id}] Executed command : " + plugin.Command);
return;
} }
} }
} }

View File

@@ -1,19 +1,19 @@
using DiscordBot.Discord.Core; using System;
using PluginManager;
using PluginManager.Items;
using PluginManager.Others;
using System;
using System.IO; using System.IO;
using System.Linq; using System.Linq;
using System.Threading.Tasks; using System.Threading.Tasks;
using DiscordBot.Discord.Core;
using PluginManager;
using PluginManager.Items;
using PluginManager.Online; using PluginManager.Online;
using PluginManager.Others;
namespace DiscordBot namespace DiscordBot;
public class Program
{ {
public class Program private static bool loadPluginsOnStartup;
{ private static bool listPluginsAtStartup;
private static bool loadPluginsOnStartup = false;
private static bool listPluginsAtStartup = false;
/// <summary> /// <summary>
/// The main entry point for the application. /// The main entry point for the application.
@@ -28,42 +28,35 @@ namespace DiscordBot
PreLoadComponents().Wait(); PreLoadComponents().Wait();
if (!Config.ContainsKey("token") || Config.GetValue<string>("token") == null || Config.GetValue<string>("token")?.Length != 70) if (!Config.ContainsKey("token") || Config.GetValue<string>("token") == null || Config.GetValue<string>("token")?.Length != 70)
{
while (true)
{ {
Console.WriteLine("Please insert your token"); Console.WriteLine("Please insert your token");
Console.Write("Token = "); Console.Write("Token = ");
string token = Console.ReadLine(); var token = Console.ReadLine();
if (token?.Length == 59 || token?.Length == 70) if (token?.Length == 59 || token?.Length == 70)
Config.AddValueToVariables("token", token, true); Config.AddValueToVariables("token", token, true);
else else
{
Console.WriteLine("Invalid token"); Console.WriteLine("Invalid token");
continue;
}
Console.WriteLine("Please insert your prefix (max. 1 character long):"); Console.WriteLine("Please insert your prefix (max. 1 character long):");
Console.WriteLine("For a prefix longer then one character, the first character will be saved and the others will be ignored.\n No spaces or numbers allowed"); Console.WriteLine("For a prefix longer then one character, the first character will be saved and the others will be ignored.\n No spaces or numbers allowed");
Console.Write("Prefix = "); Console.Write("Prefix = ");
char prefix = Console.ReadLine()![0]; var prefix = Console.ReadLine()![0];
if (prefix == ' ' || char.IsDigit(prefix)) continue;
Config.AddValueToVariables("prefix", prefix.ToString(), false);
break;
}
}
if (!Config.ContainsKey("prefix"))
{
Console.WriteLine("Please insert your prefix (max. 1 character long):");
Console.WriteLine("For a prefix longer then one character, the first character will be saved and the others will be ignored.\n No spaces or numbers allowed");
Console.Write("Prefix = ");
char prefix = Console.ReadLine()![0];
if (prefix == ' ' || char.IsDigit(prefix)) return; if (prefix == ' ' || char.IsDigit(prefix)) return;
Config.AddValueToVariables("prefix", prefix.ToString(), false); Config.AddValueToVariables("prefix", prefix.ToString(), false);
} }
if (!Config.ContainsKey("prefix") || Config.GetValue<string>("prefix") == default)
{
Console.WriteLine("Please insert your prefix (max. 1 character long):");
Console.WriteLine("For a prefix longer then one character, the first character will be saved and the others will be ignored.\n No spaces or numbers allowed");
Console.Write("Prefix = ");
var prefix = Console.ReadLine()![0];
if (prefix == ' ') return;
Config.AddValueToVariables("prefix", prefix.ToString(), false);
}
HandleInput(args).Wait(); HandleInput(args).Wait();
} }
@@ -73,14 +66,14 @@ namespace DiscordBot
/// <param name="discordbooter">The discord booter used to start the application</param> /// <param name="discordbooter">The discord booter used to start the application</param>
private static Task NoGUI(Boot discordbooter) private static Task NoGUI(Boot discordbooter)
{ {
ConsoleCommandsHandler consoleCommandsHandler = new ConsoleCommandsHandler(discordbooter.client); var consoleCommandsHandler = new ConsoleCommandsHandler(discordbooter.client);
if (loadPluginsOnStartup) consoleCommandsHandler.HandleCommand("lp"); if (loadPluginsOnStartup) consoleCommandsHandler.HandleCommand("lp");
if (listPluginsAtStartup) consoleCommandsHandler.HandleCommand("listplugs"); if (listPluginsAtStartup) consoleCommandsHandler.HandleCommand("listplugs");
Config.SaveConfig(); Config.SaveConfig();
while (true) while (true)
{ {
Console.ForegroundColor = ConsoleColor.White; Console.ForegroundColor = ConsoleColor.White;
string cmd = Console.ReadLine(); var cmd = Console.ReadLine();
consoleCommandsHandler.HandleCommand(cmd); consoleCommandsHandler.HandleCommand(cmd);
} }
} }
@@ -101,8 +94,8 @@ namespace DiscordBot
try try
{ {
string token = Config.GetValue<string>("token"); var token = Config.GetValue<string>("token");
string prefix = Config.GetValue<string>("prefix"); var prefix = Config.GetValue<string>("prefix");
var discordbooter = new Boot(token, prefix); var discordbooter = new Boot(token, prefix);
await discordbooter.Awake(); await discordbooter.Awake();
@@ -121,8 +114,8 @@ namespace DiscordBot
/// <param name="d">Directory path</param> /// <param name="d">Directory path</param>
private static Task ClearFolder(string d) private static Task ClearFolder(string d)
{ {
string[] files = Directory.GetFiles(d); var files = Directory.GetFiles(d);
int fileNumb = files.Length; var fileNumb = files.Length;
for (var i = 0; i < fileNumb; i++) for (var i = 0; i < fileNumb; i++)
{ {
File.Delete(files[i]); File.Delete(files[i]);
@@ -138,37 +131,12 @@ namespace DiscordBot
/// <param name="args">The arguments</param> /// <param name="args">The arguments</param>
private static async Task HandleInput(string[] args) private static async Task HandleInput(string[] args)
{ {
int len = args.Length; var len = args.Length;
if (len == 1 && args[0] == "--help")
{
Console.WriteLine("Available commands:\n--exec -> start the bot with tools enabled");
return;
}
if (len == 1 && args[0] == "--logout")
{
File.Delete(Functions.dataFolder + "config.json");
await Task.Run(async () =>
{
await Task.Delay(1000);
Environment.Exit(0x08);
}
);
return;
}
if (len >= 2 && args[0] == "--encrypt")
{
string s2e = args.MergeStrings(1);
Console.WriteLine("MD5: " + await Cryptography.CreateMD5(s2e));
Console.WriteLine("SHA356: " + await Cryptography.CreateSHA256(s2e));
return;
}
if (len == 3 && args[0] == "/download") if (len == 3 && args[0] == "/download")
{ {
string url = args[1]; var url = args[1];
string location = args[2]; var location = args[2];
await ServerCom.DownloadFileAsync(url, location); await ServerCom.DownloadFileAsync(url, location);
@@ -183,9 +151,9 @@ namespace DiscordBot
} }
if (len == 0 || args[0] != "--exec" && args[0] != "--execute") if (len == 0 || (args[0] != "--exec" && args[0] != "--execute"))
{ {
Boot b = await StartNoGUI(); var b = await StartNoGUI();
await NoGUI(b); await NoGUI(b);
return; return;
} }
@@ -205,7 +173,7 @@ namespace DiscordBot
{ {
Console.ForegroundColor = ConsoleColor.White; Console.ForegroundColor = ConsoleColor.White;
Console.Write("> "); Console.Write("> ");
string[] message = Console.ReadLine().Split(' '); var message = Console.ReadLine().Split(' ');
switch (message[0]) switch (message[0])
{ {
@@ -241,7 +209,7 @@ namespace DiscordBot
Environment.Exit(0); Environment.Exit(0);
break; break;
case "--start": case "--start":
Boot booter = await StartNoGUI(); var booter = await StartNoGUI();
await NoGUI(booter); await NoGUI(booter);
return; return;
@@ -257,8 +225,7 @@ namespace DiscordBot
await Config.LoadConfig(); await Config.LoadConfig();
if (Config.ContainsKey("DeleteLogsAtStartup")) if (Config.ContainsKey("DeleteLogsAtStartup"))
if (Config.GetValue<bool>("DeleteLogsAtStartup")) if (Config.GetValue<bool>("DeleteLogsAtStartup"))
foreach (string file in Directory.GetFiles("./Output/Logs/")) foreach (var file in Directory.GetFiles("./Output/Logs/"))
File.Delete(file); File.Delete(file);
} }
}
} }

View File

@@ -1,8 +1,7 @@
using Discord; using Discord;
using Discord.Audio; using Discord.Audio;
using MusicCommands;
namespace CMD_Utils.Music; namespace MusicCommands;
internal static class Data internal static class Data
{ {

View File

@@ -2,7 +2,7 @@
using Discord.WebSocket; using Discord.WebSocket;
using PluginManager.Interfaces; using PluginManager.Interfaces;
namespace CMD_Utils.Music; namespace MusicCommands;
internal class Leave : DBCommand internal class Leave : DBCommand
{ {

View File

@@ -3,6 +3,7 @@
<PropertyGroup> <PropertyGroup>
<TargetFramework>net6.0</TargetFramework> <TargetFramework>net6.0</TargetFramework>
<Nullable>warnings</Nullable> <Nullable>warnings</Nullable>
<BaseOutputPath>..\DiscordBot\bin\Debug\net6.0\Data\Plugins\Commands\MusicCommands</BaseOutputPath>
</PropertyGroup> </PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'"> <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">

View File

@@ -3,7 +3,6 @@ using System.IO;
using System.Net.Http; using System.Net.Http;
using System.Threading; using System.Threading;
using System.Threading.Tasks; using System.Threading.Tasks;
using CMD_Utils.Music;
using PluginManager.Others; using PluginManager.Others;
namespace MusicCommands; namespace MusicCommands;

View File

@@ -2,7 +2,7 @@
using Discord.WebSocket; using Discord.WebSocket;
using PluginManager.Interfaces; using PluginManager.Interfaces;
namespace CMD_Utils.Music; namespace MusicCommands;
internal class Pause : DBCommand internal class Pause : DBCommand
{ {

View File

@@ -5,11 +5,10 @@ using Discord;
using Discord.Audio; using Discord.Audio;
using Discord.Commands; using Discord.Commands;
using Discord.WebSocket; using Discord.WebSocket;
using MusicCommands;
using PluginManager.Interfaces; using PluginManager.Interfaces;
using PluginManager.Others; using PluginManager.Others;
namespace CMD_Utils.Music; namespace MusicCommands;
internal class Play : DBCommand internal class Play : DBCommand
{ {
@@ -29,7 +28,7 @@ internal class Play : DBCommand
{ {
var path = "./Music"; var path = "./Music";
var FileName = Functions.GetArguments(message).ToArray().MergeStrings(0); var FileName = Functions.GetArguments(message).ToArray().MergeStrings(0);
path += "/" + FileName + ".mp3"; path += "/" + FileName + ".ogg";
if (!File.Exists(path)) if (!File.Exists(path))
{ {
Console.WriteLine("Unknown path " + path); Console.WriteLine("Unknown path " + path);

View File

@@ -1,5 +1,4 @@
using CMD_Utils.Music; using Discord.Commands;
using Discord.Commands;
using Discord.WebSocket; using Discord.WebSocket;
using PluginManager.Interfaces; using PluginManager.Interfaces;

View File

@@ -1,5 +1,4 @@
using CMD_Utils.Music; using Discord;
using Discord;
using Discord.Audio; using Discord.Audio;
using Discord.Commands; using Discord.Commands;
using Discord.WebSocket; using Discord.WebSocket;