From af33b74ec0bde9d9a5e8d1bbc9168607b31b737e Mon Sep 17 00:00:00 2001 From: Geoffrey Kizer Date: Sat, 7 Nov 2020 17:55:59 -0800 Subject: [PATCH] add missing constructor overloads --- .../System.Net.Quic/ref/System.Net.Quic.cs | 2 ++ .../System/Net/Quic/QuicClientConnectionOptions.cs | 2 +- .../src/System/Net/Quic/QuicConnection.cs | 12 +++++++++++- .../src/System/Net/Quic/QuicListener.cs | 14 ++++++++++++-- 4 files changed, 26 insertions(+), 4 deletions(-) diff --git a/src/libraries/System.Net.Quic/ref/System.Net.Quic.cs b/src/libraries/System.Net.Quic/ref/System.Net.Quic.cs index 4b4616878a51f..12f167a2a6623 100644 --- a/src/libraries/System.Net.Quic/ref/System.Net.Quic.cs +++ b/src/libraries/System.Net.Quic/ref/System.Net.Quic.cs @@ -15,6 +15,7 @@ public static class QuicImplementationProviders public sealed class QuicListener : IDisposable { public QuicListener(IPEndPoint listenEndPoint, System.Net.Security.SslServerAuthenticationOptions sslServerAuthenticationOptions) { throw null; } + public QuicListener(QuicListenerOptions options) { throw null; } public QuicListener(Implementations.QuicImplementationProvider implementationProvider, IPEndPoint listenEndPoint, System.Net.Security.SslServerAuthenticationOptions sslServerAuthenticationOptions) { throw null; } public QuicListener(Implementations.QuicImplementationProvider implementationProvider, QuicListenerOptions options) { throw null; } public IPEndPoint ListenEndPoint => throw null; @@ -37,6 +38,7 @@ public class QuicListenerOptions public sealed class QuicConnection : IDisposable { public QuicConnection(System.Net.EndPoint remoteEndPoint, System.Net.Security.SslClientAuthenticationOptions? sslClientAuthenticationOptions, System.Net.IPEndPoint? localEndPoint = null) { throw null; } + public QuicConnection(QuicClientConnectionOptions options) { throw null; } public QuicConnection(Implementations.QuicImplementationProvider implementationProvider, System.Net.EndPoint remoteEndPoint, System.Net.Security.SslClientAuthenticationOptions? sslClientAuthenticationOptions, System.Net.IPEndPoint? localEndPoint = null) { throw null; } public QuicConnection(Implementations.QuicImplementationProvider implementationProvider, QuicClientConnectionOptions options) { throw null; } public bool Connected => throw null; diff --git a/src/libraries/System.Net.Quic/src/System/Net/Quic/QuicClientConnectionOptions.cs b/src/libraries/System.Net.Quic/src/System/Net/Quic/QuicClientConnectionOptions.cs index 352357dfaefdb..47162f98cd265 100644 --- a/src/libraries/System.Net.Quic/src/System/Net/Quic/QuicClientConnectionOptions.cs +++ b/src/libraries/System.Net.Quic/src/System/Net/Quic/QuicClientConnectionOptions.cs @@ -43,7 +43,7 @@ public class QuicClientConnectionOptions public long MaxUnidirectionalStreams { get; set; } = 100; /// - /// Idle timeout for connections, afterwhich the connection will be closed. + /// Idle timeout for connections, after which the connection will be closed. /// public TimeSpan IdleTimeout { get; set; } = TimeSpan.FromMinutes(2); } diff --git a/src/libraries/System.Net.Quic/src/System/Net/Quic/QuicConnection.cs b/src/libraries/System.Net.Quic/src/System/Net/Quic/QuicConnection.cs index 6e379facb7e7b..445b4893f3c79 100644 --- a/src/libraries/System.Net.Quic/src/System/Net/Quic/QuicConnection.cs +++ b/src/libraries/System.Net.Quic/src/System/Net/Quic/QuicConnection.cs @@ -25,12 +25,22 @@ public QuicConnection(EndPoint remoteEndPoint, SslClientAuthenticationOptions? s { } - // !!! TEMPORARY: Remove "implementationProvider" before shipping + /// + /// Create an outbound QUIC connection. + /// + /// The connection options. + public QuicConnection(QuicClientConnectionOptions options) + : this(QuicImplementationProviders.Default, options) + { + } + + // !!! TEMPORARY: Remove or make internal before shipping public QuicConnection(QuicImplementationProvider implementationProvider, EndPoint remoteEndPoint, SslClientAuthenticationOptions? sslClientAuthenticationOptions, IPEndPoint? localEndPoint = null) : this(implementationProvider, new QuicClientConnectionOptions() { RemoteEndPoint = remoteEndPoint, ClientAuthenticationOptions = sslClientAuthenticationOptions, LocalEndPoint = localEndPoint }) { } + // !!! TEMPORARY: Remove or make internal before shipping public QuicConnection(QuicImplementationProvider implementationProvider, QuicClientConnectionOptions options) { _provider = implementationProvider.CreateConnection(options); diff --git a/src/libraries/System.Net.Quic/src/System/Net/Quic/QuicListener.cs b/src/libraries/System.Net.Quic/src/System/Net/Quic/QuicListener.cs index c0db8cdad2d25..e465bc2b631a3 100644 --- a/src/libraries/System.Net.Quic/src/System/Net/Quic/QuicListener.cs +++ b/src/libraries/System.Net.Quic/src/System/Net/Quic/QuicListener.cs @@ -13,7 +13,7 @@ public sealed class QuicListener : IDisposable private readonly QuicListenerProvider _provider; /// - /// Create a QUIC listener on the specified local endpoint and start listening. + /// Create a QUIC listener. /// /// The local endpoint to listen on. /// TLS options for the listener. @@ -22,12 +22,22 @@ public QuicListener(IPEndPoint listenEndPoint, SslServerAuthenticationOptions ss { } - // !!! TEMPORARY: Remove "implementationProvider" before shipping + /// + /// Create a QUIC listener. + /// + /// The listener options. + public QuicListener(QuicListenerOptions options) + : this(QuicImplementationProviders.Default, options) + { + } + + // !!! TEMPORARY: Remove or make internal before shipping public QuicListener(QuicImplementationProvider implementationProvider, IPEndPoint listenEndPoint, SslServerAuthenticationOptions sslServerAuthenticationOptions) : this(implementationProvider, new QuicListenerOptions() { ListenEndPoint = listenEndPoint, ServerAuthenticationOptions = sslServerAuthenticationOptions }) { } + // !!! TEMPORARY: Remove or make internal before shipping public QuicListener(QuicImplementationProvider implementationProvider, QuicListenerOptions options) { _provider = implementationProvider.CreateListener(options);