//
// Copyright (c) ZeroC, Inc. All rights reserved.
//
using System.Security.Cryptography.X509Certificates;
namespace IceSSL
{
///
/// Plug-in factories must implement this interface.
///
public sealed class PluginFactory : Ice.PluginFactory
{
///
/// Returns a new plug-in.
///
/// The communicator for the plug-in.
/// The name of the plug-in.
/// The arguments that are specified in the plug-in's configuration.
///
/// The new plug-in. null can be returned to indicate
/// that a general error occurred. Alternatively, create can throw
/// PluginInitializationException to provide more detailed information.
public Ice.Plugin create(Ice.Communicator communicator, string name, string[] args)
{
return new PluginI(communicator);
}
}
public sealed class PluginI : Plugin
{
public PluginI(Ice.Communicator communicator)
{
IceInternal.ProtocolPluginFacade facade = IceInternal.Util.getProtocolPluginFacade(communicator);
_engine = new SSLEngine(facade);
//
// SSL based on TCP
//
Instance instance = new Instance(_engine, Ice.SSLEndpointType.value, "ssl");
facade.addEndpointFactory(new EndpointFactoryI(instance, Ice.TCPEndpointType.value));
}
public override void initialize()
{
_engine.initialize();
}
public override void destroy()
{
}
public override void setCACertificates(X509Certificate2Collection certs)
{
_engine.setCACertificates(certs);
}
public override void setCertificates(X509Certificate2Collection certs)
{
_engine.setCertificates(certs);
}
public override void setCertificateVerifier(CertificateVerifier verifier)
{
_engine.setCertificateVerifier(verifier);
}
public override CertificateVerifier getCertificateVerifier()
{
return _engine.getCertificateVerifier();
}
public override void setPasswordCallback(PasswordCallback callback)
{
_engine.setPasswordCallback(callback);
}
public override PasswordCallback getPasswordCallback()
{
return _engine.getPasswordCallback();
}
private SSLEngine _engine;
}
}