private async Task ConsoleSampleServer() { ApplicationInstance.MessageDlg = new ApplicationMessageDlg(); ApplicationInstance application = new ApplicationInstance(); application.ApplicationName = "Quickstart Reference Server"; application.ApplicationType = ApplicationType.Server; application.ConfigSectionName = "Quickstarts.ReferenceServer"; // load the application configuration. ApplicationConfiguration config = await application.LoadApplicationConfiguration(false); // check the application certificate. bool haveAppCertificate = await application.CheckApplicationInstanceCertificate(false, CertificateFactory.defaultKeySize); if (!haveAppCertificate) { throw new Exception("Application instance certificate invalid!"); } if (!config.SecurityConfiguration.AutoAcceptUntrustedCertificates) { config.CertificateValidator.CertificateValidation += new CertificateValidationEventHandler(CertificateValidator_CertificateValidation); } // start the server. server = new ReferenceServer(); await application.Start(server); // start the status thread status = Task.Run(new Action(StatusThread)); // print notification on session events server.CurrentInstance.SessionManager.SessionActivated += EventStatus; server.CurrentInstance.SessionManager.SessionClosing += EventStatus; server.CurrentInstance.SessionManager.SessionCreated += EventStatus; }
public void Start() { try { Task t = ConsoleSampleServer(); t.Wait(); Console.WriteLine("Server started. Press any key to exit..."); } catch (Exception ex) { Utils.Trace("ServiceResultException:" + ex.Message); Console.WriteLine("Exception: {0}", ex.Message); } try { Console.ReadKey(true); } catch { // wait forever if there is no console Thread.Sleep(Timeout.Infinite); } if (server != null) { Console.WriteLine("Server stopped. Waiting for exit..."); server.Dispose(); server = null; status.Wait(); } }
private async Task StartConsoleReferenceServerAsync() { ApplicationInstance.MessageDlg = new ApplicationMessageDlg(); CertificatePasswordProvider PasswordProvider = new CertificatePasswordProvider(Password); ApplicationInstance application = new ApplicationInstance { ApplicationName = "Quickstart Reference Server", ApplicationType = ApplicationType.Server, ConfigSectionName = Utils.IsRunningOnMono() ? "Quickstarts.MonoReferenceServer" : "Quickstarts.ReferenceServer", CertificatePasswordProvider = PasswordProvider }; // load the application configuration. ApplicationConfiguration config = await application.LoadApplicationConfiguration(false).ConfigureAwait(false); var loggerConfiguration = new Serilog.LoggerConfiguration(); if (LogConsole) { loggerConfiguration.WriteTo.Console(restrictedToMinimumLevel: Serilog.Events.LogEventLevel.Warning); } #if DEBUG else { loggerConfiguration.WriteTo.Debug(restrictedToMinimumLevel: Serilog.Events.LogEventLevel.Warning); } #endif SerilogTraceLogger.Create(loggerConfiguration, config); // check the application certificate. bool haveAppCertificate = await application.CheckApplicationInstanceCertificate( false, CertificateFactory.DefaultKeySize, CertificateFactory.DefaultLifeTime).ConfigureAwait(false); if (!haveAppCertificate) { throw new Exception("Application instance certificate invalid!"); } if (!config.SecurityConfiguration.AutoAcceptUntrustedCertificates) { config.CertificateValidator.CertificateValidation += new CertificateValidationEventHandler(CertificateValidator_CertificateValidation); } // start the server. m_server = new ReferenceServer(); await application.Start(m_server).ConfigureAwait(false); // print endpoint info var endpoints = application.Server.GetEndpoints().Select(e => e.EndpointUrl).Distinct(); foreach (var endpoint in endpoints) { Console.WriteLine(endpoint); } // start the status thread m_status = Task.Run(new Action(StatusThreadAsync)); // print notification on session events m_server.CurrentInstance.SessionManager.SessionActivated += EventStatus; m_server.CurrentInstance.SessionManager.SessionClosing += EventStatus; m_server.CurrentInstance.SessionManager.SessionCreated += EventStatus; }