- #1370, #1374 - improve test coverage (@rafaelsc)
- #1371, #1377, #1429, #1445 - documentation updates (@perjahn, @morgankenyon, @rafaelsc, @JakenVeina)
- #1378, #1392 - build fixes (@nblumhardt)
- #1477 - don't fail to log when
ToString()
throws an exception (@rafaelsc) - #1435 -
netstandard2.1
support and default implementations forILogger
methods (@skomis-mm) - #1442 -
MinimumLevel.Override()
runtime optimizations (@skomis-mm) - #1463 - fix disposal of wrapped sinks through
LoggerSinkConfiguration.Wrap()
- #1466 - internal wrapper sink refactoring (@nblumhardt)
- #1427, #1452, #1467 - when
ToString()
on a logged object returnsnull
, serialize as""
(@rafaelsc, @nblumhardt) - #1472 - improve handling of minimum level overrides in sub-loggers (@skomis-mm)
- #1296 - switch from TravisCI to AppVeyor for Linux builds (@merbla)
- #1254, #1255 - reduce allocations in hot path (@Pliner)
- #1300 - link Pluralsight courses (@dahlsailrunner)
- #1312 - code clean-up (@sungam3r)
- #1314, #1317 - code clean-up (@SimonCropp)
- #1315 - reduce allocations in hot path (@nblumhardt)
- #1266 - update package license declaration to the new format (@tsimbalar)
- #1316 - support wrapped enrichers, conditional sinks, and conditional enrichers (@nblumhardt)
- #1320 - publish
snupkg
symbol packages (@teo-tsirpanis) - #1325 - respect explicit format specifiers when using JSON formatting defaults (@nblumhardt)
- #1330 - make the nullable format provider syntactically optional when constructing
MessageTemplateTextFormatter
(@bender2k14) - #1341 - remove redundant System.Collections.NonGeneric dependency from
netstandard2.0
target (@WeihanLi) - #1348 - add
INFLUENCES.md
(@nblumhardt) - #1357 - fix API documentation for default destructuring depth (@rob-earwaker)
- #1366 - fix message template parsing of custom format strings that contain
+
(@martinh2011)
- #1179 - support for
Destructure.AsScalar(type)
in key-value settings (@tsimbalar) - #1174 - partial support for
Destructure.Xxx()
in key-value settings (@tsimbalar) - #1192 - support for
Destructure.With(policy)
in key-value settings (@tsimbalar) - #1189 - renew certificate to fix UWP integration tests (@skomis-mm)
- #1197 - make it simple to compare
Logger.Instance
withLogger.None
(@ie-zero) - #1198 - support
*.With(...)
andAuditTo.Sink(sink)
/WriteTo.Sink(sink)
in key-value settings (@tsimbalar) - #1220 - include
repositoryUrl
in the NuGet package (@MaximRouiller) - #1233 - fix padding of non-string values in output templates (@nblumhardt)
- #1169 - update performance tests to
netcoreapp2.0
(@merbla) - #1234 - add tests for custom
IFormatProvider
support (@tsimbalar) - #1236 - fix failure/exception thrown when calling
ForContext()
to destructure some generated proxy types (@balayoglu) - #1269 - add
netstandard2.0
target to shrink dependency graph on compatible platforms (@nblumhardt)
- #1075 - overload of
LoggerSinkConfiguration.Wrap()
acceptingLoggingLevelSwitch
- #1083 - update package metadata, including
https://
project and icon URLs - #1091 - make
{Properties:j}
work consistently with the console sink - #1110 - expose an efficient
Logger.None
- #1113 - (tooling) improve tests for
LogContext
- #1136 - (tooling) fix
build.sh
exit code - #1141 - fix logging of
byte[]
smaller than 1 KB - #1157 - (tooling) update .gitignore
- #1158 - (tooling) re-enable macOS builds
- #1163 - SourceLink v2 support
- #1165 - fix a number of issues with
LoggerSinkConfiguration.Wrap()
affectingWriteTo.Async()
- #1134 - (tooling) add README badges for downloads/stats
- #1166 - allow
LoggerConfiguration
to be garbage collected after logger is created - #1160 - (tooling) update NuGet.org API key
- (tooling) Update to use the latest .NET SDK
- #992 - fix
LogContext
remoting issue on .NET Framework 4.5 - #1007 -
LogContext.Suspend()
andLogContext.Reset()
to pass or drop context from child tasks - #1018 - include source in NUPKGs
- #1020 - support for
LoggingLevelSwitch
in key-value/<appSettings>
settings - #1033 - warn when
MinimumLevel.Override()
is used in a sub-logger - #1034 - more efficient levelled
ILogger.ForContext()
/Log.ForContext()
- #1051 - handle duplicate keys in key-value/
<appSettings>
settings (last-in wins) - #1064 - support static member references as key-value/
<appSettings>
values - #1059 - support for abstract class parameters in settings
- #1068 - handle parsing of token width more robustly
- Plus build/documentation items #988, #994, #996, #1019, #842, #1042, #1050, #1055, #1063.
- #939, #946, #972 - RTM .NET Standard/Core tooling
- #955 -
LoggerSinkConfiguration.Wrap()
- #944 -
{Properties}
in output templates - #961 - fix parser exception when property tokens with zero-length names are encountered
- #773 -
LogContext.Clone()
andLogContext.Push(ILogEventEnricher)
- #976 - support for logging C# 7
ValueTuple<>
values - #977 - output formatting performance improvements,
{Message:l}
(unquoted string) and{Message:j}
(JSON structure) support in output templates - #981 - reduced allocations required for structured data capturing
Plus multiple build/test/configuration improvements.
- #866 and #877- additional event payload limiting controls
- #833 - improve performance of message template cache lookup
- #885 - fix JSON formatting of
NaN
and infinity values - #888 - allow minimum level overrides to be specified by configuration providers like Serilog.Settings.AppSettings
- #903 - add further
Log
static methods to matchILogger
methods - #907 - properly dispose audit sinks
- #913 - include commit hash in
AssemblyInformationalVersion
- #925 - allow configuration providers to specify
filter
directives - Build and test coverage work in #821, #824, #896.
- #870 - fix dispose for level-restricted sinks
- #852 - fix dictionary capturing when key/value are anonymous types
- #835 - avoid
RemotingException
viaLogContext
- #855 - allow custom enum rendering (better
ICustomFormatter
support - #841 -
audit-to
in key-value settings
- #835 (fix for .NET 4.6+ only)
- #826 - audit-style logging
- #819 - deprecate virtual extension points on JsonFormatter
- #782 - provide
Destructure.ByTransformingWhere()
- #779 - capture additional parameters even when template is malformed
- #798 - fix overload selection in
KeyValueSettings
- #815 - allow level to be lowered by overrides, in addition to being raised
- #535 - .NET Core support; split sinks, enrichers and settings providers into standalone packages; refactor to eliminate Serilog.FullNetFx.dll; remove .NET 4.0 support
- #566 -
Log.CloseAndFlush()
- #561 - detect and throw exception if
LoggerConfiguration.CreateLogger()
is called more than once - #617 - update project to use C# 6 where appropriate
- Use
R
round-trip formatting when converting floating point values to JSON - #623 - PeriodicBatchingSink - reduce contention when enqueueing events to
PeriodicBatchingSink
- #618 - correctly handle VB.NET anonymous types when destructuring
- #636 - support more enrichment scenarios in
<appSettings>
- #588 - enable
LogContext
on all target platforms - #654 - improved
WriteTo.Logger()
level and switch handling - #656 - FileSink - support buffered writes in file-based sinks
- #649 - ColoredConsoleSink - do not print empty properties in colored console output
- #719 - concrete,
IDisposable
return value fromLoggerConfiguration.CreateLogger()
- #727 - remove the unimplementable
IScalarConversionPolicy
interface - #728 - allow user-specified destructuring of reflection types
- #711 and #765 - formatting for short, all-upper/all-lowercase and fixed-width level names in output templates
- #747 -
ForContext()
performance improvements - #752 - zero-allocation generic methods on
ILogger
for up to three args - #746 - add
BindMessageTemplate()
andBindProperty()
toILogger
- #731 -
SelfLog
API improvements - #754 -
MinimumLevel.Override()
per-source level overrides - #770 - message template parser optimization
- #769 - BenchmarkDotNet performance tests for solution
- #760 - TravisCI build on Mac OS and Linux
- #772 - included
LogEventPropertyValueVisitor
andJsonValueFormatter
- #776 - message template construction optimization
- #733 - use
ObjectHandle
to wrapLogContext
stack on remoting-capable targets; allows cross-AppDomain
calls withoutSuspend()
orPermitCrossAppDomainCalls
, both removed - #781 - allow interface-typed values to be set in
<appSettings>
configuration by specifying an implementation type name
- #567 - allow literal formatting to be overridden in
JsonFormatter
- #579 - fixed
NullReferenceException
in someRollingFileSink
failure modes - #550 - support custom prefixes in
ReadFrom.AppSettings()
configuration - #570 - added
Enrich.WithEnvironmentUserName()
- #562 - turn logging off when no sinks are configured
- #538 - mark assemblies as CLS compliant
- #532 -
WriteTo.Logger()
improvements for sub-pipelines
- #523 - prevent excessive RAM use when large strings are cached as message templates
- #514 - provide
OnEmptyBatch()
to allow batching sinks to perform background work
- #491 - enable
ReadFrom.KeyValuePairs()
in .NET 4.0 build
- #484 - generic overloads on
Log
to avoid boxing/allocation
- #456 - support
ReadFrom.AppSettings()
and friends on .NET 4.0
- Builds on
master
now derive their version fromCHANGES.md
(rather than vice-versa) - #441 - Fix conversion of
Nullable<>
settings
- #433 - Revert the default destructuring depth back to 10
- #402 -
<appSettings>
configuration support now in the Serilog package
- #344 - Moved "Extras" including Web, Owin, F#, destructuring to new organizations
- #344 (partial) - Moved remaining sinks to individual repositories
- #393 - Removed the Splunk sink for move to https://github.com/serilog/serilog-sinks-splunk
- #389 - Fixed the default URI in the ES sink
- #385 - Provided
IndexDecider
option to ES sink configuration
- #382 - Fixed
CounterMeasure
counting in Serilog.Extras.Timing - #386 - Expand environment variables on Serilog.Extras.AppSettings values
- #387 - Elmah.io sink dependency version updated
- #376 - Fixed flushing of async events to Loggly sink (moved to serilog/serilog-sinks-loggly)
- #374 - Run destructuring policies before converting
IEnumerable
types
- #196 -
LogContext.PermitCrossAppDomainCalls
property to prevent serialization exceptions in test frameworks and when .NET remoting is used - #365 - Serilog.Sinks.ApplicationInsights now targets the new Azure Portal-based version (preview)
- #367 - Serilog.Sinks.MongoDB now targets the new preview driver (preview)
- #369 - Fixed log message property in .NET 4.0 build of Elasticsearch sink
- #373 - Update the Raygun sink from 2.0.4 to 4.2.0
- #344 - Moved the MongoDB and Application Insights sinks out to independent repositories
- #125 - Merged MonoTouch and MonoAndroid sinks (not currently published to NuGet)
- #362 - Update Loggly sink package dependencies
- #203 - Azure Document DB sink
- #354 - Added Serilog.Extras.FSharp
- #351 - Azure Event Hubs sink
- #329 - Write event properties as columns using the new
WriteTo.AzureTableStorageWithProperties()
- #346 - Pass all properties through to Serilog.Sinks.NLog as context properties
- #347 - Update Serilog.Sinks.SignalR to SignalR version 2.1.0 (breaking)
- #342 - Accept
ILogEventEnricher
rather than justPropertyEnricher
toForContext
- #341 - Selectable logging level for request details in Serilog.Extras.Web
- #340 - Accept an
Encoding
parameter on the file sinks - #336 - Use stream when writing to Splunk via HTTP
- #335 - Remove use of
dynamic
when destructuringNullable<T>
(iOS)
- #321 - Revert ES sink message property name to original value
- #324 - Calculate ES index name from UTC timestamp
- #315 - Remove Logentries SSL cert pinning (the cert changed)
- #327 - Hide obsolete ES configuration methods
- #311 - Accept multiple recipient addresses in the email sink
- #289 - Elasticsearch sink improvements and new virtual methods on
JsonFormatter
- #302 - If a the last batch of log events sent by
PeriodicBatchingSink
was not full, wait theperiod
- #304 - Make sure IO exceptions are suppressed by the
WriteTo.File()
configuration method
- #303 -
AssemblyInformationalVersion
needs to track the package, not assembly, version, in order to play nicely with MSI
- #283 - New solution targeting ASP.NET v.NEXT (when final, we'll refactor to give this first-class support)
- #301 - Serilog.Extras.Web improvements
- Fixed some more NuGet packaging issues (Serilog.Sinks.Splunk this time)
- #297 - Update loggly-csharp package dependency
- Fixed some NuGet packaging issues (including a return to dependency groups for Serilog.Sinks.Seq)
- New CI server used
- #227 - Reduced default maximum destructuring depth and added configuration option
- #245 - XML content escaping fixed in MSSQL sink
- #272 - Allow underscores in property names
- #259 - Update loggly-sharp dependency (breaking change for Serilog.Sinks.Loggly, see PR for instructions)
- #257 - Added Serilog.Sinks.XSockets
- #246 - Changed target from Profile78 to (compatible but broader) Profile259
- #250 - Allow an existing
MongoDatabase
instance to be used when configuring Mongo sink
- #253 - Added
MessageTemplateFormatMethodAttribute
- #244 - Improvements to ElasticSearch sink, switch to just ElasticSearch.NET
- #254 - Fix ElasticSearch dependency version
- #249 - Track message template token indexes in parser to support tooling (binary-breaking)
- #240 - Update TopShelf dependency
- #243 - Caching in
AttributedDestructuringPolicy
closes over first seen object of a type rather than using the passed parameter - #242 - Update NLogSink to map
Verbose
level toTrace
level in NLog - #229 - Created net40 version of Extras Topshelf
- #236 - Ensure dictionary keys are quoted in JSON even when they're numeric
- #237 - When
JsonFormatter
formats a dictionary of<int, object>
, the key should be double quoted - #235 - Fixed serialization of dictionary keys in ES and similar sinks
- #238 - Dynamic level switching
- #225 - Ensure Azure Tablestorage rowkey is unique
- #224 - Use UTC to generate partitionkey
- #219 - .NET 4.0 support for Elastic Search
- #221 - Exponential back-off for PeriodicBatchingSink
- #213 - Check for null User.Identity when enriching events with usernames in ASP.NET
- #216 - Updated to use Splunk TCP Writer
- #204 - Basic HTTP authentication support for the CouchDB sink
- #207 - Fixed typo in
DepthLimiter
error message - #209 - Update Serilog.Sinks.Splunk to Splunk SDK 2.0 GA
- #210 - Fixed string formatting in
PropertyBinder
error message
- #192 - Additional enrichers for Serilog.Extras.Web
- #202 - Batching mode for Serilog.Sinks.AzureTableStorage
- Reintroduced fix from datalust/seq-client-log4net#19 dropped in project move
- #179 - Serilog.Sinks.Splunk updated for the Splunk SDK 2.0
- Includes the Serilog.Sinks.Seq sink, to write to the http://getseq.net event server
- #169 - Added the Serilog.Extras.DestructureByIgnoring package
- #197 - Allow
EventSource
creation to be skipped when the source does not exist
- #196 - Introduce
LogContext.Suspend()
to clearLogicalCallContext
for cross-domain calls