2014-10-16 09:03:46 -05:00
|
|
|
#
|
|
|
|
# Copyright (C) 2014 FreeIPA Contributors see COPYING for license
|
|
|
|
#
|
|
|
|
|
2018-04-05 02:21:16 -05:00
|
|
|
from __future__ import absolute_import
|
|
|
|
|
2017-05-24 09:35:07 -05:00
|
|
|
import logging
|
2014-10-16 09:03:46 -05:00
|
|
|
import os
|
|
|
|
import pwd
|
|
|
|
import grp
|
|
|
|
|
|
|
|
import ldap
|
|
|
|
|
2015-07-31 03:15:01 -05:00
|
|
|
from ipaserver.install import service
|
|
|
|
from ipaserver.install import installutils
|
2014-10-16 09:03:46 -05:00
|
|
|
from ipapython.dn import DN
|
2016-11-03 10:38:06 -05:00
|
|
|
from ipapython import ipautil
|
2016-03-18 05:22:33 -05:00
|
|
|
from ipaplatform.constants import constants
|
2014-10-16 09:03:46 -05:00
|
|
|
from ipaplatform.paths import paths
|
|
|
|
from ipaplatform import services
|
2015-05-13 07:45:32 -05:00
|
|
|
from ipalib import errors, api
|
2014-10-16 09:03:46 -05:00
|
|
|
|
2017-05-24 09:35:07 -05:00
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2014-10-16 09:03:46 -05:00
|
|
|
|
|
|
|
class ODSExporterInstance(service.Service):
|
2016-10-06 10:35:04 -05:00
|
|
|
def __init__(self, fstore=None):
|
2016-11-03 10:38:06 -05:00
|
|
|
super(ODSExporterInstance, self).__init__(
|
|
|
|
"ipa-ods-exporter",
|
|
|
|
service_desc="IPA OpenDNSSEC exporter daemon",
|
2016-11-03 11:54:14 -05:00
|
|
|
fstore=fstore,
|
|
|
|
keytab=paths.IPA_ODS_EXPORTER_KEYTAB,
|
|
|
|
service_prefix=u'ipa-ods-exporter'
|
2014-10-16 09:03:46 -05:00
|
|
|
)
|
|
|
|
self.ods_uid = None
|
|
|
|
self.ods_gid = None
|
|
|
|
self.enable_if_exists = False
|
|
|
|
|
|
|
|
suffix = ipautil.dn_attribute_property('_suffix')
|
|
|
|
|
|
|
|
def create_instance(self, fqdn, realm_name):
|
|
|
|
self.backup_state("enabled", self.is_enabled())
|
|
|
|
self.backup_state("running", self.is_running())
|
|
|
|
self.fqdn = fqdn
|
|
|
|
self.realm = realm_name
|
|
|
|
self.suffix = ipautil.realm_to_suffix(self.realm)
|
|
|
|
|
|
|
|
try:
|
|
|
|
self.stop()
|
2016-03-11 12:51:07 -06:00
|
|
|
except Exception:
|
2014-10-16 09:03:46 -05:00
|
|
|
pass
|
|
|
|
|
|
|
|
# checking status step must be first
|
|
|
|
self.step("checking status", self.__check_dnssec_status)
|
|
|
|
self.step("setting up DNS Key Exporter", self.__setup_key_exporter)
|
|
|
|
self.step("setting up kerberos principal", self.__setup_principal)
|
|
|
|
self.step("disabling default signer daemon", self.__disable_signerd)
|
|
|
|
self.step("starting DNS Key Exporter", self.__start)
|
|
|
|
self.step("configuring DNS Key Exporter to start on boot", self.__enable)
|
|
|
|
self.start_creation()
|
|
|
|
|
|
|
|
def __check_dnssec_status(self):
|
|
|
|
try:
|
2016-03-18 05:22:33 -05:00
|
|
|
self.ods_uid = pwd.getpwnam(constants.ODS_USER).pw_uid
|
2014-10-16 09:03:46 -05:00
|
|
|
except KeyError:
|
|
|
|
raise RuntimeError("OpenDNSSEC UID not found")
|
|
|
|
|
|
|
|
try:
|
2016-03-18 05:22:33 -05:00
|
|
|
self.ods_gid = grp.getgrnam(constants.ODS_GROUP).gr_gid
|
2014-10-16 09:03:46 -05:00
|
|
|
except KeyError:
|
|
|
|
raise RuntimeError("OpenDNSSEC GID not found")
|
|
|
|
|
|
|
|
def __enable(self):
|
|
|
|
|
|
|
|
try:
|
2016-10-06 10:35:04 -05:00
|
|
|
self.ldap_enable('DNSKeyExporter', self.fqdn, None,
|
2014-10-16 09:03:46 -05:00
|
|
|
self.suffix)
|
|
|
|
except errors.DuplicateEntry:
|
2017-05-24 09:35:07 -05:00
|
|
|
logger.error("DNSKeyExporter service already exists")
|
2014-10-16 09:03:46 -05:00
|
|
|
|
|
|
|
def __setup_key_exporter(self):
|
2015-08-13 08:03:05 -05:00
|
|
|
installutils.set_directive(paths.SYSCONFIG_IPA_ODS_EXPORTER,
|
2014-10-16 09:03:46 -05:00
|
|
|
'SOFTHSM2_CONF',
|
|
|
|
paths.DNSSEC_SOFTHSM2_CONF,
|
|
|
|
quotes=False, separator='=')
|
|
|
|
|
|
|
|
def __setup_principal(self):
|
|
|
|
assert self.ods_uid is not None
|
2015-09-01 09:17:16 -05:00
|
|
|
|
2016-11-03 11:54:14 -05:00
|
|
|
for f in [paths.IPA_ODS_EXPORTER_CCACHE, self.keytab]:
|
2015-09-01 09:17:16 -05:00
|
|
|
try:
|
|
|
|
os.remove(f)
|
|
|
|
except OSError:
|
|
|
|
pass
|
|
|
|
|
2016-11-03 11:54:14 -05:00
|
|
|
installutils.kadmin_addprinc(self.principal)
|
2014-10-16 09:03:46 -05:00
|
|
|
|
|
|
|
# Store the keytab on disk
|
2016-11-03 11:54:14 -05:00
|
|
|
installutils.create_keytab(paths.IPA_ODS_EXPORTER_KEYTAB,
|
|
|
|
self.principal)
|
|
|
|
p = self.move_service(self.principal)
|
2014-10-16 09:03:46 -05:00
|
|
|
if p is None:
|
|
|
|
# the service has already been moved, perhaps we're doing a DNS reinstall
|
|
|
|
dns_exporter_principal_dn = DN(
|
2016-11-03 11:54:14 -05:00
|
|
|
('krbprincipalname', self.principal),
|
2014-10-16 09:03:46 -05:00
|
|
|
('cn', 'services'), ('cn', 'accounts'), self.suffix)
|
|
|
|
else:
|
|
|
|
dns_exporter_principal_dn = p
|
|
|
|
|
|
|
|
# Make sure access is strictly reserved to the ods user
|
2016-11-03 11:54:14 -05:00
|
|
|
os.chmod(self.keytab, 0o440)
|
|
|
|
os.chown(self.keytab, 0, self.ods_gid)
|
2014-10-16 09:03:46 -05:00
|
|
|
|
|
|
|
dns_group = DN(('cn', 'DNS Servers'), ('cn', 'privileges'),
|
|
|
|
('cn', 'pbac'), self.suffix)
|
|
|
|
mod = [(ldap.MOD_ADD, 'member', dns_exporter_principal_dn)]
|
|
|
|
|
|
|
|
try:
|
2016-11-09 05:53:14 -06:00
|
|
|
api.Backend.ldap2.modify_s(dns_group, mod)
|
2014-10-16 09:03:46 -05:00
|
|
|
except ldap.TYPE_OR_VALUE_EXISTS:
|
|
|
|
pass
|
2015-07-30 09:49:29 -05:00
|
|
|
except Exception as e:
|
2017-05-24 09:35:07 -05:00
|
|
|
logger.critical("Could not modify principal's %s entry: %s",
|
|
|
|
dns_exporter_principal_dn, str(e))
|
2014-10-16 09:03:46 -05:00
|
|
|
raise
|
|
|
|
|
|
|
|
# limit-free connection
|
|
|
|
|
|
|
|
mod = [(ldap.MOD_REPLACE, 'nsTimeLimit', '-1'),
|
|
|
|
(ldap.MOD_REPLACE, 'nsSizeLimit', '-1'),
|
|
|
|
(ldap.MOD_REPLACE, 'nsIdleTimeout', '-1'),
|
|
|
|
(ldap.MOD_REPLACE, 'nsLookThroughLimit', '-1')]
|
|
|
|
try:
|
2016-11-09 05:53:14 -06:00
|
|
|
api.Backend.ldap2.modify_s(dns_exporter_principal_dn, mod)
|
2015-07-30 09:49:29 -05:00
|
|
|
except Exception as e:
|
2017-05-24 09:35:07 -05:00
|
|
|
logger.critical("Could not set principal's %s LDAP limits: %s",
|
|
|
|
dns_exporter_principal_dn, str(e))
|
2014-10-16 09:03:46 -05:00
|
|
|
raise
|
|
|
|
|
|
|
|
def __disable_signerd(self):
|
|
|
|
signerd_service = services.knownservices.ods_signerd
|
2015-10-22 10:05:27 -05:00
|
|
|
if self.get_state("singerd_running") is None:
|
|
|
|
self.backup_state("singerd_running", signerd_service.is_running())
|
|
|
|
if self.get_state("singerd_enabled") is None:
|
|
|
|
self.backup_state("singerd_enabled", signerd_service.is_enabled())
|
2014-10-16 09:03:46 -05:00
|
|
|
|
|
|
|
# disable default opendnssec signer daemon
|
|
|
|
signerd_service.stop()
|
|
|
|
signerd_service.mask()
|
|
|
|
|
|
|
|
def __start(self):
|
|
|
|
self.start()
|
|
|
|
|
2015-05-13 07:45:32 -05:00
|
|
|
def remove_service(self):
|
|
|
|
try:
|
2016-11-03 11:54:14 -05:00
|
|
|
api.Command.service_del(self.principal)
|
2015-05-13 07:45:32 -05:00
|
|
|
except errors.NotFound:
|
|
|
|
pass
|
|
|
|
|
2014-10-16 09:03:46 -05:00
|
|
|
def uninstall(self):
|
|
|
|
if not self.is_configured():
|
|
|
|
return
|
|
|
|
|
|
|
|
self.print_msg("Unconfiguring %s" % self.service_name)
|
|
|
|
|
2015-01-27 04:04:03 -06:00
|
|
|
# just eat states
|
|
|
|
self.restore_state("running")
|
|
|
|
self.restore_state("enabled")
|
2014-10-16 09:03:46 -05:00
|
|
|
|
2015-01-27 04:04:03 -06:00
|
|
|
# stop and disable service (IPA service, we do not need it anymore)
|
|
|
|
self.disable()
|
|
|
|
self.stop()
|
2014-10-16 09:03:46 -05:00
|
|
|
|
|
|
|
# restore state of dnssec default signer daemon
|
|
|
|
signerd_enabled = self.restore_state("singerd_enabled")
|
2015-11-02 11:33:05 -06:00
|
|
|
signerd_running = self.restore_state("singerd_running")
|
2014-10-16 09:03:46 -05:00
|
|
|
signerd_service = services.knownservices.ods_signerd
|
|
|
|
|
|
|
|
signerd_service.unmask()
|
|
|
|
|
|
|
|
# service was stopped and disabled by setup
|
|
|
|
if signerd_enabled:
|
|
|
|
signerd_service.enable()
|
|
|
|
|
|
|
|
if signerd_running:
|
|
|
|
signerd_service.start()
|
2015-10-09 11:08:38 -05:00
|
|
|
|
2016-11-03 11:54:14 -05:00
|
|
|
installutils.remove_keytab(self.keytab)
|
2015-10-09 11:08:38 -05:00
|
|
|
installutils.remove_ccache(ccache_path=paths.IPA_ODS_EXPORTER_CCACHE)
|