| | | 1 | | // Copyright (c) ZeroC, Inc. |
| | | 2 | | |
| | | 3 | | using IceRpc.Logger; |
| | | 4 | | using Microsoft.Extensions.Logging; |
| | | 5 | | |
| | | 6 | | namespace IceRpc.Extensions.DependencyInjection; |
| | | 7 | | |
| | | 8 | | /// <summary>Provides an extension method for <see cref="IDispatcherBuilder" /> to add the logger middleware.</summary> |
| | | 9 | | public static class LoggerDispatcherBuilderExtensions |
| | | 10 | | { |
| | | 11 | | /// <summary>Adds a <see cref="LoggerMiddleware" /> to this dispatcher builder. This interceptor relies on the |
| | | 12 | | /// <see cref="ILogger{T}" /> service managed by the service provider.</summary> |
| | | 13 | | /// <param name="builder">The builder being configured.</param> |
| | | 14 | | /// <returns>The builder being configured.</returns> |
| | | 15 | | public static IDispatcherBuilder UseLogger(this IDispatcherBuilder builder) => |
| | 0 | 16 | | builder.ServiceProvider.GetService(typeof(ILogger<LoggerMiddleware>)) is ILogger logger ? |
| | 0 | 17 | | builder.Use(next => new LoggerMiddleware(next, logger)) : |
| | 0 | 18 | | throw new InvalidOperationException( |
| | 0 | 19 | | $"Could not find service of type '{nameof(ILogger<LoggerMiddleware>)}' in the service container."); |
| | | 20 | | } |