Files
server/src/Core/Utilities/LoggerFactoryExtensions.cs

97 lines
3.5 KiB
C#
Raw Normal View History

2018-03-23 18:33:31 +01:00
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
2019-07-23 16:38:49 -04:00
using Microsoft.Extensions.Configuration;
2020-01-10 08:33:13 -05:00
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
using Serilog;
using Serilog.Events;
using System;
namespace Bit.Core.Utilities
{
public static class LoggerFactoryExtensions
{
2019-07-23 16:38:49 -04:00
public static void UseSerilog(
this IApplicationBuilder appBuilder,
2020-01-10 08:33:13 -05:00
IWebHostEnvironment env,
IHostApplicationLifetime applicationLifetime,
2019-07-23 16:38:49 -04:00
GlobalSettings globalSettings)
{
if (env.IsDevelopment())
{
return;
2019-07-23 16:38:49 -04:00
}
applicationLifetime.ApplicationStopped.Register(Log.CloseAndFlush);
}
public static ILoggingBuilder AddSerilog(
this ILoggingBuilder builder,
WebHostBuilderContext context,
Func<LogEvent, bool> filter = null)
{
if (context.HostingEnvironment.IsDevelopment())
2019-07-23 16:38:49 -04:00
{
return builder;
2018-03-27 22:16:55 -04:00
}
bool inclusionPredicate(LogEvent e)
2018-03-27 22:16:55 -04:00
{
if (filter == null)
{
return true;
}
var eventId = e.Properties.ContainsKey("EventId") ? e.Properties["EventId"].ToString() : null;
if (eventId?.Contains(Constants.BypassFiltersEventId.ToString()) ?? false)
{
return true;
}
return filter(e);
2018-03-27 22:16:55 -04:00
}
2019-07-23 16:38:49 -04:00
var globalSettings = new GlobalSettings();
ConfigurationBinder.Bind(context.Configuration.GetSection("GlobalSettings"), globalSettings);
2018-03-27 22:16:55 -04:00
var config = new LoggerConfiguration()
.Enrich.FromLogContext()
.Filter.ByIncludingOnly(inclusionPredicate);
2018-03-23 18:33:31 +01:00
if (CoreHelpers.SettingHasValue(globalSettings?.DocumentDb.Uri) &&
2018-03-27 22:16:55 -04:00
CoreHelpers.SettingHasValue(globalSettings?.DocumentDb.Key))
{
config.WriteTo.AzureDocumentDB(new Uri(globalSettings.DocumentDb.Uri),
2018-03-30 00:01:53 -04:00
globalSettings.DocumentDb.Key, timeToLive: TimeSpan.FromDays(7))
.Enrich.FromLogContext()
.Enrich.WithProperty("Project", globalSettings.ProjectName);
2018-03-27 22:16:55 -04:00
}
else if (CoreHelpers.SettingHasValue(globalSettings?.Sentry.Dsn))
2018-03-27 22:16:55 -04:00
{
config.WriteTo.Sentry(globalSettings.Sentry.Dsn)
.Enrich.FromLogContext()
.Enrich.WithProperty("Project", globalSettings.ProjectName);
}
else if (CoreHelpers.SettingHasValue(globalSettings.LogDirectory))
2018-03-27 22:16:55 -04:00
{
if (globalSettings.LogRollBySizeLimit.HasValue)
{
config.WriteTo.File($"{globalSettings.LogDirectory}/{globalSettings.ProjectName}/log.txt",
rollOnFileSizeLimit: true, fileSizeLimitBytes: globalSettings.LogRollBySizeLimit);
}
else
{
config.WriteTo
.RollingFile($"{globalSettings.LogDirectory}/{globalSettings.ProjectName}/{{Date}}.txt");
}
config
2018-03-30 00:01:53 -04:00
.Enrich.FromLogContext()
.Enrich.WithProperty("Project", globalSettings.ProjectName);
2018-03-27 22:16:55 -04:00
}
var serilog = config.CreateLogger();
2019-07-23 16:38:49 -04:00
builder.AddSerilog(serilog);
2019-07-23 16:38:49 -04:00
return builder;
}
}
}