chore: format with csharpier
This commit is contained in:
parent
2f516dcb73
commit
4f54077c68
59 changed files with 2000 additions and 942 deletions
|
|
@ -27,7 +27,10 @@ public static class StartupExtensions
|
|||
/// <summary>
|
||||
/// Adds Serilog to this service collection. This method also initializes Serilog, so it should be called as early as possible, before any log calls.
|
||||
/// </summary>
|
||||
public static WebApplicationBuilder AddSerilog(this WebApplicationBuilder builder, Config config)
|
||||
public static WebApplicationBuilder AddSerilog(
|
||||
this WebApplicationBuilder builder,
|
||||
Config config
|
||||
)
|
||||
{
|
||||
var logCfg = new LoggerConfiguration()
|
||||
.Enrich.FromLogContext()
|
||||
|
|
@ -35,8 +38,10 @@ public static class StartupExtensions
|
|||
// ASP.NET's built in request logs are extremely verbose, so we use Serilog's instead.
|
||||
// Serilog doesn't disable the built-in logs, so we do it here.
|
||||
.MinimumLevel.Override("Microsoft", LogEventLevel.Information)
|
||||
.MinimumLevel.Override("Microsoft.EntityFrameworkCore.Database.Command",
|
||||
config.Logging.LogQueries ? LogEventLevel.Information : LogEventLevel.Fatal)
|
||||
.MinimumLevel.Override(
|
||||
"Microsoft.EntityFrameworkCore.Database.Command",
|
||||
config.Logging.LogQueries ? LogEventLevel.Information : LogEventLevel.Fatal
|
||||
)
|
||||
.MinimumLevel.Override("Microsoft.AspNetCore.Hosting", LogEventLevel.Warning)
|
||||
.MinimumLevel.Override("Microsoft.AspNetCore.Mvc", LogEventLevel.Warning)
|
||||
.MinimumLevel.Override("Microsoft.AspNetCore.Routing", LogEventLevel.Warning)
|
||||
|
|
@ -69,32 +74,43 @@ public static class StartupExtensions
|
|||
.AddEnvironmentVariables();
|
||||
}
|
||||
|
||||
public static IServiceCollection AddCustomServices(this IServiceCollection services) => services
|
||||
.AddSingleton<IClock>(SystemClock.Instance)
|
||||
.AddSingleton<GuildCache>()
|
||||
.AddSingleton<RoleCache>()
|
||||
.AddSingleton<ChannelCache>()
|
||||
.AddSingleton<UserCache>()
|
||||
.AddSingleton<AuditLogCache>()
|
||||
.AddSingleton<PluralkitApiService>()
|
||||
.AddScoped<IEncryptionService, EncryptionService>()
|
||||
.AddSingleton<MetricsCollectionService>()
|
||||
.AddSingleton<AuditLogEnrichedResponderService>()
|
||||
.AddScoped<MessageRepository>()
|
||||
.AddSingleton<WebhookExecutorService>()
|
||||
.AddSingleton<PkMessageHandler>()
|
||||
.AddSingleton(InMemoryDataService<Snowflake, ChannelCommandData>.Instance)
|
||||
.AddSingleton<GuildFetchService>()
|
||||
.AddHostedService(serviceProvider => serviceProvider.GetRequiredService<GuildFetchService>());
|
||||
public static IServiceCollection AddCustomServices(this IServiceCollection services) =>
|
||||
services
|
||||
.AddSingleton<IClock>(SystemClock.Instance)
|
||||
.AddSingleton<GuildCache>()
|
||||
.AddSingleton<RoleCache>()
|
||||
.AddSingleton<ChannelCache>()
|
||||
.AddSingleton<UserCache>()
|
||||
.AddSingleton<AuditLogCache>()
|
||||
.AddSingleton<PluralkitApiService>()
|
||||
.AddScoped<IEncryptionService, EncryptionService>()
|
||||
.AddSingleton<MetricsCollectionService>()
|
||||
.AddSingleton<AuditLogEnrichedResponderService>()
|
||||
.AddScoped<MessageRepository>()
|
||||
.AddSingleton<WebhookExecutorService>()
|
||||
.AddSingleton<PkMessageHandler>()
|
||||
.AddSingleton(InMemoryDataService<Snowflake, ChannelCommandData>.Instance)
|
||||
.AddSingleton<GuildFetchService>()
|
||||
.AddHostedService(serviceProvider =>
|
||||
serviceProvider.GetRequiredService<GuildFetchService>()
|
||||
);
|
||||
|
||||
public static IHostBuilder AddShardedDiscordService(this IHostBuilder builder,
|
||||
Func<IServiceProvider, string> tokenFactory) =>
|
||||
builder.ConfigureServices((_, services) => services
|
||||
.AddDiscordGateway(tokenFactory)
|
||||
.AddSingleton<ShardedGatewayClient>()
|
||||
.AddHostedService<ShardedDiscordService>());
|
||||
public static IHostBuilder AddShardedDiscordService(
|
||||
this IHostBuilder builder,
|
||||
Func<IServiceProvider, string> tokenFactory
|
||||
) =>
|
||||
builder.ConfigureServices(
|
||||
(_, services) =>
|
||||
services
|
||||
.AddDiscordGateway(tokenFactory)
|
||||
.AddSingleton<ShardedGatewayClient>()
|
||||
.AddHostedService<ShardedDiscordService>()
|
||||
);
|
||||
|
||||
public static IServiceCollection MaybeAddRedisCaches(this IServiceCollection services, Config config)
|
||||
public static IServiceCollection MaybeAddRedisCaches(
|
||||
this IServiceCollection services,
|
||||
Config config
|
||||
)
|
||||
{
|
||||
if (config.Database.Redis == null)
|
||||
{
|
||||
|
|
@ -104,7 +120,8 @@ public static class StartupExtensions
|
|||
.AddSingleton<IInviteCache, InMemoryInviteCache>();
|
||||
}
|
||||
|
||||
return services.AddSingleton<RedisService>()
|
||||
return services
|
||||
.AddSingleton<RedisService>()
|
||||
.AddSingleton<IWebhookCache, RedisWebhookCache>()
|
||||
.AddSingleton<IMemberCache, RedisMemberCache>()
|
||||
.AddSingleton<IInviteCache, RedisInviteCache>();
|
||||
|
|
@ -116,7 +133,9 @@ public static class StartupExtensions
|
|||
var logger = scope.ServiceProvider.GetRequiredService<ILogger>().ForContext<Program>();
|
||||
logger.Information("Starting Catalogger.NET");
|
||||
|
||||
CataloggerMetrics.Startup = scope.ServiceProvider.GetRequiredService<IClock>().GetCurrentInstant();
|
||||
CataloggerMetrics.Startup = scope
|
||||
.ServiceProvider.GetRequiredService<IClock>()
|
||||
.GetCurrentInstant();
|
||||
|
||||
await using (var db = scope.ServiceProvider.GetRequiredService<DatabaseContext>())
|
||||
{
|
||||
|
|
@ -126,7 +145,8 @@ public static class StartupExtensions
|
|||
logger.Information("Applying {Count} database migrations", migrationCount);
|
||||
await db.Database.MigrateAsync();
|
||||
}
|
||||
else logger.Information("There are no pending migrations");
|
||||
else
|
||||
logger.Information("There are no pending migrations");
|
||||
}
|
||||
|
||||
var config = scope.ServiceProvider.GetRequiredService<Config>();
|
||||
|
|
@ -135,20 +155,28 @@ public static class StartupExtensions
|
|||
if (config.Discord.ApplicationId == 0)
|
||||
{
|
||||
logger.Warning(
|
||||
"Application ID not set in config. Fetching and setting it now, but for future restarts, please add it to config.ini as Discord.ApplicationId.");
|
||||
"Application ID not set in config. Fetching and setting it now, but for future restarts, please add it to config.ini as Discord.ApplicationId."
|
||||
);
|
||||
var restApi = scope.ServiceProvider.GetRequiredService<IDiscordRestApplicationAPI>();
|
||||
var application = await restApi.GetCurrentApplicationAsync().GetOrThrow();
|
||||
config.Discord.ApplicationId = application.ID.ToUlong();
|
||||
logger.Information("Current application ID is {ApplicationId}", config.Discord.ApplicationId);
|
||||
logger.Information(
|
||||
"Current application ID is {ApplicationId}",
|
||||
config.Discord.ApplicationId
|
||||
);
|
||||
}
|
||||
|
||||
if (config.Discord.SyncCommands)
|
||||
{
|
||||
if (config.Discord.CommandsGuildId != null)
|
||||
{
|
||||
logger.Information("Syncing application commands with guild {GuildId}", config.Discord.CommandsGuildId);
|
||||
logger.Information(
|
||||
"Syncing application commands with guild {GuildId}",
|
||||
config.Discord.CommandsGuildId
|
||||
);
|
||||
await slashService.UpdateSlashCommandsAsync(
|
||||
guildID: DiscordSnowflake.New(config.Discord.CommandsGuildId.Value));
|
||||
guildID: DiscordSnowflake.New(config.Discord.CommandsGuildId.Value)
|
||||
);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -156,6 +184,9 @@ public static class StartupExtensions
|
|||
await slashService.UpdateSlashCommandsAsync();
|
||||
}
|
||||
}
|
||||
else logger.Information("Not syncing slash commands, Discord.SyncCommands is false or unset");
|
||||
else
|
||||
logger.Information(
|
||||
"Not syncing slash commands, Discord.SyncCommands is false or unset"
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue