|
|
9f2ebf |
From 2f712c8fe0ecaa07f7b15ebeae5213978d033278 Mon Sep 17 00:00:00 2001
|
|
|
5e7617 |
From: amitkuma <amitkuma@redhat.com>
|
|
|
5e7617 |
Date: Thu, 30 Nov 2017 22:18:39 +0530
|
|
|
9f2ebf |
Subject: [PATCH 87/87] cache: Check for max_id/min_id in cache_req
|
|
|
5e7617 |
MIME-Version: 1.0
|
|
|
5e7617 |
Content-Type: text/plain; charset=UTF-8
|
|
|
5e7617 |
Content-Transfer-Encoding: 8bit
|
|
|
5e7617 |
|
|
|
5e7617 |
The cache_req code doesn't check the min_id/max_id
|
|
|
5e7617 |
boundaries for requests by ID.
|
|
|
5e7617 |
Extending the .lookup_fn function in each plugin
|
|
|
5e7617 |
that searches by ID for a check that returns non-zero
|
|
|
5e7617 |
if the entry is out of the range and 0 if not.
|
|
|
5e7617 |
|
|
|
5e7617 |
Resolves: https://pagure.io/SSSD/sssd/issue/3569
|
|
|
5e7617 |
|
|
|
5e7617 |
Reviewed-by: Jakub Hrozek <jhrozek@redhat.com>
|
|
|
5e7617 |
Reviewed-by: Fabiano FidĂȘncio <fidencio@redhat.com>
|
|
|
5e7617 |
(cherry picked from commit 2af80640f18966d65cf82106059ce3c060df93bf)
|
|
|
5e7617 |
---
|
|
|
9f2ebf |
src/responder/common/cache_req/cache_req.c | 1 +
|
|
|
9f2ebf |
src/responder/common/cache_req/cache_req_private.h | 3 +
|
|
|
9f2ebf |
src/responder/common/cache_req/cache_req_search.c | 5 +
|
|
|
9f2ebf |
.../common/cache_req/plugins/cache_req_common.c | 11 ++
|
|
|
9f2ebf |
.../cache_req/plugins/cache_req_group_by_id.c | 6 +
|
|
|
9f2ebf |
.../cache_req/plugins/cache_req_object_by_id.c | 6 +
|
|
|
9f2ebf |
.../cache_req/plugins/cache_req_user_by_id.c | 5 +
|
|
|
9f2ebf |
src/tests/cmocka/test_responder_cache_req.c | 127 +++++++++++++++++----
|
|
|
9f2ebf |
src/util/util_errors.c | 1 +
|
|
|
9f2ebf |
src/util/util_errors.h | 1 +
|
|
|
9f2ebf |
10 files changed, 141 insertions(+), 25 deletions(-)
|
|
|
5e7617 |
|
|
|
5e7617 |
diff --git a/src/responder/common/cache_req/cache_req.c b/src/responder/common/cache_req/cache_req.c
|
|
|
9f2ebf |
index ad9bc040dd999a205713141e6a1512e47b69c45e..134688b0f62c6546763d91468af3f54b73b6073a 100644
|
|
|
5e7617 |
--- a/src/responder/common/cache_req/cache_req.c
|
|
|
5e7617 |
+++ b/src/responder/common/cache_req/cache_req.c
|
|
|
9f2ebf |
@@ -953,6 +953,7 @@ static void cache_req_search_domains_done(struct tevent_req *subreq)
|
|
|
9f2ebf |
goto done;
|
|
|
5e7617 |
}
|
|
|
5e7617 |
break;
|
|
|
5e7617 |
+ case ERR_ID_OUTSIDE_RANGE:
|
|
|
5e7617 |
case ENOENT:
|
|
|
5e7617 |
if (state->check_next == false) {
|
|
|
5e7617 |
/* Not found. */
|
|
|
5e7617 |
diff --git a/src/responder/common/cache_req/cache_req_private.h b/src/responder/common/cache_req/cache_req_private.h
|
|
|
9f2ebf |
index 95f24c0e5b9ab1150591d308c7288c57fe478c5d..9538b9568ca7f77e377cfee67235c8a52ebbe454 100644
|
|
|
5e7617 |
--- a/src/responder/common/cache_req/cache_req_private.h
|
|
|
5e7617 |
+++ b/src/responder/common/cache_req/cache_req_private.h
|
|
|
9f2ebf |
@@ -192,4 +192,7 @@ cache_reg_common_get_acct_domain_recv(TALLOC_CTX *mem_ctx,
|
|
|
9f2ebf |
struct tevent_req *subreq,
|
|
|
9f2ebf |
struct cache_req *cr,
|
|
|
9f2ebf |
char **_domain);
|
|
|
9f2ebf |
+
|
|
|
5e7617 |
+errno_t cache_req_idminmax_check(struct cache_req_data *data,
|
|
|
5e7617 |
+ struct sss_domain_info *domain);
|
|
|
5e7617 |
#endif /* _CACHE_REQ_PRIVATE_H_ */
|
|
|
5e7617 |
diff --git a/src/responder/common/cache_req/cache_req_search.c b/src/responder/common/cache_req/cache_req_search.c
|
|
|
9f2ebf |
index 3365962d473b0982945de2541e44ba86b43a0db5..7423feb6305df87d368bcc10ba28b9b29d57ecf0 100644
|
|
|
5e7617 |
--- a/src/responder/common/cache_req/cache_req_search.c
|
|
|
5e7617 |
+++ b/src/responder/common/cache_req/cache_req_search.c
|
|
|
9f2ebf |
@@ -203,6 +203,11 @@ static errno_t cache_req_search_cache(TALLOC_CTX *mem_ctx,
|
|
|
5e7617 |
|
|
|
5e7617 |
*_result = result;
|
|
|
5e7617 |
break;
|
|
|
5e7617 |
+ case ERR_ID_OUTSIDE_RANGE:
|
|
|
5e7617 |
+ CACHE_REQ_DEBUG(SSSDBG_TRACE_FUNC, cr,
|
|
|
5e7617 |
+ "ID [%s] was filtered out\n",
|
|
|
5e7617 |
+ cr->debugobj);
|
|
|
5e7617 |
+ break;
|
|
|
5e7617 |
case ENOENT:
|
|
|
5e7617 |
CACHE_REQ_DEBUG(SSSDBG_TRACE_FUNC, cr,
|
|
|
5e7617 |
"Object [%s] was not found in cache\n",
|
|
|
5e7617 |
diff --git a/src/responder/common/cache_req/plugins/cache_req_common.c b/src/responder/common/cache_req/plugins/cache_req_common.c
|
|
|
9f2ebf |
index 408c91949ceb3ecaf743f270f58f4e3fcfc3ccb1..bb11eaa86a8bca3f9d15afe48dab9921319d184e 100644
|
|
|
5e7617 |
--- a/src/responder/common/cache_req/plugins/cache_req_common.c
|
|
|
5e7617 |
+++ b/src/responder/common/cache_req/plugins/cache_req_common.c
|
|
|
5e7617 |
@@ -26,6 +26,17 @@
|
|
|
5e7617 |
#include "providers/data_provider.h"
|
|
|
5e7617 |
#include "responder/common/cache_req/cache_req_plugin.h"
|
|
|
5e7617 |
|
|
|
5e7617 |
+errno_t cache_req_idminmax_check(struct cache_req_data *data,
|
|
|
5e7617 |
+ struct sss_domain_info *domain)
|
|
|
5e7617 |
+{
|
|
|
5e7617 |
+ if (((domain->id_min != 0) && (data->id < domain->id_min)) ||
|
|
|
5e7617 |
+ ((domain->id_max != 0) && (data->id > domain->id_max))) {
|
|
|
5e7617 |
+ DEBUG(SSSDBG_FUNC_DATA, "id exceeds min/max boundaries\n");
|
|
|
5e7617 |
+ return ERR_ID_OUTSIDE_RANGE;
|
|
|
5e7617 |
+ }
|
|
|
5e7617 |
+ return EOK;
|
|
|
5e7617 |
+}
|
|
|
5e7617 |
+
|
|
|
5e7617 |
static struct ldb_message *
|
|
|
5e7617 |
cache_req_well_known_sid_msg(TALLOC_CTX *mem_ctx,
|
|
|
5e7617 |
const char *sid,
|
|
|
5e7617 |
diff --git a/src/responder/common/cache_req/plugins/cache_req_group_by_id.c b/src/responder/common/cache_req/plugins/cache_req_group_by_id.c
|
|
|
9f2ebf |
index ce84b1b4458b447ff6b4b036c6e8fe8f4d7758c8..d178283c33c84e277b83772d04973aa6069af967 100644
|
|
|
5e7617 |
--- a/src/responder/common/cache_req/plugins/cache_req_group_by_id.c
|
|
|
5e7617 |
+++ b/src/responder/common/cache_req/plugins/cache_req_group_by_id.c
|
|
|
9f2ebf |
@@ -81,6 +81,12 @@ cache_req_group_by_id_lookup(TALLOC_CTX *mem_ctx,
|
|
|
5e7617 |
struct sss_domain_info *domain,
|
|
|
5e7617 |
struct ldb_result **_result)
|
|
|
5e7617 |
{
|
|
|
5e7617 |
+ errno_t ret;
|
|
|
5e7617 |
+
|
|
|
5e7617 |
+ ret = cache_req_idminmax_check(data, domain);
|
|
|
5e7617 |
+ if (ret != EOK) {
|
|
|
5e7617 |
+ return ret;
|
|
|
5e7617 |
+ }
|
|
|
5e7617 |
return sysdb_getgrgid_with_views(mem_ctx, domain, data->id, _result);
|
|
|
5e7617 |
}
|
|
|
5e7617 |
|
|
|
5e7617 |
diff --git a/src/responder/common/cache_req/plugins/cache_req_object_by_id.c b/src/responder/common/cache_req/plugins/cache_req_object_by_id.c
|
|
|
9f2ebf |
index 1327b480c1b1b68f9826fa229c9b001f2d92b79b..be9488d298885320139ccfcd3c59a83ff088e77d 100644
|
|
|
5e7617 |
--- a/src/responder/common/cache_req/plugins/cache_req_object_by_id.c
|
|
|
5e7617 |
+++ b/src/responder/common/cache_req/plugins/cache_req_object_by_id.c
|
|
|
9f2ebf |
@@ -110,6 +110,12 @@ cache_req_object_by_id_lookup(TALLOC_CTX *mem_ctx,
|
|
|
5e7617 |
struct sss_domain_info *domain,
|
|
|
5e7617 |
struct ldb_result **_result)
|
|
|
5e7617 |
{
|
|
|
5e7617 |
+ errno_t ret;
|
|
|
5e7617 |
+
|
|
|
5e7617 |
+ ret = cache_req_idminmax_check(data, domain);
|
|
|
5e7617 |
+ if (ret != EOK) {
|
|
|
5e7617 |
+ return ret;
|
|
|
5e7617 |
+ }
|
|
|
5e7617 |
return sysdb_search_object_by_id(mem_ctx, domain, data->id,
|
|
|
5e7617 |
data->attrs, _result);
|
|
|
5e7617 |
}
|
|
|
5e7617 |
diff --git a/src/responder/common/cache_req/plugins/cache_req_user_by_id.c b/src/responder/common/cache_req/plugins/cache_req_user_by_id.c
|
|
|
9f2ebf |
index 656fa41af5f39f68c64e241aa97c4eaf3ec57395..151c3e17acf6ef0d958d5a73a36e1c93b9e7a9a9 100644
|
|
|
5e7617 |
--- a/src/responder/common/cache_req/plugins/cache_req_user_by_id.c
|
|
|
5e7617 |
+++ b/src/responder/common/cache_req/plugins/cache_req_user_by_id.c
|
|
|
9f2ebf |
@@ -81,6 +81,11 @@ cache_req_user_by_id_lookup(TALLOC_CTX *mem_ctx,
|
|
|
5e7617 |
struct sss_domain_info *domain,
|
|
|
5e7617 |
struct ldb_result **_result)
|
|
|
5e7617 |
{
|
|
|
5e7617 |
+ errno_t ret;
|
|
|
5e7617 |
+ ret = cache_req_idminmax_check(data, domain);
|
|
|
5e7617 |
+ if (ret != EOK) {
|
|
|
5e7617 |
+ return ret;
|
|
|
5e7617 |
+ }
|
|
|
5e7617 |
return sysdb_getpwuid_with_views(mem_ctx, domain, data->id, _result);
|
|
|
5e7617 |
}
|
|
|
5e7617 |
|
|
|
5e7617 |
diff --git a/src/tests/cmocka/test_responder_cache_req.c b/src/tests/cmocka/test_responder_cache_req.c
|
|
|
9f2ebf |
index 0ee0070d0c9fbb89020f522b2f7613f1076a8cbb..5f50b27a5ee846c9ccf71e1e661359a07c2e02e8 100644
|
|
|
5e7617 |
--- a/src/tests/cmocka/test_responder_cache_req.c
|
|
|
5e7617 |
+++ b/src/tests/cmocka/test_responder_cache_req.c
|
|
|
9f2ebf |
@@ -59,6 +59,11 @@ struct test_group {
|
|
|
5e7617 |
test_single_domain_setup, \
|
|
|
5e7617 |
test_single_domain_teardown)
|
|
|
5e7617 |
|
|
|
5e7617 |
+#define new_single_domain_id_limit_test(test) \
|
|
|
5e7617 |
+ cmocka_unit_test_setup_teardown(test_ ## test, \
|
|
|
5e7617 |
+ test_single_domain_id_limits_setup, \
|
|
|
5e7617 |
+ test_single_domain_teardown)
|
|
|
5e7617 |
+
|
|
|
5e7617 |
#define new_multi_domain_test(test) \
|
|
|
5e7617 |
cmocka_unit_test_setup_teardown(test_ ## test, \
|
|
|
5e7617 |
test_multi_domain_setup, \
|
|
|
9f2ebf |
@@ -521,33 +526,39 @@ __wrap_sss_dp_get_account_send(TALLOC_CTX *mem_ctx,
|
|
|
5e7617 |
return test_req_succeed_send(mem_ctx, rctx->ev);
|
|
|
5e7617 |
}
|
|
|
5e7617 |
|
|
|
5e7617 |
+static int test_single_domain_setup_common(void **state,
|
|
|
5e7617 |
+ struct sss_test_conf_param *params)
|
|
|
9f2ebf |
+{
|
|
|
9f2ebf |
+ struct cache_req_test_ctx *test_ctx = NULL;
|
|
|
9f2ebf |
+ errno_t ret;
|
|
|
9f2ebf |
+
|
|
|
9f2ebf |
+ assert_true(leak_check_setup());
|
|
|
9f2ebf |
+
|
|
|
9f2ebf |
+ test_dom_suite_setup(TESTS_PATH);
|
|
|
9f2ebf |
+
|
|
|
9f2ebf |
+ test_ctx = talloc_zero(global_talloc_context, struct cache_req_test_ctx);
|
|
|
9f2ebf |
+ assert_non_null(test_ctx);
|
|
|
9f2ebf |
+ *state = test_ctx;
|
|
|
9f2ebf |
+
|
|
|
9f2ebf |
+ test_ctx->tctx = create_dom_test_ctx(test_ctx, TESTS_PATH, TEST_CONF_DB,
|
|
|
9f2ebf |
+ TEST_DOM_NAME, TEST_ID_PROVIDER, params);
|
|
|
9f2ebf |
+ assert_non_null(test_ctx->tctx);
|
|
|
9f2ebf |
+
|
|
|
9f2ebf |
+ test_ctx->rctx = mock_rctx(test_ctx, test_ctx->tctx->ev,
|
|
|
9f2ebf |
+ test_ctx->tctx->dom, NULL);
|
|
|
9f2ebf |
+ assert_non_null(test_ctx->rctx);
|
|
|
9f2ebf |
+
|
|
|
9f2ebf |
+ ret = sss_ncache_init(test_ctx, 10, 0, &test_ctx->ncache);
|
|
|
9f2ebf |
+ assert_int_equal(ret, EOK);
|
|
|
9f2ebf |
+
|
|
|
9f2ebf |
+ check_leaks_push(test_ctx);
|
|
|
9f2ebf |
+
|
|
|
9f2ebf |
+ return 0;
|
|
|
9f2ebf |
+}
|
|
|
9f2ebf |
+
|
|
|
9f2ebf |
static int test_single_domain_setup(void **state)
|
|
|
5e7617 |
{
|
|
|
9f2ebf |
- struct cache_req_test_ctx *test_ctx = NULL;
|
|
|
9f2ebf |
- errno_t ret;
|
|
|
9f2ebf |
-
|
|
|
9f2ebf |
- assert_true(leak_check_setup());
|
|
|
9f2ebf |
-
|
|
|
9f2ebf |
- test_dom_suite_setup(TESTS_PATH);
|
|
|
9f2ebf |
-
|
|
|
9f2ebf |
- test_ctx = talloc_zero(global_talloc_context, struct cache_req_test_ctx);
|
|
|
9f2ebf |
- assert_non_null(test_ctx);
|
|
|
9f2ebf |
- *state = test_ctx;
|
|
|
9f2ebf |
-
|
|
|
9f2ebf |
- test_ctx->tctx = create_dom_test_ctx(test_ctx, TESTS_PATH, TEST_CONF_DB,
|
|
|
5e7617 |
- TEST_DOM_NAME, TEST_ID_PROVIDER, NULL);
|
|
|
9f2ebf |
- assert_non_null(test_ctx->tctx);
|
|
|
9f2ebf |
-
|
|
|
9f2ebf |
- test_ctx->rctx = mock_rctx(test_ctx, test_ctx->tctx->ev,
|
|
|
9f2ebf |
- test_ctx->tctx->dom, NULL);
|
|
|
9f2ebf |
- assert_non_null(test_ctx->rctx);
|
|
|
9f2ebf |
-
|
|
|
9f2ebf |
- ret = sss_ncache_init(test_ctx, 10, 0, &test_ctx->ncache);
|
|
|
9f2ebf |
- assert_int_equal(ret, EOK);
|
|
|
9f2ebf |
-
|
|
|
9f2ebf |
- check_leaks_push(test_ctx);
|
|
|
9f2ebf |
-
|
|
|
9f2ebf |
- return 0;
|
|
|
9f2ebf |
+ return test_single_domain_setup_common(state, NULL);
|
|
|
5e7617 |
}
|
|
|
5e7617 |
|
|
|
5e7617 |
static int test_single_domain_teardown(void **state)
|
|
|
9f2ebf |
@@ -565,6 +576,16 @@ static int test_single_domain_teardown(void **state)
|
|
|
5e7617 |
return 0;
|
|
|
5e7617 |
}
|
|
|
5e7617 |
|
|
|
5e7617 |
+static int test_single_domain_id_limits_setup(void **state)
|
|
|
5e7617 |
+{
|
|
|
5e7617 |
+ struct sss_test_conf_param params[] = {
|
|
|
5e7617 |
+ { "min_id", "100" },
|
|
|
5e7617 |
+ { "max_id", "10000" },
|
|
|
5e7617 |
+ { NULL, NULL }, /* Sentinel */
|
|
|
5e7617 |
+ };
|
|
|
5e7617 |
+ return test_single_domain_setup_common(state, params);
|
|
|
5e7617 |
+}
|
|
|
5e7617 |
+
|
|
|
5e7617 |
static int test_multi_domain_setup(void **state)
|
|
|
5e7617 |
{
|
|
|
5e7617 |
struct cache_req_test_ctx *test_ctx = NULL;
|
|
|
9f2ebf |
@@ -596,6 +617,32 @@ static int test_multi_domain_setup(void **state)
|
|
|
5e7617 |
return 0;
|
|
|
5e7617 |
}
|
|
|
5e7617 |
|
|
|
5e7617 |
+void test_user_by_id_below_id_range(void **state)
|
|
|
5e7617 |
+{
|
|
|
5e7617 |
+ struct cache_req_test_ctx *test_ctx = NULL;
|
|
|
5e7617 |
+
|
|
|
5e7617 |
+ test_ctx = talloc_get_type_abort(*state, struct cache_req_test_ctx);
|
|
|
5e7617 |
+
|
|
|
5e7617 |
+ /* Test. */
|
|
|
5e7617 |
+ run_cache_req(test_ctx, cache_req_user_by_id_send,
|
|
|
5e7617 |
+ cache_req_user_by_id_test_done, test_ctx->tctx->dom,
|
|
|
5e7617 |
+ 0, 10, ENOENT);
|
|
|
5e7617 |
+ assert_false(test_ctx->dp_called);
|
|
|
5e7617 |
+}
|
|
|
5e7617 |
+
|
|
|
5e7617 |
+void test_user_by_id_above_id_range(void **state)
|
|
|
5e7617 |
+{
|
|
|
5e7617 |
+ struct cache_req_test_ctx *test_ctx = NULL;
|
|
|
5e7617 |
+
|
|
|
5e7617 |
+ test_ctx = talloc_get_type_abort(*state, struct cache_req_test_ctx);
|
|
|
5e7617 |
+
|
|
|
5e7617 |
+ /* Test. */
|
|
|
5e7617 |
+ run_cache_req(test_ctx, cache_req_user_by_id_send,
|
|
|
5e7617 |
+ cache_req_user_by_id_test_done, test_ctx->tctx->dom,
|
|
|
5e7617 |
+ 0, 100000, ENOENT);
|
|
|
5e7617 |
+ assert_false(test_ctx->dp_called);
|
|
|
5e7617 |
+}
|
|
|
5e7617 |
+
|
|
|
5e7617 |
static int test_multi_domain_teardown(void **state)
|
|
|
5e7617 |
{
|
|
|
5e7617 |
struct cache_req_test_ctx *test_ctx;
|
|
|
9f2ebf |
@@ -1332,6 +1379,32 @@ void test_user_by_id_sub_domains_locator_missing_found(void **state)
|
|
|
9f2ebf |
talloc_free(tmp_ctx);
|
|
|
5e7617 |
}
|
|
|
5e7617 |
|
|
|
5e7617 |
+void test_group_by_id_below_id_range(void **state)
|
|
|
5e7617 |
+{
|
|
|
5e7617 |
+ struct cache_req_test_ctx *test_ctx = NULL;
|
|
|
5e7617 |
+
|
|
|
5e7617 |
+ test_ctx = talloc_get_type_abort(*state, struct cache_req_test_ctx);
|
|
|
5e7617 |
+
|
|
|
5e7617 |
+ /* Test. */
|
|
|
5e7617 |
+ run_cache_req(test_ctx, cache_req_group_by_id_send,
|
|
|
5e7617 |
+ cache_req_group_by_id_test_done, test_ctx->tctx->dom,
|
|
|
5e7617 |
+ 0, 10, ENOENT);
|
|
|
5e7617 |
+ assert_false(test_ctx->dp_called);
|
|
|
5e7617 |
+}
|
|
|
5e7617 |
+
|
|
|
5e7617 |
+void test_group_by_id_above_id_range(void **state)
|
|
|
5e7617 |
+{
|
|
|
5e7617 |
+ struct cache_req_test_ctx *test_ctx = NULL;
|
|
|
5e7617 |
+
|
|
|
5e7617 |
+ test_ctx = talloc_get_type_abort(*state, struct cache_req_test_ctx);
|
|
|
5e7617 |
+
|
|
|
5e7617 |
+ /* Test. */
|
|
|
5e7617 |
+ run_cache_req(test_ctx, cache_req_group_by_id_send,
|
|
|
5e7617 |
+ cache_req_group_by_id_test_done, test_ctx->tctx->dom,
|
|
|
5e7617 |
+ 0, 100000, ENOENT);
|
|
|
5e7617 |
+ assert_false(test_ctx->dp_called);
|
|
|
5e7617 |
+}
|
|
|
5e7617 |
+
|
|
|
9f2ebf |
void test_user_by_id_sub_domains_locator_missing_notfound(void **state)
|
|
|
5e7617 |
{
|
|
|
5e7617 |
struct cache_req_test_ctx *test_ctx = NULL;
|
|
|
9f2ebf |
@@ -3874,6 +3947,8 @@ int main(int argc, const char *argv[])
|
|
|
5e7617 |
new_single_domain_test(user_by_id_missing_notfound),
|
|
|
5e7617 |
new_multi_domain_test(user_by_id_multiple_domains_found),
|
|
|
5e7617 |
new_multi_domain_test(user_by_id_multiple_domains_notfound),
|
|
|
5e7617 |
+ new_single_domain_id_limit_test(user_by_id_below_id_range),
|
|
|
5e7617 |
+ new_single_domain_id_limit_test(user_by_id_above_id_range),
|
|
|
5e7617 |
|
|
|
5e7617 |
new_single_domain_test(group_by_name_cache_valid),
|
|
|
5e7617 |
new_single_domain_test(group_by_name_cache_expired),
|
|
|
9f2ebf |
@@ -3884,6 +3959,8 @@ int main(int argc, const char *argv[])
|
|
|
5e7617 |
new_multi_domain_test(group_by_name_multiple_domains_found),
|
|
|
5e7617 |
new_multi_domain_test(group_by_name_multiple_domains_notfound),
|
|
|
5e7617 |
new_multi_domain_test(group_by_name_multiple_domains_parse),
|
|
|
5e7617 |
+ new_single_domain_id_limit_test(group_by_id_below_id_range),
|
|
|
5e7617 |
+ new_single_domain_id_limit_test(group_by_id_above_id_range),
|
|
|
5e7617 |
|
|
|
5e7617 |
new_single_domain_test(group_by_id_cache_valid),
|
|
|
5e7617 |
new_single_domain_test(group_by_id_cache_expired),
|
|
|
5e7617 |
diff --git a/src/util/util_errors.c b/src/util/util_errors.c
|
|
|
9f2ebf |
index 06c620b40aaa00d6ce58ace3a28449ffbdf8da88..39ce3d7dcf4af4c489a0a9b7768668497cb84ba5 100644
|
|
|
5e7617 |
--- a/src/util/util_errors.c
|
|
|
5e7617 |
+++ b/src/util/util_errors.c
|
|
|
9f2ebf |
@@ -117,6 +117,7 @@ struct err_string error_to_str[] = {
|
|
|
5e7617 |
{ "Unable to resolve host" }, /* ERR_UNABLE_TO_RESOLVE_HOST */
|
|
|
9f2ebf |
{ "GetAccountDomain() not supported" }, /* ERR_GET_ACCT_DOM_NOT_SUPPORTED */
|
|
|
9f2ebf |
{ "The last GetAccountDomain() result is still valid" }, /* ERR_GET_ACCT_DOM_CACHED */
|
|
|
5e7617 |
+ { "ID is outside the allowed range" }, /* ERR_ID_OUTSIDE_RANGE */
|
|
|
5e7617 |
{ "ERR_LAST" } /* ERR_LAST */
|
|
|
5e7617 |
};
|
|
|
5e7617 |
|
|
|
5e7617 |
diff --git a/src/util/util_errors.h b/src/util/util_errors.h
|
|
|
9f2ebf |
index bebd6e198fc0077891a602f80182a993ce3f789b..621a3b116edac45960190684055bcd0692135957 100644
|
|
|
5e7617 |
--- a/src/util/util_errors.h
|
|
|
5e7617 |
+++ b/src/util/util_errors.h
|
|
|
9f2ebf |
@@ -139,6 +139,7 @@ enum sssd_errors {
|
|
|
5e7617 |
ERR_UNABLE_TO_RESOLVE_HOST,
|
|
|
9f2ebf |
ERR_GET_ACCT_DOM_NOT_SUPPORTED,
|
|
|
9f2ebf |
ERR_GET_ACCT_DOM_CACHED,
|
|
|
5e7617 |
+ ERR_ID_OUTSIDE_RANGE,
|
|
|
5e7617 |
ERR_LAST /* ALWAYS LAST */
|
|
|
5e7617 |
};
|
|
|
5e7617 |
|
|
|
5e7617 |
--
|
|
|
5e7617 |
2.14.3
|
|
|
5e7617 |
|