Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

93 lines
2.5 KiB

///////////////////////////////////////////////////////////////////////////////
//
// Copyright (c) 1998, Microsoft Corp. All rights reserved.
//
// FILE
//
// ldapdnary.h
//
// SYNOPSIS
//
// This file declares the class LDAPDictionary.
//
// MODIFICATION HISTORY
//
// 02/24/1998 Original version.
// 04/20/1998 Added flags and InjectorProc to the attribute schema.
// 05/01/1998 Changed signature of InjectorProc.
//
///////////////////////////////////////////////////////////////////////////////
#ifndef _LDAPDNARY_H_
#define _LDAPDNARY_H_
#include <iaspolcy.h>
#include <winldap.h>
//////////
// Prototype for an injector procedure. These are procedures for inserting
// attributes into a request.
//////////
typedef VOID (WINAPI *InjectorProc)(
IAttributesRaw* dst,
PATTRIBUTEPOSITION first,
PATTRIBUTEPOSITION last
);
//////////
// Struct that defines an LDAP/IAS attribute.
//////////
struct LDAPAttribute
{
PCWSTR ldapName; // The LDAP name of the attribute.
DWORD iasID; // The IAS attribute ID.
IASTYPE iasType; // The IAS syntax of the attribute.
DWORD flags; // Flags that should be applied to the attribute.
InjectorProc injector; // Used for adding the attribute to the request.
};
///////////////////////////////////////////////////////////////////////////////
//
// CLASS
//
// LDAPDictionary
//
// DESCRIPTION
//
// This class uses a sorted array of LDAPAttribute's to convert LDAP
// attribute/value pairs into IASATTRIBUTE structs.
//
///////////////////////////////////////////////////////////////////////////////
class LDAPDictionary
{
public:
// 'entries' must already be sorted.
LDAPDictionary(
size_t numEntries,
const LDAPAttribute* entries
) throw ()
: num(numEntries), base(entries)
{ }
// Finds the definition for a given attribute. Returns NULL if not found.
const LDAPAttribute* find(PCWSTR key) const throw ()
{
return (const LDAPAttribute*)
bsearch(&key, base, num, sizeof(LDAPAttribute), compare);
}
// Inserts all the attributes from src into dst.
void insert(
IAttributesRaw* dst,
LDAPMessage* src
) const;
protected:
const size_t num; // Number of attributes in dictionary.
const LDAPAttribute* const base; // Sorted array of attributes.
// Comparison function used for searching the dictionary.
static int __cdecl compare(const void *elem1, const void *elem2);
};
#endif // _LDAPDNARY_H_