]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/nt_svc.c
Per ITS#419, don't require SLAPD_RLOOKUPS when HAVE_TCPD
[openldap] / servers / slapd / nt_svc.c
index a63b58f65b2d78a410e49ea35bd2ef3193cde27c..6eb5730dba6cea3c7975b240d0638f5ab3f873db 100644 (file)
@@ -1,45 +1,45 @@
-// nt_main.c
+/* $OpenLDAP$ */
+
 #include "portable.h"
 #include <stdio.h>
-
-//#include <ac/signal.h>
-//#include <ac/socket.h>
 #include <ac/string.h>
-//#include <ac/time.h>
-//#include <ac/unistd.h>
-//#include <ac/wait.h>
-//#include <ac/signal.h>
-//#include <ac/errno.h>
-
-#include "ldap_defaults.h"
 #include "slap.h"
 
-#include "slapdmsg.h"
-
-#define SCM_NOTIFICATION_INTERVAL      5000
-#define THIRTY_SECONDS                         (30 * 1000)
+static void stubs()
+{
+    ldap_abandon(NULL, 0);
+    ldap_add_s(NULL, NULL, NULL);
+    ldap_bind_s(NULL, NULL, NULL, 0);
+    ldap_delete_s(NULL, NULL);
+    ldap_first_attribute(NULL, NULL, NULL);
+    ldap_first_entry(NULL, NULL);
+    ldap_get_dn(NULL, NULL);
+    ldap_get_option(NULL, 0, NULL);
+    ldap_get_values_len(NULL, NULL, NULL);
+    ldap_init(NULL, 0);
+    ldap_modify_s(NULL, NULL, NULL);
+    ldap_modrdn_s(NULL, NULL, NULL);
+    ldap_msgfree(NULL);
+    ldap_next_attribute(NULL, NULL, NULL);
+    ldap_result(NULL, 0, 0, NULL, NULL);
+    ldap_search(NULL, NULL, 0, NULL, NULL, 0);
+    ldap_unbind(NULL);
+}
 
-#define SERVICE_NAME           "OpenLDAP"
+#ifdef HAVE_NT_SERVICE_MANAGER
 
 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( int argc, LPTSTR *argv )
 {
        int             length;
        char    filename[MAX_PATH], *fname_start;
@@ -50,8 +50,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 +62,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 +105,8 @@ void main( DWORD argc, LPTSTR *argv )
                is_NT_Service = 0;
                ServiceMain( argc, argv );
        }
+
+       return EXIT_SUCCESS;
 }
+
+#endif