summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorSumit Bose <sbose@redhat.com>2015-11-30 12:14:16 +0100
committerLukas Slebodnik <lslebodn@redhat.com>2016-06-09 16:12:25 +0200
commit6cdeb0923c16e3fafe21aaadca6dac1d71474c31 (patch)
treea157c161e863204a5b326ab3c45ac6e743e8c6a9 /src
parentd86224608ff60ec5cc7e7cbf9e53d8a04e083530 (diff)
downloadsssd-6cdeb0923c16e3fafe21aaadca6dac1d71474c31.tar.gz
sssd-6cdeb0923c16e3fafe21aaadca6dac1d71474c31.tar.xz
sssd-6cdeb0923c16e3fafe21aaadca6dac1d71474c31.zip
sysdb: add sysdb_attrs_add_base64_blob()
Reviewed-by: Jakub Hrozek <jhrozek@redhat.com>
Diffstat (limited to 'src')
-rw-r--r--src/db/sysdb.c22
-rw-r--r--src/db/sysdb.h2
-rw-r--r--src/tests/cmocka/test_sysdb_utils.c36
3 files changed, 60 insertions, 0 deletions
diff --git a/src/db/sysdb.c b/src/db/sysdb.c
index 3c888a42c..d7540f0cc 100644
--- a/src/db/sysdb.c
+++ b/src/db/sysdb.c
@@ -23,6 +23,7 @@
#include "util/util.h"
#include "util/strtonum.h"
#include "util/sss_utf8.h"
+#include "util/crypto/sss_crypto.h"
#include "db/sysdb_private.h"
#include "confdb/confdb.h"
#include <time.h>
@@ -634,6 +635,27 @@ int sysdb_attrs_add_mem(struct sysdb_attrs *attrs, const char *name,
return sysdb_attrs_add_val(attrs, name, &v);
}
+int sysdb_attrs_add_base64_blob(struct sysdb_attrs *attrs, const char *name,
+ const char *base64_str)
+{
+ struct ldb_val v;
+ int ret;
+
+ if (base64_str == NULL) {
+ return EINVAL;
+ }
+
+ v.data = sss_base64_decode(attrs, base64_str, &v.length);
+ if (v.data == NULL) {
+ DEBUG(SSSDBG_OP_FAILURE, "sss_base64_decode failed.\n");
+ return ENOMEM;
+ }
+
+ ret = sysdb_attrs_add_val(attrs, name, &v);
+ talloc_free(v.data);
+ return ret;
+}
+
int sysdb_attrs_add_bool(struct sysdb_attrs *attrs,
const char *name, bool value)
{
diff --git a/src/db/sysdb.h b/src/db/sysdb.h
index 11b680f3f..ec398496d 100644
--- a/src/db/sysdb.h
+++ b/src/db/sysdb.h
@@ -322,6 +322,8 @@ int sysdb_attrs_add_lower_case_string(struct sysdb_attrs *attrs, bool safe,
const char *name, const char *str);
int sysdb_attrs_add_mem(struct sysdb_attrs *attrs, const char *name,
const void *mem, size_t size);
+int sysdb_attrs_add_base64_blob(struct sysdb_attrs *attrs, const char *name,
+ const char *base64_str);
int sysdb_attrs_add_bool(struct sysdb_attrs *attrs,
const char *name, bool value);
int sysdb_attrs_add_long(struct sysdb_attrs *attrs,
diff --git a/src/tests/cmocka/test_sysdb_utils.c b/src/tests/cmocka/test_sysdb_utils.c
index b791f14b7..570fe0235 100644
--- a/src/tests/cmocka/test_sysdb_utils.c
+++ b/src/tests/cmocka/test_sysdb_utils.c
@@ -103,6 +103,41 @@ static void test_sysdb_handle_original_uuid(void **state)
talloc_free(dest_attrs);
}
+#define TEST_BASE64_ABC "YWJj"
+#define TEST_BASE64_123 "AQID"
+static void test_sysdb_attrs_add_base64_blob(void **state)
+{
+ struct sysdb_attrs *attrs;
+ struct ldb_message_element *el;
+ char zero[] = { '\1', '\2', '\3' };
+ int ret;
+
+ attrs = sysdb_new_attrs(NULL);
+ assert_non_null(attrs);
+
+ ret = sysdb_attrs_add_base64_blob(attrs, "testAttrABC", TEST_BASE64_ABC);
+ assert_int_equal(ret, EOK);
+
+ ret = sysdb_attrs_add_base64_blob(attrs, "testAttr000", TEST_BASE64_123);
+ assert_int_equal(ret, EOK);
+
+ ret = sysdb_attrs_get_el(attrs, "testAttrABC", &el);
+ assert_int_equal(ret, EOK);
+ assert_int_equal(el->num_values, 1);
+ assert_non_null(el->values);
+ assert_non_null(el->values[0].data);
+ assert_int_equal(el->values[0].length, 3);
+ assert_memory_equal(el->values[0].data, "abc", 3);
+
+ ret = sysdb_attrs_get_el(attrs, "testAttr000", &el);
+ assert_int_equal(ret, EOK);
+ assert_int_equal(el->num_values, 1);
+ assert_non_null(el->values);
+ assert_non_null(el->values[0].data);
+ assert_int_equal(el->values[0].length, 3);
+ assert_memory_equal(el->values[0].data, zero, 3);
+}
+
int main(int argc, const char *argv[])
{
int rv;
@@ -116,6 +151,7 @@ int main(int argc, const char *argv[])
const struct CMUnitTest tests[] = {
cmocka_unit_test(test_sysdb_handle_original_uuid),
+ cmocka_unit_test(test_sysdb_attrs_add_base64_blob),
};
/* Set debug level to invalid value so we can deside if -d 0 was used. */