From: Howard Chu Date: Mon, 17 Jan 2022 16:32:28 +0000 (+0000) Subject: ITS#9779 slapo-dynlist: fix static group filter with multiple members X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=e73cdc55e0e758b11d893af7927477dbea115775;p=thirdparty%2Fopenldap.git ITS#9779 slapo-dynlist: fix static group filter with multiple members --- diff --git a/servers/slapd/overlays/dynlist.c b/servers/slapd/overlays/dynlist.c index ac98744392..b04f65c0c6 100644 --- a/servers/slapd/overlays/dynlist.c +++ b/servers/slapd/overlays/dynlist.c @@ -1208,20 +1208,13 @@ dynlist_filter_stgroup( Operation *op, Filter *n, Attribute *a ) Filter *dnf, *orf = NULL; int i; - if ( a->a_numvals == 1 && n->f_choice == SLAPD_FILTER_COMPUTED ) { + if ( a->a_numvals == 1 ) { dnf = n; - dnf->f_next = NULL; } else { orf = n; - if ( n->f_choice != LDAP_FILTER_OR ) { - dnf = op->o_tmpalloc( sizeof(Filter), op->o_tmpmemctx ); - *dnf = *n; - orf->f_choice = LDAP_FILTER_OR; - orf->f_next = NULL; - orf->f_list = dnf; - } + orf->f_choice = LDAP_FILTER_OR; dnf = op->o_tmpalloc( sizeof(Filter), op->o_tmpmemctx ); - dnf->f_next = orf->f_list; + dnf->f_next = NULL; orf->f_list = dnf; }