Example #1
0
        /// <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)
                });
            }
        }
Example #2
0
        /// <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);
        }