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.
129 lines
4.7 KiB
129 lines
4.7 KiB
//+-------------------------------------------------------------------------
|
|
//
|
|
// Microsoft Windows
|
|
//
|
|
// Copyright (C) Microsoft Corporation, 1997 - 1999
|
|
//
|
|
// File: schema.h
|
|
//
|
|
//--------------------------------------------------------------------------
|
|
|
|
#ifndef _SCHEMA_CACHE_H_
|
|
#define _SCHEMA_CACHE_H_
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
//
|
|
// Generic Mapping for DS, adapted from \nt\private\ds\src\inc\permit.h
|
|
//
|
|
#define DS_GENERIC_READ ((STANDARD_RIGHTS_READ) | \
|
|
(ACTRL_DS_LIST) | \
|
|
(ACTRL_DS_READ_PROP) | \
|
|
(ACTRL_DS_LIST_OBJECT))
|
|
|
|
#define DS_GENERIC_EXECUTE ((STANDARD_RIGHTS_EXECUTE) | \
|
|
(ACTRL_DS_LIST))
|
|
|
|
// Note, STANDARD_RIGHTS_WRITE is specifically NOT included here
|
|
#define DS_GENERIC_WRITE ((ACTRL_DS_SELF) | \
|
|
(ACTRL_DS_WRITE_PROP))
|
|
|
|
#define DS_GENERIC_ALL ((STANDARD_RIGHTS_REQUIRED) | \
|
|
(ACTRL_DS_CREATE_CHILD) | \
|
|
(ACTRL_DS_DELETE_CHILD) | \
|
|
(ACTRL_DS_DELETE_TREE) | \
|
|
(ACTRL_DS_READ_PROP) | \
|
|
(ACTRL_DS_WRITE_PROP) | \
|
|
(ACTRL_DS_LIST) | \
|
|
(ACTRL_DS_LIST_OBJECT) | \
|
|
(ACTRL_DS_CONTROL_ACCESS) | \
|
|
(ACTRL_DS_SELF))
|
|
|
|
//
|
|
// Flags for SchemaCache_Get****ID
|
|
//
|
|
#define IDC_CLASS_NO_CREATE 0x00000001
|
|
#define IDC_CLASS_NO_DELETE 0x00000002
|
|
#define IDC_CLASS_NO_INHERIT 0x00000004
|
|
#define IDC_PROP_NO_READ IDC_CLASS_NO_CREATE
|
|
#define IDC_PROP_NO_WRITE IDC_CLASS_NO_DELETE
|
|
#define OTL_ADDED_TO_LIST 0x00000008
|
|
|
|
#define IDC_CLASS_NONE (IDC_CLASS_NO_CREATE | IDC_CLASS_NO_DELETE | IDC_CLASS_NO_INHERIT)
|
|
#define IDC_PROP_NONE (IDC_PROP_NO_READ | IDC_PROP_NO_WRITE)
|
|
|
|
#define SCHEMA_COMMON_PERM 0x80000000
|
|
#define SCHEMA_NO_FILTER 0x40000000
|
|
#define SCHEMA_CLASS 0x20000000
|
|
|
|
|
|
//
|
|
//Purpose: Used to store information about aux class
|
|
//
|
|
typedef struct _AUX_INFO{
|
|
GUID guid; //Object Type Guid of class
|
|
WCHAR pszClassName[ANYSIZE_ARRAY]; //class Name
|
|
}AUX_INFO, *PAUX_INFO;
|
|
|
|
//
|
|
//Purpose: Used to cache Access information passed to get access right
|
|
//
|
|
typedef struct _ACCESS_INFO{
|
|
GUID ObjectTypeGuid;
|
|
DWORD dwFlags;
|
|
BOOL bLocalFree;
|
|
PSI_ACCESS pAccess;
|
|
ULONG cAccesses;
|
|
ULONG iDefaultAccess;
|
|
}ACCESS_INFO, *PACCESS_INFO;
|
|
|
|
HRESULT SchemaCache_Create(LPCTSTR pszServer);
|
|
void SchemaCache_Destroy(void);
|
|
|
|
HRESULT SchemaCache_GetInheritTypes(LPCGUID pguidObjectType,
|
|
DWORD dwFlags,
|
|
PSI_INHERIT_TYPE *ppInheritTypes,
|
|
ULONG *pcInheritTypes);
|
|
HRESULT SchemaCache_GetAccessRights(LPCGUID pguidObjectType,
|
|
LPCTSTR pszClassName, // optional (faster if provided)
|
|
HDPA hAuxList,
|
|
LPCTSTR pszSchemaPath,
|
|
DWORD dwFlags, // 0, SI_ADVANCED, or SI_ADVANCED | SI_EDIT_PROPERTIES
|
|
PACCESS_INFO* ppAccesInfo);
|
|
|
|
HRESULT Schema_BindToObject(LPCTSTR pszSchemaPath,
|
|
LPCTSTR pszName,
|
|
REFIID riid,
|
|
LPVOID *ppv);
|
|
HRESULT Schema_GetObjectID(IADs *pObj, LPGUID pGUID);
|
|
|
|
HRESULT Schema_GetDefaultSD( GUID *pSchemaGuid,
|
|
PSID pDomainSid,
|
|
PSID pRootDomainSid,
|
|
PSECURITY_DESCRIPTOR *ppSD = NULL );
|
|
|
|
HRESULT Schema_GetObjectTypeList(GUID *pSchamaGuid,
|
|
HDPA hAuxList,
|
|
LPCWSTR pszSchemaPath,
|
|
DWORD dwFlags,
|
|
POBJECT_TYPE_LIST *ppObjectTypeList,
|
|
DWORD * pObjectTypeListCount);
|
|
|
|
HRESULT Schema_GetObjectTypeGuid(LPCWSTR pszClassName, LPGUID pGuid);
|
|
|
|
AUTHZ_RESOURCE_MANAGER_HANDLE Schema_GetAUTHZ_RM();
|
|
|
|
bool DoesPathContainServer(LPCWSTR pszPath);
|
|
HRESULT OpenDSObject (LPTSTR lpPath, LPTSTR lpUserName, LPTSTR lpPassword, DWORD dwFlags, REFIID riid, void FAR * FAR * ppObject);
|
|
|
|
|
|
void
|
|
DestroyDPA(HDPA hList);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif // _SCHEMA_CACHE_H_
|