summaryrefslogtreecommitdiffstats
path: root/src/providers/krb5/krb5_utils.c
diff options
context:
space:
mode:
authorSumit Bose <sbose@redhat.com>2012-10-24 09:33:23 +0200
committerJakub Hrozek <jhrozek@redhat.com>2012-11-05 00:14:05 +0100
commitb598728537c67557f20d760e2e4127ec868a434b (patch)
treece078362a3cf380225bc0389636b2284c623b303 /src/providers/krb5/krb5_utils.c
parentef3053bd244cb3b104b608b338c764c6a2e34f29 (diff)
downloadsssd-b598728537c67557f20d760e2e4127ec868a434b.tar.gz
sssd-b598728537c67557f20d760e2e4127ec868a434b.tar.xz
sssd-b598728537c67557f20d760e2e4127ec868a434b.zip
Add new call find_or_guess_upn()
With the current approach the upn was either a pointer to a const string in a ldb_message or a string created with the help of talloc. This new function always makes it a talloc'ed value. Additionally krb5_get_simple_upn() is enhanced to handle sub-domains as well.
Diffstat (limited to 'src/providers/krb5/krb5_utils.c')
-rw-r--r--src/providers/krb5/krb5_utils.c27
1 files changed, 27 insertions, 0 deletions
diff --git a/src/providers/krb5/krb5_utils.c b/src/providers/krb5/krb5_utils.c
index 7a68b0f4c..98376169f 100644
--- a/src/providers/krb5/krb5_utils.c
+++ b/src/providers/krb5/krb5_utils.c
@@ -30,6 +30,33 @@
#include "src/util/find_uid.h"
#include "util/util.h"
+errno_t find_or_guess_upn(TALLOC_CTX *mem_ctx, struct ldb_message *msg,
+ struct krb5_ctx *krb5_ctx,
+ const char *domain_name, const char *user,
+ const char *user_dom, char **_upn)
+{
+ const char *upn;
+ int ret;
+
+ upn = ldb_msg_find_attr_as_string(msg, SYSDB_UPN, NULL);
+ if (upn == NULL) {
+ ret = krb5_get_simple_upn(mem_ctx, krb5_ctx, domain_name, user,
+ user_dom, _upn);
+ if (ret != EOK) {
+ DEBUG(SSSDBG_OP_FAILURE, ("krb5_get_simple_upn failed.\n"));
+ return ret;
+ }
+ } else {
+ *_upn = talloc_strdup(mem_ctx, upn);
+ if (*_upn == NULL) {
+ DEBUG(SSSDBG_OP_FAILURE, ("talloc_strdup failed.\n"));
+ return ENOMEM;
+ }
+ }
+
+ return EOK;
+}
+
char *expand_ccname_template(TALLOC_CTX *mem_ctx, struct krb5child_req *kr,
const char *template, bool file_mode,
bool case_sensitive, bool *private_path)