/// <summary> /// Main entry point into the Credentials Service Host /// </summary> internal static void Main(string[] args) { try { // read command-line arguments CommandOptions commandOptions = new CommandOptions(args, ServiceName); if (commandOptions.ShouldExit) { return; } string logFilePath = commandOptions.LogFilePath; if (string.IsNullOrWhiteSpace(logFilePath)) { logFilePath = "SqlToolsResourceProviderService"; } if (!string.IsNullOrWhiteSpace(commandOptions.LoggingDirectory)) { logFilePath = Path.Combine(commandOptions.LoggingDirectory, logFilePath); } // turn on Verbose logging during early development // we need to switch to Information when preparing for public preview Logger.Initialize(tracingLevel: commandOptions.TracingLevel, logFilePath: logFilePath, traceSource: "resourceprovider"); Logger.Write(TraceEventType.Information, "Starting SqlTools Resource Provider"); // set up the host details and profile paths var hostDetails = new HostDetails( name: "SqlTools Resource Provider", profileId: "Microsoft.SqlTools.ResourceProvider", version: new Version(1, 0)); SqlToolsContext sqlToolsContext = new SqlToolsContext(hostDetails); UtilityServiceHost serviceHost = ResourceProviderHostLoader.CreateAndStartServiceHost(sqlToolsContext); serviceHost.WaitForExit(); } catch (Exception e) { Logger.WriteWithCallstack(TraceEventType.Critical, $"An unhandled exception occurred: {e}"); Environment.Exit(1); } finally { Logger.Close(); } }
/// <summary> /// Main entry point into the Credentials Service Host /// </summary> internal static void Main(string[] args) { try { // read command-line arguments CommandOptions commandOptions = new CommandOptions(args, ServiceName); if (commandOptions.ShouldExit) { return; } string logFilePath = commandOptions.LogFilePath; if (string.IsNullOrWhiteSpace(logFilePath)) { logFilePath = Logger.GenerateLogFilePath("credentials"); } Logger.AutoFlush = commandOptions.AutoFlushLog; Logger.Initialize(tracingLevel: commandOptions.TracingLevel, logFilePath: logFilePath, traceSource: "credentials"); // set up the host details and profile paths var hostDetails = new HostDetails( name: "SqlTools Credentials Provider", profileId: "Microsoft.SqlTools.Credentials", version: new Version(1, 0)); SqlToolsContext sqlToolsContext = new SqlToolsContext(hostDetails); UtilityServiceHost serviceHost = HostLoader.CreateAndStartServiceHost(sqlToolsContext); serviceHost.WaitForExit(); } catch (Exception e) { Logger.WriteWithCallstack(TraceEventType.Critical, $"An unhandled exception occurred: {e}"); Environment.Exit(1); } finally { Logger.Close(); } }
/// <summary> /// Main entry point into the Credentials Service Host /// </summary> internal static void Main(string[] args) { try { // read command-line arguments CommandOptions commandOptions = new CommandOptions(args, ServiceName); if (commandOptions.ShouldExit) { return; } string logFilePath = "credentials"; if (!string.IsNullOrWhiteSpace(commandOptions.LoggingDirectory)) { logFilePath = Path.Combine(commandOptions.LoggingDirectory, logFilePath); } // turn on Verbose logging during early development // we need to switch to Normal when preparing for public preview Logger.Initialize(logFilePath: logFilePath, minimumLogLevel: LogLevel.Verbose, isEnabled: commandOptions.EnableLogging); Logger.Write(LogLevel.Normal, "Starting SqlTools Credentials Provider"); // set up the host details and profile paths var hostDetails = new HostDetails( name: "SqlTools Credentials Provider", profileId: "Microsoft.SqlTools.Credentials", version: new Version(1, 0)); SqlToolsContext sqlToolsContext = new SqlToolsContext(hostDetails); UtilityServiceHost serviceHost = HostLoader.CreateAndStartServiceHost(sqlToolsContext); serviceHost.WaitForExit(); } catch (Exception e) { Logger.Write(LogLevel.Error, string.Format("An unhandled exception occurred: {0}", e)); Environment.Exit(1); } }