Re: [389-devel] Please Review: Add centralized start/stop/restart scripts.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Pushed to master.

Thanks to Rich for his review.  He spotted a few paths that should have been macros in the new stop and restart script.  This patch fixes those issues and includes the generated Makefile.in changes.

On 08/13/2009 04:30 PM, Nathan Kinder wrote:


-- 389-devel mailing list 389-devel@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/fedora-directory-devel

>From 1cc186ad31449aebff4fa220bff7c90a45472fcd Mon Sep 17 00:00:00 2001
From: Nathan Kinder <nkinder@xxxxxxxxxx>
Date: Fri, 14 Aug 2009 08:28:01 -0700
Subject: [PATCH] Add centralized start/stop/restart scipts.

This adds centralized start, stop, and restart scripts
for ns-slapd.  These scripts live in the sbin directory
and will act upon all instances if an instance identifier
is not specified (similar to the init script).  The
instance specific scripts have been modified to call the
new centralized scripts.

The instance specific parameters needed by the new scripts
are located in the instance specific initconfig scripts,
which are now created by setup-ds.pl with values mapped
from the inf file.
---
 Makefile.am                                      |   20 +++--
 Makefile.in                                      |   20 +++--
 ldap/admin/src/initconfig.in                     |    9 +-
 ldap/admin/src/scripts/DSCreate.pm.in            |   33 +++++++
 ldap/admin/src/scripts/restart-dirsrv.in         |   47 +++++++++
 ldap/admin/src/scripts/start-dirsrv.in           |  112 ++++++++++++++++++++++
 ldap/admin/src/scripts/stop-dirsrv.in            |   72 ++++++++++++++
 ldap/admin/src/scripts/template-restart-slapd.in |   18 +---
 ldap/admin/src/scripts/template-start-slapd.in   |   75 +--------------
 ldap/admin/src/scripts/template-stop-slapd.in    |   36 +-------
 ldap/admin/src/template-initconfig.in            |   18 ++++
 11 files changed, 318 insertions(+), 142 deletions(-)
 mode change 100644 => 100755 Makefile.in
 mode change 100644 => 100755 aclocal.m4
 create mode 100644 ldap/admin/src/scripts/restart-dirsrv.in
 create mode 100755 ldap/admin/src/scripts/start-dirsrv.in
 create mode 100755 ldap/admin/src/scripts/stop-dirsrv.in
 create mode 100644 ldap/admin/src/template-initconfig.in
 mode change 100644 => 100755 ltmain.sh

diff --git a/Makefile.am b/Makefile.am
index 6bfad08..ac7ab27 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -66,16 +66,18 @@ LIBCRUN=@LIBCRUN@
 BUILT_SOURCES = dberrstrs.h
 
 CLEANFILES =  dberrstrs.h ns-slapd.properties \
+	ldap/admin/src/scripts/template-dbverify ldap/admin/src/template-initconfig \
 	ldap/admin/src/scripts/dscreate.map ldap/admin/src/scripts/remove-ds.pl \
 	ldap/admin/src/scripts/DSCreate.pm ldap/admin/src/scripts/DSMigration.pm \
 	ldap/admin/src/scripts/dsorgentries.map ldap/admin/src/scripts/migrate-ds.pl \
 	ldap/admin/src/scripts/Migration.pm ldap/admin/src/scripts/SetupDialogs.pm \
 	ldap/admin/src/scripts/setup-ds.pl ldap/admin/src/scripts/setup-ds.res \
-	ldap/admin/src/scripts/Setup.pm ldap/admin/src/scripts/template-bak2db \
-	ldap/admin/src/scripts/template-bak2db.pl ldap/admin/src/scripts/template-db2bak \
-	ldap/admin/src/scripts/template-db2bak.pl ldap/admin/src/scripts/template-db2index \
-	ldap/admin/src/scripts/template-db2index.pl ldap/admin/src/scripts/template-db2ldif \
-	ldap/admin/src/scripts/template-db2ldif.pl ldap/admin/src/scripts/template-dbverify \
+	ldap/admin/src/scripts/start-dirsrv ldap/admin/src/scripts/stop-dirsrv \
+	ldap/admin/src/scripts/restart-dirsrv ldap/admin/src/scripts/Setup.pm \
+	ldap/admin/src/scripts/template-bak2db ldap/admin/src/scripts/template-bak2db.pl \
+	ldap/admin/src/scripts/template-db2bak ldap/admin/src/scripts/template-db2bak.pl \
+	ldap/admin/src/scripts/template-db2index ldap/admin/src/scripts/template-db2index.pl \
+	ldap/admin/src/scripts/template-db2ldif ldap/admin/src/scripts/template-db2ldif.pl \
 	ldap/admin/src/scripts/template-ldif2db ldap/admin/src/scripts/template-ldif2db.pl \
 	ldap/admin/src/scripts/template-ldif2ldap ldap/admin/src/scripts/template-monitor \
 	ldap/admin/src/scripts/template-ns-accountstatus.pl ldap/admin/src/scripts/template-ns-activate.pl \
@@ -169,7 +171,8 @@ noinst_LIBRARIES = libavl.a libldaputil.a
 # Installed Files
 #------------------------
 config_DATA = $(srcdir)/lib/ldaputil/certmap.conf \
-	$(srcdir)/ldap/schema/slapd-collations.conf
+	$(srcdir)/ldap/schema/slapd-collations.conf \
+	ldap/admin/src/template-initconfig
 
 # the schema files in this list are either not
 # standard schema, not tested, or not compatible
@@ -247,7 +250,10 @@ schema_DATA = $(srcdir)/ldap/schema/00core.ldif \
 
 sbin_SCRIPTS = ldap/admin/src/scripts/setup-ds.pl \
 	ldap/admin/src/scripts/migrate-ds.pl \
-	ldap/admin/src/scripts/remove-ds.pl
+	ldap/admin/src/scripts/remove-ds.pl \
+	ldap/admin/src/scripts/start-dirsrv \
+	ldap/admin/src/scripts/stop-dirsrv \
+	ldap/admin/src/scripts/restart-dirsrv
 
 bin_SCRIPTS = ldap/servers/slapd/tools/rsearch/scripts/dbgen.pl \
 	wrappers/dbscan \
diff --git a/Makefile.in b/Makefile.in
old mode 100644
new mode 100755
index a96f78b..dcea507
--- a/Makefile.in
+++ b/Makefile.in
@@ -1161,16 +1161,18 @@ KERBEROS_LINK = $(kerberos_lib)
 #------------------------
 BUILT_SOURCES = dberrstrs.h
 CLEANFILES = dberrstrs.h ns-slapd.properties \
+	ldap/admin/src/scripts/template-dbverify ldap/admin/src/template-initconfig \
 	ldap/admin/src/scripts/dscreate.map ldap/admin/src/scripts/remove-ds.pl \
 	ldap/admin/src/scripts/DSCreate.pm ldap/admin/src/scripts/DSMigration.pm \
 	ldap/admin/src/scripts/dsorgentries.map ldap/admin/src/scripts/migrate-ds.pl \
 	ldap/admin/src/scripts/Migration.pm ldap/admin/src/scripts/SetupDialogs.pm \
 	ldap/admin/src/scripts/setup-ds.pl ldap/admin/src/scripts/setup-ds.res \
-	ldap/admin/src/scripts/Setup.pm ldap/admin/src/scripts/template-bak2db \
-	ldap/admin/src/scripts/template-bak2db.pl ldap/admin/src/scripts/template-db2bak \
-	ldap/admin/src/scripts/template-db2bak.pl ldap/admin/src/scripts/template-db2index \
-	ldap/admin/src/scripts/template-db2index.pl ldap/admin/src/scripts/template-db2ldif \
-	ldap/admin/src/scripts/template-db2ldif.pl ldap/admin/src/scripts/template-dbverify \
+	ldap/admin/src/scripts/start-dirsrv ldap/admin/src/scripts/stop-dirsrv \
+	ldap/admin/src/scripts/restart-dirsrv ldap/admin/src/scripts/Setup.pm \
+	ldap/admin/src/scripts/template-bak2db ldap/admin/src/scripts/template-bak2db.pl \
+	ldap/admin/src/scripts/template-db2bak ldap/admin/src/scripts/template-db2bak.pl \
+	ldap/admin/src/scripts/template-db2index ldap/admin/src/scripts/template-db2index.pl \
+	ldap/admin/src/scripts/template-db2ldif ldap/admin/src/scripts/template-db2ldif.pl \
 	ldap/admin/src/scripts/template-ldif2db ldap/admin/src/scripts/template-ldif2db.pl \
 	ldap/admin/src/scripts/template-ldif2ldap ldap/admin/src/scripts/template-monitor \
 	ldap/admin/src/scripts/template-ns-accountstatus.pl ldap/admin/src/scripts/template-ns-activate.pl \
@@ -1219,7 +1221,8 @@ noinst_LIBRARIES = libavl.a libldaputil.a
 # Installed Files
 #------------------------
 config_DATA = $(srcdir)/lib/ldaputil/certmap.conf \
-	$(srcdir)/ldap/schema/slapd-collations.conf
+	$(srcdir)/ldap/schema/slapd-collations.conf \
+	ldap/admin/src/template-initconfig
 
 
 # the schema files in this list are either not
@@ -1298,7 +1301,10 @@ schema_DATA = $(srcdir)/ldap/schema/00core.ldif \
 
 sbin_SCRIPTS = ldap/admin/src/scripts/setup-ds.pl \
 	ldap/admin/src/scripts/migrate-ds.pl \
-	ldap/admin/src/scripts/remove-ds.pl
+	ldap/admin/src/scripts/remove-ds.pl \
+	ldap/admin/src/scripts/start-dirsrv \
+	ldap/admin/src/scripts/stop-dirsrv \
+	ldap/admin/src/scripts/restart-dirsrv
 
 bin_SCRIPTS = ldap/servers/slapd/tools/rsearch/scripts/dbgen.pl \
 	wrappers/dbscan \
diff --git a/aclocal.m4 b/aclocal.m4
old mode 100644
new mode 100755
diff --git a/ldap/admin/src/initconfig.in b/ldap/admin/src/initconfig.in
index 2bcc628..7f9dd8f 100644
--- a/ldap/admin/src/initconfig.in
+++ b/ldap/admin/src/initconfig.in
@@ -1,10 +1,9 @@
 # This file is sourced by @package_name@ upon startup to set
 # the default environment for all directory server instances.
-# To set instance specific defaults, make a copy of this
-# file in the same directory called @package_name@-instance
-# where "instance" is the name of your directory server
-# instance e.g. @package_name@-localhost for the
-# slapd-localhost instance
+# To set instance specific defaults, use the file in the same
+# directory called @package_name@-instance where "instance"
+# is the name of your directory server instance e.g.
+# @package_name@-localhost for the slapd-localhost instance.
 
 # In order to make more file descriptors available
 # to the directory server, first make sure the system
diff --git a/ldap/admin/src/scripts/DSCreate.pm.in b/ldap/admin/src/scripts/DSCreate.pm.in
index 66183e8..d33f13a 100644
--- a/ldap/admin/src/scripts/DSCreate.pm.in
+++ b/ldap/admin/src/scripts/DSCreate.pm.in
@@ -421,6 +421,16 @@ sub createConfigFile {
 sub makeOtherConfigFiles {
     my $inf = shift;
     my @errs;
+    my %maptable = (
+        "DS-ROOT" => $inf->{General}->{prefix},
+        "SERVER-DIR" => $inf->{General}->{ServerRoot},
+        "CONFIG-DIR" => $inf->{slapd}->{config_dir},
+        "INST-DIR" => $inf->{slapd}->{inst_dir},
+        "RUN-DIR" => $inf->{slapd}->{run_dir},
+        "PRODUCT-NAME" => "slapd",
+        "SERVERBIN-DIR" => $inf->{slapd}->{sbindir},
+    );
+
     # install certmap.conf at <configdir>
     my $src = "$inf->{General}->{prefix}@configdir@/certmap.conf";
     my $dest = "$inf->{slapd}->{config_dir}/certmap.conf";
@@ -444,6 +454,29 @@ sub makeOtherConfigFiles {
         return @errs;
     }
 
+    # install instance specific initconfig script
+    $src = "$inf->{General}->{prefix}@configdir@/template-initconfig";
+    $dest = "$inf->{General}->{prefix}@initconfigdir@/@package_name@-$inf->{slapd}->{ServerIdentifier}";
+    $! = 0; # clear errno
+
+    if (!open(SRC, "< $src")) {
+        return ("error_opening_scripttmpl", $src, $!);
+    }
+    if (!open(DEST, "> $dest")) {
+        return ("error_opening_scripttmpl", $dest, $!);
+    }
+    my $contents; # slurp entire file into memory
+    read SRC, $contents, int(-s $src);
+    close(SRC);
+    while (my ($key, $val) = each %maptable) {
+        $contents =~ s/\{\{$key\}\}/$val/g;
+    }
+    print DEST $contents;
+    close(DEST);
+    if (@errs = changeOwnerMode($inf, 4, $dest)) {
+        return @errs;
+    }
+
     return ();
 }
 
diff --git a/ldap/admin/src/scripts/restart-dirsrv.in b/ldap/admin/src/scripts/restart-dirsrv.in
new file mode 100644
index 0000000..29203fd
--- /dev/null
+++ b/ldap/admin/src/scripts/restart-dirsrv.in
@@ -0,0 +1,47 @@
+#!/bin/sh
+
+# Script that restarts the ns-slapd server.
+# Exit status can be:
+#       0: Server restarted successfully
+#       1: Server could not be started
+#       2: Server started successfully (was not running)
+#       3: Server could not be stopped
+
+restart_instance() {
+    SERV_ID=$1
+
+    server_already_stopped=0
+    @sbindir@/stop-dirsrv $SERV_ID
+    status=$?
+    if [ $status -eq 1 ] ; then
+        return 3;
+    else
+       if [ $status -eq 2 ] ; then
+            server_already_stopped=1
+       fi
+    fi
+    @sbindir@/start-dirsrv $SERV_ID
+    status=$?
+    if [ $server_already_stopped -eq 1 ] && [ $status -eq 0 ] ; then
+        return 2;
+    fi
+    return $status
+}
+
+if [ "$#" -eq 0 ]; then
+    # We're restarting all instances.
+    ret=0
+    for i in @initconfigdir@/@package_name@-*; do
+        inst=`echo $i | sed -e 's,@initconfigdir@/@package_name@-,,g'`
+        echo Restarting instance \"$inst\"
+        restart_instance $inst
+        if [ "$?" -ne 0 ]; then
+            ret=$?
+        fi
+    done
+    exit $ret
+else
+    # We're restarting a single instance.
+    restart_instance $*
+    exit $?
+fi
diff --git a/ldap/admin/src/scripts/start-dirsrv.in b/ldap/admin/src/scripts/start-dirsrv.in
new file mode 100755
index 0000000..fb9bfdb
--- /dev/null
+++ b/ldap/admin/src/scripts/start-dirsrv.in
@@ -0,0 +1,112 @@
+#!/bin/sh
+
+# Script that starts the ns-slapd server.
+# Exit status can be:
+#       0: Server started successfully
+#       1: Server could not be started
+#       2: Server already running
+
+# Starts a single instance
+start_instance() {
+    # The first argument is the server ID.  Anything
+    # after that is an argument to ns-slapd.
+    SERV_ID=$1
+    shift
+
+    # source env. for this instance
+    if [ -f @initconfigdir@/@package_name@-$SERV_ID ] ; then
+        . @initconfigdir@/@package_name@-$SERV_ID
+    else
+        echo Instance $SERV_ID not found.
+        return 1
+    fi
+
+    prefix="$DS_ROOT"
+    LD_LIBRARY_PATH=$prefix$SERVER_DIR:$prefix@nss_libdir@:$prefix@libdir@:@nss_libdir@
+    export LD_LIBRARY_PATH
+    SHLIB_PATH=$prefix$SERVER_DIR:$prefix@nss_libdir@:$prefix@libdir@:@nss_libdir@
+    export SHLIB_PATH
+
+    DS_CONFIG_DIR=$CONFIG_DIR
+    export DS_CONFIG_DIR
+    PIDFILE=$RUN_DIR/$PRODUCT_NAME-$SERV_ID.pid
+    STARTPIDFILE=$RUN_DIR/$PRODUCT_NAME-$SERV_ID.startpid
+    if test -f $STARTPIDFILE ; then
+        PID=`cat $STARTPIDFILE`
+        if kill -0 $PID > /dev/null 2>&1 ; then
+            echo There is an ns-slapd process already running: $PID
+            return 2;
+        else
+            rm -f $STARTPIDFILE
+        fi
+    fi
+    if test -f $PIDFILE ; then
+        PID=`cat $PIDFILE`
+        if kill -0 $PID > /dev/null 2>&1 ; then
+            echo There is an ns-slapd running: $PID
+            return 2;
+        else
+            rm -f $PIDFILE
+        fi
+    fi
+    cd $SERVERBIN_DIR; ./ns-slapd -D $CONFIG_DIR -i $PIDFILE -w $STARTPIDFILE "$@"
+    if [ $? -ne 0 ]; then
+        return 1
+    fi
+
+    loop_counter=1
+    # wait for 10 seconds for the start pid file to appear
+    max_count=${STARTPID_TIME:-10}
+    while test $loop_counter -le $max_count; do
+        loop_counter=`expr $loop_counter + 1`
+        if test ! -f $STARTPIDFILE ; then
+            sleep 1;
+        else
+            PID=`cat $STARTPIDFILE`
+        fi
+    done
+    if test ! -f $STARTPIDFILE ; then
+        echo Server failed to start !!! Please check errors log for problems
+        return 1
+    fi
+    loop_counter=1
+    # wait for 10 minutes (600 times 1 seconds)
+    max_count=${PID_TIME:-600}
+    while test $loop_counter -le $max_count; do
+        loop_counter=`expr $loop_counter + 1`
+        if test ! -f $PIDFILE ; then
+            if kill -0 $PID > /dev/null 2>&1 ; then
+                sleep 1
+        else
+            echo Server failed to start !!! Please check errors log for problems
+            return 1
+        fi
+        else
+            PID=`cat $PIDFILE`
+            return 0;
+        fi
+    done
+    echo Server not running!! Failed to start ns-slapd process.  Please check the errors log for problems.
+    return 1
+}
+
+# source env. for all instances
+[ -f @initconfigdir@/@package_name@ ] && . @initconfigdir@/@package_name@
+
+if [ "$#" -eq 0 ]; then
+    # We're starting all instances.
+    ret=0
+    for i in @initconfigdir@/@package_name@-*; do
+        inst=`echo $i | sed -e 's,@initconfigdir@/@package_name@-,,g'`
+        echo Starting instance \"$inst\"
+        start_instance $inst
+        if [ "$?" -ne 0 ]; then
+            ret=$?
+        fi
+    done
+    exit $ret
+else
+    # We're starting a single instance.
+    start_instance $*
+    exit $?
+fi
diff --git a/ldap/admin/src/scripts/stop-dirsrv.in b/ldap/admin/src/scripts/stop-dirsrv.in
new file mode 100755
index 0000000..8ba8d5d
--- /dev/null
+++ b/ldap/admin/src/scripts/stop-dirsrv.in
@@ -0,0 +1,72 @@
+#!/bin/sh
+
+# Script that stops the ns-slapd server.
+# Exit status can be:
+#       0: Server stopped successfully
+#       1: Server could not be stopped
+#       2: Server was not running
+
+stop_instance() {
+    SERV_ID=$1
+
+    # source env. for this instance
+    if [ -f @initconfigdir@/@package_name@-$SERV_ID ]; then
+        . @initconfigdir@/@package_name@-$SERV_ID
+    else
+        echo Instance $SERV_ID not found.
+        return 1
+    fi
+
+    PIDFILE=$RUN_DIR/$PRODUCT_NAME-$SERV_ID.pid
+    if test ! -f $PIDFILE ; then
+        echo No ns-slapd PID file found. Server is probably not running
+        return 2
+    fi
+    PID=`cat $PIDFILE`
+    # see if the server is already stopped
+    kill -0 $PID > /dev/null 2>&1 || {
+        echo Server not running
+        if test -f $PIDFILE ; then
+            rm -f $PIDFILE
+        fi
+        return 2
+    }
+    # server is running - kill it
+    kill $PID
+    loop_counter=1
+    # wait for 10 minutes (600 times 1 second)
+    max_count=600
+    while test $loop_counter -le $max_count; do
+        loop_counter=`expr $loop_counter + 1`
+        if kill -0 $PID > /dev/null 2>&1 ; then
+            sleep 1;
+        else
+            if test -f $PIDFILE ; then
+                rm -f $PIDFILE
+            fi
+            return 0
+        fi
+    done
+    if test -f $PIDFILE ; then
+        echo Server still running!! Failed to stop the ns-slapd process: $PID.  Please check the errors log for problems.
+    fi
+    return 1
+}
+
+if [ "$#" -eq 0 ]; then
+    # We're stopping all instances.
+    ret=0
+    for i in @initconfigdir@/@package_name@-*; do
+        inst=`echo $i | sed -e 's,@initconfigdir@/@package_name@-,,g'`
+        echo Stopping instance \"$inst\"
+        stop_instance $inst
+        if [ "$?" -ne 0 ]; then
+            ret=$?
+        fi
+    done
+    exit $ret
+else
+    # We're stopping a single instance.
+    stop_instance $*
+    exit $?
+fi
diff --git a/ldap/admin/src/scripts/template-restart-slapd.in b/ldap/admin/src/scripts/template-restart-slapd.in
index 6f5c0c8..19e2414 100644
--- a/ldap/admin/src/scripts/template-restart-slapd.in
+++ b/ldap/admin/src/scripts/template-restart-slapd.in
@@ -7,19 +7,5 @@
 #       2: Server started successfully (was not running)
 #       3: Server could not be stopped
 
-server_already_stopped=0
-{{INST-DIR}}/stop-slapd
-status=$?
-if [ $status -eq 1 ] ; then
-    exit 3;
-else
-   if [ $status -eq 2 ] ; then
-        server_already_stopped=1
-   fi
-fi
-{{INST-DIR}}/start-slapd
-status=$?
-if [ $server_already_stopped -eq 1 ] && [ $status -eq 0 ] ; then
-    exit 2;
-fi
-exit $status
+@sbindir@/restart-dirsrv {{SERV-ID}} "$@"
+exit $?
diff --git a/ldap/admin/src/scripts/template-start-slapd.in b/ldap/admin/src/scripts/template-start-slapd.in
index 223d6ed..7608d37 100755
--- a/ldap/admin/src/scripts/template-start-slapd.in
+++ b/ldap/admin/src/scripts/template-start-slapd.in
@@ -1,81 +1,10 @@
 #!/bin/sh
 
-prefix="{{DS-ROOT}}"
-LD_LIBRARY_PATH=$prefix{{SERVER-DIR}}:$prefix@nss_libdir@:$prefix@libdir@:@nss_libdir@
-export LD_LIBRARY_PATH
-SHLIB_PATH=$prefix{{SERVER-DIR}}:$prefix@nss_libdir@:$prefix@libdir@:@nss_libdir@
-export SHLIB_PATH
-
-# source env. for all instances
-[ -f @initconfigdir@/@package_name@ ] && . @initconfigdir@/@package_name@
-
-# source env. for this instance
-[ -f @initconfigdir@/@package_name@-{{SERV-ID}} ] && . @initconfigdir@/@package_name@-{{SERV-ID}}
-
 # Script that starts the ns-slapd server.
 # Exit status can be:
 #       0: Server started successfully
 #       1: Server could not be started
 #       2: Server already running
 
-DS_CONFIG_DIR={{CONFIG-DIR}}
-export DS_CONFIG_DIR
-PIDFILE={{RUN-DIR}}/{{PRODUCT-NAME}}-{{SERV-ID}}.pid
-STARTPIDFILE={{RUN-DIR}}/{{PRODUCT-NAME}}-{{SERV-ID}}.startpid
-if test -f $STARTPIDFILE ; then
-    PID=`cat $STARTPIDFILE`
-    if kill -0 $PID > /dev/null 2>&1 ; then
-        echo There is an ns-slapd process already running: $PID
-        exit 2;
-    else
-        rm -f $STARTPIDFILE
-    fi
-fi
-if test -f $PIDFILE ; then
-    PID=`cat $PIDFILE`
-    if kill -0 $PID > /dev/null 2>&1 ; then
-        echo There is an ns-slapd running: $PID
-        exit 2;
-    else
-        rm -f $PIDFILE
-    fi
-fi
-cd {{SERVERBIN-DIR}}; ./ns-slapd -D {{CONFIG-DIR}} -i $PIDFILE -w $STARTPIDFILE "$@"
-if [ $? -ne 0 ]; then
-    exit 1
-fi
-
-loop_counter=1
-# wait for 10 seconds for the start pid file to appear
-max_count=${STARTPID_TIME:-10}
-while test $loop_counter -le $max_count; do
-    loop_counter=`expr $loop_counter + 1`
-    if test ! -f $STARTPIDFILE ; then
-        sleep 1;
-    else
-        PID=`cat $STARTPIDFILE`
-    fi
-done
-if test ! -f $STARTPIDFILE ; then
-    echo Server failed to start !!! Please check errors log for problems
-    exit 1
-fi
-loop_counter=1
-# wait for 10 minutes (600 times 1 seconds)
-max_count=${PID_TIME:-600}
-while test $loop_counter -le $max_count; do
-    loop_counter=`expr $loop_counter + 1`
-    if test ! -f $PIDFILE ; then
-        if kill -0 $PID > /dev/null 2>&1 ; then
-            sleep 1
-    else
-        echo Server failed to start !!! Please check errors log for problems
-        exit 1
-    fi
-    else
-        PID=`cat $PIDFILE`
-        exit 0;
-    fi
-done
-echo Server not running!! Failed to start ns-slapd process.  Please check the errors log for problems.
-exit 1
+@sbindir@/start-dirsrv {{SERV-ID}} "$@"
+exit $?
diff --git a/ldap/admin/src/scripts/template-stop-slapd.in b/ldap/admin/src/scripts/template-stop-slapd.in
index cc9f968..3531464 100755
--- a/ldap/admin/src/scripts/template-stop-slapd.in
+++ b/ldap/admin/src/scripts/template-stop-slapd.in
@@ -6,37 +6,5 @@
 #       1: Server could not be stopped
 #       2: Server was not running
 
-PIDFILE={{RUN-DIR}}/{{PRODUCT-NAME}}-{{SERV-ID}}.pid
-if test ! -f $PIDFILE ; then
-    echo No ns-slapd PID file found. Server is probably not running
-    exit 2
-fi
-PID=`cat $PIDFILE`
-# see if the server is already stopped
-kill -0 $PID > /dev/null 2>&1 || {
-    echo Server not running
-    if test -f $PIDFILE ; then
-        rm -f $PIDFILE
-    fi
-    exit 2
-}
-# server is running - kill it
-kill $PID
-loop_counter=1
-# wait for 10 minutes (600 times 1 second)
-max_count=600
-while test $loop_counter -le $max_count; do
-    loop_counter=`expr $loop_counter + 1`
-    if kill -0 $PID > /dev/null 2>&1 ; then
-        sleep 1;
-    else
-        if test -f $PIDFILE ; then
-            rm -f $PIDFILE
-        fi
-        exit 0
-    fi
-done
-if test -f $PIDFILE ; then
-    echo Server still running!! Failed to stop the ns-slapd process: $PID.  Please check the errors log for problems.
-fi
-exit 1
+@sbindir@/stop-dirsrv {{SERV-ID}} "$@"
+exit $?
diff --git a/ldap/admin/src/template-initconfig.in b/ldap/admin/src/template-initconfig.in
new file mode 100644
index 0000000..4945885
--- /dev/null
+++ b/ldap/admin/src/template-initconfig.in
@@ -0,0 +1,18 @@
+# This file is sourced by @package_name@ upon startup to set
+# the default environment for a single specific  directory
+# server instances.  To set defaults for all instances, edit
+# the file in the same directory called @package_name@.
+
+# These settings are used by the start-dirsrv and
+# start-slapd scripts (as well as their associates stop
+# and restart scripts).  Do not edit them unless you know
+# what you are doing.
+SERVER_DIR={{SERVER-DIR}} ; export SERVER_DIR
+SERVERBIN_DIR={{SERVERBIN-DIR}} ; export SERVERBIN_DIR
+CONFIG_DIR={{CONFIG-DIR}} ; export CONFIG_DIR
+INST_DIR={{INST-DIR}} ; export INST_DIR
+RUN_DIR={{RUN-DIR}} ; export RUN_DIR
+DS_ROOT={{DS-ROOT}} ; export DS_ROOT
+PRODUCT_NAME={{PRODUCT-NAME}} ; export PRODUCT_NAME
+
+# Put custom instance specific settings below here.
diff --git a/ltmain.sh b/ltmain.sh
old mode 100644
new mode 100755
-- 
1.6.2.5

--
389-devel mailing list
389-devel@xxxxxxxxxx
https://www.redhat.com/mailman/listinfo/fedora-directory-devel

[Index of Archives]     [Fedora Directory Announce]     [Fedora Users]     [Older Fedora Users Mail]     [Fedora Advisory Board]     [Fedora Security]     [Fedora Devel Java]     [Fedora Desktop]     [ATA RAID]     [Fedora Marketing]     [Fedora Mentors]     [Fedora Package Review]     [Fedora Art]     [Fedora Music]     [Fedora Packaging]     [CentOS]     [Fedora SELinux]     [Big List of Linux Books]     [KDE Users]     [Fedora Art]     [Fedora Docs]

  Powered by Linux