PluralKit/PluralKit.Core/Logging/PatchObjectDestructuring.cs

30 lines
1.0 KiB
C#
Raw Normal View History

2021-08-27 15:03:47 +00:00
using System.Collections.Generic;
using Serilog.Core;
using Serilog.Events;
namespace PluralKit.Core
{
public class PatchObjectDestructuring: IDestructuringPolicy
{
public bool TryDestructure(object value, ILogEventPropertyValueFactory factory,
out LogEventPropertyValue result)
{
result = null;
if (!(value is PatchObject po)) return false;
2021-08-27 15:03:47 +00:00
var propList = new List<LogEventProperty>();
foreach (var props in po.GetType().GetProperties())
{
var propValue = props.GetValue(po);
if (propValue is IPartial p && p.IsPresent)
propList.Add(new LogEventProperty(props.Name, factory.CreatePropertyValue(p.RawValue, true)));
else if (!(propValue is IPartial))
propList.Add(new LogEventProperty(props.Name, factory.CreatePropertyValue(propValue, true)));
}
result = new StructureValue(propList);
return true;
}
}
}