diff options
| author | Matthew Harmsen <mharmsen@redhat.com> | 2012-02-07 10:57:32 -0800 |
|---|---|---|
| committer | Matthew Harmsen <mharmsen@redhat.com> | 2012-03-01 19:35:11 -0800 |
| commit | b5219f534cf0b60452346b31a84b9eddd881f614 (patch) | |
| tree | 7ac19c46de35557f70a859e12e5c8ece10090a55 /pki/base/deploy/src/scriptlets/instance.py | |
| parent | daa4b591dfed937a8384babbe6d39686b70f7efd (diff) | |
| download | pki-b5219f534cf0b60452346b31a84b9eddd881f614.tar.gz pki-b5219f534cf0b60452346b31a84b9eddd881f614.tar.xz pki-b5219f534cf0b60452346b31a84b9eddd881f614.zip | |
Initial attempt at 'http://pki.fedoraproject.org/wiki/PKI_Instance_Deployment'.
Corrected imports to work with site-packages.
Standardized log messages via encapsulation in a central file.
Corrected imports to work with site-packages.
Standardized log messages via encapsulation in a central file.
Updated top-level instance directory.
Streamlined parsing and enhanced logging.
Added "--dry_run" option.
Added umask and default permissions; sanitized use of '+' and '\'.
Diffstat (limited to 'pki/base/deploy/src/scriptlets/instance.py')
| -rw-r--r-- | pki/base/deploy/src/scriptlets/instance.py | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/pki/base/deploy/src/scriptlets/instance.py b/pki/base/deploy/src/scriptlets/instance.py new file mode 100644 index 000000000..636f63b27 --- /dev/null +++ b/pki/base/deploy/src/scriptlets/instance.py @@ -0,0 +1,105 @@ +#!/usr/bin/python -t +# Authors: +# Matthew Harmsen <mharmsen@redhat.com> +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; version 2 of the License. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License along +# with this program; if not, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. +# +# Copyright (C) 2011 Red Hat, Inc. +# All rights reserved. +# + +# System Imports +import os +import grp +import pwd + +# PKI Deployment Imports +import pkiconfig +import pkimessages as log +import pkiscriptlet + + +# PKI Deployment Instance Population Classes +class PkiScriptlet(pkiscriptlet.AbstractBasePkiScriptlet): + rv = 0 + pki_path = pkiconfig.pki_root_prefix +\ + pkiconfig.pki_common_dict['pki_instance_root'] + pki_instance_path = pki_path + "/" +\ + pkiconfig.pki_common_dict['pki_instance_name'] + pki_subsystem_path = pki_instance_path + "/" +\ + pkiconfig.pki_subsystem_dict['pki_subsystem'].lower() + + def spawn(self): + if not os.path.exists(self.pki_subsystem_path): + pkiconfig.pki_log.info(log.INSTANCE_SPAWN_1, __name__) + pkiconfig.pki_log.info(log.INSTANCE_SPAWN_MKDIR_1, + self.pki_subsystem_path) + if not pkiconfig.pki_dry_run_flag: + try: + pki_gid = grp.getgrnam( + pkiconfig.pki_common_dict['pki_group'])[2] + pki_uid = pwd.getpwnam( + pkiconfig.pki_common_dict['pki_user'])[2] + os.mkdir(self.pki_path, + pkiconfig.PKI_DEPLOYMENT_DEFAULT_DIR_PERMISSIONS) + os.chown(self.pki_path, + pki_uid, + pki_gid) + os.mkdir(self.pki_instance_path, + pkiconfig.PKI_DEPLOYMENT_DEFAULT_DIR_PERMISSIONS) + os.chown(self.pki_instance_path, + pki_uid, + pki_gid) + os.mkdir(self.pki_subsystem_path, + pkiconfig.PKI_DEPLOYMENT_DEFAULT_DIR_PERMISSIONS) + os.chown(self.pki_subsystem_path, + pki_uid, + pki_gid) + except KeyError: + self.rv = KeyError + except OSError: + self.rv = OSError + elif not os.path.isdir(self.pki_subsystem_path): + pkiconfig.pki_log.error( + log.PKI_DIRECTORY_ALREADY_EXISTS_NOT_A_DIRECTORY_1, + self.pki_subsystem_path) + self.rv = -1 + else: + pkiconfig.pki_log.error(log.PKI_DIRECTORY_ALREADY_EXISTS_1, + self.pki_subsystem_path) + self.rv = -1 + return self.rv + + def respawn(self): + if not os.path.exists(self.pki_subsystem_path) or\ + not os.path.isdir(self.pki_subsystem_path): + pkiconfig.pki_log.error( + log.PKI_DIRECTORY_MISSING_OR_NOT_A_DIRECTORY_1, + self.pki_subsystem_path) + self.rv = -1 + else: + pkiconfig.pki_log.info(log.INSTANCE_RESPAWN_1, __name__) + return self.rv + + def destroy(self): + if not os.path.exists(self.pki_subsystem_path) or\ + not os.path.isdir(self.pki_subsystem_path): + pkiconfig.pki_log.error( + log.PKI_DIRECTORY_MISSING_OR_NOT_A_DIRECTORY_1, + self.pki_subsystem_path) + self.rv = -1 + else: + pkiconfig.pki_log.info(log.INSTANCE_DESTROY_1, __name__) + return self.rv + |
