diff options
author | Pavel Březina <pbrezina@redhat.com> | 2013-09-02 15:15:59 +0200 |
---|---|---|
committer | Jakub Hrozek <jhrozek@redhat.com> | 2013-09-17 16:13:32 +0200 |
commit | 1110ac9c5739ca19dd71917ddb4012110ff64469 (patch) | |
tree | 9fdf4e43bce83b0de354214988cebff60dd64fc1 /src | |
parent | c4a1a6707426f97537190a32895922507844d547 (diff) | |
download | sssd-1110ac9c5739ca19dd71917ddb4012110ff64469.tar.gz sssd-1110ac9c5739ca19dd71917ddb4012110ff64469.tar.xz sssd-1110ac9c5739ca19dd71917ddb4012110ff64469.zip |
util: add find_subdomain_by_sid()
This function takes domain SID (doesn't have the last component)
or object SID (have all components) and returns subdomain.
The subdomain is found by comparing domain->domainid with the SID.
E.g.
domain SID: S-1-5-21-3940105347-3434501867-2690409756
object SID: S-1-5-21-3940105347-3434501867-2690409756-513
Resolves:
https://fedorahosted.org/sssd/ticket/2034
Diffstat (limited to 'src')
-rw-r--r-- | src/util/domain_info_utils.c | 33 | ||||
-rw-r--r-- | src/util/util.h | 2 |
2 files changed, 35 insertions, 0 deletions
diff --git a/src/util/domain_info_utils.c b/src/util/domain_info_utils.c index 8b03e9a53..f9d9057a8 100644 --- a/src/util/domain_info_utils.c +++ b/src/util/domain_info_utils.c @@ -95,6 +95,39 @@ struct sss_domain_info *find_subdomain_by_name(struct sss_domain_info *domain, return NULL; } +struct sss_domain_info *find_subdomain_by_sid(struct sss_domain_info *domain, + const char *sid) +{ + struct sss_domain_info *dom = domain; + size_t sid_len = strlen(sid); + size_t dom_sid_len; + + while (dom && dom->disabled) { + dom = get_next_domain(dom, true); + } + + while (dom) { + dom_sid_len = strlen(dom->domain_id); + + if (strncasecmp(dom->domain_id, sid, dom_sid_len) == 0) { + if (dom_sid_len == sid_len) { + /* sid is domain sid */ + return dom; + } + + /* sid is object sid, check if domain sid is align with + * sid first subauthority component */ + if (sid[dom_sid_len] == '-') { + return dom; + } + } + + dom = get_next_domain(dom, true); + } + + return NULL; +} + struct sss_domain_info *new_subdomain(TALLOC_CTX *mem_ctx, struct sss_domain_info *parent, const char *name, diff --git a/src/util/util.h b/src/util/util.h index cae4a49ab..3a1da2dcf 100644 --- a/src/util/util.h +++ b/src/util/util.h @@ -546,6 +546,8 @@ struct sss_domain_info *get_next_domain(struct sss_domain_info *domain, struct sss_domain_info *find_subdomain_by_name(struct sss_domain_info *domain, const char *name, bool match_any); +struct sss_domain_info *find_subdomain_by_sid(struct sss_domain_info *domain, + const char *sid); bool subdomain_enumerates(struct sss_domain_info *parent, const char *sd_name); |