diff options
author | Rob Crittenden <rcritten@redhat.com> | 2008-02-06 11:02:05 -0500 |
---|---|---|
committer | Rob Crittenden <rcritten@redhat.com> | 2008-02-06 11:02:05 -0500 |
commit | 217019e9de5b72f661c091cc57bc6752c7dc7d14 (patch) | |
tree | e48fb3356ea15115df836886ec084d7af9be2a5f /ipa-server/ipa-gui | |
parent | ef5b4391debe6b053ea8bea60b0caa7721a09122 (diff) | |
download | freeipa-217019e9de5b72f661c091cc57bc6752c7dc7d14.tar.gz freeipa-217019e9de5b72f661c091cc57bc6752c7dc7d14.tar.xz freeipa-217019e9de5b72f661c091cc57bc6752c7dc7d14.zip |
Create /var/run/<process>.pid to play nicers with the start scripts
Need to start ipa_webgui as root and drop privs in order to write in /var/run
Diffstat (limited to 'ipa-server/ipa-gui')
-rw-r--r-- | ipa-server/ipa-gui/ipa_webgui | 23 | ||||
-rw-r--r-- | ipa-server/ipa-gui/ipa_webgui.init | 2 |
2 files changed, 23 insertions, 2 deletions
diff --git a/ipa-server/ipa-gui/ipa_webgui b/ipa-server/ipa-gui/ipa_webgui index f7780af8e..96558d570 100644 --- a/ipa-server/ipa-gui/ipa_webgui +++ b/ipa-server/ipa-gui/ipa_webgui @@ -17,7 +17,7 @@ # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # -import os, sys +import os, sys, pwd, grp from optparse import OptionParser import ipa.config import traceback @@ -119,6 +119,27 @@ def main(): sys.stderr.write("error becoming daemon: " + str(e)) sys.exit(1) + # Drop privileges and write our pid file only if we're running as root + if os.getuid() == 0: + # Write out our pid file + pidfile = open("/var/run/ipa_webgui.pid", "w") + pidfile.write(str(os.getpid())) + pidfile.close() + + # Drop privs + apache_uid = pwd.getpwnam("apache")[2] + apache_gid = grp.getgrnam("apache")[2] + + try: + os.setgid(apache_gid) + except OSError, e: + log.error("Could not set effective group id: %s" % e) + + try: + os.setuid(apache_uid) + except OSError, e: + log.error("Could not set effective user id: %s" % e) + sys.path.append("/usr/share/ipa") # this must be after sys.path is changed to work correctly diff --git a/ipa-server/ipa-gui/ipa_webgui.init b/ipa-server/ipa-gui/ipa_webgui.init index e603f9f2a..42478588f 100644 --- a/ipa-server/ipa-gui/ipa_webgui.init +++ b/ipa-server/ipa-gui/ipa_webgui.init @@ -30,7 +30,7 @@ RUNAS="apache" start() { echo -n $"Starting $NAME: " - daemon --user $RUNAS $PROG + daemon $PROG RETVAL=$? echo [ $RETVAL -eq 0 ] && touch /var/lock/subsys/ipa_webgui || \ |