diff options
author | Jakub Hrozek <jhrozek@redhat.com> | 2014-01-14 11:10:25 +0100 |
---|---|---|
committer | Jakub Hrozek <jhrozek@redhat.com> | 2014-01-15 17:17:07 +0100 |
commit | 654fa152629cf93d6681d138eb806247fca4d9ae (patch) | |
tree | 16e5cf11403d7e166bf4692f37da2be75e9bb7df | |
parent | 156bbc97b3ebb8df42b658b8ab04c00f0d312eec (diff) | |
download | sssd-654fa152629cf93d6681d138eb806247fca4d9ae.tar.gz sssd-654fa152629cf93d6681d138eb806247fca4d9ae.tar.xz sssd-654fa152629cf93d6681d138eb806247fca4d9ae.zip |
NSS: Use plain user name when expanding homedir
-rw-r--r-- | src/responder/nss/nsssrv_cmd.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/src/responder/nss/nsssrv_cmd.c b/src/responder/nss/nsssrv_cmd.c index 550017c0e..c59078b54 100644 --- a/src/responder/nss/nsssrv_cmd.c +++ b/src/responder/nss/nsssrv_cmd.c @@ -172,13 +172,24 @@ static const char *get_homedir_override(TALLOC_CTX *mem_ctx, struct ldb_message *msg, struct nss_ctx *nctx, struct sss_domain_info *dom, - const char *name, + const char *orig_name, uint32_t uid) { const char *homedir; + char *name; + char *domname; + errno_t ret; homedir = ldb_msg_find_attr_as_string(msg, SYSDB_HOMEDIR, NULL); + /* Subdomain users store FQDN in their name attribute */ + ret = sss_parse_name(mem_ctx, dom->names, orig_name, &domname, &name); + if (ret != EOK) { + DEBUG(SSSDBG_MINOR_FAILURE, ("Could not parse [%s] into " + "name-value components.\n", orig_name)); + return NULL; + } + /* Check whether we are unconditionally overriding the server * for home directory locations. */ |