API Review Dependency Injection (#2015)
This commit is contained in:
parent
1fbb940b82
commit
3f0a6ebc0d
|
|
@ -1,7 +1,9 @@
|
||||||
// Copyright (c) .NET Foundation. All rights reserved.
|
// Copyright (c) .NET Foundation. All rights reserved.
|
||||||
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
|
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
|
||||||
|
|
||||||
|
using System;
|
||||||
using Microsoft.AspNetCore.Connections;
|
using Microsoft.AspNetCore.Connections;
|
||||||
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
|
|
||||||
namespace Microsoft.AspNetCore.SignalR
|
namespace Microsoft.AspNetCore.SignalR
|
||||||
{
|
{
|
||||||
|
|
@ -9,6 +11,13 @@ namespace Microsoft.AspNetCore.SignalR
|
||||||
{
|
{
|
||||||
public static IConnectionBuilder UseHub<THub>(this IConnectionBuilder connectionBuilder) where THub : Hub
|
public static IConnectionBuilder UseHub<THub>(this IConnectionBuilder connectionBuilder) where THub : Hub
|
||||||
{
|
{
|
||||||
|
var marker = connectionBuilder.ApplicationServices.GetService(typeof(SignalRMarkerService));
|
||||||
|
if (marker == null)
|
||||||
|
{
|
||||||
|
throw new InvalidOperationException("Unable to find the required services. Please add all the required services by calling " +
|
||||||
|
"'IServiceCollection.AddSignalR' inside the call to 'ConfigureServices(...)' in the application startup code.");
|
||||||
|
}
|
||||||
|
|
||||||
return connectionBuilder.UseConnectionHandler<HubConnectionHandler<THub>>();
|
return connectionBuilder.UseConnectionHandler<HubConnectionHandler<THub>>();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -11,6 +11,7 @@ namespace Microsoft.Extensions.DependencyInjection
|
||||||
{
|
{
|
||||||
public static ISignalRServerBuilder AddSignalRCore(this IServiceCollection services)
|
public static ISignalRServerBuilder AddSignalRCore(this IServiceCollection services)
|
||||||
{
|
{
|
||||||
|
services.AddSingleton<SignalRMarkerService>();
|
||||||
services.AddSingleton(typeof(HubLifetimeManager<>), typeof(DefaultHubLifetimeManager<>));
|
services.AddSingleton(typeof(HubLifetimeManager<>), typeof(DefaultHubLifetimeManager<>));
|
||||||
services.AddSingleton(typeof(IHubProtocolResolver), typeof(DefaultHubProtocolResolver));
|
services.AddSingleton(typeof(IHubProtocolResolver), typeof(DefaultHubProtocolResolver));
|
||||||
services.AddSingleton(typeof(IHubContext<>), typeof(HubContext<>));
|
services.AddSingleton(typeof(IHubContext<>), typeof(HubContext<>));
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,9 @@
|
||||||
|
// Copyright (c) .NET Foundation. All rights reserved.
|
||||||
|
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
|
||||||
|
|
||||||
|
namespace Microsoft.Extensions.DependencyInjection
|
||||||
|
{
|
||||||
|
internal class SignalRMarkerService
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -29,5 +29,14 @@ namespace Microsoft.Extensions.DependencyInjection
|
||||||
builder.Services.AddSingleton(typeof(HubLifetimeManager<>), typeof(RedisHubLifetimeManager<>));
|
builder.Services.AddSingleton(typeof(HubLifetimeManager<>), typeof(RedisHubLifetimeManager<>));
|
||||||
return builder;
|
return builder;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static ISignalRServerBuilder AddRedis(this ISignalRServerBuilder builder, string redisConnectionString, Action<RedisOptions> configure)
|
||||||
|
{
|
||||||
|
return AddRedis(builder, o =>
|
||||||
|
{
|
||||||
|
o.Options = ConfigurationOptions.Parse(redisConnectionString);
|
||||||
|
configure(o);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,6 @@
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using Microsoft.AspNetCore.SignalR;
|
using Microsoft.AspNetCore.SignalR;
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
|
||||||
|
|
||||||
namespace Microsoft.AspNetCore.Builder
|
namespace Microsoft.AspNetCore.Builder
|
||||||
{
|
{
|
||||||
|
|
@ -11,13 +10,6 @@ namespace Microsoft.AspNetCore.Builder
|
||||||
{
|
{
|
||||||
public static IApplicationBuilder UseSignalR(this IApplicationBuilder app, Action<HubRouteBuilder> configure)
|
public static IApplicationBuilder UseSignalR(this IApplicationBuilder app, Action<HubRouteBuilder> configure)
|
||||||
{
|
{
|
||||||
var marker = app.ApplicationServices.GetService(typeof(SignalRMarkerService));
|
|
||||||
if (marker == null)
|
|
||||||
{
|
|
||||||
throw new InvalidOperationException("Unable to find the SignalR service. Please add it by " +
|
|
||||||
"calling 'IServiceCollection.AddSignalR()'.");
|
|
||||||
}
|
|
||||||
|
|
||||||
app.UseConnections(routes =>
|
app.UseConnections(routes =>
|
||||||
{
|
{
|
||||||
configure(new HubRouteBuilder(routes));
|
configure(new HubRouteBuilder(routes));
|
||||||
|
|
|
||||||
|
|
@ -20,7 +20,6 @@ namespace Microsoft.Extensions.DependencyInjection
|
||||||
public static ISignalRServerBuilder AddSignalR(this IServiceCollection services)
|
public static ISignalRServerBuilder AddSignalR(this IServiceCollection services)
|
||||||
{
|
{
|
||||||
services.AddConnections();
|
services.AddConnections();
|
||||||
services.AddSingleton<SignalRMarkerService>();
|
|
||||||
services.AddSingleton<IConfigureOptions<HubOptions>, HubOptionsSetup>();
|
services.AddSingleton<IConfigureOptions<HubOptions>, HubOptionsSetup>();
|
||||||
return services.AddSignalRCore();
|
return services.AddSignalRCore();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue