X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fnt_svc.c;h=42fe2f034851e29f78392ff97182abd13110ebe2;hb=740f1b422edc48c9eeed8346c45872a63b683370;hp=a63b58f65b2d78a410e49ea35bd2ef3193cde27c;hpb=21e081dc5b4e9f115302c4d3ab231b2caf1ad2c5;p=openldap diff --git a/servers/slapd/nt_svc.c b/servers/slapd/nt_svc.c index a63b58f65b..42fe2f0348 100644 --- a/servers/slapd/nt_svc.c +++ b/servers/slapd/nt_svc.c @@ -2,44 +2,23 @@ #include "portable.h" #include -//#include -//#include #include -//#include -//#include -//#include -//#include -//#include #include "ldap_defaults.h" #include "slap.h" -#include "slapdmsg.h" - -#define SCM_NOTIFICATION_INTERVAL 5000 -#define THIRTY_SECONDS (30 * 1000) - -#define SERVICE_NAME "OpenLDAP" - ldap_pvt_thread_cond_t started_event, stopped_event; ldap_pvt_thread_t start_status_tid, stop_status_tid; -// in main.c +/* in main.c */ void WINAPI ServiceMain( DWORD argc, LPTSTR *argv ); - -// in wsa_err.c -char *WSAGetLastErrorString( void ); - -// in nt_err.c -char *GetLastErrorString( void ); - -// in ntservice.c +/* in ntservice.c */ int srv_install( char* service, char* filename ); int srv_remove ( char* service, char* filename ); -void main( DWORD argc, LPTSTR *argv ) +int main( DWORD argc, LPTSTR *argv ) { int length; char filename[MAX_PATH], *fname_start; @@ -50,8 +29,10 @@ void main( DWORD argc, LPTSTR *argv ) { NULL, NULL } }; + /* // 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 + */ GetModuleFileName( NULL, filename, sizeof( filename ) ); fname_start = strrchr( filename, *LDAP_DIRSEP ); *fname_start = '\0'; @@ -60,34 +41,40 @@ void main( DWORD argc, LPTSTR *argv ) if ( argc > 1 ) { if ( _stricmp( "install", argv[1] ) == 0 ) { + 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; + return EXIT_FAILURE; } - if ( !srv_install(SERVICE_NAME, filename) ) + if ( !srv_install(svcName, filename) ) { fputs( "service failed installation ...\n", stderr ); - return; + return EXIT_FAILURE; } fputs( "service has been installed ...\n", stderr ); - return; + return EXIT_SUCCESS; } if ( _stricmp( "remove", argv[1] ) == 0 ) { + 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; + return EXIT_FAILURE; } - if ( !srv_remove(SERVICE_NAME, filename) ) + if ( !srv_remove(svcName, filename) ) { fputs( "failed to remove the service ...\n", stderr ); - return; + return EXIT_FAILURE; } fputs( "service has been removed ...\n", stderr ); - return; + return EXIT_SUCCESS; } } @@ -97,4 +84,6 @@ void main( DWORD argc, LPTSTR *argv ) is_NT_Service = 0; ServiceMain( argc, argv ); } + + return EXIT_SUCCESS; }