|
|
b38368 |
From 243f7ebf6a07fa54cbd5db6bf7f67fee04e4f14c Mon Sep 17 00:00:00 2001
|
|
|
b38368 |
From: Martin Babinsky <mbabinsk@redhat.com>
|
|
|
b38368 |
Date: Thu, 22 Jun 2017 13:20:05 +0200
|
|
|
b38368 |
Subject: [PATCH] delegate the indentation handling in advises to dedicated
|
|
|
b38368 |
class
|
|
|
b38368 |
|
|
|
b38368 |
Indentation levels are now handled transparently by a dedicated class
|
|
|
b38368 |
and should not pollute the statement printing logic.
|
|
|
b38368 |
|
|
|
b38368 |
https://pagure.io/freeipa/issue/7036
|
|
|
b38368 |
|
|
|
b38368 |
Reviewed-By: Florence Blanc-Renaud <frenaud@redhat.com>
|
|
|
b38368 |
Reviewed-By: Alexander Bokovoy <abokovoy@redhat.com>
|
|
|
b38368 |
---
|
|
|
b38368 |
ipaserver/advise/base.py | 106 +++++++++++++++++++---------
|
|
|
b38368 |
ipaserver/advise/plugins/smart_card_auth.py | 45 ++++++------
|
|
|
b38368 |
2 files changed, 93 insertions(+), 58 deletions(-)
|
|
|
b38368 |
|
|
|
b38368 |
diff --git a/ipaserver/advise/base.py b/ipaserver/advise/base.py
|
|
|
b38368 |
index 639fd1807f72f11f46136999c4ce4c6eec6b3698..c320b002c83198cbb0fd73a5c158df07dd309242 100644
|
|
|
b38368 |
--- a/ipaserver/advise/base.py
|
|
|
b38368 |
+++ b/ipaserver/advise/base.py
|
|
|
b38368 |
@@ -19,6 +19,7 @@
|
|
|
b38368 |
|
|
|
b38368 |
from __future__ import print_function
|
|
|
b38368 |
|
|
|
b38368 |
+from contextlib import contextmanager
|
|
|
b38368 |
import os
|
|
|
b38368 |
from textwrap import wrap
|
|
|
b38368 |
|
|
|
b38368 |
@@ -75,6 +76,8 @@ As a result, you can redirect the advice's output directly to a script file.
|
|
|
b38368 |
# ./script.sh
|
|
|
b38368 |
"""
|
|
|
b38368 |
|
|
|
b38368 |
+DEFAULT_INDENTATION_INCREMENT = 2
|
|
|
b38368 |
+
|
|
|
b38368 |
|
|
|
b38368 |
class _IndentationTracker(object):
|
|
|
b38368 |
"""
|
|
|
b38368 |
@@ -131,39 +134,77 @@ class _AdviceOutput(object):
|
|
|
b38368 |
self.content = []
|
|
|
b38368 |
self.prefix = '# '
|
|
|
b38368 |
self.options = None
|
|
|
b38368 |
+ self._indentation_tracker = _IndentationTracker(
|
|
|
b38368 |
+ spaces_per_indent=DEFAULT_INDENTATION_INCREMENT)
|
|
|
b38368 |
+
|
|
|
b38368 |
+ def indent(self):
|
|
|
b38368 |
+ """
|
|
|
b38368 |
+ Indent the statements by one level
|
|
|
b38368 |
+ """
|
|
|
b38368 |
+ self._indentation_tracker.indent()
|
|
|
b38368 |
+
|
|
|
b38368 |
+ def dedent(self):
|
|
|
b38368 |
+ """
|
|
|
b38368 |
+ Dedent the statements by one level
|
|
|
b38368 |
+ """
|
|
|
b38368 |
+ self._indentation_tracker.dedent()
|
|
|
b38368 |
+
|
|
|
b38368 |
+ @contextmanager
|
|
|
b38368 |
+ def indented_block(self):
|
|
|
b38368 |
+ self.indent()
|
|
|
b38368 |
+ try:
|
|
|
b38368 |
+ yield
|
|
|
b38368 |
+ finally:
|
|
|
b38368 |
+ self.dedent()
|
|
|
b38368 |
|
|
|
b38368 |
def comment(self, line, wrapped=True):
|
|
|
b38368 |
if wrapped:
|
|
|
b38368 |
- for wrapped_line in wrap(line, 70):
|
|
|
b38368 |
- self.content.append(self.prefix + wrapped_line)
|
|
|
b38368 |
+ self.append_wrapped_and_indented_comment(line)
|
|
|
b38368 |
else:
|
|
|
b38368 |
- self.content.append(self.prefix + line)
|
|
|
b38368 |
+ self.append_comment(line)
|
|
|
b38368 |
+
|
|
|
b38368 |
+ def append_wrapped_and_indented_comment(self, line, character_limit=70):
|
|
|
b38368 |
+ """
|
|
|
b38368 |
+ append wrapped and indented comment to the output
|
|
|
b38368 |
+ """
|
|
|
b38368 |
+ for wrapped_indented_line in wrap(
|
|
|
b38368 |
+ self.indent_statement(line), character_limit):
|
|
|
b38368 |
+ self.append_comment(wrapped_indented_line)
|
|
|
b38368 |
+
|
|
|
b38368 |
+ def append_comment(self, line):
|
|
|
b38368 |
+ self.append_statement(self.prefix + line)
|
|
|
b38368 |
+
|
|
|
b38368 |
+ def append_statement(self, statement):
|
|
|
b38368 |
+ """
|
|
|
b38368 |
+ Append a line to the generated content indenting it by tracked number
|
|
|
b38368 |
+ of spaces
|
|
|
b38368 |
+ """
|
|
|
b38368 |
+ self.content.append(self.indent_statement(statement))
|
|
|
b38368 |
+
|
|
|
b38368 |
+ def indent_statement(self, statement):
|
|
|
b38368 |
+ return '{indent}{statement}'.format(
|
|
|
b38368 |
+ indent=self._indentation_tracker.indentation_string,
|
|
|
b38368 |
+ statement=statement)
|
|
|
b38368 |
|
|
|
b38368 |
def debug(self, line):
|
|
|
b38368 |
if self.options.verbose:
|
|
|
b38368 |
self.comment('DEBUG: ' + line)
|
|
|
b38368 |
|
|
|
b38368 |
- def command(self, line, indent_spaces=0):
|
|
|
b38368 |
- self.content.append(
|
|
|
b38368 |
- '{}{}'.format(self._format_indent(indent_spaces), line))
|
|
|
b38368 |
-
|
|
|
b38368 |
- def _format_indent(self, num_spaces):
|
|
|
b38368 |
- return ' ' * num_spaces
|
|
|
b38368 |
+ def command(self, line):
|
|
|
b38368 |
+ self.append_statement(line)
|
|
|
b38368 |
|
|
|
b38368 |
- def echo_error(self, error_message, indent_spaces=0):
|
|
|
b38368 |
- self.command(
|
|
|
b38368 |
- self._format_error(error_message), indent_spaces=indent_spaces)
|
|
|
b38368 |
+ def echo_error(self, error_message):
|
|
|
b38368 |
+ self.command(self._format_error(error_message))
|
|
|
b38368 |
|
|
|
b38368 |
def _format_error(self, error_message):
|
|
|
b38368 |
return 'echo "{}" >&2'.format(error_message)
|
|
|
b38368 |
|
|
|
b38368 |
def exit_on_failed_command(self, command_to_run,
|
|
|
b38368 |
- error_message_lines, indent_spaces=0):
|
|
|
b38368 |
- self.command(command_to_run, indent_spaces=indent_spaces)
|
|
|
b38368 |
+ error_message_lines):
|
|
|
b38368 |
+ self.command(command_to_run)
|
|
|
b38368 |
self.exit_on_predicate(
|
|
|
b38368 |
'[ "$?" -ne "0" ]',
|
|
|
b38368 |
- error_message_lines,
|
|
|
b38368 |
- indent_spaces=indent_spaces)
|
|
|
b38368 |
+ error_message_lines)
|
|
|
b38368 |
|
|
|
b38368 |
def exit_on_nonroot_euid(self):
|
|
|
b38368 |
self.exit_on_predicate(
|
|
|
b38368 |
@@ -171,8 +212,7 @@ class _AdviceOutput(object):
|
|
|
b38368 |
["This script has to be run as root user"]
|
|
|
b38368 |
)
|
|
|
b38368 |
|
|
|
b38368 |
- def exit_on_predicate(self, predicate, error_message_lines,
|
|
|
b38368 |
- indent_spaces=0):
|
|
|
b38368 |
+ def exit_on_predicate(self, predicate, error_message_lines):
|
|
|
b38368 |
commands_to_run = [
|
|
|
b38368 |
self._format_error(error_message_line)
|
|
|
b38368 |
for error_message_line in error_message_lines]
|
|
|
b38368 |
@@ -180,30 +220,26 @@ class _AdviceOutput(object):
|
|
|
b38368 |
commands_to_run.append('exit 1')
|
|
|
b38368 |
self.commands_on_predicate(
|
|
|
b38368 |
predicate,
|
|
|
b38368 |
- commands_to_run,
|
|
|
b38368 |
- indent_spaces=indent_spaces)
|
|
|
b38368 |
+ commands_to_run)
|
|
|
b38368 |
|
|
|
b38368 |
def commands_on_predicate(self, predicate, commands_to_run_when_true,
|
|
|
b38368 |
- commands_to_run_when_false=None,
|
|
|
b38368 |
- indent_spaces=0):
|
|
|
b38368 |
+ commands_to_run_when_false=None):
|
|
|
b38368 |
if_command = 'if {}'.format(predicate)
|
|
|
b38368 |
- self.command(if_command, indent_spaces=indent_spaces)
|
|
|
b38368 |
- self.command('then', indent_spaces=indent_spaces)
|
|
|
b38368 |
-
|
|
|
b38368 |
- indented_block_spaces = indent_spaces + 2
|
|
|
b38368 |
+ self.command(if_command)
|
|
|
b38368 |
+ self.command('then')
|
|
|
b38368 |
|
|
|
b38368 |
- for command_to_run_when_true in commands_to_run_when_true:
|
|
|
b38368 |
- self.command(
|
|
|
b38368 |
- command_to_run_when_true, indent_spaces=indented_block_spaces)
|
|
|
b38368 |
+ with self.indented_block():
|
|
|
b38368 |
+ for command_to_run_when_true in commands_to_run_when_true:
|
|
|
b38368 |
+ self.command(
|
|
|
b38368 |
+ command_to_run_when_true)
|
|
|
b38368 |
|
|
|
b38368 |
if commands_to_run_when_false is not None:
|
|
|
b38368 |
- self.command("else", indent_spaces=indent_spaces)
|
|
|
b38368 |
- for command_to_run_when_false in commands_to_run_when_false:
|
|
|
b38368 |
- self.command(
|
|
|
b38368 |
- command_to_run_when_false,
|
|
|
b38368 |
- indent_spaces=indented_block_spaces)
|
|
|
b38368 |
+ self.command("else")
|
|
|
b38368 |
+ with self.indented_block():
|
|
|
b38368 |
+ for command_to_run_when_false in commands_to_run_when_false:
|
|
|
b38368 |
+ self.command(command_to_run_when_false)
|
|
|
b38368 |
|
|
|
b38368 |
- self.command('fi', indent_spaces=indent_spaces)
|
|
|
b38368 |
+ self.command('fi')
|
|
|
b38368 |
|
|
|
b38368 |
|
|
|
b38368 |
class Advice(Plugin):
|
|
|
b38368 |
diff --git a/ipaserver/advise/plugins/smart_card_auth.py b/ipaserver/advise/plugins/smart_card_auth.py
|
|
|
b38368 |
index 16c01204444883ed949db73b2314ba5c404124df..75efa6f854acd5f746111ea44957a538117381ae 100644
|
|
|
b38368 |
--- a/ipaserver/advise/plugins/smart_card_auth.py
|
|
|
b38368 |
+++ b/ipaserver/advise/plugins/smart_card_auth.py
|
|
|
b38368 |
@@ -44,13 +44,13 @@ class common_smart_card_auth_config(Advice):
|
|
|
b38368 |
"for {} in ${}".format(
|
|
|
b38368 |
single_ca_path_variable, ca_paths_variable))
|
|
|
b38368 |
self.log.command("do")
|
|
|
b38368 |
- self.log.exit_on_predicate(
|
|
|
b38368 |
- '[ ! -f "${}" ]'.format(single_ca_path_variable),
|
|
|
b38368 |
- ['Invalid CA certificate filename: ${}'.format(
|
|
|
b38368 |
- single_ca_path_variable),
|
|
|
b38368 |
- 'Please check that the path exists and is a valid file'],
|
|
|
b38368 |
- indent_spaces=2
|
|
|
b38368 |
- )
|
|
|
b38368 |
+ with self.log.indented_block():
|
|
|
b38368 |
+ self.log.exit_on_predicate(
|
|
|
b38368 |
+ '[ ! -f "${}" ]'.format(single_ca_path_variable),
|
|
|
b38368 |
+ ['Invalid CA certificate filename: ${}'.format(
|
|
|
b38368 |
+ single_ca_path_variable),
|
|
|
b38368 |
+ 'Please check that the path exists and is a valid file']
|
|
|
b38368 |
+ )
|
|
|
b38368 |
self.log.command("done")
|
|
|
b38368 |
|
|
|
b38368 |
def upload_smartcard_ca_certificates_to_systemwide_db(self):
|
|
|
b38368 |
@@ -59,13 +59,13 @@ class common_smart_card_auth_config(Advice):
|
|
|
b38368 |
self.single_ca_cert_variable_name,
|
|
|
b38368 |
self.smart_card_ca_certs_variable_name))
|
|
|
b38368 |
self.log.command("do")
|
|
|
b38368 |
- self.log.command(
|
|
|
b38368 |
- 'certutil -d {} -A -i ${} -n "Smart Card CA $(uuidgen)" '
|
|
|
b38368 |
- '-t CT,C,C'.format(
|
|
|
b38368 |
- self.systemwide_nssdb, self.single_ca_cert_variable_name
|
|
|
b38368 |
- ),
|
|
|
b38368 |
- indent_spaces=2
|
|
|
b38368 |
- )
|
|
|
b38368 |
+ with self.log.indented_block():
|
|
|
b38368 |
+ self.log.command(
|
|
|
b38368 |
+ 'certutil -d {} -A -i ${} -n "Smart Card CA $(uuidgen)" '
|
|
|
b38368 |
+ '-t CT,C,C'.format(
|
|
|
b38368 |
+ self.systemwide_nssdb, self.single_ca_cert_variable_name
|
|
|
b38368 |
+ ),
|
|
|
b38368 |
+ )
|
|
|
b38368 |
self.log.command("done")
|
|
|
b38368 |
|
|
|
b38368 |
def install_smart_card_signing_ca_certs(self):
|
|
|
b38368 |
@@ -74,13 +74,13 @@ class common_smart_card_auth_config(Advice):
|
|
|
b38368 |
self.single_ca_cert_variable_name,
|
|
|
b38368 |
self.smart_card_ca_certs_variable_name))
|
|
|
b38368 |
self.log.command("do")
|
|
|
b38368 |
- self.log.exit_on_failed_command(
|
|
|
b38368 |
- 'ipa-cacert-manage install ${} -t CT,C,C'.format(
|
|
|
b38368 |
- self.single_ca_cert_variable_name
|
|
|
b38368 |
- ),
|
|
|
b38368 |
- ['Failed to install external CA certificate to IPA'],
|
|
|
b38368 |
- indent_spaces=2
|
|
|
b38368 |
- )
|
|
|
b38368 |
+ with self.log.indented_block():
|
|
|
b38368 |
+ self.log.exit_on_failed_command(
|
|
|
b38368 |
+ 'ipa-cacert-manage install ${} -t CT,C,C'.format(
|
|
|
b38368 |
+ self.single_ca_cert_variable_name
|
|
|
b38368 |
+ ),
|
|
|
b38368 |
+ ['Failed to install external CA certificate to IPA']
|
|
|
b38368 |
+ )
|
|
|
b38368 |
self.log.command("done")
|
|
|
b38368 |
|
|
|
b38368 |
def update_ipa_ca_certificate_store(self):
|
|
|
b38368 |
@@ -221,8 +221,7 @@ class config_server_for_smart_card_auth(common_smart_card_auth_config):
|
|
|
b38368 |
self.log.command('else')
|
|
|
b38368 |
self.log.exit_on_failed_command(
|
|
|
b38368 |
'ipa-pkinit-manage enable',
|
|
|
b38368 |
- ['Failed to issue PKINIT certificates to local KDC'],
|
|
|
b38368 |
- indent_spaces=2)
|
|
|
b38368 |
+ ['Failed to issue PKINIT certificates to local KDC'])
|
|
|
b38368 |
self.log.command('fi')
|
|
|
b38368 |
|
|
|
b38368 |
def enable_ok_to_auth_as_delegate_on_http_principal(self):
|
|
|
b38368 |
--
|
|
|
b38368 |
2.9.4
|
|
|
b38368 |
|