From 204cfc89a076fd32bf34f2abb3f809304aaa88ab Mon Sep 17 00:00:00 2001 From: Simo Sorce Date: Thu, 19 Jul 2012 19:15:57 -0400 Subject: Add realm paramter to subdomain list This will be used later for setting domain_realm mappings in krb5.conf --- src/providers/ipa/ipa_subdomains.c | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'src/providers') diff --git a/src/providers/ipa/ipa_subdomains.c b/src/providers/ipa/ipa_subdomains.c index e842e24bf..8a49c6343 100644 --- a/src/providers/ipa/ipa_subdomains.c +++ b/src/providers/ipa/ipa_subdomains.c @@ -25,6 +25,7 @@ #include "providers/ldap/sdap_async.h" #include "providers/ipa/ipa_subdomains.h" #include "providers/ipa/ipa_common.h" +#include #define SUBDOMAINS_FILTER "objectclass=ipaNTTrustedDomain" #define MASTER_DOMAIN_FILTER "objectclass=ipaNTDomainAttrs" @@ -151,6 +152,22 @@ done: return ret; } +static char *name_to_realm(TALLOC_CTX *memctx, const char *name) +{ + char *realm; + char *p; + + realm = talloc_strdup(memctx, name); + if (!realm) { + return NULL; + } + for (p = realm; *p; p++) { + *p = toupper(*p); + } + + return realm; +} + static errno_t ipa_subdomains_parse_results(struct be_subdom_req *sd_data, size_t count, struct sysdb_attrs **reply) @@ -187,6 +204,16 @@ static errno_t ipa_subdomains_parse_results(struct be_subdom_req *sd_data, goto done; } + /* Add Realm as upper(domain name), this is generally always correct + * with AD domains */ + new_domain_list[c]->realm = name_to_realm(new_domain_list[c], + new_domain_list[c]->name); + if (!new_domain_list[c]->realm) { + DEBUG(SSSDBG_OP_FAILURE, ("talloc_strdup failed.\n")); + ret = ENOMEM; + goto done; + } + ret = sysdb_attrs_get_string(reply[c], IPA_FLATNAME, &value); if (ret == EOK) { new_domain_list[c]->flat_name = talloc_strdup(new_domain_list[c], -- cgit