mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-01-16 11:21:56 -06:00
56401c1abe
change default_logger_level to debug in configure_standard_logging add new ipa_log_manager module, move log_mgr there, also export root_logger from log_mgr. change all log_manager imports to ipa_log_manager and change log_manager.root_logger to root_logger. add missing import for parse_log_level()
170 lines
5.9 KiB
Python
Executable File
170 lines
5.9 KiB
Python
Executable File
#!/usr/bin/python
|
|
# Authors: Rob Crittenden <rcritten@redhat.com>
|
|
#
|
|
# Copyright (C) 2008 Red Hat
|
|
# see file 'COPYING' for use and warranty information
|
|
#
|
|
# 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, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# 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, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
|
|
# Documentation can be found at http://freeipa.org/page/LdapUpdate
|
|
|
|
# TODO
|
|
# save undo files?
|
|
|
|
import os
|
|
import sys
|
|
try:
|
|
from ipapython.config import IPAOptionParser
|
|
from ipapython import ipautil, config
|
|
from ipaserver.install import installutils
|
|
from ipaserver.install.ldapupdate import LDAPUpdate, BadSyntax, UPDATES_DIR
|
|
from ipaserver.install.upgradeinstance import IPAUpgrade
|
|
from ipapython import sysrestore
|
|
import krbV
|
|
from ipalib import api
|
|
from ipapython.ipa_log_manager import *
|
|
except ImportError:
|
|
print >> sys.stderr, """\
|
|
There was a problem importing one of the required Python modules. The
|
|
error was:
|
|
|
|
%s
|
|
""" % sys.exc_value
|
|
sys.exit(1)
|
|
|
|
def parse_options():
|
|
usage = "%prog [options] input_file(s)\n"
|
|
usage += "%prog [options]\n"
|
|
parser = IPAOptionParser(usage=usage, formatter=config.IPAFormatter())
|
|
|
|
parser.add_option("-d", "--debug", action="store_true", dest="debug",
|
|
help="Display debugging information about the update(s)",
|
|
default=False)
|
|
parser.add_option("-t", "--test", action="store_true", dest="test",
|
|
help="Run through the update without changing anything",
|
|
default=False)
|
|
parser.add_option("-y", dest="password",
|
|
help="File containing the Directory Manager password")
|
|
parser.add_option("-l", '--ldapi', action="store_true", dest="ldapi",
|
|
default=False, help="Connect to the LDAP server using the ldapi socket")
|
|
parser.add_option("-u", '--upgrade', action="store_true", dest="upgrade",
|
|
default=False, help="Upgrade an installed server in offline mode")
|
|
parser.add_option("-p", '--plugins', action="store_true", dest="plugins",
|
|
default=False, help="Execute update plugins. Always true when applying all update files.")
|
|
parser.add_option("-W", '--password', action="store_true",
|
|
dest="ask_password",
|
|
help="Prompt for the Directory Manager password")
|
|
|
|
options, args = parser.parse_args()
|
|
safe_options = parser.get_safe_opts(options)
|
|
|
|
return safe_options, options, args
|
|
|
|
def get_dirman_password():
|
|
"""Prompt the user for the Directory Manager password and verify its
|
|
correctness.
|
|
"""
|
|
password = installutils.read_password("Directory Manager", confirm=False, validate=False)
|
|
|
|
return password
|
|
|
|
def main():
|
|
badsyntax = False
|
|
upgradefailed = False
|
|
run_plugins = False
|
|
|
|
safe_options, options, args = parse_options()
|
|
|
|
if os.getegid() == 0:
|
|
installutils.check_server_configuration()
|
|
elif not os.path.exists('/etc/ipa/default.conf'):
|
|
sys.exit("IPA is not configured on this system.")
|
|
|
|
dirman_password = ""
|
|
if options.password:
|
|
pw = ipautil.template_file(options.password, [])
|
|
dirman_password = pw.strip()
|
|
else:
|
|
if (options.ask_password or not options.ldapi) and not options.upgrade:
|
|
dirman_password = get_dirman_password()
|
|
if dirman_password is None:
|
|
sys.exit("\nDirectory Manager password required")
|
|
|
|
if options.upgrade:
|
|
standard_logging_setup('/var/log/ipaupgrade.log', verbose=True, debug=options.debug, filemode='a')
|
|
else:
|
|
standard_logging_setup(None, verbose=True, debug=options.debug)
|
|
|
|
cfg = dict (
|
|
in_server=True,
|
|
context='updates',
|
|
debug=options.debug,
|
|
)
|
|
api.bootstrap(**cfg)
|
|
api.finalize()
|
|
|
|
files = []
|
|
if len(args) > 0:
|
|
files = args
|
|
|
|
if len(files) < 1:
|
|
run_plugins = True
|
|
|
|
updates = None
|
|
if options.upgrade:
|
|
if os.getegid() != 0:
|
|
sys.exit('Upgrade can only be done as root')
|
|
root_logger.debug('%s was invoked with arguments %s and options: %s' % (sys.argv[0], args, safe_options))
|
|
realm = krbV.default_context().default_realm
|
|
upgrade = IPAUpgrade(realm, files, live_run=not options.test)
|
|
upgrade.create_instance()
|
|
modified = upgrade.modified
|
|
badsyntax = upgrade.badsyntax
|
|
upgradefailed = upgrade.upgradefailed
|
|
else:
|
|
ld = LDAPUpdate(dm_password=dirman_password, sub_dict={}, live_run=not options.test, ldapi=options.ldapi, plugins=options.plugins or run_plugins)
|
|
if len(files) < 1:
|
|
files = ld.get_all_files(UPDATES_DIR)
|
|
modified = ld.update(files)
|
|
|
|
if badsyntax:
|
|
root_logger.info('Bad syntax detected in upgrade file(s).')
|
|
print 'Bad syntax detected in upgrade file(s).'
|
|
return 1
|
|
elif upgradefailed:
|
|
root_logger.info('IPA upgrade failed.')
|
|
print 'IPA upgrade failed.'
|
|
return 1
|
|
elif modified and options.test:
|
|
root_logger.info('Update complete, changes to be made, test mode')
|
|
return 2
|
|
else:
|
|
root_logger.info('Update complete')
|
|
return 0
|
|
|
|
try:
|
|
if __name__ == "__main__":
|
|
sys.exit(main())
|
|
except BadSyntax, e:
|
|
print "There is a syntax error in this update file:"
|
|
print " %s" % e
|
|
sys.exit(1)
|
|
except RuntimeError, e:
|
|
sys.exit(e)
|
|
except SystemExit, e:
|
|
sys.exit(e)
|
|
except KeyboardInterrupt, e:
|
|
sys.exit(1)
|