summaryrefslogtreecommitdiffstats
path: root/pki/base/deploy/src/scriptlets/instance.py
diff options
context:
space:
mode:
authorMatthew Harmsen <mharmsen@redhat.com>2012-03-12 22:04:20 -0700
committerMatthew Harmsen <mharmsen@redhat.com>2012-03-12 22:04:20 -0700
commitc24c8f080f987ed63034abcedf9320e962c4c415 (patch)
tree6a904c1699f870200062478ad2b6b3282653f92c /pki/base/deploy/src/scriptlets/instance.py
parentce69d1c0f83e9dc1d66c58c40ab3b2f5f58cc8fa (diff)
downloadpki-c24c8f080f987ed63034abcedf9320e962c4c415.tar.gz
pki-c24c8f080f987ed63034abcedf9320e962c4c415.tar.xz
pki-c24c8f080f987ed63034abcedf9320e962c4c415.zip
PKI Deployment Framework
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. Updated top-level instance directory. Streamlined parsing and enhanced logging. Added "--dry_run" option. Added umask and default permissions; sanitized use of '+' and '\'. Aliased 'pkiconfig' as 'config' Created a single master PKI dictionary from the sectional dictionaries
Diffstat (limited to 'pki/base/deploy/src/scriptlets/instance.py')
-rw-r--r--pki/base/deploy/src/scriptlets/instance.py105
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 00000000..a7ca35c6
--- /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 as config
+import pkimessages as log
+import pkiscriptlet
+
+
+# PKI Deployment Instance Population Classes
+class PkiScriptlet(pkiscriptlet.AbstractBasePkiScriptlet):
+ rv = 0
+ pki_path = config.pki_root_prefix +\
+ config.pki_master_dict['pki_instance_root']
+ pki_instance_path = pki_path + "/" +\
+ config.pki_master_dict['pki_instance_name']
+ pki_subsystem_path = pki_instance_path + "/" +\
+ config.pki_master_dict['pki_subsystem'].lower()
+
+ def spawn(self):
+ if not os.path.exists(self.pki_subsystem_path):
+ config.pki_log.info(log.INSTANCE_SPAWN_1, __name__)
+ config.pki_log.info(log.INSTANCE_SPAWN_MKDIR_1,
+ self.pki_subsystem_path)
+ if not config.pki_dry_run_flag:
+ try:
+ pki_gid = grp.getgrnam(
+ config.pki_master_dict['pki_group'])[2]
+ pki_uid = pwd.getpwnam(
+ config.pki_master_dict['pki_user'])[2]
+ os.mkdir(self.pki_path,
+ config.PKI_DEPLOYMENT_DEFAULT_DIR_PERMISSIONS)
+ os.chown(self.pki_path,
+ pki_uid,
+ pki_gid)
+ os.mkdir(self.pki_instance_path,
+ config.PKI_DEPLOYMENT_DEFAULT_DIR_PERMISSIONS)
+ os.chown(self.pki_instance_path,
+ pki_uid,
+ pki_gid)
+ os.mkdir(self.pki_subsystem_path,
+ config.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):
+ config.pki_log.error(
+ log.PKI_DIRECTORY_ALREADY_EXISTS_NOT_A_DIRECTORY_1,
+ self.pki_subsystem_path)
+ self.rv = -1
+ else:
+ config.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):
+ config.pki_log.error(
+ log.PKI_DIRECTORY_MISSING_OR_NOT_A_DIRECTORY_1,
+ self.pki_subsystem_path)
+ self.rv = -1
+ else:
+ config.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):
+ config.pki_log.error(
+ log.PKI_DIRECTORY_MISSING_OR_NOT_A_DIRECTORY_1,
+ self.pki_subsystem_path)
+ self.rv = -1
+ else:
+ config.pki_log.info(log.INSTANCE_DESTROY_1, __name__)
+ return self.rv
+