summaryrefslogtreecommitdiffstats
path: root/base/server/upgrade
diff options
context:
space:
mode:
authorFraser Tweedale <ftweedal@redhat.com>2016-12-07 15:24:07 +1000
committerFraser Tweedale <ftweedal@redhat.com>2017-04-19 11:15:00 +1000
commitdcc42ad4ed7fcbc566b7cf7ce1cbfae93b24a9a9 (patch)
tree723eb12a2f883f7f6efc0ffd7d198965cea429a9 /base/server/upgrade
parentf67071910c6b74790f7ad75329f05e599076dee4 (diff)
downloadpki-dcc42ad4ed7fcbc566b7cf7ce1cbfae93b24a9a9.tar.gz
pki-dcc42ad4ed7fcbc566b7cf7ce1cbfae93b24a9a9.tar.xz
pki-dcc42ad4ed7fcbc566b7cf7ce1cbfae93b24a9a9.zip
Add ExternalProcessConstraint for request validation
Add the ExternalProcessConstraint profile policy constraint class. It can be configured to execute an arbitrary program that performs additional request validation, rejecting the request if it terminates with a nonzero exit status. Information about the request is conveyed in the subprocess' environment. Part of: https://pagure.io/dogtagpki/issue/1359
Diffstat (limited to 'base/server/upgrade')
-rwxr-xr-xbase/server/upgrade/10.4.0/04-AddExternalProcessConstraintToRegistry67
1 files changed, 67 insertions, 0 deletions
diff --git a/base/server/upgrade/10.4.0/04-AddExternalProcessConstraintToRegistry b/base/server/upgrade/10.4.0/04-AddExternalProcessConstraintToRegistry
new file mode 100755
index 000000000..a9ee00aec
--- /dev/null
+++ b/base/server/upgrade/10.4.0/04-AddExternalProcessConstraintToRegistry
@@ -0,0 +1,67 @@
+#!/usr/bin/python
+# Authors:
+# Fraser Tweedale <ftweedal@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) 2017 Red Hat, Inc.
+# All rights reserved.
+
+from __future__ import absolute_import
+import os.path
+
+import pki
+from pki.server.upgrade import PKIServerUpgradeScriptlet
+
+
+class AddExternalProcessConstraintToRegistry(PKIServerUpgradeScriptlet):
+
+ new_config = {
+ 'constraintPolicy.externalProcessConstraintImpl.class':
+ 'com.netscape.cms.profile.constraint.ExternalProcessConstraint',
+ 'constraintPolicy.externalProcessConstraintImpl.desc':
+ 'External Process Constraint',
+ 'constraintPolicy.externalProcessConstraintImpl.name':
+ 'External Process Constraint',
+ }
+
+ constraint_name = 'externalProcessConstraintImpl'
+
+ def __init__(self):
+ super(AddExternalProcessConstraintToRegistry, self).__init__()
+ self.message = 'Add ExternalProcessConstraint to registry'
+
+ def upgrade_subsystem(self, instance, subsystem):
+ if subsystem.name == 'ca':
+ self.add_new_entries(instance, subsystem)
+
+ def add_new_entries(self, instance, subsystem): # pylint: disable=W0613
+ filename = os.path.join(subsystem.conf_dir, 'registry.cfg')
+ self.backup(filename)
+
+ properties = pki.PropertyFile(filename)
+ properties.read()
+
+ # add constraint to constraint list
+ constraints = properties.get('constraintPolicy.ids').split(',')
+ if self.constraint_name in constraints:
+ return # update not required
+
+ constraints.append(self.constraint_name)
+ properties.set('constraintPolicy.ids', ','.join(constraints))
+
+ for k, v in self.new_config.items():
+ properties.set(k, v)
+
+ properties.write()