Headless CMS and Content Managment Hub
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

43 lines
1.6 KiB

// ==========================================================================
// Squidex Headless CMS
// ==========================================================================
// Copyright (c) Squidex UG (haftungsbeschränkt)
// All rights reserved. Licensed under the MIT license.
// ==========================================================================
using System;
using System.Collections.Generic;
using System.Linq;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Squidex.Infrastructure.Log;
namespace Squidex.Config.Domain
{
public static class LoggingExtensions
{
public static void LogConfiguration(this IServiceProvider services)
{
var log = services.GetRequiredService<ISemanticLog>();
log.LogInformation(w => w
.WriteProperty("message", "Application started")
.WriteObject("environment", c =>
{
var config = services.GetRequiredService<IConfiguration>();
var logged = new HashSet<string>(StringComparer.OrdinalIgnoreCase);
var orderedConfigs = config.AsEnumerable().Where(kvp => kvp.Value != null).OrderBy(x => x.Key, StringComparer.OrdinalIgnoreCase);
foreach (var (key, val) in orderedConfigs)
{
if (logged.Add(key))
{
c.WriteProperty(key.ToLowerInvariant(), val);
}
}
}));
}
}
}