summaryrefslogtreecommitdiffstats
path: root/base/deploy/src/scriptlets/finalization.py
diff options
context:
space:
mode:
authorMatthew Harmsen <mharmsen@redhat.com>2012-04-23 13:39:04 -0700
committerMatthew Harmsen <mharmsen@redhat.com>2012-04-26 15:28:54 -0700
commitdd566ed3c64a69801a9edf3b27f11077aa40ecef (patch)
treee582b16f39c2a284bff873f23410fa058539a0ca /base/deploy/src/scriptlets/finalization.py
parent7741dd4a44f87012974e9849d35f1df0d56929c2 (diff)
downloadpki-dd566ed3c64a69801a9edf3b27f11077aa40ecef.tar.gz
pki-dd566ed3c64a69801a9edf3b27f11077aa40ecef.tar.xz
pki-dd566ed3c64a69801a9edf3b27f11077aa40ecef.zip
PKI Deployment Scriptlets
* Completed the following six 'scriptlets': * Dogtag 10: Python 'initialization.py' Installation Scriptlet (https://fedorahosted.org/pki/ticket/147) * Dogtag 10: Python 'instance_layout.py' Installation Scriptlet (https://fedorahosted.org/pki/ticket/75) * Dogtag 10: Python 'webserver_layout.py' Installation Scriptlet (https://fedorahosted.org/pki/ticket/140) * Dogtag 10: Python 'subsystem_layout.py' Installation Scriptlet (https://fedorahosted.org/pki/ticket/141) * Dogtag 10: Python 'war_explosion.py' Installation Scriptlet (https://fedorahosted.org/pki/ticket/76) * Dogtag 10: Python 'finalization.py' Installation Scriptlet (https://fedorahosted.org/pki/ticket/148) * Created numerous PKI deployment helper utilities. * Augmented logging to provide indentation. * Generated logic for installation 'manifest'. * Tested logic using '--dry_run' option and '-p' prefix options. * Per initial review, removed numerous "constants" and consolidated logic into "master" dictionary. * Corrected the following ticket: * Dogtag 10: Fix 'build_dogtag_pki' script to account for 'pki-deploy' RPM (https://fedorahosted.org/pki/ticket/138) Resolves Bugzilla Bug #810047 - build_dogtag_pki fails with requirements for pki-deploy (https://bugzilla.redhat.com/show_bug.cgi?id=810047) * Created the following three 'scriptlets' as 'NOT YET IMPLEMENTED' place-holders: * Dogtag 10: Python 'security_databases.py' Installation Scriptlet (https://fedorahosted.org/pki/ticket/136) * Dogtag 10: Python 'slot_assignment.py' Installation Scriptlet (https://fedorahosted.org/pki/ticket/146) * Dogtag 10: Python 'configuration.py' Configuration Scriptlet (https://fedorahosted.org/pki/ticket/137)
Diffstat (limited to 'base/deploy/src/scriptlets/finalization.py')
-rw-r--r--base/deploy/src/scriptlets/finalization.py109
1 files changed, 109 insertions, 0 deletions
diff --git a/base/deploy/src/scriptlets/finalization.py b/base/deploy/src/scriptlets/finalization.py
new file mode 100644
index 000000000..60073262d
--- /dev/null
+++ b/base/deploy/src/scriptlets/finalization.py
@@ -0,0 +1,109 @@
+#!/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) 2012 Red Hat, Inc.
+# All rights reserved.
+#
+
+# PKI Deployment Imports
+import pkiconfig as config
+from pkiconfig import pki_master_dict as master
+import pkihelper as util
+import pkimanifest as manifest
+import pkimessages as log
+import pkiscriptlet
+
+
+# PKI Deployment Instance Population Classes
+class PkiScriptlet(pkiscriptlet.AbstractBasePkiScriptlet):
+ rv = 0
+
+ def spawn(self):
+ config.pki_log.info(log.FINALIZATION_SPAWN_1, __name__,
+ extra=config.PKI_INDENTATION_LEVEL_1)
+ # Save a copy of the configuration file used by this process
+ # (which may be used later by 'pkidestroy')
+ util.file.copy(config.pkideployment_cfg,
+ master['pki_subsystem_registry_path'] +\
+ "/" + config.PKI_DEPLOYMENT_DEFAULT_CONFIGURATION_FILE)
+ # Save a timestamped copy of the installation manifest file
+ filename = master['pki_root_prefix'] +\
+ config.PKI_DEPLOYMENT_REGISTRY_ROOT + "/" +\
+ master['pki_instance_name'] + "/" +\
+ master['pki_subsystem'].lower() +"/" +\
+ "spawn" + "_" + "manifest" + "." +\
+ master['pki_timestamp'] + "." + "csv"
+ config.pki_log.info(log.PKI_MANIFEST_MESSAGE_1, filename,
+ extra=config.PKI_INDENTATION_LEVEL_2)
+ # for record in manifest.database:
+ # print tuple(record)
+ if not config.pki_dry_run_flag:
+ manifest.file.register(filename)
+ manifest.file.write()
+ util.file.modify(filename, silent=True)
+ # Log final process messages
+ config.pki_log.info(log.PKISPAWN_END_MESSAGE_2,
+ master['pki_subsystem'],
+ master['pki_instance_name'],
+ extra=config.PKI_INDENTATION_LEVEL_0)
+ if not config.pki_dry_run_flag:
+ util.file.modify(master['pki_spawn_log'], silent=True)
+ return self.rv
+
+ def respawn(self):
+ config.pki_log.info(log.FINALIZATION_RESPAWN_1, __name__,
+ extra=config.PKI_INDENTATION_LEVEL_1)
+ # Save a copy of the configuration file used by this process
+ # (which may be used later by 'pkidestroy')
+ util.file.copy(config.pkideployment_cfg,
+ master['pki_subsystem_registry_path'] +\
+ "/" + config.PKI_DEPLOYMENT_DEFAULT_CONFIGURATION_FILE,
+ overwrite_flag=True)
+ # Save a timestamped copy of the updated manifest file
+ filename = master['pki_root_prefix'] +\
+ config.PKI_DEPLOYMENT_REGISTRY_ROOT + "/" +\
+ master['pki_instance_name'] + "/" +\
+ master['pki_subsystem'].lower() +"/" +\
+ "respawn" + "_" + "manifest" + "." +\
+ master['pki_timestamp'] + "." + "csv"
+ config.pki_log.info(log.PKI_MANIFEST_MESSAGE_1, filename,
+ extra=config.PKI_INDENTATION_LEVEL_2)
+ # for record in manifest.database:
+ # print tuple(record)
+ if not config.pki_dry_run_flag:
+ manifest.file.register(filename)
+ manifest.file.write()
+ util.file.modify(filename, silent=True)
+ # Log final process messages
+ config.pki_log.info(log.PKIRESPAWN_END_MESSAGE_2,
+ master['pki_subsystem'],
+ master['pki_instance_name'],
+ extra=config.PKI_INDENTATION_LEVEL_0)
+ if not config.pki_dry_run_flag:
+ util.file.modify(master['pki_respawn_log'], silent=True)
+ return self.rv
+
+ def destroy(self):
+ config.pki_log.info(log.FINALIZATION_DESTROY_1, __name__,
+ extra=config.PKI_INDENTATION_LEVEL_1)
+ config.pki_log.info(log.PKIDESTROY_END_MESSAGE_2,
+ master['pki_subsystem'],
+ master['pki_instance_name'],
+ extra=config.PKI_INDENTATION_LEVEL_0)
+ if not config.pki_dry_run_flag:
+ util.file.modify(master['pki_destroy_log'], silent=True)
+ return self.rv