new stats

This commit is contained in:
Master Kwoth 2016-01-26 21:42:22 +01:00
parent 705ef60075
commit 5f7d4c805a

View File

@ -10,11 +10,10 @@ using Discord.Audio;
using NadekoBot.Extensions; using NadekoBot.Extensions;
using System.Timers; using System.Timers;
using System.Linq; using System.Linq;
using System.Diagnostics;
namespace NadekoBot namespace NadekoBot {
{ class NadekoBot {
class NadekoBot
{
public static DiscordClient client; public static DiscordClient client;
public static StatsCollector stats_collector; public static StatsCollector stats_collector;
public static string botMention; public static string botMention;
@ -24,15 +23,14 @@ namespace NadekoBot
public static string password; public static string password;
public static string TrelloAppKey; public static string TrelloAppKey;
public static bool ForwardMessages = false; public static bool ForwardMessages = false;
public static string BotVersion = "0.7-beta4"; public static string BotVersion = "0.7-beta5";
public static int commandsRan = 0;
static void Main() static void Main() {
{
//load credentials from credentials.json //load credentials from credentials.json
Credentials c; Credentials c;
bool loadTrello = false; bool loadTrello = false;
try try {
{
c = JsonConvert.DeserializeObject<Credentials>(File.ReadAllText("credentials.json")); c = JsonConvert.DeserializeObject<Credentials>(File.ReadAllText("credentials.json"));
botMention = c.BotMention; botMention = c.BotMention;
if (c.GoogleAPIKey == null || c.GoogleAPIKey == "") { if (c.GoogleAPIKey == null || c.GoogleAPIKey == "") {
@ -57,9 +55,7 @@ namespace NadekoBot
OwnerID = c.OwnerID; OwnerID = c.OwnerID;
password = c.Password; password = c.Password;
} } catch (Exception ex) {
catch (Exception ex)
{
Console.WriteLine("Failed to load stuff from credentials.json, RTFM"); Console.WriteLine("Failed to load stuff from credentials.json, RTFM");
Console.ReadKey(); Console.ReadKey();
return; return;
@ -69,8 +65,7 @@ namespace NadekoBot
client = new DiscordClient(); client = new DiscordClient();
//create a command service //create a command service
var commandService = new CommandService(new CommandServiceConfig var commandService = new CommandService(new CommandServiceConfig {
{
CommandChar = null, CommandChar = null,
HelpMode = HelpMode.Disable HelpMode = HelpMode.Disable
}); });
@ -88,6 +83,9 @@ namespace NadekoBot
//reply to personal messages and forward if enabled. //reply to personal messages and forward if enabled.
client.MessageReceived += Client_MessageReceived; client.MessageReceived += Client_MessageReceived;
//count commands ran
client.Commands().CommandExecuted += (s, e) => commandsRan++;
//add command service //add command service
var commands = client.Services.Add<CommandService>(commandService); var commands = client.Services.Add<CommandService>(commandService);
@ -108,12 +106,11 @@ namespace NadekoBot
modules.Add(new Games(), "Games", ModuleFilter.None); modules.Add(new Games(), "Games", ModuleFilter.None);
modules.Add(new Music(), "Music", ModuleFilter.None); modules.Add(new Music(), "Music", ModuleFilter.None);
modules.Add(new Searches(), "Searches", ModuleFilter.None); modules.Add(new Searches(), "Searches", ModuleFilter.None);
if(loadTrello) if (loadTrello)
modules.Add(new Trello(), "Trello", ModuleFilter.None); modules.Add(new Trello(), "Trello", ModuleFilter.None);
//run the bot //run the bot
client.ExecuteAndWait(async () => client.ExecuteAndWait(async () => {
{
await client.Connect(c.Username, c.Password); await client.Connect(c.Username, c.Password);
Console.WriteLine("-----------------"); Console.WriteLine("-----------------");
@ -131,16 +128,22 @@ namespace NadekoBot
} }
public static string GetStats() => public static string GetStats() =>
"Discord.Net version: " + DiscordConfig.LibVersion + "Author: Kwoth" +
"\nRuntime: " + client.GetRuntime() + $"\nDiscord.Net version: {DiscordConfig.LibVersion}"+
"\nBot Version: " + BotVersion + $"\nRuntime: {client.GetRuntime()}" +
"\nLogged in as: " + client.CurrentUser.Name + $"\nBot Version: {BotVersion}"+
"\nBot id: " + client.CurrentUser.Id + $"\nLogged in as: {client.CurrentUser.Name}" +
"\nServers: " + client.Servers.Count() + $"\nBot id: {client.CurrentUser.Id}" +
"\nChannels: " + client.Servers.Sum(s => s.AllChannels.Count()) + $"\nUptime: {GetUptimeString()}" +
"\nUsers: " + client.Servers.Sum(s => s.Users.Count()) + $"\nServers: {client.Servers.Count()}" +
"\nHeap: " + Math.Round(GC.GetTotalMemory(true) / (1024.0 * 1024.0), 2).ToString() + "MB"; $"\nChannels: {client.Servers.Sum(s => s.AllChannels.Count())}" +
$"\nUsers: {client.Servers.SelectMany(x => x.Users.Select(y => y.Id)).Count()} ({client.Servers.SelectMany(x => x.Users.Select(y => y.Id)).Distinct().Count()} unique) ({client.Servers.SelectMany(x => x.Users.Where(y => y.Status != UserStatus.Offline).Select(y => y.Id)).Distinct().Count()} online)\n" +
$"\nHeap: {Math.Round(GC.GetTotalMemory(true) / (1024.0 * 1024.0), 2).ToString()}MB";
public static string GetUptimeString() {
var time = (DateTime.Now - Process.GetCurrentProcess().StartTime);
return "I am online for " + time.Days + " days, " + time.Hours + " hours, and " + time.Minutes + " minutes.";
}
static bool repliedRecently = false; static bool repliedRecently = false;
private static async void Client_MessageReceived(object sender, MessageEventArgs e) { private static async void Client_MessageReceived(object sender, MessageEventArgs e) {