From 81fd3f564d0def0ec13f6d54578f27fa52eb7b72 Mon Sep 17 00:00:00 2001 From: Rolf Kristensen Date: Tue, 30 May 2023 22:06:38 +0200 Subject: [PATCH] Improve docs for using NLog AppCenter Target with MAUI (#38) --- README.md | 75 +++++++++++++------ .../Config/SetupBuilderExtensions.cs | 19 +++++ .../SetupExtensionsBuilderExtensions.cs | 19 +++++ .../SetupLoadConfigurationExtensions.cs | 31 ++++++++ .../NLog.Targets.AppCenter.csproj | 13 ++-- 5 files changed, 128 insertions(+), 29 deletions(-) create mode 100644 src/NLog.Targets.AppCenter/Config/SetupBuilderExtensions.cs create mode 100644 src/NLog.Targets.AppCenter/Config/SetupExtensionsBuilderExtensions.cs create mode 100644 src/NLog.Targets.AppCenter/Config/SetupLoadConfigurationExtensions.cs diff --git a/README.md b/README.md index 6131542..d4f40fa 100644 --- a/README.md +++ b/README.md @@ -4,40 +4,52 @@ NLog Target for [Microsoft Visual Studio App Center with Azure](https://azure.mi [![Version](https://badge.fury.io/nu/NLog.Targets.AppCenter.svg)](https://www.nuget.org/packages/NLog.Targets.AppCenter) [![AppVeyor](https://img.shields.io/appveyor/ci/nlog/nlog-azureappcenter/master.svg)](https://ci.appveyor.com/project/nlog/nlog-azureappcenter/branch/master) -### How to use +### How to setup NLog in MAUI -1) Install the package +1) Install the NLog packages - `Install-Package NLog.Targets.AppCenter` or in your csproj: + - `Install-Package NLog.Targets.AppCenter` + - `Install-Package NLog.Extensions.Logging` + + or in your csproj: ```xml + ``` -2) Add to your nlog.config: +2) Add NLog to the MauiApp - ```xml - - - - ``` + Update `MauiProgram.cs` to include NLog as Logging Provider: + ```csharp + var builder = MauiApp.CreateBuilder(); -3) Use the target "appcenter" in your nlog.config + // Add NLog for Logging + builder.Logging.ClearProviders(); + builder.Logging.AddNLog(); + ``` - ```xml - - - - - - - - - - - ``` + If getting compiler errors with unknown methods, then update `using`-section: + ```csharp + using Microsoft.Extensions.Logging; + using NLog; + using NLog.Extensions.Logging; + ``` + +3) Load NLog configuration for logging + + Add the `NLog.config` into the Application-project as assembly-resource (`Build Action` = `embedded resource`), and load like this: + ```csharp + NLog.LogManager.Setup().RegisterAppCenter().LoadConfigurationFromAssemblyResource(typeof(App).Assembly); + ``` + Alternative setup NLog configuration using [fluent-API](https://github.com/NLog/NLog/wiki/Fluent-Configuration-API): + ```csharp + var logger = NLog.LogManager.Setup().RegisterAppCenter() + .LoadConfiguration(c => c.ForLogger(NLog.LogLevel.Debug).WriteToAppCenter()) + .GetCurrentClassLogger(); + ``` -### Configuration options for AppCenterTarget +### Configuration options for AppCenter NLog Target - **AppSecret** - Appsecret for starting AppCenter if needed (optional) - **UserId** - Application UserId to register in AppCenter (optional) @@ -47,3 +59,20 @@ NLog Target for [Microsoft Visual Studio App Center with Azure](https://azure.mi - **IncludeEventProperties** - Include LogEvent properties in AppCenter properties (default=true) - **IncludeScopeProperties** - Include MappedDiagnosticsLogicalContext (MLDC) that can be provided with MEL BeginScope (default=false) +```xml + + + + + + + + + + + + + + + +``` \ No newline at end of file diff --git a/src/NLog.Targets.AppCenter/Config/SetupBuilderExtensions.cs b/src/NLog.Targets.AppCenter/Config/SetupBuilderExtensions.cs new file mode 100644 index 0000000..666d36e --- /dev/null +++ b/src/NLog.Targets.AppCenter/Config/SetupBuilderExtensions.cs @@ -0,0 +1,19 @@ +using NLog.Config; + +namespace NLog +{ + /// + /// Extension methods to setup LogFactory options + /// + public static class SetupBuilderExtensions + { + /// + /// Register the NLog.Web LayoutRenderers before loading NLog config + /// + public static ISetupBuilder RegisterAppCenter(this ISetupBuilder setupBuilder) + { + setupBuilder.SetupExtensions(e => e.RegisterAppCenter()); + return setupBuilder; + } + } +} diff --git a/src/NLog.Targets.AppCenter/Config/SetupExtensionsBuilderExtensions.cs b/src/NLog.Targets.AppCenter/Config/SetupExtensionsBuilderExtensions.cs new file mode 100644 index 0000000..c11b046 --- /dev/null +++ b/src/NLog.Targets.AppCenter/Config/SetupExtensionsBuilderExtensions.cs @@ -0,0 +1,19 @@ +using NLog.Config; +using NLog.Targets; + +namespace NLog +{ + /// + /// Extension methods to setup NLog extensions, so they are known when loading NLog LoggingConfiguration + /// + public static class SetupExtensionsBuilderExtensions + { + /// + /// Register the NLog.Web LayoutRenderers + /// + public static ISetupExtensionsBuilder RegisterAppCenter(this ISetupExtensionsBuilder setupBuilder) + { + return setupBuilder.RegisterTarget("AppCenter"); + } + } +} diff --git a/src/NLog.Targets.AppCenter/Config/SetupLoadConfigurationExtensions.cs b/src/NLog.Targets.AppCenter/Config/SetupLoadConfigurationExtensions.cs new file mode 100644 index 0000000..d5d99c4 --- /dev/null +++ b/src/NLog.Targets.AppCenter/Config/SetupLoadConfigurationExtensions.cs @@ -0,0 +1,31 @@ +using NLog.Config; +using NLog.Layouts; +using NLog.Targets; + +namespace NLog +{ + /// + /// Extension methods to setup NLog + /// + public static class SetupLoadConfigurationExtensions + { + /// + /// Write to AppCenter NLog Target + /// + /// + /// Override the default Layout for output + /// appsecret for starting AppCenter if needed + /// activate AppCenter-Crashes and report Exceptions as crashes + public static ISetupConfigurationTargetBuilder WriteToAppCenter(this ISetupConfigurationTargetBuilder configBuilder, Layout layout = null, Layout appSecret = null, bool reportExceptionAsCrash = false) + { + var logTarget = new AppCenterTarget(); + if (layout != null) + logTarget.Layout = layout; + if (appSecret != null) + logTarget.AppSecret = appSecret; + if (reportExceptionAsCrash) + logTarget.ReportExceptionAsCrash = reportExceptionAsCrash; + return configBuilder.WriteTo(logTarget); + } + } +} diff --git a/src/NLog.Targets.AppCenter/NLog.Targets.AppCenter.csproj b/src/NLog.Targets.AppCenter/NLog.Targets.AppCenter.csproj index 8497e32..e8740e1 100644 --- a/src/NLog.Targets.AppCenter/NLog.Targets.AppCenter.csproj +++ b/src/NLog.Targets.AppCenter/NLog.Targets.AppCenter.csproj @@ -2,7 +2,7 @@ net462;netstandard2.0 - 5.0.2 + 5.2.0 5.0.0.0 $(APPVEYOR_BUILD_NUMBER) 0 @@ -18,8 +18,9 @@ N.png BSD-3-Clause -- Updated dependency Microsoft.AppCenter to v5.0.1 - Fixed StrongName Support -- Added StrongName Support +- Updated dependency NLog v5.2 +- Updated dependency Microsoft.AppCenter v5.0.2 +- Added fluent API Setup() extension methods RegisterAppCenter() and WriteToAppCenter() true @@ -33,9 +34,9 @@ - - - + + +