jwadssec.pas 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. {******************************************************************************}
  2. { }
  3. { AD Security Property Pages API interface Unit for Object Pascal }
  4. { }
  5. { Portions created by Microsoft are Copyright (C) 1995-2001 Microsoft }
  6. { Corporation. All Rights Reserved. }
  7. { }
  8. { The original file is: dssec.h, released Feb 2003. The original Pascal }
  9. { code is: DsSec.pas, released December 2003. The initial developer of the }
  10. { Pascal code is Marcel van Brakel (brakelm att chello dott nl). }
  11. { }
  12. { Portions created by Marcel van Brakel are Copyright (C) 1999-2001 }
  13. { Marcel van Brakel. All Rights Reserved. }
  14. { }
  15. { Obtained through: Joint Endeavour of Delphi Innovators (Project JEDI) }
  16. { }
  17. { You may retrieve the latest version of this file at the Project JEDI }
  18. { APILIB home page, located at http://jedi-apilib.sourceforge.net }
  19. { }
  20. { The contents of this file are used with permission, subject to the Mozilla }
  21. { Public License Version 1.1 (the "License"); you may not use this file except }
  22. { in compliance with the License. You may obtain a copy of the License at }
  23. { http://www.mozilla.org/MPL/MPL-1.1.html }
  24. { }
  25. { Software distributed under the License is distributed on an "AS IS" basis, }
  26. { WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for }
  27. { the specific language governing rights and limitations under the License. }
  28. { }
  29. { Alternatively, the contents of this file may be used under the terms of the }
  30. { GNU Lesser General Public License (the "LGPL License"), in which case the }
  31. { provisions of the LGPL License are applicable instead of those above. }
  32. { If you wish to allow use of your version of this file only under the terms }
  33. { of the LGPL License and not to allow others to use your version of this file }
  34. { under the MPL, indicate your decision by deleting the provisions above and }
  35. { replace them with the notice and other provisions required by the LGPL }
  36. { License. If you do not delete the provisions above, a recipient may use }
  37. { your version of this file under either the MPL or the LGPL License. }
  38. { }
  39. { For more information about the LGPL: http://www.gnu.org/copyleft/lesser.html }
  40. { }
  41. {******************************************************************************}
  42. // $Id: JwaDsSec.pas,v 1.10 2005/09/06 16:36:50 marquardt Exp $
  43. unit JwaDsSec;
  44. {$WEAKPACKAGEUNIT}
  45. {$HPPEMIT ''}
  46. {$HPPEMIT '#include "dssec.h"'}
  47. {$HPPEMIT ''}
  48. {$I jediapilib.inc}
  49. interface
  50. uses
  51. JwaWindows, JwaPrSht;
  52. //+---------------------------------------------------------------------------
  53. //
  54. // Function: PFNREADOBJECTSECURITY
  55. //
  56. // Synopsis: Reads the security descriptor of a DS object
  57. //
  58. // Arguments: [IN LPCWSTR] -- ADS path of DS Object
  59. // [IN SECURITY_INFORMATION] -- Which SD parts to read
  60. // [OUT PSECURITY_DESCRIPTOR*] -- Return SD here. Caller frees with LocalFree
  61. // [IN LPARAM] -- Context param
  62. //
  63. // Return: HRESULT
  64. //
  65. //----------------------------------------------------------------------------
  66. //
  67. // Function: PFNWRITEOBJECTSECURITY
  68. //
  69. // Synopsis: Writes a security descriptor to a DS object
  70. //
  71. // Arguments: [IN LPCWSTR] -- ADS path of DS Object
  72. // [IN SECURITY_INFORMATION] -- Which SD parts to write
  73. // [OUT PSECURITY_DESCRIPTOR] -- Security descriptor to write
  74. // [IN LPARAM] -- Context param
  75. //
  76. // Return: HRESULT
  77. //
  78. //----------------------------------------------------------------------------
  79. type
  80. PFNREADOBJECTSECURITY = function(p1: LPCWSTR; p2: SECURITY_INFORMATION; p3: PPSECURITY_DESCRIPTOR; p4: LPARAM): HRESULT; stdcall;
  81. {$EXTERNALSYM PFNREADOBJECTSECURITY}
  82. PFNWRITEOBJECTSECURITY = function(p1: LPCWSTR; p2: SECURITY_INFORMATION; p3: PSECURITY_DESCRIPTOR; p4: LPARAM): HRESULT; stdcall;
  83. {$EXTERNALSYM PFNWRITEOBJECTSECURITY}
  84. const
  85. DSSI_READ_ONLY = $00000001;
  86. {$EXTERNALSYM DSSI_READ_ONLY}
  87. DSSI_NO_ACCESS_CHECK = $00000002;
  88. {$EXTERNALSYM DSSI_NO_ACCESS_CHECK}
  89. DSSI_NO_EDIT_SACL = $00000004;
  90. {$EXTERNALSYM DSSI_NO_EDIT_SACL}
  91. DSSI_NO_EDIT_OWNER = $00000008;
  92. {$EXTERNALSYM DSSI_NO_EDIT_OWNER}
  93. DSSI_IS_ROOT = $00000010;
  94. {$EXTERNALSYM DSSI_IS_ROOT}
  95. DSSI_NO_FILTER = $00000020;
  96. {$EXTERNALSYM DSSI_NO_FILTER}
  97. DSSI_NO_READONLY_MESSAGE = $00000040;
  98. {$EXTERNALSYM DSSI_NO_READONLY_MESSAGE}
  99. //+---------------------------------------------------------------------------
  100. //
  101. // Function: DSCreateSecurityPage
  102. //
  103. // Synopsis: Creates a Security property page for a DS object
  104. //
  105. // Arguments: [IN pwszObjectPath] -- Full ADS path of DS object
  106. // [IN pwszObjectClass] -- Class of the object (optional)
  107. // [IN dwFlags] -- Combination of DSSI_* flags
  108. // [OUT phPage] -- HPROPSHEETPAGE returned here
  109. // [IN pfnReadSD] -- Optional function for reading SD
  110. // [IN pfnWriteSD] -- Optional function for writing SD
  111. // [IN LPARAM] -- Passed to pfnReadSD/pfnWriteSD
  112. //
  113. // Return: HRESULT
  114. //
  115. //----------------------------------------------------------------------------
  116. function DSCreateSecurityPage(
  117. pwszObjectPath: LPCWSTR;
  118. pwszObjectClass: LPCWSTR;
  119. dwFlags: DWORD;
  120. out phPage: HPROPSHEETPAGE;
  121. pfnReadSD: PFNREADOBJECTSECURITY;
  122. pfnWriteSD: PFNWRITEOBJECTSECURITY;
  123. lpContext:LPARAM): HRESULT; stdcall;
  124. {$EXTERNALSYM DSCreateSecurityPage}
  125. type
  126. PFNDSCREATESECPAGE = function(
  127. pwszObjectPath: LPCWSTR;
  128. pwszObjectClass: LPCWSTR;
  129. dwFlags: DWORD;
  130. out phPage: HPROPSHEETPAGE;
  131. pfnReadSD: PFNREADOBJECTSECURITY;
  132. pfnWriteSD: PFNWRITEOBJECTSECURITY;
  133. lpContext:LPARAM): HRESULT; stdcall;
  134. {$EXTERNALSYM PFNDSCREATESECPAGE}
  135. implementation
  136. uses
  137. JwaWinDLLNames;
  138. {$IFDEF DYNAMIC_LINK}
  139. var
  140. _DSCreateSecurityPage: Pointer;
  141. function DSCreateSecurityPage;
  142. begin
  143. GetProcedureAddress(_DSCreateSecurityPage, dssec, 'DSCreateSecurityPage');
  144. asm
  145. MOV ESP, EBP
  146. POP EBP
  147. JMP [_DSCreateSecurityPage]
  148. end;
  149. end;
  150. {$ELSE}
  151. function DSCreateSecurityPage; external dssec name 'DSCreateSecurityPage';
  152. {$ENDIF DYNAMIC_LINK}
  153. end.