You need to add an "Incoming Webhook" connector to your Teams channel and get it's URL. titleTemplate
is optional but can help your distinguish logs coming from different sources.
Check https://docs.microsoft.com/en-us/microsoftteams/platform/concepts/connectors/connectors-using.
var logger = new LoggerConfiguration()
.WriteTo.MicrosoftTeams(webHookUri, titleTemplate: titleTemplate)
.CreateLogger();
The project can be found on nuget.
Parameter | Meaning | Example | Default value |
---|---|---|---|
webHookUri | The Microsoft teams weebhook uri. | https://outlook.office.com/webhook/1234567890 |
None, is mandatory. |
titleTemplate | The title template of the card. The Serilog templating can be used to customize the title (Same as the outputTemplate property). |
"Some Message" |
None, but is optional. |
batchSizeLimit | The maximum number of events to include in a single batch. | batchSizeLimit: 40 |
1 |
period | The time to wait between checking for event batches. | period: new TimeSpan(0, 0, 20) |
00:00:01 |
outputTemplate | The output template for a log event. | outputTemplate:"{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} [{Level:u3}] {Message:lj}{NewLine}{Exception}" |
null |
formatProvider | The IFormatProvider to use. Supplies culture-specific formatting information. Check https://docs.microsoft.com/en-us/dotnet/api/system.iformatprovider?view=net-5.0. |
new CultureInfo("de-DE") |
null |
restrictedToMinimumLevel | The minimum level of the logging. | restrictedToMinimumLevel: LogEventLevel.Verbose |
LogEventLevel.Verbose |
proxy | The proxy addresss used. | proxy: "http://test.de/proxy" |
null |
omitPropertiesSection | Indicates whether the properties section should be omitted or not. | omitPropertiesSection: true |
false |
useCodeTagsForMessage | A value indicating whether code tags are used for the message template or not. This is useful if you have complex messages that might get formatted as unwanted markdown elements. | useCodeTagsForMessage:true |
false |
usePowerAutomateWorkflows | A value indicating whether Power Automate workflows are used or not. | usePowerAutomateWorkflows:true |
false |
buttons | Option to add static clickable buttons to each message. | buttons: new[] { new MicrosoftTeamsSinkOptionsButton("Google", "https://google.de") } |
null |
failureCallback | Adds an option to add a failure callback action. | failureCallback: e => Console.WriteLine($"Sink error: {e.Message}") |
null |
queueLimit | The maximum number of events that should be stored in the batching queue. | queueLimit: 10 |
int.MaxValue or 2147483647 |
channelHandler | Configuration for dispatching events to multiple channels. | See Support for multiple channels | null |
It's possible to send messages for multiple channels based on the value of a property for the event.
Parameter | Meaning | Default value |
---|---|---|
filterOnProperty | Send only the events that have a property with this name. | null |
channelList | Mapping for the target channels Uri and the filter property value. If the filter property for the event is not in this list, the webHookUri will be used. | null |
Example configuration:
{
"Serilog": {
"Using": [ "Serilog.Sinks.MicrosoftTeams.Alternative" ],
"MinimumLevel": "Debug",
"WriteTo": [
{
"Name": "MicrosoftTeams",
"Args": {
"webHookUri": "http://example.com/",
"channelHandler":
{
"filterOnProperty": "MsTeams",
"channelList": {
"ITTeam": "http://example.com/ITTeam/",
"SupportTeam": "http://example.com/SupportTeam/"
}
}
}
}
]
}
}
Note: filterOnProperty can be used with an empty channelList to send only some log events to Teams.
Once filterOnProperty is set, some events will need to be marked to be sent to Teams.
Using Serilog:
var loggerForChannel = logger.ForContext("filterOnPropertyValue", "ChannelName");
loggerForChannel.Information("Hello");
Using Microsoft ILogger:
using (logger.BeginScope(
new Dictionary<string, object> { ["filterOnPropertyValue"] = "ChannelName" }))
{
logger.LogInformation("Hello");
}
This project is a fork of https://github.com/DixonDs/serilog-sinks-teams but is maintained. Do not hesitate to create issues or pull requests. The relevant reference from Microsoft can be found here: https://docs.microsoft.com/en-us/outlook/actionable-messages/message-card-reference.