jwaiadmext.pas 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. {******************************************************************************}
  2. { }
  3. { IISAdmin Extensions 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: iadmext.h, released November 2002. The original Pascal }
  9. { code is: IAdmExt.pas, released March 2002. 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: JwaIAdmExt.pas,v 1.6 2005/09/03 14:27:48 marquardt Exp $
  43. unit JwaIAdmExt;
  44. {$WEAKPACKAGEUNIT}
  45. {$HPPEMIT ''}
  46. {$HPPEMIT '#include "iadmext.h"'}
  47. {$HPPEMIT ''}
  48. {$I jediapilib.inc}
  49. interface
  50. uses
  51. JwaIisCnfg, JwaWindows;
  52. //
  53. // The Main Interface. All extensions must support this interface.
  54. //
  55. // {51DFE970-F6F2-11d0-B9BD-00A0C922E750}
  56. const
  57. IID_IADMEXT: TGUID = (D1:$51dfe970; D2:$f6f2; D3:$11d0; D4:($b9, $bd, $0, $a0, $c9, $22, $e7, $50));
  58. {$EXTERNALSYM IID_IADMEXT}
  59. //
  60. // InProcess COM Registration. All extensions must write a subkey name by the
  61. // CLSID for the above interface under this key in the Registry.
  62. //
  63. IISADMIN_EXTENSIONS_REG_KEYA = 'SOFTWARE\Microsoft\InetStp\Extensions';
  64. {$EXTERNALSYM IISADMIN_EXTENSIONS_REG_KEYA}
  65. IISADMIN_EXTENSIONS_REG_KEYW = WideString('SOFTWARE\Microsoft\InetStp\Extensions');
  66. {$EXTERNALSYM IISADMIN_EXTENSIONS_REG_KEYW}
  67. IISADMIN_EXTENSIONS_REG_KEY = TEXT('SOFTWARE\Microsoft\InetStp\Extensions');
  68. {$EXTERNALSYM IISADMIN_EXTENSIONS_REG_KEY}
  69. //
  70. // COM Registration. CLSIDS for the DCOM interface provided by these extensions will
  71. // be written to this key and ID by IISADMIN as a multisz property.
  72. //
  73. // This is intended for use by other applications which need to find out what classid's are
  74. // registered.
  75. //
  76. IISADMIN_EXTENSIONS_CLSID_MD_KEYA = 'LM/IISADMIN/EXTENSIONS/DCOMCLSIDS';
  77. {$EXTERNALSYM IISADMIN_EXTENSIONS_CLSID_MD_KEYA}
  78. IISADMIN_EXTENSIONS_CLSID_MD_KEYW = WideString('LM/IISADMIN/EXTENSIONS/DCOMCLSIDS');
  79. {$EXTERNALSYM IISADMIN_EXTENSIONS_CLSID_MD_KEYW}
  80. IISADMIN_EXTENSIONS_CLSID_MD_KEY = TEXT('LM/IISADMIN/EXTENSIONS/DCOMCLSIDS');
  81. {$EXTERNALSYM IISADMIN_EXTENSIONS_CLSID_MD_KEY}
  82. IISADMIN_EXTENSIONS_CLSID_MD_ID = MD_IISADMIN_EXTENSIONS;
  83. {$EXTERNALSYM IISADMIN_EXTENSIONS_CLSID_MD_ID}
  84. type
  85. IADMEXT = interface (IUnknown)
  86. ['{51DFE970-F6F2-11d0-B9BD-00A0C922E750}']
  87. //
  88. // All methods below will be called under a thread which has called
  89. // CoInitializeEx(NULL, COINIT_MULTITHREADED).
  90. //
  91. // The IMSAdminBase Object will be available during all of these calls.
  92. //
  93. //
  94. // Initialize will be called by IISADMIN when it initializes.
  95. //
  96. function Initialize: HRESULT; stdcall;
  97. //
  98. // EnumDcomCLSIDs will be called by IISADMIN when it initializes,
  99. // and the returned CLSIDs will be written to the metabase at
  100. // the path IISADMIN_EXTENSIONS_CLSID_MD_KEY.
  101. //
  102. function EnumDcomCLSIDs(var pclsidDcom: CLSID; dwEnumIndex: DWORD): HRESULT; stdcall;
  103. //
  104. // Terminate will be called by IISADMIN when it terminates.
  105. //
  106. function Terminate: HRESULT; stdcall;
  107. end;
  108. {$EXTERNALSYM IADMEXT}
  109. implementation
  110. end.