2020-09-30 16:53:55 +02:00

1767 lines
62 KiB
C++

/*++
Copyright (c) 1995 Microsoft Corporation
Module Name:
Nds32.h
Abstract:
This module defines functions to access and manage Novell NDS Directory
objects and attributes using the Microsoft NT Netware redirector.
---- NDS Object functions ----
NwNdsAddObject
NwNdsCloseObject
NwNdsGetEffectiveRights
NwNdsListSubObjects
NwNdsModifyObject
NwNdsMoveObject
NwNdsOpenObject
NwNdsReadObject
NwNdsRemoveObject
NwNdsRenameObject
---- NDS Buffer functions ----
NwNdsCreateBuffer
NwNdsFreeBuffer
---- NDS Marshaling functions to prepare or read data buffers ----
NwNdsGetAttrDefListFromBuffer
NwNdsGetAttrListFromBuffer
NwNdsGetClassDefListFromBuffer
NwNdsGetObjectListFromBuffer
NwNdsPutInBuffer
---- NDS Schema functions ----
NwNdsAddAttributeToClass
NwNdsDefineAttribute
NwNdsDefineClass
NwNdsDeleteAttrDef
NwNdsDeleteClassDef
NwNdsGetSyntaxID
NwNdsReadAttrDef
NwNdsReadClassDef
---- NDS Schema functions under investigation ----
NwNdsListContainableClasses(IN ParentObjectHandle,OUT ListOfClassNames);
---- NDS Search functions ----
NwNdsCreateQueryNode
NwNdsDeleteQueryNode
NwNdsDeleteQueryTree
NwNdsSearch
---- NDS Special functions ----
NwNdsChangeUserPassword
---- NDS File functions under investigation ----
NwNdsAddTrusteeToFile
NwNdsAllocateFileHandle
NwNdsDeallocateFileHandle
NwNdsGetEffectiveDirectoryRights
NwNdsGetObjectEffectiveRights
NwNdsRemoveTrusteeFromFile
Author:
Glenn Curtis [GlennC] 15-Dec-1995
Glenn Curtis [GlennC] 04-Apr-1996 - Added Schema APIs
--*/
#ifndef __NDSOBJ32_H
#define __NDSOBJ32_H
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
#include "ndssntx.h"
#include "ndsattr.h"
#include "ndsclass.h"
/* Netware NDS general definitions */
#define NDS_MAX_NAME_CHARS 256
#define NDS_MAX_NAME_SIZE ( NDS_MAX_NAME_CHARS * 2 )
#define NDS_MAX_SCHEMA_NAME_CHARS 32
#define NDS_MAX_SCHEMA_NAME_BYTES ( 2 * ( NDS_MAX_SCHEMA_NAME_CHARS + 1 ) )
#define NDS_MAX_TREE_NAME_LEN 32
#define NDS_MAX_ASN1_NAME_LEN 32
#define NDS_NO_MORE_ITERATIONS 0xFFFFFFFF
#define NDS_INITIAL_SEARCH 0xFFFFFFFF
/* Netware NDS create buffer operations */
#define NDS_OBJECT_ADD 0
#define NDS_OBJECT_MODIFY 1
#define NDS_OBJECT_READ 2
#define NDS_OBJECT_LIST_SUBORDINATES 3
#define NDS_SCHEMA_DEFINE_CLASS 4
#define NDS_SCHEMA_READ_ATTR_DEF 5
#define NDS_SCHEMA_READ_CLASS_DEF 6
#define NDS_SEARCH 7
/* Netware NDS attribute modification operations */
#define NDS_ATTR_ADD 0 /* Add first value to an attribute,
error if it already exists */
#define NDS_ATTR_REMOVE 1 /* Remove all values from an attribute,
error if attribute doesn't exist */
#define NDS_ATTR_ADD_VALUE 2 /* Add first or additional value to
an attribute, error if duplicate */
#define NDS_ATTR_REMOVE_VALUE 3 /* Remove a value from an attribute,
error if it doesn't exist */
#define NDS_ATTR_ADDITIONAL_VALUE 4 /* Add additional value to an attribute,
error if duplicate or first value */
#define NDS_ATTR_OVERWRITE_VALUE 5 /* Add first or additional value to an
attribute, overwrite if duplicate */
#define NDS_ATTR_CLEAR 6 /* Remove all values from an attribute,
no error if attribute doesn't exist */
#define NDS_ATTR_CLEAR_VALUE 7 /* Remove a value from an attribute,
no error if it doesn't exist */
/* Netware NDS schema attribute definition flags */
#define NDS_SINGLE_VALUED_ATTR 0x0001
#define NDS_SIZED_ATTR 0x0002
#define NDS_NONREMOVABLE_ATTR 0x0004 // Only for NwNDSReadAttributeDef
#define NDS_READ_ONLY_ATTR 0x0008 // Only for NwNDSReadAttributeDef
#define NDS_HIDDEN_ATTR 0x0010 // Only for NwNDSReadAttributeDef
#define NDS_STRING_ATTR 0x0020 // Only for NwNDSReadAttributeDef
#define NDS_SYNC_IMMEDIATE 0x0040
#define NDS_PUBLIC_READ 0x0080
#define NDS_SERVER_READ 0x0100 // Only for NwNDSReadAttributeDef
#define NDS_WRITE_MANAGED 0x0200
#define NDS_PER_REPLICA 0x0400
/* Netware NDS schema class definition flags */
#define NDS_CONTAINER_CLASS 0x01
#define NDS_EFFECTIVE_CLASS 0x02
#define NDS_NONREMOVABLE_CLASS 0x04
#define NDS_AMBIGUOUS_NAMING 0x08
#define NDS_AMBIGUOUS_CONTAINMENT 0x10
/* Netware NDS information flags */
#define NDS_INFO_NAMES 0 // Search and Read operations
#define NDS_INFO_ATTR_NAMES_VALUES 1 // Search operations
#define NDS_INFO_NAMES_DEFS 1 // Read operations
#define NDS_CLASS_INFO_EXPANDED_DEFS 2 // Schema class definition only
/* Netware NDS information flags - NOT YET SUPPORTED */
#define NDS_CLASS_INFO 3 // Schema class definition only
/* Netware NDS attribute right definitions */
#define NDS_RIGHT_COMPARE_ATTR 0x00000001L
#define NDS_RIGHT_READ_ATTR 0x00000002L
#define NDS_RIGHT_WRITE_ATTR 0x00000004L
#define NDS_RIGHT_ADD_SELF_ATTR 0x00000008L
#define NDS_RIGHT_SUPERVISE_ATTR 0x00000020L
/* Netware NDS object right definitions */
#define NDS_RIGHT_BROWSE_OBJECT 0x00000001L
#define NDS_RIGHT_CREATE_OBJECT 0x00000002L
#define NDS_RIGHT_DELETE_OBJECT 0x00000004L
#define NDS_RIGHT_RENAME_OBJECT 0x00000008L
#define NDS_RIGHT_SUPERVISE_OBJECT 0x00000010L
/* Netware file right definitions */
#define NW_RIGHTS WORD
#define NW_RIGHT_NONE 0x0000
#define NW_RIGHT_READ_FROM_FILE 0x0001
#define NW_RIGHT_WRITE_TO_FILE 0x0002
#define NW_RIGHT_CREATE_DIR_OR_FILE 0x0008
#define NW_RIGHT_ERASE_DIR_OR_FILE 0x0010
#define NW_RIGHT_ACCESS_CONTROL 0x0020
#define NW_RIGHT_FILE_SCAN 0x0040
#define NW_RIGHT_MODIFY_DIR_OR_FILE 0x0080
#define NW_RIGHT_SUPERVISOR 0x0100
#define NW_RIGHT_ALL NW_RIGHT_READ_FROM_FILE | \
NW_RIGHT_WRITE_TO_FILE | \
NW_RIGHT_CREATE_DIR_OR_FILE | \
NW_RIGHT_ERASE_DIR_OR_FILE | \
NW_RIGHT_ACCESS_CONTROL | \
NW_RIGHT_FILE_SCAN | \
NW_RIGHT_MODIFY_DIR_OR_FILE
/* Netware NDS query node operations for building a search query */
#define NDS_QUERY_OR 0x00000001L
#define NDS_QUERY_AND 0x00000002L
#define NDS_QUERY_NOT 0x00000003L
#define NDS_QUERY_EQUAL 0x00000007L
#define NDS_QUERY_GE 0x00000008L
#define NDS_QUERY_LE 0x00000009L
#define NDS_QUERY_APPROX 0x0000000AL
#define NDS_QUERY_PRESENT 0x0000000FL
/* Netware NDS search query scopes */
#define NDS_SCOPE_ONE_LEVEL 0x00000000L
#define NDS_SCOPE_SUB_TREE 0x00000001L
#define NDS_SCOPE_BASE_LEVEL 0x00000002L
/* Netware NDS function return codes */
#define NDS_ERR_SUCCESS 0x00000000
#define NDS_ERR_NO_SUCH_ENTRY 0xFFFFFDA7
#define NDS_ERR_NO_SUCH_VALUE 0xFFFFFDA6
#define NDS_ERR_NO_SUCH_ATTRIBUTE 0xFFFFFDA5
#define NDS_ERR_NO_SUCH_CLASS 0xFFFFFDA4
#define NDS_ERR_NO_SUCH_PARTITION 0xFFFFFDA3
#define NDS_ERR_ENTRY_ALREADY_EXISTS 0xFFFFFDA2
#define NDS_ERR_NOT_EFFECTIVE_CLASS 0xFFFFFDA1
#define NDS_ERR_ILLEGAL_ATTRIBUTE 0xFFFFFDA0
#define NDS_ERR_MISSING_MANDATORY 0xFFFFFD9F
#define NDS_ERR_ILLEGAL_DS_NAME 0xFFFFFD9E
#define NDS_ERR_ILLEGAL_CONTAINMENT 0xFFFFFD9D
#define NDS_ERR_CANT_HAVE_MULTIPLE_VALUES 0xFFFFFD9C
#define NDS_ERR_SYNTAX_VIOLATION 0xFFFFFD9B
#define NDS_ERR_DUPLICATE_VALUE 0xFFFFFD9A
#define NDS_ERR_ATTRIBUTE_ALREADY_EXISTS 0xFFFFFD99
#define NDS_ERR_MAXIMUM_ENTRIES_EXIST 0xFFFFFD98
#define NDS_ERR_DATABASE_FORMAT 0xFFFFFD97
#define NDS_ERR_INCONSISTANT_DATABASE 0xFFFFFD96
#define NDS_ERR_INVALID_COMPARISON 0xFFFFFD95
#define NDS_ERR_COMPARISON_FAILED 0xFFFFFD94
#define NDS_ERR_TRANSACTIONS_DISABLED 0xFFFFFD93
#define NDS_ERR_INVALID_TRANSPORT 0xFFFFFD92
#define NDS_ERR_SYNTAX_INVALID_IN_NAME 0xFFFFFD91
#define NDS_ERR_REPLICA_ALREADY_EXISTS 0xFFFFFD90
#define NDS_ERR_TRANSPORT_FAILURE 0xFFFFFD8F
#define NDS_ERR_ALL_REFERRALS_FAILED 0xFFFFFD8E
#define NDS_ERR_CANT_REMOVE_NAMING_VALUE 0xFFFFFD8D
#define NDS_ERR_OBJECT_CLASS_VIOLATION 0xFFFFFD8C
#define NDS_ERR_ENTRY_IS_NOT_LEAF 0xFFFFFD8B
#define NDS_ERR_DIFFERENT_TREE 0xFFFFFD8A
#define NDS_ERR_ILLEGAL_REPLICA_TYPE 0xFFFFFD89
#define NDS_ERR_SYSTEM_FAILURE 0xFFFFFD88
#define NDS_ERR_INVALID_ENTRY_FOR_ROOT 0xFFFFFD87
#define NDS_ERR_NO_REFERRALS 0xFFFFFD86
#define NDS_ERR_REMOTE_FAILURE 0xFFFFFD85
#define NDS_ERR_PREVIOUS_MOVE_IN_PROGRESS 0xFFFFFD83
#define NDS_ERR_INVALID_REQUEST 0xFFFFFD7F
#define NDS_ERR_INVALID_ITERATION 0xFFFFFD7E
#define NDS_ERR_SCHEMA_IS_NONREMOVABLE 0xFFFFFD7D
#define NDS_ERR_SCHEMA_IS_IN_USE 0xFFFFFD7C
#define NDS_ERR_CLASS_ALREADY_EXISTS 0xFFFFFD7B
#define NDS_ERR_BAD_NAMING_ATTRIBUTES 0xFFFFFD7A
#define NDS_ERR_NOT_ROOT_PARTITION 0xFFFFFD79
#define NDS_ERR_INSUFFICIENT_STACK 0xFFFFFD78
#define NDS_ERR_INSUFFICIENT_BUFFER 0xFFFFFD77
#define NDS_ERR_AMBIGUOUS_CONTAINMENT 0xFFFFFD76
#define NDS_ERR_AMBIGUOUS_NAMING 0xFFFFFD75
#define NDS_ERR_DUPLICATE_MANDATORY 0xFFFFFD74
#define NDS_ERR_DUPLICATE_OPTIONAL 0xFFFFFD73
#define NDS_ERR_MULTIPLE_REPLICAS 0xFFFFFD71
#define NDS_ERR_CRUCIAL_REPLICA 0xFFFFFD70
#define NDS_ERR_SCHEMA_SYNC_IN_PROGRESS 0xFFFFFD6F
#define NDS_ERR_SKULK_IN_PROGRESS 0xFFFFFD6E
#define NDS_ERR_TIME_NOT_SYNCRONIZED 0xFFFFFD6D
#define NDS_ERR_RECORD_IN_USE 0xFFFFFD6C
#define NDS_ERR_DS_VOLUME_NOT_MOUNTED 0xFFFFFD6B
#define NDS_ERR_DS_VOLUME_IO_FAILURE 0xFFFFFD6A
#define NDS_ERR_DS_LOCKED 0xFFFFFD69
#define NDS_ERR_OLD_EPOCH 0xFFFFFD68
#define NDS_ERR_NEW_EPOCH 0xFFFFFD67
#define NDS_ERR_PARTITION_ROOT 0xFFFFFD65
#define NDS_ERR_ENTRY_NOT_CONTAINER 0xFFFFFD64
#define NDS_ERR_FAILED_AUTHENTICATION 0xFFFFFD63
#define NDS_ERR_NO_SUCH_PARENT 0xFFFFFD61
#define NDS_ERR_NO_ACCESS 0xFFFFFD60
#define NDS_ERR_REPLICA_NOT_ON 0xFFFFFD5F
#define NDS_ERR_DUPLICATE_ACL 0xFFFFFD5A
#define NDS_ERR_PARTITION_ALREADY_EXISTS 0xFFFFFD59
#define NDS_ERR_NOT_SUBREF 0xFFFFFD58
#define NDS_ERR_ALIAS_OF_AN_ALIAS 0xFFFFFD57
#define NDS_ERR_AUDITING_FAILED 0xFFFFFD56
#define NDS_ERR_INVALID_API_VERSION 0xFFFFFD55
#define NDS_ERR_SECURE_NCP_VIOLATION 0xFFFFFD54
#define NDS_ERR_FATAL 0xFFFFFD45
/* Structure definitions used */
typedef struct _WSTR_LIST_ELEM
{
struct _WSTR_LIST_ELEM * Next;
LPWSTR szString;
} WSTR_LIST_ELEM, * LPWSTR_LIST;
typedef struct
{
DWORD length;
BYTE data[NDS_MAX_ASN1_NAME_LEN];
} ASN1_ID, * LPASN1_ID;
//
// NDS Attribute Definition structure
//
typedef struct
{
LPWSTR szAttributeName;
DWORD dwFlags;
DWORD dwSyntaxID;
DWORD dwLowerLimit;
DWORD dwUpperLimit;
ASN1_ID asn1ID;
} NDS_ATTR_DEF, * LPNDS_ATTR_DEF;
//
// NDS Class Definition structure
//
typedef struct
{
LPWSTR szClassName;
DWORD dwFlags;
ASN1_ID asn1ID;
DWORD dwNumberOfSuperClasses;
LPWSTR_LIST lpSuperClasses;
DWORD dwNumberOfContainmentClasses;
LPWSTR_LIST lpContainmentClasses;
DWORD dwNumberOfNamingAttributes;
LPWSTR_LIST lpNamingAttributes;
DWORD dwNumberOfMandatoryAttributes;
LPWSTR_LIST lpMandatoryAttributes;
DWORD dwNumberOfOptionalAttributes;
LPWSTR_LIST lpOptionalAttributes;
} NDS_CLASS_DEF, * LPNDS_CLASS_DEF;
//
// If read results from NwNdsReadAttrDef, or NwNdsReadClassDef
// returned names only (no attribute or class definitions),
// then an array of these NDS_DEF_NAME_ONLY structures is returned.
//
typedef struct
{
LPWSTR szName;
} NDS_NAME_ONLY, * LPNDS_NAME_ONLY;
//
// NDS Attribute Information structure
//
typedef struct
{
LPWSTR szAttributeName;
DWORD dwSyntaxId;
DWORD dwNumberOfValues;
LPBYTE lpValue;
} NDS_ATTR_INFO, * LPNDS_ATTR_INFO;
//
// NDS Object Information structure
//
typedef struct
{
LPWSTR szObjectFullName;
LPWSTR szObjectName;
LPWSTR szObjectClass;
DWORD dwEntryId;
DWORD dwModificationTime;
DWORD dwSubordinateCount;
DWORD dwNumberOfAttributes; // Zero for NwNdsReadObject results.
LPVOID lpAttribute; // For NwNdsSearch results, cast this
// to either LPNDS_ATTR_INFO or
// LPNDS_NAME_ONLY, depending on value of
// lpdwAttrInformationType from call to
// NwNdsGetObjectListFromBuffer.
} NDS_OBJECT_INFO, * LPNDS_OBJECT_INFO;
//
// tommye MS bug 88021 / MCS
//
// Moved this structure here from nw/nwlib/nds32.c so it could be
// accessed by NwNdsObjectHandleToConnHandle() in nw/nwlib/nwapi32.c.
// Renamed it from NDS_OBJECT to NDS_OBJECT_PRIV to avoid conflict
// with other structure of the same name.
//
typedef struct
{
DWORD Signature;
HANDLE NdsTree;
DWORD ObjectId;
DWORD ResumeId;
DWORD NdsRawDataBuffer;
DWORD NdsRawDataSize;
DWORD NdsRawDataId;
DWORD NdsRawDataCount;
WCHAR szContainerName[NDS_MAX_NAME_CHARS+4]; // add room for slashes and terminating null
WCHAR szRelativeName[NDS_MAX_NAME_CHARS+4]; // add room for slashes and terminating null
} NDS_OBJECT_PRIV, * LPNDS_OBJECT_PRIV;
//
// List Subordinate Objects Search Filter structures
//
typedef struct
{
LPWSTR szObjectClass;
} NDS_FILTER, * LPNDS_FILTER;
typedef struct
{
DWORD dwNumberOfFilters;
NDS_FILTER Filters[1];
} NDS_FILTER_LIST, * LPNDS_FILTER_LIST;
//
// NDS Search Query Tree structure
//
typedef struct _QUERY_NODE
{
DWORD dwOperation;
DWORD dwSyntaxId;
struct _QUERY_NODE * lpLVal;
struct _QUERY_NODE * lpRVal;
} QUERY_NODE, * LPQUERY_NODE, * LPQUERY_TREE;
//
// Given an NDS object handle, provides the NDS object ID
//
#define NwNdsGetObjectId(hObject) (((LPNDS_OBJECT_PRIV) hObject)->ObjectId)
/* API definitions */
DWORD
NwNdsAddObject(
IN HANDLE hParentObject,
IN LPWSTR szObjectName,
IN HANDLE hOperationData );
/*
NwNdsAddObject()
This function is used to add a leaf object to an NDS directory tree.
Arguments:
HANDLE hParentObject - A handle to the parent object in
the directory tree to add a new leaf to. Handle is
obtained by calling NwNdsOpenObject.
LPWSTR szObjectName - The directory name that the new leaf
object will be known by.
HANDLE hOperationData - A buffer containing a list of
attributes and values to create the new object. This
buffer is manipulated by the following functions:
NwNdsCreateBuffer (NDS_OBJECT_ADD),
NwNdsPutInBuffer, and NwNdsFreeBuffer.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsAddAttributeToClass(
IN HANDLE hTree,
IN LPWSTR szClassName,
IN LPWSTR szAttributeName );
/*
NwNdsAddAttributeToClass()
This function is used to modify the schema definition of a class by adding
an optional attribute to a particular class. Modification of existing NDS
class defintions is limited to only adding additional optional attributes.
NOTE: Currently this function only supports one attribute addition at a time.
It is possible to provide a version of this function that can add more
than one attribute at a time, although I don't think it will be
neccessary. Schema manipulation is considered to be an uncommon event.
Arguments:
HANDLE hTree - A handle to the directory tree to be
manipulated. Handle is obtained by calling
NwNdsOpenObject.
LPWSTR szClassName - The name of the class definition to be
modified.
LPWSTR szAttributeName - The name of the attribute to be added
as an optional attribute to the class defintion in the
schema.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsChangeUserPassword(
IN HANDLE hUserObject,
IN LPWSTR szOldPassword,
IN LPWSTR szNewPassword );
/*
NwNdsChangeUserPassword()
This function is used to change the password for a given user object
in a NDS directory tree.
Arguments:
HANDLE hUserObject - A handle to a specific user object in
the directory tree to change the password on. Handle
is obtained by calling NwNdsOpenObject.
LPWSTR szOldPassword - The current password set on the user
object hUserObject.
- OR -
If NwNdsChangeUserPassword is called from a client with
administrative priveleges to the specified user object
identified by hUserObject, then the szOldPassword
value can be blank (L""). This way resetting the user
password to szNewPassword.
LPWSTR szNewPassword - The new password to be set on the user
object hUserObject.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsCloseObject(
IN HANDLE hObject );
/*
NwNdsCloseObject()
This function is used to close the handle used to manipulate an object
in an NDS directory tree. The handle must be one Opened by NwNdsOpenObject.
Arguments:
HANDLE hObject - The handle of the object to be closed.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsCreateBuffer(
IN DWORD dwOperation,
OUT HANDLE * lphOperationData );
/*
NwNdsCreateBuffer()
This function is used to create a buffer used to describe object
transactions to a specific object in an NDS directory tree. This routine
allocates memory and is automatically resized as needed during calls
to NwNdsPutInBuffer. This buffer must be freed with NwNdsFreeBuffer.
Arguments:
DWORD dwOperation - Indicates how buffer is to be utilized.
Use defined values NDS_OBJECT_ADD, NDS_OBJECT_MODIFY,
NDS_OBJECT_READ, NDS_SCHEMA_DEFINE_CLASS,
NDS_SCHEMA_READ_ATTR_DEF, NDS_SCHEMA_READ_CLASS_DEF,
or NDS_SEARCH.
HANDLE * lphOperationData - Address of a HANDLE handle to
receive created buffer.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsCreateQueryNode(
IN DWORD dwOperation,
IN LPVOID lpLValue,
IN DWORD dwSyntaxId,
IN LPVOID lpRValue,
OUT LPQUERY_NODE * lppQueryNode
);
/*
NwNdsCreateQueryNode()
This function is used to generate a tree node that is part of a query
to be used with the function NwNdsSearch.
Arguments:
DWORD dwOperation - Indicates the type of node to create
for a search query. Use one of the defined values
below:
NDS_QUERY_OR
NDS_QUERY_AND :
These operations must have both lpLValue and
lpRValue pointing to a QUERY_NODE structure.
In this case the dwSyntaxId value is ignored.
NDS_QUERY_NOT :
This operation must have lpLValue pointing to a
QUERY_NODE structure and lpRValue set to NULL.
In this case the dwSyntaxId value is ignored.
NDS_QUERY_EQUAL
NDS_QUERY_GE
NDS_QUERY_LE
NDS_QUERY_APPROX :
These operations must have lpLValue pointing to
a LPWSTR containing the name of an NDS attribute,
and lpRValue pointing to an ASN1 structure defined
in NdsSntx.h. dwSyntaxId must be set to the syntax
identifier of the ASN1 structure pointed to by
lpRValue.
NDS_QUERY_PRESENT :
This operation must have lpLValue pointing to a
LPWSTR containing the name of an NDS attribute,
and lpRValue set to NULL. In this case the
dwSyntaxId value is ignored.
LPVOID lpLValue - A pointer to either a QUERY_NODE structure
or a LPWSTR depending on the value for dwOperation.
DWORD dwSyntaxId - The syntax identifier of the ASN1
structure pointed to by lpRValue for the dwOperations
NDS_QUERY_EQUAL, NDS_QUERY_GE, NDS_QUERY_LE, or
NDS_QUERY_APPROX. For other dwOperation values, this
is ignored.
LPVOID lpRValue - A pointer to either a QUERY_NODE structure,
an ASN1 structure, or NULL, depending on the value for
dwOperation.
LPQUERY_NODE * lppQueryNode - Address of a LPQUERY_NODE to receive
a pointer to created node.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsDefineAttribute(
IN HANDLE hTree,
IN LPWSTR szAttributeName,
IN DWORD dwFlags,
IN DWORD dwSyntaxID,
IN DWORD dwLowerLimit,
IN DWORD dwUpperLimit,
IN ASN1_ID asn1ID );
/*
NwNdsDefineAttribute()
This function is used to create an attribute definition in the schema of
NDS tree hTree.
Arguments:
HANDLE hTree - A handle to the directory tree to be
manipulated. Handle is obtained by calling
NwNdsOpenObject.
LPWSTR szAttributeName - The name that the new attribute will
be referred to by.
DWORD dwFlags - Flags values to be set for new attribute
definition. Definitions for flag values are found at
the top of this file.
DWORD dwSyntaxID - The ID of the syntax structure to be use
for the new attribute. Syntax IDs and their associated
structures are defined in the file NdsSntx.h. According
to the NetWare NDS schema spec, there is and always will
be, only 28 (0..27) different syntaxes.
DWORD dwLowerLimit - The lower limit of a sized attribute
(dwFlags value set to NDS_SIZED_ATTR). Can be set to
zero if attribute is not sized.
DWORD dwUpperLimit - The upper limit of a sized attribute
(dwFlags value set to NDS_SIZED_ATTR). Can be set to
zero if attribute is not sized.
ASN1_ID asn1ID - The ASN.1 ID for the attribute. If no
attribute identifier has been registered, a
zero-length octet string is specified.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsDefineClass(
IN HANDLE hTree,
IN LPWSTR szClassName,
IN DWORD dwFlags,
IN ASN1_ID asn1ID,
IN HANDLE hSuperClasses,
IN HANDLE hContainmentClasses,
IN HANDLE hNamingAttributes,
IN HANDLE hMandatoryAttributes,
IN HANDLE hOptionalAttributes );
/*
NwNdsDefineClass()
This function is used to create a class definition in the schema of
NDS tree hTree.
Arguments:
HANDLE hTree - A handle to the directory tree to be
manipulated. Handle is obtained by calling
NwNdsOpenObject.
LPWSTR szClassName - The name that the new class will
be referred to by.
DWORD dwFlags - Flags values to be set for new class
definition. Definitions for flag values are found at
the top of this file.
ASN1_ID asn1ID - The ASN.1 ID for the class. If no
class identifier has been registered, a
zero-length octet string is specified.
HANDLE(S) hSuperClasses,
hContainmentClasses,
hNamingAttributes,
hMandatoryAttributes,
hOptionalAttributes -
Handle to buffers that contain class definition
information to create new class in schema.
These handles are manipulated by the following
functions:
NwNdsCreateBuffer (NDS_SCHEMA_DEFINE_CLASS),
NwNdsPutInBuffer, and NwNdsFreeBuffer.
- OR -
Handles can be NULL to indicate that no list
is associated with the specific class defintion
item.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsDeleteAttrDef(
IN HANDLE hTree,
IN LPWSTR szAttributeName );
/*
NwNdsDeleteAttrDef()
This function is used to remove an attribute definition from the schema of
NDS tree hTree.
Arguments:
HANDLE hTree - A handle to the directory tree to be
manipulated. Handle is obtained by calling
NwNdsOpenObject.
LPWSTR szAttributeName - The name of the attribute
defintion to remove.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsDeleteClassDef(
IN HANDLE hTree,
IN LPWSTR szClassName );
/*
NwNdsDeleteClassDef()
This function is used to remove a class definition from the schema of
NDS tree hTree.
Arguments:
HANDLE hTree - A handle to the directory tree to be
manipulated. Handle is obtained by calling
NwNdsOpenObject.
LPWSTR szClassName - The name of the class defintion to remove.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
VOID
NwNdsDeleteQueryNode(
IN LPQUERY_NODE lpQueryNode
);
/*
NwNdsDeleteQueryNode()
This function is used to free a tree node that was part of a query
used with the function NwNdsSearch.
Arguments:
LPQUERY_NODE lpQueryNode - A pointer to a particular node of
a query tree that defines a search.
Returns:
Nothing
*/
DWORD
NwNdsDeleteQueryTree(
IN LPQUERY_TREE lpQueryTree
);
/*
NwNdsDeleteQueryTree()
This function is used to free a tree that describes a query that was
used with the function NwNdsSearch.
Arguments:
LPQUERY_TREE lpQueryTree - A pointer to the root of a query
tree that defines a search. The tree is created
manually by the user through the function
NwNdsCreateQueryNode.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsFreeBuffer(
IN HANDLE hOperationData );
/*
NwNdsFreeBuffer()
This function is used to free the buffer used to describe object
operations to a specific object in an NDS directory tree. The buffer must
be one created by NwNdsCreateBuffer, or returned by calling NwNdsReadObject.
Arguments:
HANDLE hOperationData - Handle to buffer that is to be freed.
Returns:
NO_ERROR
one of the error codes defined in the file winerror.h
*/
DWORD
NwNdsGetAttrDefListFromBuffer(
IN HANDLE hOperationData,
OUT LPDWORD lpdwNumberOfEntries,
OUT LPDWORD lpdwInformationType,
OUT LPVOID * lppEntries );
/*
NwNdsGetAttrDefListFromBuffer()
This function is used to retrieve an array of attribute definition entries
for a schema that was read with a prior call to NwNdsReadAttrDef.
Arguments:
HANDLE hOperationData - Buffer containing the read
response from calling NwNdsReadAttrDef.
LPDWORD lpdwNumberOfEntries - The address of a DWORD to
receive the number of array elements pointed to by
lppEntries.
LPDWORD lpdwInformationType - The address of a DWORD to
receive a value that indicates the type of information
returned by the call to NwNdsReadAttrDef.
LPVOID * lppEntries - The address of a pointer to the beginning
of an array of attribute schema structures. Each
structure contains the details of each attribute
definition read from a given schema by calling
NwNdsReadAttrDef. The lppEntries value should be
cast to either a LPNDS_ATTR_DEF or LPNDS_NAME_ONLY
structure depending on the value returned in
lpdwInformationType.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsGetAttrListFromBuffer(
IN HANDLE hOperationData,
OUT LPDWORD lpdwNumberOfEntries,
OUT LPNDS_ATTR_INFO * lppEntries );
/*
NwNdsGetAttrListFromBuffer()
This function is used to retrieve an array of attribute entries for an
object that was read with a prior call to NwNdsReadObject.
Arguments:
HANDLE hOperationData - Buffer containing the read
response from calling NwNdsReadObject.
LPDWORD lpdwNumberOfEntries - The address of a DWORD to
receive the number of array elements pointed to by
lppEntries.
LPNDS_ATTR_INFO *
lppEntries - The address of a pointer to the beginning
of an array of NDS_ATTR_INFO structures. Each
structure contains the details of each attribute read
from a given object by calling NwNdsReadObject.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsGetClassDefListFromBuffer(
IN HANDLE hOperationData,
OUT LPDWORD lpdwNumberOfEntries,
OUT LPDWORD lpdwInformationType,
OUT LPVOID * lppEntries );
/*
NwNdsGetClassDefListFromBuffer()
This function is used to retrieve an array of class definition entries
for a schema that was read with a prior call to NwNdsReadClassDef.
Arguments:
HANDLE hOperationData - Buffer containing the read
response from calling NwNdsReadClassDef.
LPDWORD lpdwNumberOfEntries - The address of a DWORD to
receive the number of array elements pointed to by
lppEntries.
LPDWORD lpdwInformationType - The address of a DWORD to
receive a value that indicates the type of information
returned by the call to NwNdsReadClassDef.
LPVOID * lppEntries - The address of a pointer to the beginning
of an array of schema class structures. Each
structure contains the details of each class
definition read from a given schema by calling
NwNdsReadClassDef. The lppEntries value should be
cast to either a LPNDS_CLASS_DEF or LPNDS_NAME_ONLY
structure depending on the value returned in
lpdwInformationType.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsGetEffectiveRights(
IN HANDLE hObject,
IN LPWSTR szSubjectName,
IN LPWSTR szAttributeName,
OUT LPDWORD lpdwRights );
/*
NwNdsGetEffectiveRights()
This function is used to determine the effective rights of a particular
subject on a particular object in the NDS tree. The user needs to have
appropriate priveleges to make the determination.
Arguments:
HANDLE hObject - A handle to the object in the directory
tree to determine effective rights on. Handle is
obtained by calling NwNdsOpenObject.
LPWSTR szSubjectName - The distinguished name of user whose
rights we're interested in determining.
LPWSTR szAttributeName - Regular attribute name (i.e.
L"Surname" , L"CN" ) for reading a particular
attribute right, or L"[All Attributes Rights]" and
L"[Entry Rights]" can be used to determine the default
attribute rights and object rights respectively.
LPDWORD lpdwRights - A pointer to a DWORD to receive the
results. If the call is successful, lpdwRights will
contain a mask representing the subject's rights:
Attribute rights - NDS_RIGHT_COMPARE_ATTR,
NDS_RIGHT_READ_ATTR, NDS_RIGHT_WRITE_ATTR,
NDS_RIGHT_ADD_SELF_ATTR, and
NDS_RIGHT_SUPERVISE_ATTR.
Object rights - NDS_RIGHT_BROWSE_OBJECT,
NDS_RIGHT_CREATE_OBJECT, NDS_RIGHT_DELETE_OBJECT,
NDS_RIGHT_RENAME_OBJECT, and
NDS_RIGHT_SUPERVISE_OBJECT.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsGetObjectListFromBuffer(
IN HANDLE hOperationData,
OUT LPDWORD lpdwNumberOfEntries,
OUT LPDWORD lpdwAttrInformationType OPTIONAL,
OUT LPNDS_OBJECT_INFO * lppEntries );
/*
NwNdsGetObjectListFromBuffer()
This function is used to retrieve an array of object entries for
objects that were read with a prior call to either
NwNdsListSubObjects or NwNdsSearch.
Arguments:
HANDLE hOperationData - Buffer containing the read
response from calling NwNdsListSubObjects, or a
buffer containing the search results from a call
to NwNdsSearch.
LPDWORD lpdwNumberOfEntries - The address of a DWORD to
receive the number of array elements pointed to by
lppEntries.
LPDWORD lpdwAttrInformationType - The address of a DWORD to
receive a value that indicates the type of attribute
information returned by the call to NwNdsSearch.
This attribute information type determines which
buffer structure (LPNDS_ATTR_INFO or LPNDS_NAME_ONLY)
should be used for the lpAttribute field found in
each NDS_OBJECT_INFO structure below.
- or -
NULL to indicate that the callee is not interested,
especially when the object list is that from a call
to NwNdsListSubObjects.
LPNDS_OBJECT_INFO *
lppEntries - The address of a pointer to the beginning
of an array of NDS_OBJECT_INFO structures. Each
structure contains the details of each object returned
from a call to NwNdsListSubObjects or NwNdsSearch.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsGetSyntaxID(
IN HANDLE hTree,
IN LPWSTR szAttributeName,
OUT LPDWORD lpdwSyntaxID );
/*
NwNdsGetObjListFromBuffer()
This function is used to retrieve the Syntax ID of a given attribute name.
Arguments:
HANDLE hTree - A handle to the directory tree to be
manipulated. Handle is obtained by calling
NwNdsOpenObject.
LPWSTR szAttributeName - The attribute name whose Syntax ID
is requested.
LPDWORD lpdwSyntaxID - The address of a DWORD to receive the
SyntaxID.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsListSubObjects(
IN HANDLE hParentObject,
IN DWORD dwEntriesRequested,
OUT LPDWORD lpdwEntriesReturned,
IN LPNDS_FILTER_LIST lpFilters OPTIONAL,
OUT HANDLE * lphOperationData );
/*
NwNdsListSubObjects()
This function is used to enumerate the subordinate objects for a particular
parent object. A filter can be passed in to restrict enumeration to a
a specific class type or list of class types.
Arguments:
HANDLE hParentObject - A handle to the object in the directory
tree whose subordinate objects (if any) will be
enumerated.
DWORD dwEntriesRequested - The number of subordinate objects
to list. A subsequent call to NwNdsListSubObjects will
continue enumeration following the last item returned.
LPDWORD lpdwEntriesReturned - A pointer to a DWORD that will
contain the actual number of subobjects enumerated in
the call.
LPNDS_FILTER_LIST lpFilters - The caller can specify the object class
names for the kinds of objects that they would like
to enumerate. For example if just User and Group
object classes should be enumerated, then a filter
for class names NDS_CLASS_USER and NDS_CLASS_GROUP
should be pass in.
- or -
NULL to indicate that all objects should be returned
(no filter).
HANDLE * lphOperationData - Address of a HANDLE handle to
receive created buffer that contains the list of
subordinate objects read from the object
hParentObject. This handle is manipulated by the
following functions:
NwNdsGetObjListFromBuffer and NwNdsFreeBuffer.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsModifyObject(
IN HANDLE hObject,
IN HANDLE hOperationData );
/*
NwNdsModifyObject()
This function is used to modify a leaf object in an NDS directory tree.
Modifying a leaf object means: changing, adding, removing, and clearing of
specified attributes for a given object.
Arguments:
HANDLE hObject - A handle to the object in the directory
tree to be manipulated. Handle is obtained by calling
NwNdsOpenObject.
HANDLE hOperationData - A handle to data containing a
list of attribute changes to be applied to the object.
This buffer is manipulated by the following functions:
NwNdsCreateBuffer (NDS_OBJECT_MODIFY),
NwNdsPutInBuffer, and NwNdsFreeBuffer.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsMoveObject(
IN HANDLE hObject,
IN LPWSTR szDestObjectParentDN );
/*
NwNdsMoveObject()
This function is used to move a leaf object in an NDS directory tree
from one container to another.
Arguments:
HANDLE hObject - A handle to the object in the directory
tree to be moved. Handle is obtained by calling
NwNdsOpenObject.
LPWSTR szDestObjectParentDN - The DN of the object's new
parent.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsOpenObject(
IN LPWSTR szObjectDN,
IN LPWSTR szUserName OPTIONAL,
IN LPWSTR szPassword OPTIONAL,
OUT HANDLE * lphObject,
OUT LPWSTR szObjectName OPTIONAL,
OUT LPWSTR szObjectFullName OPTIONAL,
OUT LPWSTR szObjectClassName OPTIONAL,
OUT LPDWORD lpdwModificationTime OPTIONAL,
OUT LPDWORD lpdwSubordinateCount OPTIONAL );
/*
NwNdsOpenObject()
Arguments:
LPWSTR szObjectDN - The distinguished name of the object
that we want resolved into an object handle.
LPWSTR szUserName - The name of the user account to create
connection to object with.
- OR -
NULL to use the base credentials of the callee's LUID.
LPWSTR szPassword - The password of the user account to create
connection to object with. If password is blank, callee
should pass "".
- OR -
NULL to use the base credentials of the callee's LUID.
HANDLE * lphObject - The address of a HANDLE to receive
the handle of the object specified by
szObjectDN.
Optional arguments: ( Callee can pass NULL in for these parameters to
indicate ignore )
LPWSTR szObjectName - A LPWSTR buffer to receive
the object's relative NDS name, or NULL if not
interested. The buffer for this string must be
provided by the user. Buffer should be at least
NDS_MAX_NAME_SIZE
LPWSTR szObjectFullName - A LPWSTR buffer to receive
the object's full NDS name (DN). The buffer for this
string must be provided by the user. Buffer should
be at least: (NW_MAX_NDS_NAME_LEN + 1 ) * sizeof(WCHAR)
LPWSTR szObjectClassName - A LPWSTR buffer to receive
the class name of the object opened. The buffer for this
string must be provided by the user. Buffer should
be at least: (NW_MAX_NDS_NAME_LEN + 1 ) * sizeof(WCHAR)
LPDWORD lpdwModificationTime - The address of a DWORD to
receive the last date/time the object was modified.
LPDWORD lpdwSubordinateCount - The address of a DWORD to
receive the number of subordinate objects that may
be found under szObjectDN, if it is a container object.
If szObjectDN is not a container, then the value is set
to zero. Although a value of zero does not imply
that object is not a container, it could just be empty.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsPutInBuffer(
IN LPWSTR szAttributeName,
IN DWORD dwSyntaxID,
IN LPVOID lpAttributeValues,
IN DWORD dwValueCount,
IN DWORD dwAttrModificationOperation,
IN OUT HANDLE hOperationData );
/*
NwNdsPutInBuffer()
This function is used to add an entry to the buffer used to describe
an object attribute or change to an object attribute. The buffer must
be created using NwNdsCreateBuffer. If the buffer was created using the
operations, NDS_OBJECT_ADD, NDS_SCHEMA_DEFINE_CLASS,
NDS_SCHEMA_READ_ATTR_DEF, or NDS_SCHEMA_READ_CLASS_DEF, then
dwAttrModificationOperation is ignored. If the buffer was created using
either the operation NDS_OBJECT_READ or NDS_SEARCH, then
dwAttrModificationOperation, puAttributeType, and lpAttributeValue are
all ingnored.
Arguments:
LPWSTR szAttributeName - A NULL terminated WCHAR string
that contains name of the attribute value to be
added to the buffer. It can be a user supplied
string, or one of the many defined string macros
in NdsAttr.h.
DWORD dwSyntaxID - The ID of the syntax structure used to
represent the attribute value. Syntax IDs and their
associated structures are defined in the file
NdsSntx.h. According to the NetWare NDS schema spec,
there is and always will be, only 28 (0..27)
different syntaxes.
LPVOID lpAttributeValues - A pointer to the beginning of a
buffer containing the value(s) for a particular
object attribute with data syntax dwSyntaxID.
DWORD dwValueCount - The number of value entries found in
buffer pointed to by lpAttributeValues.
DWORD dwAttrModificationOperation - If the buffer was created
using the operation NDS_MODIFY_OBJECT, then this is
used to desribe which type of modification operation
to apply for a given attribute. These attribute
modification operations are defined near the beginning
of this file.
HANDLE hOperationData - A handle to data created by
calling NwNdsCreateBuffer. The buffer stores the
attributes used to define transactions for
NwNdsAddObject, NwNdsModifyObject, NwNdsReadAttrDef,
NwNdsReadClassDef, NwNdsReadObject or NwNdsSearch.
Returns:
NO_ERROR
ERROR_NOT_ENOUGH_MEMORY
ERROR_INVALID_PARAMETER
*/
DWORD
NwNdsReadAttrDef(
IN HANDLE hTree,
IN DWORD dwInformationType, // NDS_INFO_NAMES
// or NDS_INFO_NAMES_DEFS
IN OUT HANDLE * lphOperationData OPTIONAL );
/*
NwNdsReadAttrDef()
This function is used to read attribute definitions in the schema of an
NDS directory tree.
Arguments:
HANDLE hTree - A handle to the directory tree to be
manipulated. Handle is obtained by calling
NwNdsOpenObject.
DWORD dwInformationType - Indicates whether user chooses to
read only the defined attribute name(s) in the schema or
read both the attribute name(s) and definition(s)
from the schema.
HANDLE * lphOperationData - The address of a HANDLE to data
containing a list of attribute names to be read from
the schema. This handle is manipulated by the following
functions:
NwNdsCreateBuffer (NDS_SCHEMA_READ_ATTR_DEF),
NwNdsPutInBuffer, and NwNdsFreeBuffer.
- OR -
The address of a HANDLE set to NULL, which indicates
that all attributes should be read from the schema.
If these calls are successful, this handle will also
contain the read results from the call. In the later
case, a buffer will be created to contain the read
results. Attribute values can be retrieved from the
buffer with the functions:
NwNdsGetAttrDefListFromBuffer
After the call to this function, this buffer is ONLY
manipulated by the functions:
NwNdsGetAttrDefListFromBuffer and NwNdsFreeBuffer.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsReadClassDef(
IN HANDLE hTree,
IN DWORD dwInformationType, // NDS_INFO_NAMES,
// NDS_INFO_NAMES_DEFS,
// NDS_CLASS_INFO_EXPANDED_DEFS,
// or NDS_CLASS_INFO
IN OUT HANDLE * lphOperationData OPTIONAL );
/*
NwNdsReadClassDef()
This function is used to read class definitions in the schema of an
NDS directory tree.
Arguments:
HANDLE hTree - A handle to the directory tree to be
manipulated. Handle is obtained by calling
NwNdsOpenObject.
DWORD dwInformationType - Indicates whether user chooses to
read only the defined class name(s) in the schema or
read both the class name(s) and definition(s)
from the schema.
HANDLE * lphOperationData - The address of a HANDLE to data
containing a list of class names to be read from
the schema. This handle is manipulated by the following
functions:
NwNdsCreateBuffer (NDS_SCHEMA_READ_CLASS_DEF),
NwNdsPutInBuffer, and NwNdsFreeBuffer.
- OR -
The address of a HANDLE set to NULL, which indicates
that all classes should be read from the schema.
If these calls are successful, this handle will also
contain the read results from the call. In the later
case, a buffer will be created to contain the read
results. Class read results can be retrieved from the
buffer with the functions:
NwNdsGetClassDefListFromBuffer
After the call to this function, this buffer is ONLY
manipulated by the functions:
NwNdsGetClassDefListFromBuffer and NwNdsFreeBuffer.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsReadObject(
IN HANDLE hObject,
IN DWORD dwInformationType, // NDS_INFO_NAMES
// or NDS_INFO_ATTR_NAMES_VALUES
IN OUT HANDLE * lphOperationData );
/*
NwNdsReadObject()
This function is used to read attributes about an object of an NDS
directory tree.
Arguments:
HANDLE hObject - A handle to the object in the directory
tree to be manipulated. Handle is obtained by calling
NwNdsOpenObject.
DWORD dwInformationType - Indicates whether user chooses to
read only the attribute name(s) on the object or
read both the attribute name(s) and value(s)
from the object.
HANDLE * lphOperationData - The address of a HANDLE to data
containing a list of attributes to be read from the
object hObject. This handle is manipulated by the
following functions:
NwNdsCreateBuffer (NDS_OBJECT_READ),
NwNdsPutInBuffer, and NwNdsFreeBuffer.
- OR -
The address of a HANDLE set to NULL, which indicates
that all object attributes should be read from object
hObject.
If these calls are successful, this handle will also
contain the read results from the call. In the later
case, a buffer will be created to contain the read
results. Attribute values can be retrieved from the
buffer with the functions:
NwNdsGetAttrListFromBuffer.
After the call to this function, this buffer is ONLY
manipulated by the functions:
NwNdsGetAttrListFromBuffer and NwNdsFreeBuffer.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsRemoveObject(
IN HANDLE hParentObject,
IN LPWSTR szObjectName );
/*
NwNdsRemoveObject()
This function is used to remove a leaf object from an NDS directory tree.
Arguments:
HANDLE hParentObject - A handle to the parent object container
in the directory tree to remove leaf object from.
Handle is obtained by calling NwNdsOpenObject.
LPWSTR szObjectName - The directory name of the leaf object
to be removed.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsRenameObject(
IN HANDLE hParentObject,
IN LPWSTR szObjectName,
IN LPWSTR szNewObjectName,
IN BOOL fDeleteOldName );
/*
NwNdsRenameObject()
This function is used to rename an object in a NDS directory tree.
Arguments:
HANDLE hParentObject - A handle to the parent object container
in the directory tree to rename leaf object in.
Handle is obtained by calling NwNdsOpenObject.
LPWSTR szObjectName - The directory name of the object to be
renamed.
LPWSTR szNewObjectName - The new directory name of the object.
BOOL fDeleteOldName - If true, the old name is discarded;
Otherwise, the old name is retained as an additional
attribute.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
DWORD
NwNdsSearch(
IN HANDLE hStartFromObject,
IN DWORD dwInformationType, // NDS_INFO_NAMES
// or NDS_INFO_ATTR_NAMES_VALUES
IN DWORD dwScope,
IN BOOL fDerefAliases,
IN LPQUERY_TREE lpQueryTree,
IN OUT LPDWORD lpdwIterHandle,
IN OUT HANDLE * lphOperationData );
/*
NwNdsSearch()
This function is used to query an NDS directory tree to find objects of
a certain object type that match a specified search filter.
Arguments:
HANDLE hStartFromObject - A HANDLE to an object in the
directory tree to start search from. Handle is
obtained by calling NwNdsOpenObject.
DWORD dwScope -
NDS_SCOPE_ONE_LEVEL - Search subordinates from given
object, one level only
NDS_SCOPE_SUB_TREE - Search from given object on down
NDS_SCOPE_BASE_LEVEL - Applies search to an object
BOOL fDerefAliases - If TRUE the search will dereference
aliased objects to the real objects and continue
to search in the aliased objects subtree. If FALSE
the search will not dereference aliases.
LPQUERY_TREE lpQueryTree - A pointer to the root of a search
tree which defines a query. This tree is manipulated
by the following functions:
NwNdsCreateQueryNode, NwNdsDeleteQueryNode,
and NwNdsDeleteQueryTree.
LPDWORD lpdwIterHandle - A pointer to a DWORD that has the
iteration handle value. On input, the handle value
is set to NDS_INITIAL_SEARCH or to a value previously
returned from a prior call to NwNdsSearch. On ouput,
the handle value is set to NDS_NO_MORE_ITERATIONS if
search is complete, or to some other value otherwise.
HANDLE * lphOperationData - The address of a HANDLE to data
containing a list of attributes to be read from the
objects that meet the search query. This handle is
manipulated by the following functions:
NwNdsCreateBuffer (NDS_SEARCH),
NwNdsPutInBuffer, and NwNdsFreeBuffer.
- OR -
The address of a HANDLE set to NULL, which indicates
that all object attributes should be read from the
search objects found.
If these calls are successful, this handle will also
contain the read results from the call. In the later
case, a buffer will be created to contain the read
results. Object information with attribute information
can be retrieved from the buffer with the function:
NwNdsGetObjectListFromBuffer.
After the call to this function, this buffer is ONLY
manipulated by the functions:
NwNdsGetObjectListFromBuffer,
and NwNdsFreeBuffer.
Returns:
NO_ERROR
UNSUCCESSFUL - Call GetLastError for Win32 error code.
*/
#ifndef NWCONN_HANDLE
#define NWCONN_HANDLE HANDLE
#endif
NWCONN_HANDLE
NwNdsObjectHandleToConnHandle(
IN HANDLE ObjectHandle);
/*
NwNdsObjectHandleToConnHandle()
This function is used to get the NWCONN_HANDLE for a ObjectHandle
(like that returned from NwNdsOpenObject).
Arguments:
HANDLE ObjectHandle - the handle to use to retrieve the NWCONN_HANDLE.
Returns:
NULL - Call GetLastError for Win32 error code.
Otherwise - NWCONN_HANDLE - this MUST be freed by the caller by the
NwNdsConnHandleFree routine.
*/
VOID
NwNdsConnHandleFree(
IN NWCONN_HANDLE hConn);
/*
NwNdsConnHandleFree()
Frees the NWCONN_HANDLE returned from NwNdsObjectHandleToConnHandle().
Arguments:
IN NWCONN_HANDLE Handle to free.
Returns:
Nothing
*/
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif