aboutsummaryrefslogtreecommitdiff
path: root/Jellyfin.Server/ServerSetupApp/StartupLoggerOfCategory.cs
blob: 64da0ce88ab068a0d2233168c764453b096c084c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
using System;
using System.Globalization;
using Microsoft.Extensions.Logging;

namespace Jellyfin.Server.ServerSetupApp;

/// <summary>
/// Startup logger for usage with DI that utilises an underlying logger from the DI.
/// </summary>
/// <typeparam name="TCategory">The category of the underlying logger.</typeparam>
#pragma warning disable SA1649 // File name should match first type name
public class StartupLogger<TCategory> : StartupLogger, IStartupLogger<TCategory>
#pragma warning restore SA1649 // File name should match first type name
{
    /// <summary>
    /// Initializes a new instance of the <see cref="StartupLogger{TCategory}"/> class.
    /// </summary>
    /// <param name="logger">The injected base logger.</param>
    public StartupLogger(ILogger<TCategory> logger) : base(logger)
    {
    }

    /// <summary>
    /// Initializes a new instance of the <see cref="StartupLogger{TCategory}"/> class.
    /// </summary>
    /// <param name="logger">The underlying base logger.</param>
    /// <param name="groupEntry">The group for this logger.</param>
    internal StartupLogger(ILogger logger, StartupLogTopic? groupEntry) : base(logger, groupEntry)
    {
    }

    IStartupLogger<TCategory> IStartupLogger<TCategory>.BeginGroup(FormattableString logEntry)
    {
        var startupEntry = new StartupLogTopic()
        {
            Content = logEntry.ToString(CultureInfo.InvariantCulture),
            DateOfCreation = DateTimeOffset.Now
        };

        if (Topic is null)
        {
            SetupServer.LogQueue?.Enqueue(startupEntry);
        }
        else
        {
            Topic.Children.Add(startupEntry);
        }

        return new StartupLogger<TCategory>(BaseLogger, startupEntry);
    }

    IStartupLogger<TCategory> IStartupLogger<TCategory>.With(ILogger logger)
    {
        return new StartupLogger<TCategory>(logger, Topic);
    }
}