/// <summary> /// Gets the facts. /// </summary> /// <param name="logEvent">The log event.</param> /// <returns>A list of facts.</returns> private IEnumerable <MicrosoftTeamsMessageFact> GetFacts(MicrosoftExtendedLogEvent logEvent) { yield return(new MicrosoftTeamsMessageFact { Name = "Level", Value = logEvent.LogEvent.Level.ToString() }); yield return(new MicrosoftTeamsMessageFact { Name = "MessageTemplate", Value = logEvent.LogEvent.MessageTemplate.Text }); if (logEvent.LogEvent.Exception != null) { yield return(new MicrosoftTeamsMessageFact { Name = "Exception", Value = logEvent.LogEvent.Exception.ToString() }); } foreach (var property in logEvent.LogEvent.Properties) { yield return(new MicrosoftTeamsMessageFact { Name = property.Key, Value = property.Value.ToString(null, this.options.FormatProvider) }); } if (logEvent.FirstOccurrence != logEvent.LastOccurrence) { yield return(new MicrosoftTeamsMessageFact { Name = "First occurrence", Value = logEvent.FirstOccurrence.ToString("G", this.options.FormatProvider) }); yield return(new MicrosoftTeamsMessageFact { Name = "Last occurrence", Value = logEvent.LastOccurrence.ToString("G", this.options.FormatProvider) }); } else { yield return(new MicrosoftTeamsMessageFact { Name = "Occurred on", Value = logEvent.FirstOccurrence.ToString("G", this.options.FormatProvider) }); } }
/// <summary> /// Creates the message. /// </summary> /// <param name="logEvent">The log event.</param> /// <returns>A message card.</returns> private MicrosoftTeamsMessageCard CreateMessage(MicrosoftExtendedLogEvent logEvent) { string renderedMessage; if (string.IsNullOrWhiteSpace(this.options.OutputTemplate)) { renderedMessage = logEvent.LogEvent.RenderMessage(this.options.FormatProvider); } else { var formatter = new MessageTemplateTextFormatter(this.options.OutputTemplate, this.options.FormatProvider); var stringWriter = new StringWriter(); formatter.Format(logEvent.LogEvent, stringWriter); renderedMessage = stringWriter.ToString(); } var request = new MicrosoftTeamsMessageCard { Title = this.options.Title, Text = renderedMessage, Color = GetAttachmentColor(logEvent.LogEvent.Level), Sections = this.options.OmitPropertiesSection ? null : new[] { new MicrosoftTeamsMessageSection { Title = "Properties", Facts = this.GetFacts(logEvent).ToArray() } }, PotentialActions = null }; // Add static URL buttons from the options if (this.options.Buttons.IsNullOrEmpty()) { return(request); } request.PotentialActions = new List <MicrosoftTeamsMessageAction>(); this.options.Buttons.ToList().ForEach(btn => request.PotentialActions.Add(new MicrosoftTeamsMessageAction("OpenUri", btn.Name, new MicrosoftTeamsMessageActionTarget(btn.Uri)))); return(request); }