123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- {******************************************************************************}
- { }
- { AD Security Property Pages API interface Unit for Object Pascal }
- { }
- { Portions created by Microsoft are Copyright (C) 1995-2001 Microsoft }
- { Corporation. All Rights Reserved. }
- { }
- { The original file is: dssec.h, released Feb 2003. The original Pascal }
- { code is: DsSec.pas, released December 2003. The initial developer of the }
- { Pascal code is Marcel van Brakel (brakelm att chello dott nl). }
- { }
- { Portions created by Marcel van Brakel are Copyright (C) 1999-2001 }
- { Marcel van Brakel. All Rights Reserved. }
- { }
- { Obtained through: Joint Endeavour of Delphi Innovators (Project JEDI) }
- { }
- { You may retrieve the latest version of this file at the Project JEDI }
- { APILIB home page, located at http://jedi-apilib.sourceforge.net }
- { }
- { 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. }
- { }
- { Alternatively, the contents of this file may be used under the terms of the }
- { GNU Lesser General Public License (the "LGPL License"), in which case the }
- { provisions of the LGPL License are applicable instead of those above. }
- { If you wish to allow use of your version of this file only under the terms }
- { of the LGPL License and not to allow others to use your version of this file }
- { under the MPL, indicate your decision by deleting the provisions above and }
- { replace them with the notice and other provisions required by the LGPL }
- { License. If you do not delete the provisions above, a recipient may use }
- { your version of this file under either the MPL or the LGPL License. }
- { }
- { For more information about the LGPL: http://www.gnu.org/copyleft/lesser.html }
- { }
- {******************************************************************************}
- // $Id: JwaDsSec.pas,v 1.10 2005/09/06 16:36:50 marquardt Exp $
- unit JwaDsSec;
- {$WEAKPACKAGEUNIT}
- {$HPPEMIT ''}
- {$HPPEMIT '#include "dssec.h"'}
- {$HPPEMIT ''}
- {$I jediapilib.inc}
- interface
- uses
- JwaWindows, JwaPrSht;
- //+---------------------------------------------------------------------------
- //
- // Function: PFNREADOBJECTSECURITY
- //
- // Synopsis: Reads the security descriptor of a DS object
- //
- // Arguments: [IN LPCWSTR] -- ADS path of DS Object
- // [IN SECURITY_INFORMATION] -- Which SD parts to read
- // [OUT PSECURITY_DESCRIPTOR*] -- Return SD here. Caller frees with LocalFree
- // [IN LPARAM] -- Context param
- //
- // Return: HRESULT
- //
- //----------------------------------------------------------------------------
- //
- // Function: PFNWRITEOBJECTSECURITY
- //
- // Synopsis: Writes a security descriptor to a DS object
- //
- // Arguments: [IN LPCWSTR] -- ADS path of DS Object
- // [IN SECURITY_INFORMATION] -- Which SD parts to write
- // [OUT PSECURITY_DESCRIPTOR] -- Security descriptor to write
- // [IN LPARAM] -- Context param
- //
- // Return: HRESULT
- //
- //----------------------------------------------------------------------------
- type
- PFNREADOBJECTSECURITY = function(p1: LPCWSTR; p2: SECURITY_INFORMATION; p3: PPSECURITY_DESCRIPTOR; p4: LPARAM): HRESULT; stdcall;
- {$EXTERNALSYM PFNREADOBJECTSECURITY}
- PFNWRITEOBJECTSECURITY = function(p1: LPCWSTR; p2: SECURITY_INFORMATION; p3: PSECURITY_DESCRIPTOR; p4: LPARAM): HRESULT; stdcall;
- {$EXTERNALSYM PFNWRITEOBJECTSECURITY}
- const
- DSSI_READ_ONLY = $00000001;
- {$EXTERNALSYM DSSI_READ_ONLY}
- DSSI_NO_ACCESS_CHECK = $00000002;
- {$EXTERNALSYM DSSI_NO_ACCESS_CHECK}
- DSSI_NO_EDIT_SACL = $00000004;
- {$EXTERNALSYM DSSI_NO_EDIT_SACL}
- DSSI_NO_EDIT_OWNER = $00000008;
- {$EXTERNALSYM DSSI_NO_EDIT_OWNER}
- DSSI_IS_ROOT = $00000010;
- {$EXTERNALSYM DSSI_IS_ROOT}
- DSSI_NO_FILTER = $00000020;
- {$EXTERNALSYM DSSI_NO_FILTER}
- DSSI_NO_READONLY_MESSAGE = $00000040;
- {$EXTERNALSYM DSSI_NO_READONLY_MESSAGE}
- //+---------------------------------------------------------------------------
- //
- // Function: DSCreateSecurityPage
- //
- // Synopsis: Creates a Security property page for a DS object
- //
- // Arguments: [IN pwszObjectPath] -- Full ADS path of DS object
- // [IN pwszObjectClass] -- Class of the object (optional)
- // [IN dwFlags] -- Combination of DSSI_* flags
- // [OUT phPage] -- HPROPSHEETPAGE returned here
- // [IN pfnReadSD] -- Optional function for reading SD
- // [IN pfnWriteSD] -- Optional function for writing SD
- // [IN LPARAM] -- Passed to pfnReadSD/pfnWriteSD
- //
- // Return: HRESULT
- //
- //----------------------------------------------------------------------------
- function DSCreateSecurityPage(
- pwszObjectPath: LPCWSTR;
- pwszObjectClass: LPCWSTR;
- dwFlags: DWORD;
- out phPage: HPROPSHEETPAGE;
- pfnReadSD: PFNREADOBJECTSECURITY;
- pfnWriteSD: PFNWRITEOBJECTSECURITY;
- lpContext:LPARAM): HRESULT; stdcall;
- {$EXTERNALSYM DSCreateSecurityPage}
- type
- PFNDSCREATESECPAGE = function(
- pwszObjectPath: LPCWSTR;
- pwszObjectClass: LPCWSTR;
- dwFlags: DWORD;
- out phPage: HPROPSHEETPAGE;
- pfnReadSD: PFNREADOBJECTSECURITY;
- pfnWriteSD: PFNWRITEOBJECTSECURITY;
- lpContext:LPARAM): HRESULT; stdcall;
- {$EXTERNALSYM PFNDSCREATESECPAGE}
- implementation
- uses
- JwaWinDLLNames;
- {$IFDEF DYNAMIC_LINK}
- var
- _DSCreateSecurityPage: Pointer;
- function DSCreateSecurityPage;
- begin
- GetProcedureAddress(_DSCreateSecurityPage, dssec, 'DSCreateSecurityPage');
- asm
- MOV ESP, EBP
- POP EBP
- JMP [_DSCreateSecurityPage]
- end;
- end;
- {$ELSE}
- function DSCreateSecurityPage; external dssec name 'DSCreateSecurityPage';
- {$ENDIF DYNAMIC_LINK}
- end.
|