mirror of
https://github.com/samba-team/samba.git
synced 2025-01-10 01:18:15 +03:00
r1761: start porting valuable volker's work on ldap from trunk
all ldb functions has been renamed to ldap_ as we don't really want to include ldb functions here, let's keep ldap and ldb separate.
This commit is contained in:
parent
512c410860
commit
f9d7b731c9
@ -22,48 +22,47 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "includes.h"
|
#include "includes.h"
|
||||||
#include "smb_ldap.h"
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
*
|
*
|
||||||
* LDAP filter parser -- main routine is ldb_parse_filter
|
* LDAP filter parser -- main routine is ldap_parse_filter
|
||||||
*
|
*
|
||||||
* Shamelessly stolen and adapted from Samba 4.
|
* Shamelessly stolen and adapted from ldb.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
/* Hmm. A blob might be more appropriate here :-) */
|
/* Hmm. A blob might be more appropriate here :-) */
|
||||||
|
|
||||||
struct ldb_val {
|
struct ldap_val {
|
||||||
unsigned int length;
|
unsigned int length;
|
||||||
void *data;
|
void *data;
|
||||||
};
|
};
|
||||||
|
|
||||||
enum ldb_parse_op {LDB_OP_SIMPLE, LDB_OP_AND, LDB_OP_OR, LDB_OP_NOT};
|
enum ldap_parse_op {LDAP_OP_SIMPLE, LDAP_OP_AND, LDAP_OP_OR, LDAP_OP_NOT};
|
||||||
|
|
||||||
struct ldb_parse_tree {
|
struct ldap_parse_tree {
|
||||||
enum ldb_parse_op operation;
|
enum ldap_parse_op operation;
|
||||||
union {
|
union {
|
||||||
struct {
|
struct {
|
||||||
char *attr;
|
char *attr;
|
||||||
struct ldb_val value;
|
struct ldap_val value;
|
||||||
} simple;
|
} simple;
|
||||||
struct {
|
struct {
|
||||||
unsigned int num_elements;
|
unsigned int num_elements;
|
||||||
struct ldb_parse_tree **elements;
|
struct ldap_parse_tree **elements;
|
||||||
} list;
|
} list;
|
||||||
struct {
|
struct {
|
||||||
struct ldb_parse_tree *child;
|
struct ldap_parse_tree *child;
|
||||||
} not;
|
} not;
|
||||||
} u;
|
} u;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define LDB_ALL_SEP "()&|=!"
|
#define LDAP_ALL_SEP "()&|=!"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
return next token element. Caller frees
|
return next token element. Caller frees
|
||||||
*/
|
*/
|
||||||
static char *ldb_parse_lex(TALLOC_CTX *mem_ctx, const char **s,
|
static char *ldap_parse_lex(TALLOC_CTX *mem_ctx, const char **s,
|
||||||
const char *sep)
|
const char *sep)
|
||||||
{
|
{
|
||||||
const char *p = *s;
|
const char *p = *s;
|
||||||
@ -127,19 +126,19 @@ static const char *match_brace(const char *s)
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct ldb_parse_tree *ldb_parse_filter(TALLOC_CTX *mem_ctx,
|
static struct ldap_parse_tree *ldap_parse_filter(TALLOC_CTX *mem_ctx,
|
||||||
const char **s);
|
const char **s);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
<simple> ::= <attributetype> <filtertype> <attributevalue>
|
<simple> ::= <attributetype> <filtertype> <attributevalue>
|
||||||
*/
|
*/
|
||||||
static struct ldb_parse_tree *ldb_parse_simple(TALLOC_CTX *mem_ctx,
|
static struct ldap_parse_tree *ldap_parse_simple(TALLOC_CTX *mem_ctx,
|
||||||
const char *s)
|
const char *s)
|
||||||
{
|
{
|
||||||
char *eq, *val, *l;
|
char *eq, *val, *l;
|
||||||
struct ldb_parse_tree *ret;
|
struct ldap_parse_tree *ret;
|
||||||
|
|
||||||
l = ldb_parse_lex(mem_ctx, &s, LDB_ALL_SEP);
|
l = ldap_parse_lex(mem_ctx, &s, LDAP_ALL_SEP);
|
||||||
if (!l) {
|
if (!l) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@ -147,11 +146,11 @@ static struct ldb_parse_tree *ldb_parse_simple(TALLOC_CTX *mem_ctx,
|
|||||||
if (strchr("()&|=", *l))
|
if (strchr("()&|=", *l))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
eq = ldb_parse_lex(mem_ctx, &s, LDB_ALL_SEP);
|
eq = ldap_parse_lex(mem_ctx, &s, LDAP_ALL_SEP);
|
||||||
if (!eq || strcmp(eq, "=") != 0)
|
if (!eq || strcmp(eq, "=") != 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
val = ldb_parse_lex(mem_ctx, &s, ")");
|
val = ldap_parse_lex(mem_ctx, &s, ")");
|
||||||
if (val && strchr("()&|", *val))
|
if (val && strchr("()&|", *val))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -161,7 +160,7 @@ static struct ldb_parse_tree *ldb_parse_simple(TALLOC_CTX *mem_ctx,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret->operation = LDB_OP_SIMPLE;
|
ret->operation = LDAP_OP_SIMPLE;
|
||||||
ret->u.simple.attr = l;
|
ret->u.simple.attr = l;
|
||||||
ret->u.simple.value.data = val;
|
ret->u.simple.value.data = val;
|
||||||
ret->u.simple.value.length = val?strlen(val):0;
|
ret->u.simple.value.length = val?strlen(val):0;
|
||||||
@ -176,11 +175,11 @@ static struct ldb_parse_tree *ldb_parse_simple(TALLOC_CTX *mem_ctx,
|
|||||||
<or> ::= '|' <filterlist>
|
<or> ::= '|' <filterlist>
|
||||||
<filterlist> ::= <filter> | <filter> <filterlist>
|
<filterlist> ::= <filter> | <filter> <filterlist>
|
||||||
*/
|
*/
|
||||||
static struct ldb_parse_tree *ldb_parse_filterlist(TALLOC_CTX *mem_ctx,
|
static struct ldap_parse_tree *ldap_parse_filterlist(TALLOC_CTX *mem_ctx,
|
||||||
enum ldb_parse_op op,
|
enum ldap_parse_op op,
|
||||||
const char *s)
|
const char *s)
|
||||||
{
|
{
|
||||||
struct ldb_parse_tree *ret, *next;
|
struct ldap_parse_tree *ret, *next;
|
||||||
|
|
||||||
ret = talloc(mem_ctx, sizeof(*ret));
|
ret = talloc(mem_ctx, sizeof(*ret));
|
||||||
|
|
||||||
@ -197,17 +196,17 @@ static struct ldb_parse_tree *ldb_parse_filterlist(TALLOC_CTX *mem_ctx,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret->u.list.elements[0] = ldb_parse_filter(mem_ctx, &s);
|
ret->u.list.elements[0] = ldap_parse_filter(mem_ctx, &s);
|
||||||
if (!ret->u.list.elements[0]) {
|
if (!ret->u.list.elements[0]) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
while (isspace(*s)) s++;
|
while (isspace(*s)) s++;
|
||||||
|
|
||||||
while (*s && (next = ldb_parse_filter(mem_ctx, &s))) {
|
while (*s && (next = ldap_parse_filter(mem_ctx, &s))) {
|
||||||
struct ldb_parse_tree **e;
|
struct ldap_parse_tree **e;
|
||||||
e = talloc_realloc(mem_ctx, ret->u.list.elements,
|
e = talloc_realloc(mem_ctx, ret->u.list.elements,
|
||||||
sizeof(struct ldb_parse_tree) *
|
sizeof(struct ldap_parse_tree) *
|
||||||
(ret->u.list.num_elements+1));
|
(ret->u.list.num_elements+1));
|
||||||
if (!e) {
|
if (!e) {
|
||||||
errno = ENOMEM;
|
errno = ENOMEM;
|
||||||
@ -226,9 +225,9 @@ static struct ldb_parse_tree *ldb_parse_filterlist(TALLOC_CTX *mem_ctx,
|
|||||||
/*
|
/*
|
||||||
<not> ::= '!' <filter>
|
<not> ::= '!' <filter>
|
||||||
*/
|
*/
|
||||||
static struct ldb_parse_tree *ldb_parse_not(TALLOC_CTX *mem_ctx, const char *s)
|
static struct ldap_parse_tree *ldap_parse_not(TALLOC_CTX *mem_ctx, const char *s)
|
||||||
{
|
{
|
||||||
struct ldb_parse_tree *ret;
|
struct ldap_parse_tree *ret;
|
||||||
|
|
||||||
ret = talloc(mem_ctx, sizeof(*ret));
|
ret = talloc(mem_ctx, sizeof(*ret));
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
@ -236,8 +235,8 @@ static struct ldb_parse_tree *ldb_parse_not(TALLOC_CTX *mem_ctx, const char *s)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret->operation = LDB_OP_NOT;
|
ret->operation = LDAP_OP_NOT;
|
||||||
ret->u.not.child = ldb_parse_filter(mem_ctx, &s);
|
ret->u.not.child = ldap_parse_filter(mem_ctx, &s);
|
||||||
if (!ret->u.not.child)
|
if (!ret->u.not.child)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -248,41 +247,41 @@ static struct ldb_parse_tree *ldb_parse_not(TALLOC_CTX *mem_ctx, const char *s)
|
|||||||
parse a filtercomp
|
parse a filtercomp
|
||||||
<filtercomp> ::= <and> | <or> | <not> | <simple>
|
<filtercomp> ::= <and> | <or> | <not> | <simple>
|
||||||
*/
|
*/
|
||||||
static struct ldb_parse_tree *ldb_parse_filtercomp(TALLOC_CTX *mem_ctx,
|
static struct ldap_parse_tree *ldap_parse_filtercomp(TALLOC_CTX *mem_ctx,
|
||||||
const char *s)
|
const char *s)
|
||||||
{
|
{
|
||||||
while (isspace(*s)) s++;
|
while (isspace(*s)) s++;
|
||||||
|
|
||||||
switch (*s) {
|
switch (*s) {
|
||||||
case '&':
|
case '&':
|
||||||
return ldb_parse_filterlist(mem_ctx, LDB_OP_AND, s+1);
|
return ldap_parse_filterlist(mem_ctx, LDAP_OP_AND, s+1);
|
||||||
|
|
||||||
case '|':
|
case '|':
|
||||||
return ldb_parse_filterlist(mem_ctx, LDB_OP_OR, s+1);
|
return ldap_parse_filterlist(mem_ctx, LDAP_OP_OR, s+1);
|
||||||
|
|
||||||
case '!':
|
case '!':
|
||||||
return ldb_parse_not(mem_ctx, s+1);
|
return ldap_parse_not(mem_ctx, s+1);
|
||||||
|
|
||||||
case '(':
|
case '(':
|
||||||
case ')':
|
case ')':
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ldb_parse_simple(mem_ctx, s);
|
return ldap_parse_simple(mem_ctx, s);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
<filter> ::= '(' <filtercomp> ')'
|
<filter> ::= '(' <filtercomp> ')'
|
||||||
*/
|
*/
|
||||||
static struct ldb_parse_tree *ldb_parse_filter(TALLOC_CTX *mem_ctx,
|
static struct ldap_parse_tree *ldap_parse_filter(TALLOC_CTX *mem_ctx,
|
||||||
const char **s)
|
const char **s)
|
||||||
{
|
{
|
||||||
char *l, *s2;
|
char *l, *s2;
|
||||||
const char *p, *p2;
|
const char *p, *p2;
|
||||||
struct ldb_parse_tree *ret;
|
struct ldap_parse_tree *ret;
|
||||||
|
|
||||||
l = ldb_parse_lex(mem_ctx, s, LDB_ALL_SEP);
|
l = ldap_parse_lex(mem_ctx, s, LDAP_ALL_SEP);
|
||||||
if (!l) {
|
if (!l) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@ -303,7 +302,7 @@ static struct ldb_parse_tree *ldb_parse_filter(TALLOC_CTX *mem_ctx,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = ldb_parse_filtercomp(mem_ctx, s2);
|
ret = ldap_parse_filtercomp(mem_ctx, s2);
|
||||||
|
|
||||||
*s = p2;
|
*s = p2;
|
||||||
|
|
||||||
@ -315,21 +314,21 @@ static struct ldb_parse_tree *ldb_parse_filter(TALLOC_CTX *mem_ctx,
|
|||||||
|
|
||||||
expression ::= <simple> | <filter>
|
expression ::= <simple> | <filter>
|
||||||
*/
|
*/
|
||||||
static struct ldb_parse_tree *ldb_parse_tree(TALLOC_CTX *mem_ctx, const char *s)
|
static struct ldap_parse_tree *ldap_parse_tree(TALLOC_CTX *mem_ctx, const char *s)
|
||||||
{
|
{
|
||||||
while (isspace(*s)) s++;
|
while (isspace(*s)) s++;
|
||||||
|
|
||||||
if (*s == '(') {
|
if (*s == '(') {
|
||||||
return ldb_parse_filter(mem_ctx, &s);
|
return ldap_parse_filter(mem_ctx, &s);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ldb_parse_simple(mem_ctx, s);
|
return ldap_parse_simple(mem_ctx, s);
|
||||||
}
|
}
|
||||||
|
|
||||||
static BOOL ldap_push_filter(ASN1_DATA *data, struct ldb_parse_tree *tree)
|
static BOOL ldap_push_filter(ASN1_DATA *data, struct ldap_parse_tree *tree)
|
||||||
{
|
{
|
||||||
switch (tree->operation) {
|
switch (tree->operation) {
|
||||||
case LDB_OP_SIMPLE: {
|
case LDAP_OP_SIMPLE: {
|
||||||
if ((tree->u.simple.value.length == 1) &&
|
if ((tree->u.simple.value.length == 1) &&
|
||||||
(((char *)(tree->u.simple.value.data))[0] == '*')) {
|
(((char *)(tree->u.simple.value.data))[0] == '*')) {
|
||||||
/* Just a presence test */
|
/* Just a presence test */
|
||||||
@ -350,7 +349,7 @@ static BOOL ldap_push_filter(ASN1_DATA *data, struct ldb_parse_tree *tree)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case LDB_OP_AND: {
|
case LDAP_OP_AND: {
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
asn1_push_tag(data, 0xa0);
|
asn1_push_tag(data, 0xa0);
|
||||||
@ -361,7 +360,7 @@ static BOOL ldap_push_filter(ASN1_DATA *data, struct ldb_parse_tree *tree)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case LDB_OP_OR: {
|
case LDAP_OP_OR: {
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
asn1_push_tag(data, 0xa1);
|
asn1_push_tag(data, 0xa1);
|
||||||
@ -454,7 +453,7 @@ static char *next_chunk(TALLOC_CTX *mem_ctx,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* simple ldif attribute parser */
|
/* simple ldif attribute parser */
|
||||||
static int next_attr(char **s, const char **attr, struct ldb_val *value)
|
static int next_attr(char **s, const char **attr, struct ldap_val *value)
|
||||||
{
|
{
|
||||||
char *p;
|
char *p;
|
||||||
int base64_encoded = 0;
|
int base64_encoded = 0;
|
||||||
@ -507,7 +506,7 @@ static int next_attr(char **s, const char **attr, struct ldb_val *value)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static BOOL add_value_to_attrib(TALLOC_CTX *mem_ctx, struct ldb_val *value,
|
static BOOL add_value_to_attrib(TALLOC_CTX *mem_ctx, struct ldap_val *value,
|
||||||
struct ldap_attribute *attrib)
|
struct ldap_attribute *attrib)
|
||||||
{
|
{
|
||||||
attrib->values = talloc_realloc(mem_ctx, attrib->values,
|
attrib->values = talloc_realloc(mem_ctx, attrib->values,
|
||||||
@ -526,7 +525,7 @@ static BOOL fill_add_attributes(struct ldap_message *msg, char **chunk)
|
|||||||
{
|
{
|
||||||
struct ldap_AddRequest *r = &msg->r.AddRequest;
|
struct ldap_AddRequest *r = &msg->r.AddRequest;
|
||||||
const char *attr_name;
|
const char *attr_name;
|
||||||
struct ldb_val value;
|
struct ldap_val value;
|
||||||
|
|
||||||
r->num_attributes = 0;
|
r->num_attributes = 0;
|
||||||
r->attributes = NULL;
|
r->attributes = NULL;
|
||||||
@ -583,7 +582,7 @@ static BOOL fill_mods(struct ldap_message *msg, char **chunk)
|
|||||||
{
|
{
|
||||||
struct ldap_ModifyRequest *r = &msg->r.ModifyRequest;
|
struct ldap_ModifyRequest *r = &msg->r.ModifyRequest;
|
||||||
const char *attr_name;
|
const char *attr_name;
|
||||||
struct ldb_val value;
|
struct ldap_val value;
|
||||||
|
|
||||||
r->num_mods = 0;
|
r->num_mods = 0;
|
||||||
r->mods = NULL;
|
r->mods = NULL;
|
||||||
@ -647,7 +646,7 @@ static struct ldap_message *ldif_read(int (*fgetc_fn)(void *),
|
|||||||
const char *attr=NULL;
|
const char *attr=NULL;
|
||||||
const char *dn;
|
const char *dn;
|
||||||
char *chunk=NULL, *s;
|
char *chunk=NULL, *s;
|
||||||
struct ldb_val value;
|
struct ldap_val value;
|
||||||
|
|
||||||
value.data = NULL;
|
value.data = NULL;
|
||||||
|
|
||||||
@ -822,13 +821,13 @@ BOOL ldap_encode(struct ldap_message *msg, DATA_BLOB *result)
|
|||||||
asn1_write_BOOLEAN2(&data, r->attributesonly);
|
asn1_write_BOOLEAN2(&data, r->attributesonly);
|
||||||
|
|
||||||
{
|
{
|
||||||
TALLOC_CTX *mem_ctx = talloc_init("ldb_parse_tree");
|
TALLOC_CTX *mem_ctx = talloc_init("ldap_parse_tree");
|
||||||
struct ldb_parse_tree *tree;
|
struct ldap_parse_tree *tree;
|
||||||
|
|
||||||
if (mem_ctx == NULL)
|
if (mem_ctx == NULL)
|
||||||
return False;
|
return False;
|
||||||
|
|
||||||
tree = ldb_parse_tree(mem_ctx, r->filter);
|
tree = ldap_parse_tree(mem_ctx, r->filter);
|
||||||
|
|
||||||
if (tree == NULL)
|
if (tree == NULL)
|
||||||
return False;
|
return False;
|
||||||
@ -872,7 +871,7 @@ BOOL ldap_encode(struct ldap_message *msg, DATA_BLOB *result)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case LDAP_TAG_SearchResultDone: {
|
case LDAP_TAG_SearchResultDone: {
|
||||||
struct ldap_SearchResultDone *r = &msg->r.SearchResultDone;
|
struct ldap_Result *r = &msg->r.SearchResultDone;
|
||||||
ldap_encode_response(msg->type, r, &data);
|
ldap_encode_response(msg->type, r, &data);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1195,7 +1194,7 @@ static void ldap_decode_attrib(TALLOC_CTX *mem_ctx, ASN1_DATA *data,
|
|||||||
asn1_start_tag(data, ASN1_SET);
|
asn1_start_tag(data, ASN1_SET);
|
||||||
while (asn1_peek_tag(data, ASN1_OCTET_STRING)) {
|
while (asn1_peek_tag(data, ASN1_OCTET_STRING)) {
|
||||||
DATA_BLOB blob;
|
DATA_BLOB blob;
|
||||||
struct ldb_val value;
|
struct ldap_val value;
|
||||||
asn1_read_OctetString(data, &blob);
|
asn1_read_OctetString(data, &blob);
|
||||||
value.data = blob.data;
|
value.data = blob.data;
|
||||||
value.length = blob.length;
|
value.length = blob.length;
|
||||||
@ -1323,7 +1322,7 @@ BOOL ldap_decode(ASN1_DATA *data, struct ldap_message *msg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
case ASN1_APPLICATION(LDAP_TAG_SearchResultDone): {
|
case ASN1_APPLICATION(LDAP_TAG_SearchResultDone): {
|
||||||
struct ldap_SearchResultDone *r = &msg->r.SearchResultDone;
|
struct ldap_Result *r = &msg->r.SearchResultDone;
|
||||||
msg->type = LDAP_TAG_SearchResultDone;
|
msg->type = LDAP_TAG_SearchResultDone;
|
||||||
ldap_decode_response(msg->mem_ctx, data,
|
ldap_decode_response(msg->mem_ctx, data,
|
||||||
LDAP_TAG_SearchResultDone, r);
|
LDAP_TAG_SearchResultDone, r);
|
||||||
@ -1364,7 +1363,7 @@ BOOL ldap_decode(ASN1_DATA *data, struct ldap_message *msg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
case ASN1_APPLICATION(LDAP_TAG_ModifyResponse): {
|
case ASN1_APPLICATION(LDAP_TAG_ModifyResponse): {
|
||||||
struct ldap_ModifyResponse *r = &msg->r.ModifyResponse;
|
struct ldap_Result *r = &msg->r.ModifyResponse;
|
||||||
msg->type = LDAP_TAG_ModifyResponse;
|
msg->type = LDAP_TAG_ModifyResponse;
|
||||||
ldap_decode_response(msg->mem_ctx, data,
|
ldap_decode_response(msg->mem_ctx, data,
|
||||||
LDAP_TAG_ModifyResponse, r);
|
LDAP_TAG_ModifyResponse, r);
|
||||||
@ -1387,7 +1386,7 @@ BOOL ldap_decode(ASN1_DATA *data, struct ldap_message *msg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
case ASN1_APPLICATION(LDAP_TAG_AddResponse): {
|
case ASN1_APPLICATION(LDAP_TAG_AddResponse): {
|
||||||
struct ldap_AddResponse *r = &msg->r.AddResponse;
|
struct ldap_Result *r = &msg->r.AddResponse;
|
||||||
msg->type = LDAP_TAG_AddResponse;
|
msg->type = LDAP_TAG_AddResponse;
|
||||||
ldap_decode_response(msg->mem_ctx, data,
|
ldap_decode_response(msg->mem_ctx, data,
|
||||||
LDAP_TAG_AddResponse, r);
|
LDAP_TAG_AddResponse, r);
|
||||||
@ -1413,7 +1412,7 @@ BOOL ldap_decode(ASN1_DATA *data, struct ldap_message *msg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
case ASN1_APPLICATION(LDAP_TAG_DelResponse): {
|
case ASN1_APPLICATION(LDAP_TAG_DelResponse): {
|
||||||
struct ldap_DelResponse *r = &msg->r.DelResponse;
|
struct ldap_Result *r = &msg->r.DelResponse;
|
||||||
msg->type = LDAP_TAG_DelResponse;
|
msg->type = LDAP_TAG_DelResponse;
|
||||||
ldap_decode_response(msg->mem_ctx, data,
|
ldap_decode_response(msg->mem_ctx, data,
|
||||||
LDAP_TAG_DelResponse, r);
|
LDAP_TAG_DelResponse, r);
|
||||||
@ -1427,7 +1426,7 @@ BOOL ldap_decode(ASN1_DATA *data, struct ldap_message *msg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
case ASN1_APPLICATION(LDAP_TAG_ModifyDNResponse): {
|
case ASN1_APPLICATION(LDAP_TAG_ModifyDNResponse): {
|
||||||
struct ldap_ModifyDNResponse *r = &msg->r.ModifyDNResponse;
|
struct ldap_Result *r = &msg->r.ModifyDNResponse;
|
||||||
msg->type = LDAP_TAG_ModifyDNResponse;
|
msg->type = LDAP_TAG_ModifyDNResponse;
|
||||||
ldap_decode_response(msg->mem_ctx, data,
|
ldap_decode_response(msg->mem_ctx, data,
|
||||||
LDAP_TAG_ModifyDNResponse, r);
|
LDAP_TAG_ModifyDNResponse, r);
|
||||||
@ -1441,7 +1440,7 @@ BOOL ldap_decode(ASN1_DATA *data, struct ldap_message *msg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
case ASN1_APPLICATION(LDAP_TAG_CompareResponse): {
|
case ASN1_APPLICATION(LDAP_TAG_CompareResponse): {
|
||||||
struct ldap_CompareResponse *r = &msg->r.CompareResponse;
|
struct ldap_Result *r = &msg->r.CompareResponse;
|
||||||
msg->type = LDAP_TAG_CompareResponse;
|
msg->type = LDAP_TAG_CompareResponse;
|
||||||
ldap_decode_response(msg->mem_ctx, data,
|
ldap_decode_response(msg->mem_ctx, data,
|
||||||
LDAP_TAG_CompareResponse, r);
|
LDAP_TAG_CompareResponse, r);
|
||||||
@ -1666,13 +1665,12 @@ static void add_search_entry(struct ldap_connection *conn,
|
|||||||
struct ldap_message *msg)
|
struct ldap_message *msg)
|
||||||
{
|
{
|
||||||
struct ldap_queue_entry *e = malloc(sizeof *e);
|
struct ldap_queue_entry *e = malloc(sizeof *e);
|
||||||
struct ldap_queue_entry *tmp;
|
|
||||||
|
|
||||||
if (e == NULL)
|
if (e == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
e->msg = msg;
|
e->msg = msg;
|
||||||
DLIST_ADD_END(conn->search_entries, e, tmp);
|
DLIST_ADD_END(conn->search_entries, e, struct ldap_queue_entry *);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user