jwacryptuiapi.pas 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. {******************************************************************************}
  2. { }
  3. { Cryptographic UI 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: cryptuiapi.h, released August 2001. The original Pascal}
  9. { code is: CryptUIApi.pas, released December 2001. 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: JwaCryptUIApi.pas,v 1.12 2007/09/06 14:57:11 marquardt Exp $
  43. {$IFNDEF JWA_OMIT_SECTIONS}
  44. unit JwaCryptUIApi;
  45. {$WEAKPACKAGEUNIT}
  46. {$ENDIF JWA_OMIT_SECTIONS}
  47. {$HPPEMIT ''}
  48. {$HPPEMIT '#include "cryptuiapi.h"'}
  49. {$HPPEMIT ''}
  50. {$IFNDEF JWA_OMIT_SECTIONS}
  51. {$I jediapilib.inc}
  52. interface
  53. uses
  54. JwaWinCrypt, JwaWinType;
  55. {$ENDIF JWA_OMIT_SECTIONS}
  56. {$IFNDEF JWA_IMPLEMENTATIONSECTION}
  57. // #include <pshpack8.h>
  58. //+-------------------------------------------------------------------------
  59. // Dialog viewer of a certificate, CTL or CRL context.
  60. //
  61. // dwContextType and associated pvContext's
  62. // CERT_STORE_CERTIFICATE_CONTEXT PCCERT_CONTEXT
  63. // CERT_STORE_CRL_CONTEXT PCCRL_CONTEXT
  64. // CERT_STORE_CTL_CONTEXT PCCTL_CONTEXT
  65. //
  66. // dwFlags currently isn't used and should be set to 0.
  67. //--------------------------------------------------------------------------
  68. function CryptUIDlgViewContext(dwContextType: DWORD; pvContext: LPVOID; hwnd: HWND; pwszTitle: LPCWSTR;
  69. dwFlags: DWORD; pvReserved: LPVOID): BOOL; stdcall;
  70. {$EXTERNALSYM CryptUIDlgViewContext}
  71. //+-------------------------------------------------------------------------
  72. // Dialog to select a certificate from the specified store.
  73. //
  74. // Returns the selected certificate context. If no certificate was
  75. // selected, NULL is returned.
  76. //
  77. // pwszTitle is either NULL or the title to be used for the dialog.
  78. // If NULL, the default title is used. The default title is
  79. // "Select Certificate".
  80. //
  81. // pwszDisplayString is either NULL or the text statement in the selection
  82. // dialog. If NULL, the default phrase
  83. // "Select a certificate you wish to use" is used in the dialog.
  84. //
  85. // dwDontUseColumn can be set to exclude columns from the selection
  86. // dialog. See the CRYPTDLG_SELECTCERT_*_COLUMN definitions below.
  87. //
  88. // dwFlags currently isn't used and should be set to 0.
  89. //--------------------------------------------------------------------------
  90. function CryptUIDlgSelectCertificateFromStore(hCertStore: HCERTSTORE; hwnd: HWND; pwszTitle, pwszDisplayString: LPCWSTR;
  91. dwDontUseColumn, dwFlags: DWORD; pvReserved: LPVOID): PCCERT_CONTEXT; stdcall;
  92. {$EXTERNALSYM CryptUIDlgSelectCertificateFromStore}
  93. // flags for dwDontUseColumn
  94. const
  95. CRYPTUI_SELECT_ISSUEDTO_COLUMN = $000000001;
  96. {$EXTERNALSYM CRYPTUI_SELECT_ISSUEDTO_COLUMN}
  97. CRYPTUI_SELECT_ISSUEDBY_COLUMN = $000000002;
  98. {$EXTERNALSYM CRYPTUI_SELECT_ISSUEDBY_COLUMN}
  99. CRYPTUI_SELECT_INTENDEDUSE_COLUMN = $000000004;
  100. {$EXTERNALSYM CRYPTUI_SELECT_INTENDEDUSE_COLUMN}
  101. CRYPTUI_SELECT_FRIENDLYNAME_COLUMN = $000000008;
  102. {$EXTERNALSYM CRYPTUI_SELECT_FRIENDLYNAME_COLUMN}
  103. CRYPTUI_SELECT_LOCATION_COLUMN = $000000010;
  104. {$EXTERNALSYM CRYPTUI_SELECT_LOCATION_COLUMN}
  105. CRYPTUI_SELECT_EXPIRATION_COLUMN = $000000020;
  106. {$EXTERNALSYM CRYPTUI_SELECT_EXPIRATION_COLUMN}
  107. {$ENDIF JWA_IMPLEMENTATIONSECTION}
  108. {$IFNDEF JWA_OMIT_SECTIONS}
  109. implementation
  110. //uses ...
  111. {$ENDIF JWA_OMIT_SECTIONS}
  112. {$IFNDEF JWA_INTERFACESECTION}
  113. {$IFNDEF JWA_INCLUDEMODE}
  114. const
  115. cryptuiapi = 'cryptui.dll';
  116. {$ENDIF JWA_INCLUDEMODE}
  117. {$IFDEF DYNAMIC_LINK}
  118. var
  119. _CryptUIDlgViewContext: Pointer;
  120. function CryptUIDlgViewContext;
  121. begin
  122. GetProcedureAddress(_CryptUIDlgViewContext, cryptuiapi, 'CryptUIDlgViewContext');
  123. asm
  124. MOV ESP, EBP
  125. POP EBP
  126. JMP [_CryptUIDlgViewContext]
  127. end;
  128. end;
  129. var
  130. _CryptUIDlgSelCertFromStore: Pointer;
  131. function CryptUIDlgSelectCertificateFromStore;
  132. begin
  133. GetProcedureAddress(_CryptUIDlgSelCertFromStore, cryptuiapi, 'CryptUIDlgSelectCertificateFromStore');
  134. asm
  135. MOV ESP, EBP
  136. POP EBP
  137. JMP [_CryptUIDlgSelCertFromStore]
  138. end;
  139. end;
  140. {$ELSE}
  141. function CryptUIDlgViewContext; external cryptuiapi name 'CryptUIDlgViewContext';
  142. function CryptUIDlgSelectCertificateFromStore; external cryptuiapi name 'CryptUIDlgSelectCertificateFromStore';
  143. {$ENDIF DYNAMIC_LINK}
  144. {$ENDIF JWA_INTERFACESECTION}
  145. {$IFNDEF JWA_OMIT_SECTIONS}
  146. end.
  147. {$ENDIF JWA_OMIT_SECTIONS}