diff options
author | Stephen Gallagher <sgallagh@redhat.com> | 2011-03-22 17:42:55 -0400 |
---|---|---|
committer | Stephen Gallagher <sgallagh@redhat.com> | 2011-03-23 04:58:50 -0400 |
commit | ea65835c09d4c930921b955416a91538da477639 (patch) | |
tree | 1fa0c5ed31ce691a1d298b7fd428c6b58d810655 /src/db/sysdb.c | |
parent | 72373c2f8dfce36ba7510356e786e08cf45c6677 (diff) | |
download | sssd-ea65835c09d4c930921b955416a91538da477639.tar.gz sssd-ea65835c09d4c930921b955416a91538da477639.tar.xz sssd-ea65835c09d4c930921b955416a91538da477639.zip |
Add sysdb_attrs_primary_name_list() routine
This routine will replace the use of sysdb_attrs_to_list() for any
case where we're trying to get the name of the entry. It's a
necessary precaution in case the name is multi-valued.
Diffstat (limited to 'src/db/sysdb.c')
-rw-r--r-- | src/db/sysdb.c | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/src/db/sysdb.c b/src/db/sysdb.c index 4f59d9d6a..7446aea90 100644 --- a/src/db/sysdb.c +++ b/src/db/sysdb.c @@ -2140,3 +2140,56 @@ done: talloc_free(tmpctx); return ret; } + +errno_t sysdb_attrs_primary_name_list(struct sysdb_ctx *sysdb, + TALLOC_CTX *mem_ctx, + struct sysdb_attrs **attr_list, + size_t attr_count, + const char *ldap_attr, + char ***name_list) +{ + errno_t ret; + size_t i, j; + char **list; + const char *name; + + /* Assume that every entry has a primary name */ + list = talloc_array(mem_ctx, char *, attr_count+1); + if (!list) { + return ENOMEM; + } + + j = 0; + for (i = 0; i < attr_count; i++) { + ret = sysdb_attrs_primary_name(sysdb, + attr_list[i], + ldap_attr, + &name); + if (ret != EOK) { + DEBUG(1, ("Could not determine primary name\n")); + /* Skip and continue. Don't advance 'j' */ + continue; + } + + list[j] = talloc_strdup(list, name); + if (!list[j]) { + ret = ENOMEM; + goto done; + } + + j++; + } + + /* NULL-terminate the list */ + list[j] = NULL; + + *name_list = list; + + ret = EOK; + +done: + if (ret != EOK) { + talloc_free(list); + } + return ret; +} |