mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-01-11 00:31:56 -06:00
99a40cbbe9
- drop unused dm_password and ldapi arguments - remove online feature that was never implemented - allow passing of api object that is used to populate substitution dictionary - simplify substitution dictionary updates - remove unused instances vars Signed-off-by: Christian Heimes <cheimes@redhat.com> Reviewed-By: Rob Crittenden <rcritten@redhat.com>
60 lines
1.5 KiB
Python
60 lines
1.5 KiB
Python
#
|
|
# Copyright (C) 2015 FreeIPA Contributors see COPYING for license
|
|
#
|
|
|
|
from __future__ import absolute_import
|
|
|
|
import logging
|
|
|
|
from ipalib import errors
|
|
from ipalib import Registry
|
|
from ipalib import Updater
|
|
from ipapython.dn import DN
|
|
from ipaserver.install import cainstance
|
|
from ipaserver.install import ldapupdate
|
|
from ipaplatform.paths import paths
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
register = Registry()
|
|
|
|
|
|
@register()
|
|
class update_ca_topology(Updater):
|
|
"""
|
|
Updates CA topology configuration entries
|
|
"""
|
|
|
|
def execute(self, **options):
|
|
|
|
ca = cainstance.CAInstance(self.api.env.realm)
|
|
if not ca.is_configured():
|
|
logger.debug("CA is not configured on this host")
|
|
return False, []
|
|
|
|
ld = ldapupdate.LDAPUpdate(api=self.api)
|
|
|
|
ld.update([paths.CA_TOPOLOGY_ULDIF])
|
|
|
|
ldap = self.api.Backend.ldap2
|
|
|
|
ca_replica_dn = DN(
|
|
('cn', 'replica'),
|
|
('cn', 'o=ipaca'),
|
|
('cn', 'mapping tree'),
|
|
('cn', 'config'))
|
|
|
|
check_interval_attr = 'nsds5replicabinddngroupcheckinterval'
|
|
default_check_interval = ['60']
|
|
|
|
try:
|
|
ca_replica_entry = ldap.get_entry(ca_replica_dn)
|
|
except errors.NotFound:
|
|
pass
|
|
else:
|
|
if check_interval_attr not in ca_replica_entry:
|
|
ca_replica_entry[check_interval_attr] = default_check_interval
|
|
ldap.update_entry(ca_replica_entry)
|
|
|
|
return False, []
|