diff options
author | Jakub Hrozek <jhrozek@redhat.com> | 2010-10-15 09:40:56 +0200 |
---|---|---|
committer | Stephen Gallagher <sgallagh@redhat.com> | 2010-10-22 10:49:01 -0400 |
commit | 8a46f4c638abbdc1dde41e0e5e9688bd19cd253a (patch) | |
tree | b95fae81712cfc57ca0e3b6fd0e110d533ad691a | |
parent | 0e5534d412771b9de34127ea401c079e5b296ef6 (diff) | |
download | sssd2-8a46f4c638abbdc1dde41e0e5e9688bd19cd253a.tar.gz sssd2-8a46f4c638abbdc1dde41e0e5e9688bd19cd253a.tar.xz sssd2-8a46f4c638abbdc1dde41e0e5e9688bd19cd253a.zip |
Add sysdb_attrs_get_ulong utility function
-rw-r--r-- | src/db/sysdb.c | 27 | ||||
-rw-r--r-- | src/db/sysdb.h | 2 |
2 files changed, 29 insertions, 0 deletions
diff --git a/src/db/sysdb.c b/src/db/sysdb.c index 0091023b..416efbaa 100644 --- a/src/db/sysdb.c +++ b/src/db/sysdb.c @@ -170,6 +170,33 @@ int sysdb_attrs_get_string(struct sysdb_attrs *attrs, const char *name, return EOK; } +int sysdb_attrs_get_ulong(struct sysdb_attrs *attrs, const char *name, + unsigned long *value) +{ + struct ldb_message_element *el; + int ret; + char *endptr; + unsigned long val; + + ret = sysdb_attrs_get_el_int(attrs, name, false, &el); + if (ret) { + return ret; + } + + if (el->num_values != 1) { + return ERANGE; + } + + errno = 0; + val = strtoul((const char *) el->values[0].data, &endptr, 0); + if (errno || *endptr) { + return EINVAL; + } + + *value = val; + return EOK; +} + int sysdb_attrs_get_string_array(struct sysdb_attrs *attrs, const char *name, TALLOC_CTX *mem_ctx, const char ***string) { diff --git a/src/db/sysdb.h b/src/db/sysdb.h index e3e69d3b..1b9edd0f 100644 --- a/src/db/sysdb.h +++ b/src/db/sysdb.h @@ -178,6 +178,8 @@ int sysdb_attrs_get_string(struct sysdb_attrs *attrs, const char *name, const char **string); int sysdb_attrs_get_string_array(struct sysdb_attrs *attrs, const char *name, TALLOC_CTX *mem_ctx, const char ***string); +int sysdb_attrs_get_ulong(struct sysdb_attrs *attrs, const char *name, + unsigned long *value); int sysdb_attrs_replace_name(struct sysdb_attrs *attrs, const char *oldname, const char *newname); |