2016-11-09 05:49:25 -06:00
|
|
|
#
|
|
|
|
# Copyright (C) 2015 FreeIPA Contributors see COPYING for license
|
|
|
|
#
|
|
|
|
|
2018-04-05 02:21:16 -05:00
|
|
|
from __future__ import absolute_import
|
|
|
|
|
2016-11-09 05:49:25 -06:00
|
|
|
from ipapython.install import cli
|
2017-03-08 02:03:13 -06:00
|
|
|
from ipapython.install.core import knob, extend_knob
|
2016-11-09 05:49:25 -06:00
|
|
|
from ipaplatform.paths import paths
|
|
|
|
from ipaserver.install.server import ServerReplicaInstall
|
|
|
|
|
|
|
|
|
|
|
|
class CompatServerReplicaInstall(ServerReplicaInstall):
|
|
|
|
ca_cert_files = None
|
|
|
|
all_ip_addresses = False
|
|
|
|
no_wait_for_dns = True
|
|
|
|
nisdomain = None
|
|
|
|
no_nisdomain = False
|
|
|
|
no_sudo = False
|
|
|
|
request_cert = False
|
|
|
|
ca_file = None
|
|
|
|
zonemgr = None
|
2018-09-10 08:16:51 -05:00
|
|
|
replica_install = True # Used in ServerInstallInterface.__init__
|
2016-11-09 05:49:25 -06:00
|
|
|
|
|
|
|
auto_password = knob(
|
|
|
|
str, None,
|
|
|
|
description="Password to join the IPA realm. Assumes bulk password "
|
|
|
|
"unless principal is also set. (domain level 1+) "
|
|
|
|
"Directory Manager (existing master) password. (domain "
|
|
|
|
"level 0)",
|
|
|
|
sensitive=True,
|
|
|
|
cli_names=['--password', '-p'],
|
|
|
|
cli_metavar='PASSWORD',
|
|
|
|
)
|
|
|
|
|
|
|
|
@property
|
|
|
|
def dm_password(self):
|
|
|
|
try:
|
|
|
|
return self.__dm_password
|
|
|
|
except AttributeError:
|
|
|
|
pass
|
|
|
|
|
|
|
|
return super(CompatServerReplicaInstall, self).dm_password
|
|
|
|
|
|
|
|
@dm_password.setter
|
|
|
|
def dm_password(self, value):
|
|
|
|
self.__dm_password = value
|
|
|
|
|
2017-03-08 02:03:13 -06:00
|
|
|
ip_addresses = extend_knob(
|
|
|
|
ServerReplicaInstall.ip_addresses, # pylint: disable=no-member
|
2016-11-09 05:49:25 -06:00
|
|
|
description="Replica server IP Address. This option can be used "
|
|
|
|
"multiple times",
|
|
|
|
)
|
|
|
|
|
2017-03-08 02:03:13 -06:00
|
|
|
admin_password = (
|
|
|
|
ServerReplicaInstall.admin_password # pylint: disable=no-member
|
|
|
|
)
|
|
|
|
admin_password = extend_knob(
|
|
|
|
admin_password,
|
|
|
|
cli_names=list(admin_password.cli_names) + ['-w'],
|
2016-11-09 05:49:25 -06:00
|
|
|
)
|
|
|
|
|
|
|
|
@admin_password.default_getter
|
|
|
|
def admin_password(self):
|
2018-09-10 08:16:51 -05:00
|
|
|
if self.principal:
|
2016-11-09 05:49:25 -06:00
|
|
|
return self.auto_password
|
|
|
|
|
|
|
|
return super(CompatServerReplicaInstall, self).admin_password
|
|
|
|
|
|
|
|
@property
|
|
|
|
def host_password(self):
|
|
|
|
admin_password = (
|
|
|
|
super(CompatServerReplicaInstall, self).admin_password)
|
2018-09-10 08:16:51 -05:00
|
|
|
if not self.principal or admin_password:
|
2016-11-09 05:49:25 -06:00
|
|
|
return self.auto_password
|
|
|
|
|
|
|
|
return super(CompatServerReplicaInstall, self).host_password
|
|
|
|
|
|
|
|
|
|
|
|
ReplicaInstall = cli.install_tool(
|
|
|
|
CompatServerReplicaInstall,
|
|
|
|
command_name='ipa-replica-install',
|
|
|
|
log_file_name=paths.IPAREPLICA_INSTALL_LOG,
|
|
|
|
debug_option=True,
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def run():
|
|
|
|
ReplicaInstall.run_cli()
|