Browse Source

Expose server certificate password and client certificate options to MqttServerOptionsBuilder

release/3.x.x
Craig Lutgen 5 years ago
parent
commit
a03bdc7616
5 changed files with 27 additions and 3 deletions
  1. +7
    -0
      Source/MQTTnet/Client/Options/MqttClientOptionsBuilder.cs
  2. +1
    -1
      Source/MQTTnet/Implementations/MqttTcpServerAdapter.cs
  3. +6
    -0
      Source/MQTTnet/Server/IMqttServerCredentials.cs
  4. +11
    -2
      Source/MQTTnet/Server/MqttServerOptionsBuilder.cs
  5. +2
    -0
      Source/MQTTnet/Server/MqttServerTlsTcpEndpointOptions.cs

+ 7
- 0
Source/MQTTnet/Client/Options/MqttClientOptionsBuilder.cs View File

@@ -139,6 +139,13 @@ namespace MQTTnet.Client.Options
return this;
}

public MqttClientOptionsBuilder WithCredentials(IMqttClientCredentials credentials)
{
_options.Credentials = credentials;

return this;
}

public MqttClientOptionsBuilder WithExtendedAuthenticationExchangeHandler(IMqttExtendedAuthenticationExchangeHandler handler)
{
_options.ExtendedAuthenticationExchangeHandler = handler;


+ 1
- 1
Source/MQTTnet/Implementations/MqttTcpServerAdapter.cs View File

@@ -48,7 +48,7 @@ namespace MQTTnet.Implementations
throw new ArgumentException("TLS certificate is not set.");
}

var tlsCertificate = new X509Certificate2(options.TlsEndpointOptions.Certificate);
var tlsCertificate = new X509Certificate2(options.TlsEndpointOptions.Certificate, options.TlsEndpointOptions.Password.Password);
if (!tlsCertificate.HasPrivateKey)
{
throw new InvalidOperationException("The certificate for TLS encryption must contain the private key.");


+ 6
- 0
Source/MQTTnet/Server/IMqttServerCredentials.cs View File

@@ -0,0 +1,6 @@
using System;

public interface IMqttServerCredentials
{
String Password { get; }
}

+ 11
- 2
Source/MQTTnet/Server/MqttServerOptionsBuilder.cs View File

@@ -82,9 +82,10 @@ namespace MQTTnet.Server
return this;
}

public MqttServerOptionsBuilder WithEncryptionCertificate(byte[] value)
public MqttServerOptionsBuilder WithEncryptionCertificate(byte[] value, IMqttServerCredentials password = null)
{
_options.TlsEndpointOptions.Certificate = value;
_options.TlsEndpointOptions.Password = password;
return this;
}

@@ -94,6 +95,14 @@ namespace MQTTnet.Server
return this;
}

public MqttServerOptionsBuilder WithClientCertificate(RemoteCertificateValidationCallback validationCallback = null, bool checkCertificateRevocation = false)
{
_options.TlsEndpointOptions.ClientCertificateRequired = true;
_options.TlsEndpointOptions.CheckCertificateRevocation = checkCertificateRevocation;
_options.TlsEndpointOptions.CertificateValidationCallback = validationCallback;
return this;
}

public MqttServerOptionsBuilder WithoutEncryptedEndpoint()
{
_options.TlsEndpointOptions.IsEnabled = false;
@@ -107,7 +116,7 @@ namespace MQTTnet.Server
return this;
}
#endif
public MqttServerOptionsBuilder WithStorage(IMqttServerStorage value)
{
_options.Storage = value;


+ 2
- 0
Source/MQTTnet/Server/MqttServerTlsTcpEndpointOptions.cs View File

@@ -12,6 +12,8 @@ namespace MQTTnet.Server

public byte[] Certificate { get; set; }

public IMqttServerCredentials Password { get; set; }

public bool ClientCertificateRequired { get; set; }

public bool CheckCertificateRevocation { get; set; }


Loading…
Cancel
Save