From 364d466fd7def3589ddb9e4a9f8d73fc2df80439 Mon Sep 17 00:00:00 2001 From: David Kupka Date: Wed, 22 Oct 2014 09:07:44 -0400 Subject: Respect UID and GID soft static allocation. https://fedoraproject.org/wiki/Packaging:UsersAndGroups?rd=Packaging/UsersAndGroups#Soft_static_allocation https://fedorahosted.org/freeipa/ticket/4585 Reviewed-By: Martin Basti --- ipaplatform/base/tasks.py | 48 +++++++++++++++++++++++++++++++++++++++++++++ ipaplatform/redhat/tasks.py | 23 ++++++++++++++++++++++ 2 files changed, 71 insertions(+) (limited to 'ipaplatform') diff --git a/ipaplatform/base/tasks.py b/ipaplatform/base/tasks.py index 408447e43..f2ba81f44 100644 --- a/ipaplatform/base/tasks.py +++ b/ipaplatform/base/tasks.py @@ -22,7 +22,13 @@ This module contains default platform-specific implementations of system tasks. ''' +import pwd +import grp from ipaplatform.paths import paths +from ipapython.ipa_log_manager import log_mgr +from ipapython import ipautil + +log = log_mgr.get_logger(__name__) class BaseTaskNamespace(object): @@ -150,5 +156,47 @@ class BaseTaskNamespace(object): return + def create_system_user(self, name, group, homedir, shell, uid = None, gid = None, comment = None): + """Create a system user with a corresponding group""" + try: + grp.getgrnam(group) + except KeyError: + log.debug('Adding group %s', group) + args = [paths.GROUPADD, '-r', group] + if gid: + args += ['-g', str(gid)] + try: + ipautil.run(args) + log.debug('Done adding group') + except ipautil.CalledProcessError as e: + log.critical('Failed to add group: %s', e) + raise + else: + log.debug('group %s exists', group) + + try: + pwd.getpwnam(name) + except KeyError: + log.debug('Adding user %s', name) + args = [ + paths.USERADD, + '-g', group, + '-d', homedir, + '-s', shell, + '-M', '-r', name, + ] + if uid: + args += ['-u', str(uid)] + if comment: + args += ['-c', comment] + try: + ipautil.run(args) + log.debug('Done adding user') + except ipautil.CalledProcessError as e: + log.critical('Failed to add user: %s', e) + raise + else: + log.debug('user %s exists', name) + task_namespace = BaseTaskNamespace() diff --git a/ipaplatform/redhat/tasks.py b/ipaplatform/redhat/tasks.py index 30033b274..0386f7f9c 100644 --- a/ipaplatform/redhat/tasks.py +++ b/ipaplatform/redhat/tasks.py @@ -390,5 +390,28 @@ class RedHatTaskNamespace(BaseTaskNamespace): return True + def create_system_user(self, name, group, homedir, shell, uid = None, gid = None, comment = None): + """ + Create a system user with a corresponding group + + According to https://fedoraproject.org/wiki/Packaging:UsersAndGroups?rd=Packaging/UsersAndGroups#Soft_static_allocation + some system users should have fixed UID, GID and other parameters set. + This values should be constant and may be hardcoded. + Add other values for other users when needed. + """ + if name == 'pkiuser': + if uid is None: + uid = 17 + if gid is None: + gid = 17 + if comment is None: + comment = 'CA System User' + if name == 'dirsrv': + if comment is None: + comment = 'DS System User' + + super(RedHatTaskNamespace, self).create_system_user(name, group, + homedir, shell, uid, gid, comment) + tasks = RedHatTaskNamespace() -- cgit