summaryrefslogtreecommitdiffstats
path: root/src/responder
diff options
context:
space:
mode:
authorJakub Hrozek <jhrozek@redhat.com>2015-05-04 12:34:32 +0200
committerJakub Hrozek <jhrozek@redhat.com>2015-07-15 17:32:20 +0200
commitcdc44abdf944b0de541fe93ecd77df4d09c856b1 (patch)
tree481d664e6a0fc7f82358ed6ad86c29f9ac2f2c1d /src/responder
parent696c17580b49d6817f1dd33915e0e209dcfe4225 (diff)
downloadsssd-cdc44abdf944b0de541fe93ecd77df4d09c856b1.tar.gz
sssd-cdc44abdf944b0de541fe93ecd77df4d09c856b1.tar.xz
sssd-cdc44abdf944b0de541fe93ecd77df4d09c856b1.zip
DP: Add DP_WILDCARD and SSS_DP_WILDCARD_USER/SSS_DP_WILDCARD_GROUP
Related: https://fedorahosted.org/sssd/ticket/2553 Extends the Data Provider interface and the responder<->Data provider interface with wildcard lookups. The patch uses a new "wildcard" prefix rather than reusing the existing user/group prefixes. Reviewed-by: Pavel Březina <pbrezina@redhat.com>
Diffstat (limited to 'src/responder')
-rw-r--r--src/responder/common/responder.h4
-rw-r--r--src/responder/common/responder_dp.c11
2 files changed, 14 insertions, 1 deletions
diff --git a/src/responder/common/responder.h b/src/responder/common/responder.h
index bd0250d52..4d927cfe3 100644
--- a/src/responder/common/responder.h
+++ b/src/responder/common/responder.h
@@ -282,7 +282,9 @@ enum sss_dp_acct_type {
SSS_DP_SERVICES,
SSS_DP_SECID,
SSS_DP_USER_AND_GROUP,
- SSS_DP_CERT
+ SSS_DP_CERT,
+ SSS_DP_WILDCARD_USER,
+ SSS_DP_WILDCARD_GROUP,
};
struct tevent_req *
diff --git a/src/responder/common/responder_dp.c b/src/responder/common/responder_dp.c
index f752c94c3..f7f8df04e 100644
--- a/src/responder/common/responder_dp.c
+++ b/src/responder/common/responder_dp.c
@@ -528,9 +528,11 @@ sss_dp_get_account_msg(void *pvt)
switch (info->type) {
case SSS_DP_USER:
+ case SSS_DP_WILDCARD_USER:
be_type = BE_REQ_USER;
break;
case SSS_DP_GROUP:
+ case SSS_DP_WILDCARD_GROUP:
be_type = BE_REQ_GROUP;
break;
case SSS_DP_INITGROUPS:
@@ -574,6 +576,15 @@ sss_dp_get_account_msg(void *pvt)
filter = talloc_asprintf(info, "%s=%s", DP_CERT,
info->opt_name);
}
+ } else if (info->type == SSS_DP_WILDCARD_USER ||
+ info->type == SSS_DP_WILDCARD_GROUP) {
+ if (info->extra) {
+ filter = talloc_asprintf(info, "%s=%s:%s", DP_WILDCARD,
+ info->opt_name, info->extra);
+ } else {
+ filter = talloc_asprintf(info, "%s=%s", DP_WILDCARD,
+ info->opt_name);
+ }
} else {
if (info->extra) {
filter = talloc_asprintf(info, "name=%s:%s",