public void Run( OpcVaultApiOptions opcVaultOptions, OpcVaultAzureADOptions azureADOptions) { try { exitCode = ExitCode.ErrorServerNotStarted; ConsoleGlobalDiscoveryServer(opcVaultOptions, azureADOptions).Wait(); Console.WriteLine("Server started. Press Ctrl-C to exit..."); exitCode = ExitCode.ErrorServerRunning; } catch (Exception ex) { Utils.Trace("ServiceResultException:" + ex.Message); Console.WriteLine("Exception: {0}", ex.Message); exitCode = ExitCode.ErrorServerException; return; } ManualResetEvent quitEvent = new ManualResetEvent(false); try { Console.CancelKeyPress += (sender, eArgs) => { quitEvent.Set(); eArgs.Cancel = true; }; } catch { } // wait for timeout or Ctrl-C quitEvent.WaitOne(); if (server != null) { Console.WriteLine("Server stopped. Waiting for exit..."); using (OpcVaultGlobalDiscoveryServer _server = server) { // Stop status thread server = null; status.Wait(); // Stop server and dispose _server.Stop(); } } exitCode = ExitCode.Ok; }
private async Task ConsoleGlobalDiscoveryServer( OpcVaultApiOptions opcVaultOptions, OpcVaultAzureADOptions azureADOptions) { ApplicationInstance.MessageDlg = new ApplicationMessageDlg(); ApplicationInstance application = new ApplicationInstance { ApplicationName = Program.Name, ApplicationType = ApplicationType.Server, ConfigSectionName = "Microsoft.Azure.IIoT.OpcUa.Modules.Vault" }; // load the application configuration. ApplicationConfiguration config = await application.LoadApplicationConfiguration(false); // check the application certificate. bool haveAppCertificate = await application.CheckApplicationInstanceCertificate(false, 0); if (!haveAppCertificate) { throw new Exception("Application instance certificate invalid!"); } if (!config.SecurityConfiguration.AutoAcceptUntrustedCertificates) { config.CertificateValidator.CertificateValidation += new CertificateValidationEventHandler(CertificateValidator_CertificateValidation); } // get the DatabaseStorePath configuration parameter. GlobalDiscoveryServerConfiguration opcVaultConfiguration = config.ParseExtension <GlobalDiscoveryServerConfiguration>(); // extract appId and vault name from database storage path string[] keyVaultConfig = opcVaultConfiguration.DatabaseStorePath?.Split(','); if (keyVaultConfig != null) { if (String.IsNullOrEmpty(opcVaultOptions.BaseAddress)) { // try configuration using XML config opcVaultOptions.BaseAddress = keyVaultConfig[0]; } if (String.IsNullOrEmpty(opcVaultOptions.ResourceId)) { if (keyVaultConfig.Length > 1 && !String.IsNullOrEmpty(keyVaultConfig[1])) { opcVaultOptions.ResourceId = keyVaultConfig[1]; } } if (String.IsNullOrEmpty(azureADOptions.ClientId)) { if (keyVaultConfig.Length > 2 && !String.IsNullOrEmpty(keyVaultConfig[2])) { azureADOptions.ClientId = keyVaultConfig[2]; } } if (String.IsNullOrEmpty(azureADOptions.ClientSecret)) { if (keyVaultConfig.Length > 3 && !String.IsNullOrEmpty(keyVaultConfig[3])) { azureADOptions.ClientSecret = keyVaultConfig[3]; } } if (String.IsNullOrEmpty(azureADOptions.TenantId)) { if (keyVaultConfig.Length > 4 && !String.IsNullOrEmpty(keyVaultConfig[4])) { azureADOptions.TenantId = keyVaultConfig[4]; } } if (String.IsNullOrEmpty(azureADOptions.Authority)) { if (keyVaultConfig.Length > 5 && !String.IsNullOrEmpty(keyVaultConfig[5])) { azureADOptions.Authority = keyVaultConfig[5]; } } } var serviceClient = new OpcVaultLoginCredentials(opcVaultOptions, azureADOptions); IOpcVault opcVaultServiceClient = new Microsoft.Azure.IIoT.OpcUa.Api.Vault.OpcVault(new Uri(opcVaultOptions.BaseAddress), serviceClient); var opcVaultHandler = new OpcVaultClientHandler(opcVaultServiceClient); // read configurations from OpcVault secret opcVaultConfiguration.CertificateGroups = await opcVaultHandler.GetCertificateConfigurationGroupsAsync(opcVaultConfiguration.BaseCertificateGroupStorePath); UpdateGDSConfigurationDocument(config.Extensions, opcVaultConfiguration); var certGroup = new OpcVaultCertificateGroup(opcVaultHandler); var requestDB = new OpcVaultCertificateRequest(opcVaultServiceClient); var appDB = new OpcVaultApplicationsDatabase(opcVaultServiceClient); requestDB.Initialize(); // for UNITTEST set auto approve true server = new OpcVaultGlobalDiscoveryServer(appDB, requestDB, certGroup, false); // start the server. await application.Start(server); // 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 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; }