]> git.sur5r.net Git - openldap/commitdiff
Sync with HEAD
authorHoward Chu <hyc@openldap.org>
Mon, 10 Mar 2003 19:16:21 +0000 (19:16 +0000)
committerHoward Chu <hyc@openldap.org>
Mon, 10 Mar 2003 19:16:21 +0000 (19:16 +0000)
servers/slurpd/nt_svc.c [new file with mode: 0644]

diff --git a/servers/slurpd/nt_svc.c b/servers/slurpd/nt_svc.c
new file mode 100644 (file)
index 0000000..9be6d49
--- /dev/null
@@ -0,0 +1,101 @@
+/* $OpenLDAP$ */
+/*
+ * Copyright 1998-2003 The OpenLDAP Foundation, All Rights Reserved.
+ * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
+ */
+
+#include "portable.h"
+#include <stdio.h>
+#include <ac/string.h>
+#include <ac/stdlib.h>
+#include "slurp.h"
+#include "lutil.h"
+
+#ifdef HAVE_NT_SERVICE_MANAGER
+
+/* in main.c */
+void WINAPI ServiceMain( DWORD argc, LPTSTR *argv );
+
+int main( int argc, LPTSTR *argv )
+{
+       int             length;
+       char    filename[MAX_PATH], *fname_start;
+
+       /*
+        * Because the service was registered as SERVICE_WIN32_OWN_PROCESS,
+        * the lpServiceName element of the SERVICE_TABLE_ENTRY will be
+        * ignored.
+        */
+
+       SERVICE_TABLE_ENTRY             DispatchTable[] = {
+               {       "",     (LPSERVICE_MAIN_FUNCTION) ServiceMain   },
+               {       NULL,                   NULL    }
+       };
+
+       /*
+        * 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 );
+
+       if ( argc > 1 ) {
+               if ( _stricmp( "install", argv[1] ) == 0 ) 
+               {
+                       char *svcName = SERVICE_NAME;
+                       char *displayName = "OpenLDAP Replication Service";
+                       BOOL auto_start = FALSE;
+
+                       if ( (argc > 2) && (argv[2] != NULL) )
+                               svcName = argv[2];
+
+                       if ( argc > 3 && argv[3])
+                               displayName = argv[3];
+
+                       if ( argc > 4 && stricmp(argv[4], "auto") == 0)
+                               auto_start = TRUE;
+
+                       strcat(filename, " service");
+                       if ( !lutil_srv_install(svcName, displayName, filename, auto_start) ) 
+                       {
+                               fputs( "service failed installation ...\n", stderr  );
+                               return EXIT_FAILURE;
+                       }
+                       fputs( "service has been installed ...\n", stderr  );
+                       return EXIT_SUCCESS;
+               }
+
+               if ( _stricmp( "remove", argv[1] ) == 0 ) 
+               {
+                       char *svcName = SERVICE_NAME;
+                       if ( (argc > 2) && (argv[2] != NULL) )
+                               svcName = argv[2];
+                       if ( !lutil_srv_remove(svcName, filename) ) 
+                       {
+                               fputs( "failed to remove the service ...\n", stderr  );
+                               return EXIT_FAILURE;
+                       }
+                       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 );
+               }
+       }
+
+       if (is_NT_Service)
+       {
+               StartServiceCtrlDispatcher(DispatchTable);
+       } else
+       {
+               ServiceMain( argc, argv );
+       }
+
+       return EXIT_SUCCESS;
+}
+
+#endif