Run as root/weldr by default.

We need to be root to read the certificates that give access to the
package repos.  Right now, the alternative seems to be changing
permissions on the certs themselves, which seems less good.  We're
running anaconda as root anyway.
This commit is contained in:
Chris Lumens 2018-08-01 10:57:53 -04:00
parent 3fd5e50c80
commit 01a3d365ef

View File

@ -45,6 +45,9 @@ from pylorax.api.yumbase import get_base_object
VERSION = "{0}-{1}".format(os.path.basename(sys.argv[0]), vernum) VERSION = "{0}-{1}".format(os.path.basename(sys.argv[0]), vernum)
DEFAULT_USER = "root"
DEFAULT_GROUP = "weldr"
def get_parser(): def get_parser():
""" Return the ArgumentParser for lorax-composer""" """ Return the ArgumentParser for lorax-composer"""
@ -53,9 +56,9 @@ def get_parser():
parser.add_argument("--socket", default="/run/weldr/api.socket", metavar="SOCKET", parser.add_argument("--socket", default="/run/weldr/api.socket", metavar="SOCKET",
help="Path to the socket file to listen on") help="Path to the socket file to listen on")
parser.add_argument("--user", default="weldr", metavar="USER", parser.add_argument("--user", default=DEFAULT_USER, metavar="USER",
help="User to use for reduced permissions") help="User to use for reduced permissions")
parser.add_argument("--group", default="weldr", metavar="GROUP", parser.add_argument("--group", default=DEFAULT_GROUP, metavar="GROUP",
help="Group to set ownership of the socket to") help="Group to set ownership of the socket to")
parser.add_argument("--log", dest="logfile", default="/var/log/lorax-composer/composer.log", metavar="LOG", parser.add_argument("--log", dest="logfile", default="/var/log/lorax-composer/composer.log", metavar="LOG",
help="Path to logfile (/var/log/lorax-composer/composer.log)") help="Path to logfile (/var/log/lorax-composer/composer.log)")
@ -267,7 +270,8 @@ if __name__ == '__main__':
start_queue_monitor(server.config["COMPOSER_CFG"], uid, gid) start_queue_monitor(server.config["COMPOSER_CFG"], uid, gid)
# Drop root privileges on the main process # Change user and group on the main process. Note that this still happens even if
# --user and --group were passed in, but changing to the same user should be fine.
os.setgid(gid) os.setgid(gid)
os.setuid(uid) os.setuid(uid)
log.debug("user is now %s:%s", os.getresuid(), os.getresgid()) log.debug("user is now %s:%s", os.getresuid(), os.getresgid())