/// <summary> /// Start the server. /// </summary> public void Start() { try { // Start the server. if (_server != null) { _server.Start(); } } catch (Exception) { if (_server != null) { _server.Dispose(); } _server = null; throw; } }
/// <summary> /// Initialise the server. /// </summary> private void Init() { try { string socketProviderHostPrefix = "DownloadManagerServer_"; string hostProviderFullName = socketProviderHostPrefix + "SocketProviderV6"; string hostProviderFullNameSecure = socketProviderHostPrefix + "SocketProviderV6Ssl"; // Get the certificate reader. Nequeo.Security.Configuration.Reader certificateReader = new Nequeo.Security.Configuration.Reader(); Nequeo.Net.Configuration.Reader hostReader = new Nequeo.Net.Configuration.Reader(); // Create the server endpoint. Nequeo.Net.Sockets.MultiEndpointModel[] model = new Nequeo.Net.Sockets.MultiEndpointModel[] { // None secure. new Nequeo.Net.Sockets.MultiEndpointModel() { Port = hostReader.GetServerHost(hostProviderFullName).Port, Addresses = new System.Net.IPAddress[] { System.Net.IPAddress.IPv6Any, System.Net.IPAddress.Any } }, // Secure. new Nequeo.Net.Sockets.MultiEndpointModel() { Port = hostReader.GetServerHost(hostProviderFullNameSecure).Port, Addresses = new System.Net.IPAddress[] { System.Net.IPAddress.IPv6Any, System.Net.IPAddress.Any } } }; // Start the server. _server = new Nequeo.Net.Download.ManagerServer(_basePath, model, hostReader.GetServerHost(hostProviderFullName).MaxNumClients); _server.Timeout = hostReader.GetServerHost(hostProviderFullName).ClientTimeOut; // Set the token provider. TokenProvider tokenProvider = new TokenProvider(); tokenProvider.ServiceName = _server.ServiceName; _server.TokenProvider = tokenProvider; // Inititalise. _server.Initialisation(); try { // Look for the certificate information in the configuration file. // Get the certificate if any. X509Certificate2 serverCertificate = certificateReader.GetServerCredentials(); // If a certificate exists. if (serverCertificate != null) { // Get the secure servers. _server.Server[2].UseSslConnection = true; _server.Server[2].X509Certificate = serverCertificate; _server.Server[3].UseSslConnection = true; _server.Server[3].X509Certificate = serverCertificate; } } catch { } } catch (Exception) { if (_server != null) { _server.Dispose(); } _server = null; throw; } }