X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fnt_svc.c;h=67893d23a94503d08c84fde8748190ce6658153e;hb=21be582df7e13ae2c8d44e1f7f02478eb9ec0762;hp=d81bc68a47ac585054e19388fb77c19b1ffc4a81;hpb=9c7127cd811d8453c2aa4dd3ec9a1e30421086f3;p=openldap diff --git a/servers/slapd/nt_svc.c b/servers/slapd/nt_svc.c index d81bc68a47..67893d23a9 100644 --- a/servers/slapd/nt_svc.c +++ b/servers/slapd/nt_svc.c @@ -1,13 +1,23 @@ /* $OpenLDAP$ */ -/* - * Copyright 1998-2000 The OpenLDAP Foundation, All Rights Reserved. - * COPYING RESTRICTIONS APPLY, see COPYRIGHT file +/* This work is part of OpenLDAP Software . + * + * Copyright 1998-2006 The OpenLDAP Foundation. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted only as authorized by the OpenLDAP + * Public License. + * + * A copy of this license is available in the file LICENSE in the + * top-level directory of the distribution or, alternatively, at + * . */ #include "portable.h" #include #include #include "slap.h" +#include "lutil.h" #ifdef HAVE_NT_SERVICE_MANAGER @@ -15,25 +25,15 @@ void WINAPI ServiceMain( DWORD argc, LPTSTR *argv ); /* in ntservice.c */ -int srv_install( char* service, char * displayName, char* filename, - BOOL auto_start ); -int srv_remove ( char* service, char* filename ); -DWORD svc_installed (LPTSTR lpszServiceName, LPTSTR lpszBinaryPathName); -DWORD svc_running (LPTSTR lpszServiceName); - int main( int argc, LPTSTR *argv ) { int length; char filename[MAX_PATH], *fname_start; - extern int is_NT_Service; /* * Because the service was registered as SERVICE_WIN32_OWN_PROCESS, * the lpServiceName element of the SERVICE_TABLE_ENTRY will be - * ignored. Since we don't even know the name of the service at - * this point (since it could have been installed under a name - * different than SERVICE_NAME), we might as well just provide - * the parameter as "". + * ignored. */ SERVICE_TABLE_ENTRY DispatchTable[] = { @@ -42,13 +42,12 @@ int main( int argc, LPTSTR *argv ) }; /* - // set the service's current directory to being the installation directory for the service. - // this way we don't have to write absolute paths in the configuration files - */ + * set the service's current directory to the installation directory + * for the service. this way we don't have to write absolute paths + * in the configuration files + */ GetModuleFileName( NULL, filename, sizeof( filename ) ); fname_start = strrchr( filename, *LDAP_DIRSEP ); - *fname_start = '\0'; - SetCurrentDirectory( filename ); if ( argc > 1 ) { if ( _stricmp( "install", argv[1] ) == 0 ) @@ -66,12 +65,8 @@ int main( int argc, LPTSTR *argv ) if ( argc > 4 && stricmp(argv[4], "auto") == 0) auto_start = TRUE; - if ( (length = GetModuleFileName(NULL, filename, sizeof( filename ))) == 0 ) - { - fputs( "unable to retrieve file name for the service.\n", stderr ); - return EXIT_FAILURE; - } - if ( !srv_install(svcName, displayName, filename, auto_start) ) + strcat(filename, " service"); + if ( !lutil_srv_install(svcName, displayName, filename, auto_start) ) { fputs( "service failed installation ...\n", stderr ); return EXIT_FAILURE; @@ -85,12 +80,7 @@ int main( int argc, LPTSTR *argv ) char *svcName = SERVICE_NAME; if ( (argc > 2) && (argv[2] != NULL) ) svcName = argv[2]; - if ( (length = GetModuleFileName(NULL, filename, sizeof( filename ))) == 0 ) - { - fputs( "unable to retrieve file name for the service.\n", stderr ); - return EXIT_FAILURE; - } - if ( !srv_remove(svcName, filename) ) + if ( !lutil_srv_remove(svcName, filename) ) { fputs( "failed to remove the service ...\n", stderr ); return EXIT_FAILURE; @@ -98,14 +88,19 @@ int main( int argc, LPTSTR *argv ) fputs( "service has been removed ...\n", stderr ); return EXIT_SUCCESS; } + if ( _stricmp( "service", argv[1] ) == 0 ) + { + is_NT_Service = 1; + *fname_start = '\0'; + SetCurrentDirectory( filename ); + } } - puts( "starting slapd..." ); - if (svc_installed(SERVICE_NAME, NULL) != 0 - || svc_running(SERVICE_NAME) == 1 - || StartServiceCtrlDispatcher(DispatchTable) != 0 ) + if (is_NT_Service) + { + StartServiceCtrlDispatcher(DispatchTable); + } else { - is_NT_Service = 0; ServiceMain( argc, argv ); }