2009-05-27 08:55:49 -05:00
|
|
|
# Authors:
|
|
|
|
# Rob Crittenden <rcritten@redhat.com>
|
|
|
|
# Pavel Zuna <pzuna@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; version 2 only
|
|
|
|
#
|
|
|
|
# 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, write to the Free Software
|
|
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
"""
|
|
|
|
Hosts/Machines (Identity)
|
|
|
|
"""
|
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
import platform
|
|
|
|
import os
|
|
|
|
import sys
|
2009-05-27 08:55:49 -05:00
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
from ipalib import api, errors, util
|
|
|
|
from ipalib import Str, Flag
|
|
|
|
from ipalib.plugins.baseldap import *
|
|
|
|
from ipalib.plugins.service import split_principal
|
2009-12-09 10:09:53 -06:00
|
|
|
from ipalib import _, ngettext
|
2009-05-27 08:55:49 -05:00
|
|
|
|
|
|
|
|
|
|
|
def validate_host(ugettext, fqdn):
|
|
|
|
"""
|
|
|
|
Require at least one dot in the hostname (to support localhost.localdomain)
|
|
|
|
"""
|
|
|
|
if fqdn.index('.') == -1:
|
|
|
|
return 'Fully-qualified hostname required'
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
class host(LDAPObject):
|
2009-05-27 08:55:49 -05:00
|
|
|
"""
|
|
|
|
Host object.
|
|
|
|
"""
|
2009-09-15 07:01:58 -05:00
|
|
|
container_dn = api.env.container_host
|
|
|
|
object_name = 'host'
|
|
|
|
object_name_plural = 'hosts'
|
|
|
|
object_class = ['ipaobject', 'nshost', 'ipahost', 'pkiuser']
|
|
|
|
# object_class_config = 'ipahostobjectclasses'
|
|
|
|
default_attributes = [
|
|
|
|
'fqdn', 'description', 'localityname', 'nshostlocation',
|
|
|
|
'nshardwareplatform', 'nsosversion'
|
|
|
|
]
|
|
|
|
uuid_attribute = 'ipauniqueid'
|
|
|
|
attribute_names = {
|
|
|
|
'cn': 'name',
|
|
|
|
'fqdn': 'hostname',
|
|
|
|
'localityname': 'locality',
|
|
|
|
'nshostlocation': 'location',
|
|
|
|
'nshardwareplatform': 'platform',
|
|
|
|
'nsosversion': 'operating system',
|
|
|
|
'serverhostname': 'server hostname',
|
|
|
|
'enrolledby user': 'enrolled by',
|
|
|
|
'krbprincipalname': 'kerberos principal',
|
|
|
|
}
|
|
|
|
attribute_members = {
|
|
|
|
'enrolledby': ['user'],
|
|
|
|
}
|
|
|
|
|
2009-05-27 08:55:49 -05:00
|
|
|
takes_params = (
|
|
|
|
Str('fqdn', validate_host,
|
|
|
|
cli_name='hostname',
|
2009-12-09 10:09:53 -06:00
|
|
|
label='Hostname',
|
2009-05-27 08:55:49 -05:00
|
|
|
primary_key=True,
|
|
|
|
normalizer=lambda value: value.lower(),
|
|
|
|
),
|
|
|
|
Str('description?',
|
2009-09-15 07:01:58 -05:00
|
|
|
cli_name='desc',
|
2009-12-09 10:09:53 -06:00
|
|
|
label='Description',
|
2009-05-27 08:55:49 -05:00
|
|
|
doc='Description of the host',
|
|
|
|
),
|
|
|
|
Str('localityname?',
|
|
|
|
cli_name='locality',
|
2009-12-09 10:09:53 -06:00
|
|
|
label='Locality',
|
2009-05-27 08:55:49 -05:00
|
|
|
doc='Locality of the host (Baltimore, MD)',
|
|
|
|
),
|
|
|
|
Str('nshostlocation?',
|
|
|
|
cli_name='location',
|
2009-12-09 10:09:53 -06:00
|
|
|
label='Location',
|
2009-05-27 08:55:49 -05:00
|
|
|
doc='Location of the host (e.g. Lab 2)',
|
|
|
|
),
|
|
|
|
Str('nshardwareplatform?',
|
|
|
|
cli_name='platform',
|
2009-12-09 10:09:53 -06:00
|
|
|
label='Platform',
|
2009-05-27 08:55:49 -05:00
|
|
|
doc='Hardware platform of the host (e.g. Lenovo T61)',
|
|
|
|
),
|
|
|
|
Str('nsosversion?',
|
|
|
|
cli_name='os',
|
2009-12-09 10:09:53 -06:00
|
|
|
label='Operating system',
|
2009-05-27 08:55:49 -05:00
|
|
|
doc='Operating System and version of the host (e.g. Fedora 9)',
|
|
|
|
),
|
|
|
|
Str('userpassword?',
|
|
|
|
cli_name='password',
|
2009-12-09 10:09:53 -06:00
|
|
|
label='User password',
|
2009-05-27 08:55:49 -05:00
|
|
|
doc='Password used in bulk enrollment',
|
|
|
|
),
|
|
|
|
)
|
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
def get_dn(self, *keys, **options):
|
|
|
|
if keys[-1].endswith('.'):
|
|
|
|
keys[-1] = keys[-1][:-1]
|
|
|
|
dn = super(host, self).get_dn(*keys, **options)
|
|
|
|
try:
|
|
|
|
self.backend.get_entry(dn, [''])
|
|
|
|
except errors.NotFound:
|
|
|
|
try:
|
|
|
|
(dn, entry_attrs) = self.backend.find_entry_by_attr(
|
|
|
|
'serverhostname', keys[-1], self.object_class, [''],
|
|
|
|
self.container_dn
|
|
|
|
)
|
|
|
|
except errors.NotFound:
|
|
|
|
pass
|
|
|
|
return dn
|
|
|
|
|
2009-06-16 07:38:27 -05:00
|
|
|
api.register(host)
|
2009-05-27 08:55:49 -05:00
|
|
|
|
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
class host_add(LDAPCreate):
|
2009-05-27 08:55:49 -05:00
|
|
|
"""
|
|
|
|
Create new host.
|
|
|
|
"""
|
2009-12-09 10:09:53 -06:00
|
|
|
|
|
|
|
msg_summary = _('Added host "%(value)s"')
|
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
def pre_callback(self, ldap, dn, entry_attrs, *keys, **options):
|
|
|
|
entry_attrs['cn'] = keys[-1]
|
|
|
|
entry_attrs['serverhostname'] = keys[-1].split('.', 1)[0]
|
|
|
|
# FIXME: do DNS lookup to ensure host exists
|
2009-05-27 08:55:49 -05:00
|
|
|
if 'userpassword' not in entry_attrs:
|
|
|
|
entry_attrs['krbprincipalname'] = 'host/%s@%s' % (
|
2009-09-15 07:01:58 -05:00
|
|
|
keys[-1], self.api.env.realm
|
2009-05-27 08:55:49 -05:00
|
|
|
)
|
|
|
|
if 'krbprincipalaux' not in entry_attrs['objectclass']:
|
|
|
|
entry_attrs['objectclass'].append('krbprincipalaux')
|
|
|
|
entry_attrs['objectclass'].append('krbprincipal')
|
|
|
|
elif 'krbprincipalaux' in entry_attrs['objectclass']:
|
|
|
|
entry_attrs['objectclass'].remove('krbprincipalaux')
|
2009-09-15 07:01:58 -05:00
|
|
|
return dn
|
2009-05-27 08:55:49 -05:00
|
|
|
|
2009-06-16 09:51:44 -05:00
|
|
|
api.register(host_add)
|
2009-05-27 08:55:49 -05:00
|
|
|
|
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
class host_del(LDAPDelete):
|
2009-05-27 08:55:49 -05:00
|
|
|
"""
|
|
|
|
Delete host.
|
|
|
|
"""
|
2009-12-09 10:09:53 -06:00
|
|
|
|
|
|
|
msg_summary = _('Deleted host "%(value)s"')
|
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
def pre_callback(self, ldap, dn, *keys, **options):
|
2009-05-27 08:55:49 -05:00
|
|
|
# Remove all service records for this host
|
2009-09-15 07:01:58 -05:00
|
|
|
truncated = True
|
|
|
|
while truncated:
|
|
|
|
try:
|
2009-12-09 10:09:53 -06:00
|
|
|
ret = api.Command['service_find'](keys[-1])
|
|
|
|
truncated = ret['truncated']
|
|
|
|
services = ret['result']
|
2009-09-15 07:01:58 -05:00
|
|
|
except errors.NotFound:
|
|
|
|
break
|
|
|
|
else:
|
2009-12-09 10:09:53 -06:00
|
|
|
for entry_attrs in services:
|
2009-09-15 07:01:58 -05:00
|
|
|
principal = entry_attrs['krbprincipalname'][0]
|
|
|
|
(service, hostname, realm) = split_principal(principal)
|
|
|
|
if hostname.lower() == keys[-1]:
|
|
|
|
api.Command['service_del'](principal)
|
|
|
|
return dn
|
2009-05-27 08:55:49 -05:00
|
|
|
|
2009-06-16 09:51:44 -05:00
|
|
|
api.register(host_del)
|
2009-05-27 08:55:49 -05:00
|
|
|
|
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
class host_mod(LDAPUpdate):
|
2009-05-27 08:55:49 -05:00
|
|
|
"""
|
|
|
|
Modify host.
|
|
|
|
"""
|
2009-12-09 10:09:53 -06:00
|
|
|
|
|
|
|
msg_summary = _('Modified host "%(value)s"')
|
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
takes_options = LDAPUpdate.takes_options + (
|
2009-09-14 16:04:08 -05:00
|
|
|
Str('krbprincipalname?',
|
|
|
|
cli_name='principalname',
|
|
|
|
doc='Kerberos principal name for this host',
|
2009-09-15 07:01:58 -05:00
|
|
|
attribute=True,
|
2009-09-14 16:04:08 -05:00
|
|
|
),
|
|
|
|
)
|
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
def pre_callback(self, ldap, dn, entry_attrs, attrs_list, *keys, **options):
|
2009-09-14 16:04:08 -05:00
|
|
|
# Once a principal name is set it cannot be changed
|
|
|
|
if 'krbprincipalname' in entry_attrs:
|
2009-09-15 07:01:58 -05:00
|
|
|
(dn, entry_attrs_old) = ldap.get_entry(
|
|
|
|
dn, ['objectclass', 'krbprincipalname']
|
|
|
|
)
|
|
|
|
if 'krbprincipalname' in entry_attrs_old:
|
|
|
|
msg = 'Principal name already set, it is unchangeable.'
|
|
|
|
raise errors.ACIError(info=msg)
|
|
|
|
obj_classes = entry_attrs_old['objectclass']
|
|
|
|
if 'krbprincipalaux' not in obj_classes:
|
|
|
|
obj_classes.append('krbprincipalaux')
|
|
|
|
entry_attrs['objectclass'] = obj_classes
|
|
|
|
return dn
|
2009-05-27 08:55:49 -05:00
|
|
|
|
2009-06-16 07:38:27 -05:00
|
|
|
api.register(host_mod)
|
2009-05-27 08:55:49 -05:00
|
|
|
|
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
class host_find(LDAPSearch):
|
2009-05-27 08:55:49 -05:00
|
|
|
"""
|
|
|
|
Search for hosts.
|
|
|
|
"""
|
|
|
|
|
2009-12-09 10:09:53 -06:00
|
|
|
msg_summary = ngettext(
|
|
|
|
'%(count)d host matched', '%(count)d hosts matched'
|
|
|
|
)
|
|
|
|
|
2009-06-16 07:38:27 -05:00
|
|
|
api.register(host_find)
|
2009-05-27 08:55:49 -05:00
|
|
|
|
|
|
|
|
2009-09-15 07:01:58 -05:00
|
|
|
class host_show(LDAPRetrieve):
|
2009-05-27 08:55:49 -05:00
|
|
|
"""
|
|
|
|
Display host.
|
|
|
|
"""
|
|
|
|
|
2009-06-16 07:38:27 -05:00
|
|
|
api.register(host_show)
|