]> git.ipfire.org Git - thirdparty/samba.git/commitdiff
CVE-2023-0614 ldb: Add ldb_parse_tree_get_attr()
authorJoseph Sutton <josephsutton@catalyst.net.nz>
Fri, 3 Mar 2023 04:31:54 +0000 (17:31 +1300)
committerAndrew Bartlett <abartlet@samba.org>
Wed, 5 Apr 2023 02:10:35 +0000 (02:10 +0000)
BUG: https://bugzilla.samba.org/show_bug.cgi?id=15270

Signed-off-by: Joseph Sutton <josephsutton@catalyst.net.nz>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
lib/ldb/ABI/ldb-2.8.0.sigs
lib/ldb/common/ldb_parse.c
lib/ldb/include/ldb_module.h

index 2f7b5e69dbc8fae19c1763a9ef961a3e4176954e..2aa8d7de86572dc5d142da675ade1df6c73bd87e 100644 (file)
@@ -220,6 +220,7 @@ ldb_parse_control_strings: struct ldb_control **(struct ldb_context *, TALLOC_CT
 ldb_parse_tree: struct ldb_parse_tree *(TALLOC_CTX *, const char *)
 ldb_parse_tree_attr_replace: void (struct ldb_parse_tree *, const char *, const char *)
 ldb_parse_tree_copy_shallow: struct ldb_parse_tree *(TALLOC_CTX *, const struct ldb_parse_tree *)
+ldb_parse_tree_get_attr: const char *(const struct ldb_parse_tree *)
 ldb_parse_tree_walk: int (struct ldb_parse_tree *, int (*)(struct ldb_parse_tree *, void *), void *)
 ldb_qsort: void (void * const, size_t, size_t, void *, ldb_qsort_cmp_fn_t)
 ldb_register_backend: int (const char *, ldb_connect_fn, bool)
index f0045ad2093bbe8ac8fed75ed36ce7e84875ca5b..2d102ff750e4a06e42d5154c9784a98c80544e07 100644 (file)
@@ -997,3 +997,28 @@ struct ldb_parse_tree *ldb_parse_tree_copy_shallow(TALLOC_CTX *mem_ctx,
 
        return nt;
 }
+
+/* Get the attribute (if any) associated with the top node of a parse tree. */
+const char *ldb_parse_tree_get_attr(const struct ldb_parse_tree *tree)
+{
+       switch (tree->operation) {
+       case LDB_OP_AND:
+       case LDB_OP_OR:
+       case LDB_OP_NOT:
+               return NULL;
+       case LDB_OP_EQUALITY:
+               return tree->u.equality.attr;
+       case LDB_OP_SUBSTRING:
+               return tree->u.substring.attr;
+       case LDB_OP_GREATER:
+       case LDB_OP_LESS:
+       case LDB_OP_APPROX:
+               return tree->u.comparison.attr;
+       case LDB_OP_PRESENT:
+               return tree->u.present.attr;
+       case LDB_OP_EXTENDED:
+               return tree->u.extended.attr;
+       }
+
+       return NULL;
+}
index 6293b9c1f60822e71cb2c440e2b4790b2a0f0eda..0c1c37a62c23391517f4c68174d909b3abab6e7f 100644 (file)
@@ -490,6 +490,9 @@ int ldb_init_module(const char *version);
  */
 bool ldb_dn_replace_components(struct ldb_dn *dn, struct ldb_dn *new_dn);
 
+/* Get the attribute (if any) associated with the top node of a parse tree. */
+const char *ldb_parse_tree_get_attr(const struct ldb_parse_tree *tree);
+
 /*
   walk a parse tree, calling the provided callback on each node
 */