diff options
author | Sumit Bose <sbose@redhat.com> | 2013-04-22 16:26:56 +0200 |
---|---|---|
committer | Jakub Hrozek <jhrozek@redhat.com> | 2013-05-02 19:33:56 +0200 |
commit | b5afbc39c09baaef57b5300b636307e277c59d66 (patch) | |
tree | a5b4174241eadc11785a37a9400a38e7966364c3 /src/responder/common/negcache.c | |
parent | 1e72a17f6527d47968032fc928f489dad10705ea (diff) | |
download | sssd-b5afbc39c09baaef57b5300b636307e277c59d66.tar.gz sssd-b5afbc39c09baaef57b5300b636307e277c59d66.tar.bz2 sssd-b5afbc39c09baaef57b5300b636307e277c59d66.zip |
Add sss_ncache_set_sid() and sss_ncache_check_sid()
Two new calls are added to allow to add SID based lookups to the
negative cache.
Diffstat (limited to 'src/responder/common/negcache.c')
-rw-r--r-- | src/responder/common/negcache.c | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/src/responder/common/negcache.c b/src/responder/common/negcache.c index 2e1c0af2..76934637 100644 --- a/src/responder/common/negcache.c +++ b/src/responder/common/negcache.c @@ -33,6 +33,7 @@ #define NC_SERVICE_PREFIX NC_ENTRY_PREFIX"SERVICE" #define NC_UID_PREFIX NC_ENTRY_PREFIX"UID" #define NC_GID_PREFIX NC_ENTRY_PREFIX"GID" +#define NC_SID_PREFIX NC_ENTRY_PREFIX"SID" struct sss_nc_ctx { struct tdb_context *tdb; @@ -401,6 +402,20 @@ int sss_ncache_check_gid(struct sss_nc_ctx *ctx, int ttl, gid_t gid) return ret; } +int sss_ncache_check_sid(struct sss_nc_ctx *ctx, int ttl, const char *sid) +{ + char *str; + int ret; + + str = talloc_asprintf(ctx, "%s/%s", NC_SID_PREFIX, sid); + if (!str) return ENOMEM; + + ret = sss_ncache_check_str(ctx, str, ttl); + + talloc_free(str); + return ret; +} + static int sss_ncache_set_user_int(struct sss_nc_ctx *ctx, bool permanent, const char *domain, const char *name) { @@ -518,6 +533,20 @@ int sss_ncache_set_gid(struct sss_nc_ctx *ctx, bool permanent, gid_t gid) return ret; } +int sss_ncache_set_sid(struct sss_nc_ctx *ctx, bool permanent, const char *sid) +{ + char *str; + int ret; + + str = talloc_asprintf(ctx, "%s/%s", NC_SID_PREFIX, sid); + if (!str) return ENOMEM; + + ret = sss_ncache_set_str(ctx, str, permanent); + + talloc_free(str); + return ret; +} + static int delete_permanent(struct tdb_context *tdb, TDB_DATA key, TDB_DATA data, void *state) { |