Move bot uptime property from Common to Program

Additionally, update code style in Common
This commit is contained in:
Noi 2021-10-18 16:58:22 -07:00
parent 160152a0b4
commit ca0dd74bae
4 changed files with 48 additions and 58 deletions

View file

@ -1,68 +1,53 @@
using Discord.WebSocket; using Discord.WebSocket;
using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Text; using System.Text;
namespace BirthdayBot namespace BirthdayBot;
{
static class Common
{
/// <summary>
/// Formats a user's name to a consistent, readable format which makes use of their nickname.
/// </summary>
public static string FormatName(SocketGuildUser member, bool ping)
{
if (ping) return member.Mention;
static string escapeFormattingCharacters(string input) static class Common {
{ /// <summary>
var result = new StringBuilder(); /// Formats a user's name to a consistent, readable format which makes use of their nickname.
foreach (var c in input) /// </summary>
{ public static string FormatName(SocketGuildUser member, bool ping) {
if (c is '\\' or '_' or '~' or '*' or '@') if (ping) return member.Mention;
{
result.Append('\\'); static string escapeFormattingCharacters(string input) {
} var result = new StringBuilder();
result.Append(c); foreach (var c in input) {
if (c is '\\' or '_' or '~' or '*' or '@') {
result.Append('\\');
} }
return result.ToString(); result.Append(c);
} }
return result.ToString();
var username = escapeFormattingCharacters(member.Username);
if (member.Nickname != null)
{
return $"**{escapeFormattingCharacters(member.Nickname)}** ({username}#{member.Discriminator})";
}
return $"**{username}**#{member.Discriminator}";
} }
public static readonly Dictionary<int, string> MonthNames = new() var username = escapeFormattingCharacters(member.Username);
{ if (member.Nickname != null) {
{1, "Jan"}, {2, "Feb"}, {3, "Mar"}, {4, "Apr"}, {5, "May"}, {6, "Jun"}, return $"**{escapeFormattingCharacters(member.Nickname)}** ({username}#{member.Discriminator})";
{7, "Jul"}, {8, "Aug"}, {9, "Sep"}, {10, "Oct"}, {11, "Nov"}, {12, "Dec"} }
}; return $"**{username}**#{member.Discriminator}";
}
public static string BotUptime => (DateTimeOffset.UtcNow - Program.BotStartTime).ToString("d' days, 'hh':'mm':'ss"); public static Dictionary<int, string> MonthNames { get; } = new() {
{ 1, "Jan" }, { 2, "Feb" }, { 3, "Mar" }, { 4, "Apr" }, { 5, "May" }, { 6, "Jun" },
{ 7, "Jul" }, { 8, "Aug" }, { 9, "Sep" }, { 10, "Oct" }, { 11, "Nov" }, { 12, "Dec" }
};
/// <summary> /// <summary>
/// An alternative to <see cref="SocketGuild.HasAllMembers"/>. /// An alternative to <see cref="SocketGuild.HasAllMembers"/>.
/// Returns true if *most* members have been downloaded. /// Returns true if *most* members have been downloaded.
/// </summary> /// </summary>
public static bool HasMostMembersDownloaded(SocketGuild guild) public static bool HasMostMembersDownloaded(SocketGuild guild) {
{ if (guild.HasAllMembers) return true;
if (guild.HasAllMembers) return true; if (guild.MemberCount > 30) {
if (guild.MemberCount > 30) // For guilds of size over 30, require 85% or more of the members to be known
{ // (26/30, 42/50, 255/300, etc)
// For guilds of size over 30, require 85% or more of the members to be known int threshold = (int)(guild.MemberCount * 0.85);
// (26/30, 42/50, 255/300, etc) return guild.DownloadedMemberCount >= threshold;
int threshold = (int)(guild.MemberCount * 0.85); } else {
return guild.DownloadedMemberCount >= threshold; // For smaller guilds, fail if two or more members are missing
} return guild.MemberCount - guild.DownloadedMemberCount <= 2;
else
{
// For smaller guilds, fail if two or more members are missing
return guild.MemberCount - guild.DownloadedMemberCount <= 2;
}
} }
} }
} }

View file

@ -6,7 +6,12 @@ namespace BirthdayBot;
class Program { class Program {
private static ShardManager _bot; private static ShardManager _bot;
public static DateTimeOffset BotStartTime { get; } = DateTimeOffset.UtcNow; private static readonly DateTimeOffset _botStartTime = DateTimeOffset.UtcNow;
/// <summary>
/// Returns the amount of time the program has been running in a human-readable format.
/// </summary>
public static string BotUptime => (DateTimeOffset.UtcNow - _botStartTime).ToString("d' days, 'hh':'mm':'ss");
static async Task Main() { static async Task Main() {
var cfg = new Configuration(); var cfg = new Configuration();

View file

@ -105,7 +105,7 @@ class ShardManager : IDisposable {
Log("Warning: Not all shards terminated cleanly after 30 seconds. Continuing..."); Log("Warning: Not all shards terminated cleanly after 30 seconds. Continuing...");
} }
Log($"Uptime: {Common.BotUptime}"); Log($"Uptime: {Program.BotUptime}");
} }
private void Log(string message) => Program.Log(nameof(ShardManager), message); private void Log(string message) => Program.Log(nameof(ShardManager), message);
@ -158,7 +158,7 @@ class ShardManager : IDisposable {
private async Task StatusLoop() { private async Task StatusLoop() {
try { try {
while (!_mainCancel.IsCancellationRequested) { while (!_mainCancel.IsCancellationRequested) {
Log($"Bot uptime: {Common.BotUptime}"); Log($"Bot uptime: {Program.BotUptime}");
// Iterate through shard list, extract data // Iterate through shard list, extract data
var guildInfo = new Dictionary<int, GuildStatusData>(); var guildInfo = new Dictionary<int, GuildStatusData>();

View file

@ -156,7 +156,7 @@ namespace BirthdayBot.UserInterface
//strStats.AppendLine("Server count: " + Discord.Guilds.Count.ToString()); //strStats.AppendLine("Server count: " + Discord.Guilds.Count.ToString());
// TODO restore this statistic // TODO restore this statistic
strStats.AppendLine("Shard #" + instance.ShardId.ToString("00")); strStats.AppendLine("Shard #" + instance.ShardId.ToString("00"));
strStats.AppendLine("Uptime: " + Common.BotUptime); strStats.AppendLine("Uptime: " + Program.BotUptime);
// TODO fun stats // TODO fun stats
// current birthdays, total names registered, unique time zones // current birthdays, total names registered, unique time zones