From db1d114d828b28fe91196d0f72e27502a052119b Mon Sep 17 00:00:00 2001 From: Iain Patterson Date: Wed, 1 Jan 2014 21:44:48 +0000 Subject: [PATCH] Fixed bugs when creating a service. A null argument to grant_logon_as_service() would cause a crash. We were calling CreateService() with the wrong access mask. We weren't printing any error message when CreateService() failed. --- messages.mc | 3 +++ service.cpp | 5 +++-- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/messages.mc b/messages.mc index 376132f..b67d79b 100644 --- a/messages.mc +++ b/messages.mc @@ -315,12 +315,15 @@ Severity = Informational Language = English Error creating service! +CreateService(): %s . Language = French Erreur à la création du service! +CreateService(): %s . Language = Italian Errore creazione servizio! +CreateService(): %s . MessageId = +1 diff --git a/service.cpp b/service.cpp index d7c7e6e..eaeb797 100644 --- a/service.cpp +++ b/service.cpp @@ -262,6 +262,7 @@ int get_service_username(const TCHAR *service_name, const QUERY_SERVICE_CONFIG * } int grant_logon_as_service(const TCHAR *username) { + if (! username) return 0; if (str_equiv(username, NSSM_LOCALSYSTEM_ACCOUNT)) return 0; /* Open Policy object. */ @@ -781,9 +782,9 @@ int install_service(nssm_service_t *service) { GetModuleFileName(0, service->image, _countof(service->image)); /* Create the service - settings will be changed in edit_service() */ - service->handle = CreateService(services, service->name, service->name, SC_MANAGER_ALL_ACCESS, SERVICE_WIN32_OWN_PROCESS, SERVICE_AUTO_START, SERVICE_ERROR_NORMAL, service->image, 0, 0, 0, 0, 0); + service->handle = CreateService(services, service->name, service->name, SERVICE_ALL_ACCESS, SERVICE_WIN32_OWN_PROCESS, SERVICE_AUTO_START, SERVICE_ERROR_NORMAL, service->image, 0, 0, 0, 0, 0); if (! service->handle) { - print_message(stderr, NSSM_MESSAGE_CREATESERVICE_FAILED); + print_message(stderr, NSSM_MESSAGE_CREATESERVICE_FAILED, error_string(GetLastError())); CloseServiceHandle(services); return 5; }