📄 activeds.pas
字号:
{******************************************************************}
{ }
{ Borland Delphi Runtime Library }
{ Active Directory Services interface unit }
{ }
{ Portions created by Microsoft are }
{ Copyright (C) 1995-1999 Microsoft Corporation. }
{ All Rights Reserved. }
{ }
{ The original file is: activeds.h, released June 2000. }
{ The original Pascal code is: ActiveDS.pas, released Dec. 2000 }
{ The initial developer of the Pascal code is Marcel van Brakel }
{ (brakelm@bart.nl). }
{ }
{ Portions created by Marcel van Brakel are }
{ Copyright (C) 1999 Marcel van Brakel. }
{ }
{ Obtained through: }
{ Joint Endeavour of Delphi Innovators (Project JEDI) }
{ }
{ You may retrieve the latest version of this file at the Project }
{ JEDI home page, located at http://delphi-jedi.org }
{ }
{ The contents of this file are used with permission, subject to }
{ the Mozilla Public License Version 1.1 (the "License"); you may }
{ not use this file except in compliance with the License. You may }
{ obtain a copy of the License at }
{ http://www.mozilla.org/MPL/MPL-1.1.html }
{ }
{ Software distributed under the License is distributed on an }
{ "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or }
{ implied. See the License for the specific language governing }
{ rights and limitations under the License. }
{ }
{******************************************************************}
unit ActiveDS;
{$WEAKPACKAGEUNIT}
{$HPPEMIT ''}
{$HPPEMIT '#include "activeds.h"'}
{$HPPEMIT ''}
{$HPPEMIT 'typedef GUID REFIID'}
{$HPPEMIT ''}
{$I WINDEFINES.INC}
interface
uses
ActiveX, AdsTLB, WinNT, WinType, WinUser;
type
REFIID = GUID;
{$NODEFINE REFIID}
type
// imports of a type library sometimes are missing a few decls, these are just
// a few of them to make this file compile at all. I really should do all of
// them one day.
PADSVALUE = ^_adsvalue;
{$EXTERNALSYM PADSVALUE}
PADS_ATTR_INFO = ^_ads_attr_info;
{$EXTERNALSYM PADS_ATTR_INFO}
// Contents: Master include file for Ole Ds
//
// Notes: All Ole Ds client applications must include this file. This
// provides access to the primary Ole Ds interfaces, the error
// codes, and function prototypes for the Ole Ds helper apis.
//
// Interface definitions and well known GUIDS for Ole Ds
//
//#include "iads.h" >> AdsTLB from activeds.dll
//
// Helper function prototypes for Ole Ds
//
//#include "adshlp.h"
function ADsGetObject(lpszPathName: LPCWSTR; const riid: REFIID; out ppObject: Pointer): HRESULT; stdcall;
{$EXTERNALSYM ADsGetObject}
function ADsBuildEnumerator(pADsContainer: IADsContainer; out ppEnumVariant: IEnumVARIANT): HRESULT; stdcall;
{$EXTERNALSYM ADsBuildEnumerator}
function ADsFreeEnumerator(var pEnumVariant: IEnumVARIANT): HRESULT;
{$EXTERNALSYM ADsFreeEnumerator}
function ADsEnumerateNext(pEnumVariant: IEnumVARIANT; cElements: ULONG;
var pvar: OleVariant; var pcElementsFetched: ULONG): HRESULT; stdcall;
{$EXTERNALSYM ADsEnumerateNext}
function ADsBuildVarArrayStr(lppPathNames: LPWSTR; dwPathNames: DWORD;
var pVar: OleVariant): HRESULT; stdcall;
{$EXTERNALSYM ADsBuildVarArrayStr}
function ADsBuildVarArrayInt(lpdwObjectTypes: LPDWORD; dwObjectTypes: DWORD;
var pVar: OleVariant): HRESULT; stdcall;
{$EXTERNALSYM ADsBuildVarArrayInt}
function ADsOpenObject(lpszPathName, lpszUserName, lpszPassword: LPCWSTR;
dwReserved: DWORD; const riid: REFIID; out ppObject: Pointer): HRESULT; stdcall;
{$EXTERNALSYM ADsOpenObject}
//
// Helper functions for extended error support
//
function ADsGetLastError(var lpError: DWORD; lpErrorBuf: LPWSTR;
dwErrorBufLen: DWORD; lpNameBuf: LPWSTR; dwNameBufLen: DWORD): HRESULT; stdcall;
{$EXTERNALSYM ADsGetLastError}
procedure ADsSetLastError(dwErr: DWORD; pszError, pszProvider: LPCWSTR); stdcall;
{$EXTERNALSYM ADsSetLastError}
//procedure ADsFreeAllErrorRecords; stdcall;
//{$EXTERNALSYM ADsFreeAllErrorRecords}
function AllocADsMem(cb: DWORD): LPVOID; stdcall;
{$EXTERNALSYM AllocADsMem}
function FreeADsMem(pMem: LPVOID): BOOL; stdcall;
{$EXTERNALSYM FreeADsMem}
function ReallocADsMem(pOldMem: LPVOID; cbOld, cbNew: DWORD): LPVOID; stdcall;
{$EXTERNALSYM ReallocADsMem}
function AllocADsStr(pStr: LPCWSTR): LPWSTR; stdcall;
{$EXTERNALSYM AllocADsStr}
function FreeADsStr(pStr: LPWSTR): BOOL; stdcall;
{$EXTERNALSYM FreeADsStr}
function ReallocADsStr(var ppStr: LPWSTR; pStr: LPWSTR): BOOL; stdcall;
{$EXTERNALSYM ReallocADsStr}
function ADsEncodeBinaryData(pbSrcData: PBYTE; dwSrcLen: DWORD;
var ppszDestData: LPWSTR): HRESULT; stdcall;
{$EXTERNALSYM ADsEncodeBinaryData}
function ADsDecodeBinaryData(szSrcData: LPCWSTR; var ppbDestData: PBYTE;
var pdwDestLen: ULONG): HRESULT; stdcall;
{$EXTERNALSYM ADsDecodeBinaryData}
function PropVariantToAdsType(var pVariant: OleVariant; dwNumVariant: DWORD;
var ppAdsValues: PADSVALUE; pdwNumValues: PDWORD): HRESULT; stdcall;
{$EXTERNALSYM PropVariantToAdsType}
function AdsTypeToPropVariant(pAdsValues: PADSVALUE; dwNumValues: DWORD;
var pVariant: OleVariant): HRESULT; stdcall;
{$EXTERNALSYM AdsTypeToPropVariant}
procedure AdsFreeAdsValues(pAdsValues: PADSVALUE; dwNumValues: DWORD); stdcall;
{$EXTERNALSYM AdsFreeAdsValues}
//
// Error codes for Ole Ds - generated from ..\..\errmsg
//
//#include "adserr.h"
// ---------------------- HRESULT value definitions -----------------
//
// HRESULT definitions
//
//
// Values are 32 bit values layed out as follows:
//
// 3 3 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1
// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0
// +---+-+-+-----------------------+-------------------------------+
// |Sev|C|R| Facility | Code |
// +---+-+-+-----------------------+-------------------------------+
//
// where
//
// Sev - is the severity code
//
// 00 - Success
// 01 - Informational
// 10 - Warning
// 11 - Error
//
// C - is the Customer code flag
//
// R - is a reserved bit
//
// Facility - is the facility code
//
// Code - is the facility's status code
//
//
// Define the facility codes
//
const
FACILITY_WINDOWS = 8;
{$EXTERNALSYM FACILITY_WINDOWS}
FACILITY_STORAGE = 3;
{$EXTERNALSYM FACILITY_STORAGE}
FACILITY_RPC = 1;
{$EXTERNALSYM FACILITY_RPC}
FACILITY_SSPI = 9;
{$EXTERNALSYM FACILITY_SSPI}
FACILITY_WIN32 = 7;
{$EXTERNALSYM FACILITY_WIN32}
FACILITY_CONTROL = 10;
{$EXTERNALSYM FACILITY_CONTROL}
FACILITY_NULL = 0;
{$EXTERNALSYM FACILITY_NULL}
FACILITY_ITF = 4;
{$EXTERNALSYM FACILITY_ITF}
FACILITY_DISPATCH = 2;
{$EXTERNALSYM FACILITY_DISPATCH}
//
// Define the severity codes
//
//
// MessageId: E_ADS_BAD_PATHNAME
//
// MessageText:
//
// An invalid Active Directory pathname was passed
//
E_ADS_BAD_PATHNAME = HRESULT($80005000);
{$EXTERNALSYM E_ADS_BAD_PATHNAME}
//
// MessageId: E_ADS_INVALID_DOMAIN_OBJECT
//
// MessageText:
//
// An unknown Active Directory domain object was requested
//
E_ADS_INVALID_DOMAIN_OBJECT = HRESULT($80005001);
{$EXTERNALSYM E_ADS_INVALID_DOMAIN_OBJECT}
//
// MessageId: E_ADS_INVALID_USER_OBJECT
//
// MessageText:
//
// An unknown Active Directory user object was requested
//
E_ADS_INVALID_USER_OBJECT = HRESULT($80005002);
{$EXTERNALSYM E_ADS_INVALID_USER_OBJECT}
//
// MessageId: E_ADS_INVALID_COMPUTER_OBJECT
//
// MessageText:
//
// An unknown Active Directory computer object was requested
//
E_ADS_INVALID_COMPUTER_OBJECT = HRESULT($80005003);
{$EXTERNALSYM E_ADS_INVALID_COMPUTER_OBJECT}
//
// MessageId: E_ADS_UNKNOWN_OBJECT
//
// MessageText:
//
// An unknown Active Directory object was requested
//
E_ADS_UNKNOWN_OBJECT = HRESULT($80005004);
{$EXTERNALSYM E_ADS_UNKNOWN_OBJECT}
//
// MessageId: E_ADS_PROPERTY_NOT_SET
//
// MessageText:
//
// The specified Active Directory property was not set
//
E_ADS_PROPERTY_NOT_SET = HRESULT($80005005);
{$EXTERNALSYM E_ADS_PROPERTY_NOT_SET}
//
// MessageId: E_ADS_PROPERTY_NOT_SUPPORTED
//
// MessageText:
//
// The specified Active Directory property is not supported
//
E_ADS_PROPERTY_NOT_SUPPORTED = HRESULT($80005006);
{$EXTERNALSYM E_ADS_PROPERTY_NOT_SUPPORTED}
//
// MessageId: E_ADS_PROPERTY_INVALID
//
// MessageText:
//
// The specified Active Directory property is invalid
//
E_ADS_PROPERTY_INVALID = HRESULT($80005007);
{$EXTERNALSYM E_ADS_PROPERTY_INVALID}
//
// MessageId: E_ADS_BAD_PARAMETER
//
// MessageText:
//
// One or more input parameters are invalid
//
E_ADS_BAD_PARAMETER = HRESULT($80005008);
{$EXTERNALSYM E_ADS_BAD_PARAMETER}
//
// MessageId: E_ADS_OBJECT_UNBOUND
//
// MessageText:
//
// The specified Active Directory object is not bound to a remote resource
//
E_ADS_OBJECT_UNBOUND = HRESULT($80005009);
{$EXTERNALSYM E_ADS_OBJECT_UNBOUND}
//
// MessageId: E_ADS_PROPERTY_NOT_MODIFIED
//
// MessageText:
//
// The specified Active Directory object has not been modified
//
E_ADS_PROPERTY_NOT_MODIFIED = HRESULT($8000500A);
{$EXTERNALSYM E_ADS_PROPERTY_NOT_MODIFIED}
//
// MessageId: E_ADS_PROPERTY_MODIFIED
//
// MessageText:
//
// The specified Active Directory object has not been modified
//
E_ADS_PROPERTY_MODIFIED = HRESULT($8000500B);
{$EXTERNALSYM E_ADS_PROPERTY_MODIFIED}
//
// MessageId: E_ADS_CANT_CONVERT_DATATYPE
//
// MessageText:
//
// The Active Directory datatype cannot be converted to/from a native DS datatype
//
E_ADS_CANT_CONVERT_DATATYPE = HRESULT($8000500C);
{$EXTERNALSYM E_ADS_CANT_CONVERT_DATATYPE}
//
// MessageId: E_ADS_PROPERTY_NOT_FOUND
//
// MessageText:
//
// The Active Directory property cannot be found in the cache.
//
E_ADS_PROPERTY_NOT_FOUND = HRESULT($8000500D);
{$EXTERNALSYM E_ADS_PROPERTY_NOT_FOUND}
//
// MessageId: E_ADS_OBJECT_EXISTS
//
// MessageText:
//
// The Active Directory object exists.
//
E_ADS_OBJECT_EXISTS = HRESULT($8000500E);
{$EXTERNALSYM E_ADS_OBJECT_EXISTS}
//
// MessageId: E_ADS_SCHEMA_VIOLATION
//
// MessageText:
//
// The attempted action violates the DS schema rules.
//
E_ADS_SCHEMA_VIOLATION = HRESULT($8000500F);
{$EXTERNALSYM E_ADS_SCHEMA_VIOLATION}
//
// MessageId: E_ADS_COLUMN_NOT_SET
//
// MessageText:
//
// The specified column in the Active Directory was not set.
//
E_ADS_COLUMN_NOT_SET = HRESULT($80005010);
{$EXTERNALSYM E_ADS_COLUMN_NOT_SET}
//
// MessageId: S_ADS_ERRORSOCCURRED
//
// MessageText:
//
// One or more errors occurred
//
S_ADS_ERRORSOCCURRED = HRESULT($00005011);
{$EXTERNALSYM S_ADS_ERRORSOCCURRED}
//
// MessageId: S_ADS_NOMORE_ROWS
//
// MessageText:
//
// No more rows to be obatained by the search result.
//
S_ADS_NOMORE_ROWS = HRESULT($00005012);
{$EXTERNALSYM S_ADS_NOMORE_ROWS}
//
// MessageId: S_ADS_NOMORE_COLUMNS
//
// MessageText:
//
// No more columns to be obatained for the current row.
//
S_ADS_NOMORE_COLUMNS = HRESULT($00005013);
{$EXTERNALSYM S_ADS_NOMORE_COLUMNS}
//
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -