diff options
author | Matthew Harmsen <mharmsen@redhat.com> | 2012-04-23 13:39:04 -0700 |
---|---|---|
committer | Matthew Harmsen <mharmsen@redhat.com> | 2012-04-26 15:28:54 -0700 |
commit | dd566ed3c64a69801a9edf3b27f11077aa40ecef (patch) | |
tree | e582b16f39c2a284bff873f23410fa058539a0ca /base/deploy/src/scriptlets/finalization.py | |
parent | 7741dd4a44f87012974e9849d35f1df0d56929c2 (diff) | |
download | pki-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.py | 109 |
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 |