summaryrefslogtreecommitdiffstats
path: root/base/server/python/pki/server/deployment/scriptlets/security_databases.py
diff options
context:
space:
mode:
authorEndi S. Dewata <edewata@redhat.com>2013-07-16 17:47:18 -0400
committerEndi S. Dewata <edewata@redhat.com>2013-07-22 09:51:38 -0400
commit6f76531f4a1b81c07f2db5183f5b10c9f4a531c3 (patch)
treee986367bc77f860ff6b0681e43a3871e4965410f /base/server/python/pki/server/deployment/scriptlets/security_databases.py
parent4d49d7e1845c372164b7bcc2fe759867cfcab0f2 (diff)
downloadpki-6f76531f4a1b81c07f2db5183f5b10c9f4a531c3.tar.gz
pki-6f76531f4a1b81c07f2db5183f5b10c9f4a531c3.tar.xz
pki-6f76531f4a1b81c07f2db5183f5b10c9f4a531c3.zip
Reorganized deployment tools.
The pkispawn and pkidestroy scripts have been moved into sbin folder. The Python deployment library and the scriptlets were moved into pki.server.deployment and pki.server.deployment.scriptlets packages, respectively.
Diffstat (limited to 'base/server/python/pki/server/deployment/scriptlets/security_databases.py')
-rw-r--r--base/server/python/pki/server/deployment/scriptlets/security_databases.py114
1 files changed, 114 insertions, 0 deletions
diff --git a/base/server/python/pki/server/deployment/scriptlets/security_databases.py b/base/server/python/pki/server/deployment/scriptlets/security_databases.py
new file mode 100644
index 000000000..3d3193cef
--- /dev/null
+++ b/base/server/python/pki/server/deployment/scriptlets/security_databases.py
@@ -0,0 +1,114 @@
+#!/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
+from .. import pkiconfig as config
+from .. import pkimessages as log
+from .. import pkiscriptlet
+
+
+# PKI Deployment Security Databases Scriptlet
+class PkiScriptlet(pkiscriptlet.AbstractBasePkiScriptlet):
+ rv = 0
+
+ def spawn(self, deployer):
+
+ if config.str2bool(deployer.master_dict['pki_skip_installation']):
+ config.pki_log.info(log.SKIP_SECURITY_DATABASES_SPAWN_1, __name__,
+ extra=config.PKI_INDENTATION_LEVEL_1)
+ return self.rv
+ config.pki_log.info(log.SECURITY_DATABASES_SPAWN_1, __name__,
+ extra=config.PKI_INDENTATION_LEVEL_1)
+ deployer.password.create_password_conf(
+ deployer.master_dict['pki_shared_password_conf'],
+ deployer.master_dict['pki_pin'])
+ # Since 'certutil' does NOT strip the 'token=' portion of
+ # the 'token=password' entries, create a temporary server 'pfile'
+ # which ONLY contains the 'password' for the purposes of
+ # allowing 'certutil' to generate the security databases
+ deployer.password.create_password_conf(
+ deployer.master_dict['pki_shared_pfile'],
+ deployer.master_dict['pki_pin'], pin_sans_token=True)
+ deployer.file.modify(deployer.master_dict['pki_shared_password_conf'])
+ deployer.certutil.create_security_databases(
+ deployer.master_dict['pki_database_path'],
+ deployer.master_dict['pki_cert_database'],
+ deployer.master_dict['pki_key_database'],
+ deployer.master_dict['pki_secmod_database'],
+ password_file=deployer.master_dict['pki_shared_pfile'])
+ deployer.file.modify(deployer.master_dict['pki_cert_database'], perms=\
+ config.PKI_DEPLOYMENT_DEFAULT_SECURITY_DATABASE_PERMISSIONS)
+ deployer.file.modify(deployer.master_dict['pki_key_database'], perms=\
+ config.PKI_DEPLOYMENT_DEFAULT_SECURITY_DATABASE_PERMISSIONS)
+ deployer.file.modify(deployer.master_dict['pki_secmod_database'], perms=\
+ config.PKI_DEPLOYMENT_DEFAULT_SECURITY_DATABASE_PERMISSIONS)
+
+ if len(deployer.instance.tomcat_instance_subsystems()) < 2:
+ # only create a self signed cert for a new instance
+ rv = deployer.certutil.verify_certificate_exists(
+ deployer.master_dict['pki_database_path'],
+ deployer.master_dict['pki_cert_database'],
+ deployer.master_dict['pki_key_database'],
+ deployer.master_dict['pki_secmod_database'],
+ deployer.master_dict['pki_self_signed_token'],
+ deployer.master_dict['pki_self_signed_nickname'],
+ password_file=deployer.master_dict['pki_shared_pfile'])
+ if not rv:
+ deployer.file.generate_noise_file(
+ deployer.master_dict['pki_self_signed_noise_file'],
+ deployer.master_dict['pki_self_signed_noise_bytes'])
+ deployer.certutil.generate_self_signed_certificate(
+ deployer.master_dict['pki_database_path'],
+ deployer.master_dict['pki_cert_database'],
+ deployer.master_dict['pki_key_database'],
+ deployer.master_dict['pki_secmod_database'],
+ deployer.master_dict['pki_self_signed_token'],
+ deployer.master_dict['pki_self_signed_nickname'],
+ deployer.master_dict['pki_self_signed_subject'],
+ deployer.master_dict['pki_self_signed_serial_number'],
+ deployer.master_dict['pki_self_signed_validity_period'],
+ deployer.master_dict['pki_self_signed_issuer_name'],
+ deployer.master_dict['pki_self_signed_trustargs'],
+ deployer.master_dict['pki_self_signed_noise_file'],
+ password_file=deployer.master_dict['pki_shared_pfile'])
+ # Delete the temporary 'noise' file
+ deployer.file.delete(deployer.master_dict['pki_self_signed_noise_file'])
+ # Delete the temporary 'pfile'
+ deployer.file.delete(deployer.master_dict['pki_shared_pfile'])
+ return self.rv
+
+ def destroy(self, deployer):
+
+ config.pki_log.info(log.SECURITY_DATABASES_DESTROY_1, __name__,
+ extra=config.PKI_INDENTATION_LEVEL_1)
+ if deployer.master_dict['pki_subsystem'] in config.PKI_APACHE_SUBSYSTEMS and\
+ deployer.instance.apache_instance_subsystems() == 0:
+ deployer.file.delete(deployer.master_dict['pki_cert_database'])
+ deployer.file.delete(deployer.master_dict['pki_key_database'])
+ deployer.file.delete(deployer.master_dict['pki_secmod_database'])
+ deployer.file.delete(deployer.master_dict['pki_shared_password_conf'])
+ elif deployer.master_dict['pki_subsystem'] in config.PKI_TOMCAT_SUBSYSTEMS and\
+ len(deployer.instance.tomcat_instance_subsystems()) == 0:
+ deployer.file.delete(deployer.master_dict['pki_cert_database'])
+ deployer.file.delete(deployer.master_dict['pki_key_database'])
+ deployer.file.delete(deployer.master_dict['pki_secmod_database'])
+ deployer.file.delete(deployer.master_dict['pki_shared_password_conf'])
+ return self.rv