summaryrefslogtreecommitdiffstats
path: root/ipalib/plugins/realmdomains.py
diff options
context:
space:
mode:
authorAna Krivokapic <akrivoka@redhat.com>2013-02-12 10:50:00 -0500
committerAlexander Bokovoy <abokovoy@redhat.com>2013-02-19 14:15:46 +0200
commit3253a305416c963fcdc2670caa2c22c167ccc0d2 (patch)
tree4ba1ebb4c40f877c58bdd7b47a58f36196d12360 /ipalib/plugins/realmdomains.py
parent8fcc8bc8d50d266b050c136de7a441d59e363d1b (diff)
downloadfreeipa-3253a305416c963fcdc2670caa2c22c167ccc0d2.tar.gz
freeipa-3253a305416c963fcdc2670caa2c22c167ccc0d2.tar.xz
freeipa-3253a305416c963fcdc2670caa2c22c167ccc0d2.zip
Add list of domains associated to our realm to cn=etc
Add new LDAP container to store the list of domains associated with IPA realm. Add two new ipa commands (ipa realmdomains-show and ipa realmdomains-mod) to allow manipulation of the list of realm domains. Unit test file covering these new commands was added. https://fedorahosted.org/freeipa/ticket/2945
Diffstat (limited to 'ipalib/plugins/realmdomains.py')
-rw-r--r--ipalib/plugins/realmdomains.py141
1 files changed, 141 insertions, 0 deletions
diff --git a/ipalib/plugins/realmdomains.py b/ipalib/plugins/realmdomains.py
new file mode 100644
index 000000000..99ab8798b
--- /dev/null
+++ b/ipalib/plugins/realmdomains.py
@@ -0,0 +1,141 @@
+# Authors:
+# Ana Krivokapic <akrivoka@redhat.com>
+#
+# Copyright (C) 2013 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/>.
+
+from ipalib import api, errors
+from ipalib import Str, Flag
+from ipalib import _
+from ipalib.plugins.baseldap import LDAPObject, LDAPUpdate, LDAPRetrieve
+from ipalib.plugins.dns import _domain_name_validator
+from ipalib.util import has_soa_or_ns_record
+from ipapython.dn import DN
+from ipapython.ipautil import get_domain_name
+
+
+__doc__ = _("""
+Realm domains
+
+Manage the list of domains associated with IPA realm.
+
+EXAMPLES:
+
+ Display the current list of realm domains:
+ ipa realmdomains-show
+
+ Replace the list of realm domains:
+ ipa realmdomains-mod --domain=example.com
+ ipa realmdomains-mod --domain={example1.com,example2.com,example3.com}
+
+ Add a domain to the list of realm domains:
+ ipa realmdomains-mod --add-domain=newdomain.com
+
+ Delete a domain from the list of realm domains:
+ ipa realmdomains-mod --del-domain=olddomain.com
+""")
+
+
+class realmdomains(LDAPObject):
+ """
+ List of domains associated with IPA realm.
+ """
+ container_dn = api.env.container_realm_domains
+ object_name = _('Realm domains')
+ search_attributes = ['associateddomain']
+ default_attributes = ['associateddomain']
+
+ label = _('Realm Domains')
+ label_singular = _('Realm Domains')
+
+ takes_params = (
+ Str('associateddomain+',
+ _domain_name_validator,
+ cli_name='domain',
+ label=_('Domain'),
+ ),
+ Str('add_domain?',
+ _domain_name_validator,
+ cli_name='add_domain',
+ label=_('Add domain'),
+ ),
+ Str('del_domain?',
+ _domain_name_validator,
+ cli_name='del_domain',
+ label=_('Delete domain'),
+ ),
+ )
+
+api.register(realmdomains)
+
+
+class realmdomains_mod(LDAPUpdate):
+ __doc__ = _('Modify realm domains.')
+
+ takes_options = LDAPUpdate.takes_options + (
+ Flag('force',
+ label=_('Force'),
+ doc=_('Force adding domain even if not in DNS'),
+ ),
+ )
+
+ def pre_callback(self, ldap, dn, entry_attrs, attrs_list, *keys, **options):
+ assert isinstance(dn, DN)
+ associateddomain = entry_attrs.get('associateddomain')
+ add_domain = entry_attrs.get('add_domain')
+ del_domain = entry_attrs.get('del_domain')
+ force = options.get('force')
+
+ if associateddomain:
+ if add_domain or del_domain:
+ raise errors.MutuallyExclusiveError(reason=_("you cannot specify the --domain option together with --add-domain or --del-domain"))
+ if get_domain_name() not in associateddomain:
+ raise errors.ValidationError(name='domain', error=_("cannot delete domain of IPA server"))
+ if not force:
+ for d in associateddomain:
+ if not has_soa_or_ns_record(d):
+ raise errors.ValidationError(name='domain', error=_("no SOA or NS records found for domain %s" % d))
+ return dn
+
+ # If --add-domain or --del-domain options were provided, read
+ # the curent list from LDAP, modify it, and write the changes back
+ domains = ldap.get_entry(dn)[1]['associateddomain']
+
+ if add_domain:
+ if not force and not has_soa_or_ns_record(add_domain):
+ raise errors.ValidationError(name='add_domain', error=_("no SOA or NS records found for domain %s" % add_domain))
+ del entry_attrs['add_domain']
+ domains.append(add_domain)
+
+ if del_domain:
+ if del_domain == get_domain_name():
+ raise errors.ValidationError(name='del_domain', error=_("cannot delete domain of IPA server"))
+ del entry_attrs['del_domain']
+ try:
+ domains.remove(del_domain)
+ except ValueError:
+ raise errors.AttrValueNotFound(attr='associateddomain', value=del_domain)
+
+ entry_attrs['associateddomain'] = domains
+ return dn
+
+api.register(realmdomains_mod)
+
+
+class realmdomains_show(LDAPRetrieve):
+ __doc__ = _('Display the list of realm domains.')
+
+api.register(realmdomains_show)