cssmkrapi.pas 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348
  1. {
  2. * Copyright (c) 1999-2001,2004 Apple Computer, Inc. All Rights Reserved.
  3. *
  4. * @APPLE_LICENSE_HEADER_START@
  5. *
  6. * This file contains Original Code and/or Modifications of Original Code
  7. * as defined in and that are subject to the Apple Public Source License
  8. * Version 2.0 (the 'License'). You may not use this file except in
  9. * compliance with the License. Please obtain a copy of the License at
  10. * http://www.opensource.apple.com/apsl/ and read it before using this
  11. * file.
  12. *
  13. * The Original Code and all software distributed under the License are
  14. * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
  15. * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
  16. * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
  17. * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
  18. * Please see the License for the specific language governing rights and
  19. * limitations under the License.
  20. *
  21. * @APPLE_LICENSE_HEADER_END@
  22. *
  23. * cssmkrapi.h -- Application Programmers Interface for Key Recovery Modules
  24. }
  25. { Pascal Translation Updated: Jonas Maebe, <[email protected]>, September 2010 }
  26. {
  27. Modified for use with Free Pascal
  28. Version 308
  29. Please report any bugs to <[email protected]>
  30. }
  31. {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE}
  32. {$mode macpas}
  33. {$packenum 1}
  34. {$macro on}
  35. {$inline on}
  36. {$calling mwpascal}
  37. unit cssmkrapi;
  38. interface
  39. {$setc UNIVERSAL_INTERFACES_VERSION := $0400}
  40. {$setc GAP_INTERFACES_VERSION := $0308}
  41. {$ifc not defined USE_CFSTR_CONSTANT_MACROS}
  42. {$setc USE_CFSTR_CONSTANT_MACROS := TRUE}
  43. {$endc}
  44. {$ifc defined CPUPOWERPC and defined CPUI386}
  45. {$error Conflicting initial definitions for CPUPOWERPC and CPUI386}
  46. {$endc}
  47. {$ifc defined FPC_BIG_ENDIAN and defined FPC_LITTLE_ENDIAN}
  48. {$error Conflicting initial definitions for FPC_BIG_ENDIAN and FPC_LITTLE_ENDIAN}
  49. {$endc}
  50. {$ifc not defined __ppc__ and defined CPUPOWERPC32}
  51. {$setc __ppc__ := 1}
  52. {$elsec}
  53. {$setc __ppc__ := 0}
  54. {$endc}
  55. {$ifc not defined __ppc64__ and defined CPUPOWERPC64}
  56. {$setc __ppc64__ := 1}
  57. {$elsec}
  58. {$setc __ppc64__ := 0}
  59. {$endc}
  60. {$ifc not defined __i386__ and defined CPUI386}
  61. {$setc __i386__ := 1}
  62. {$elsec}
  63. {$setc __i386__ := 0}
  64. {$endc}
  65. {$ifc not defined __x86_64__ and defined CPUX86_64}
  66. {$setc __x86_64__ := 1}
  67. {$elsec}
  68. {$setc __x86_64__ := 0}
  69. {$endc}
  70. {$ifc not defined __arm__ and defined CPUARM}
  71. {$setc __arm__ := 1}
  72. {$elsec}
  73. {$setc __arm__ := 0}
  74. {$endc}
  75. {$ifc defined cpu64}
  76. {$setc __LP64__ := 1}
  77. {$elsec}
  78. {$setc __LP64__ := 0}
  79. {$endc}
  80. {$ifc defined __ppc__ and __ppc__ and defined __i386__ and __i386__}
  81. {$error Conflicting definitions for __ppc__ and __i386__}
  82. {$endc}
  83. {$ifc defined __ppc__ and __ppc__}
  84. {$setc TARGET_CPU_PPC := TRUE}
  85. {$setc TARGET_CPU_PPC64 := FALSE}
  86. {$setc TARGET_CPU_X86 := FALSE}
  87. {$setc TARGET_CPU_X86_64 := FALSE}
  88. {$setc TARGET_CPU_ARM := FALSE}
  89. {$setc TARGET_OS_MAC := TRUE}
  90. {$setc TARGET_OS_IPHONE := FALSE}
  91. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  92. {$elifc defined __ppc64__ and __ppc64__}
  93. {$setc TARGET_CPU_PPC := FALSE}
  94. {$setc TARGET_CPU_PPC64 := TRUE}
  95. {$setc TARGET_CPU_X86 := FALSE}
  96. {$setc TARGET_CPU_X86_64 := FALSE}
  97. {$setc TARGET_CPU_ARM := FALSE}
  98. {$setc TARGET_OS_MAC := TRUE}
  99. {$setc TARGET_OS_IPHONE := FALSE}
  100. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  101. {$elifc defined __i386__ and __i386__}
  102. {$setc TARGET_CPU_PPC := FALSE}
  103. {$setc TARGET_CPU_PPC64 := FALSE}
  104. {$setc TARGET_CPU_X86 := TRUE}
  105. {$setc TARGET_CPU_X86_64 := FALSE}
  106. {$setc TARGET_CPU_ARM := FALSE}
  107. {$ifc defined(iphonesim)}
  108. {$setc TARGET_OS_MAC := FALSE}
  109. {$setc TARGET_OS_IPHONE := TRUE}
  110. {$setc TARGET_IPHONE_SIMULATOR := TRUE}
  111. {$elsec}
  112. {$setc TARGET_OS_MAC := TRUE}
  113. {$setc TARGET_OS_IPHONE := FALSE}
  114. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  115. {$endc}
  116. {$elifc defined __x86_64__ and __x86_64__}
  117. {$setc TARGET_CPU_PPC := FALSE}
  118. {$setc TARGET_CPU_PPC64 := FALSE}
  119. {$setc TARGET_CPU_X86 := FALSE}
  120. {$setc TARGET_CPU_X86_64 := TRUE}
  121. {$setc TARGET_CPU_ARM := FALSE}
  122. {$setc TARGET_OS_MAC := TRUE}
  123. {$setc TARGET_OS_IPHONE := FALSE}
  124. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  125. {$elifc defined __arm__ and __arm__}
  126. {$setc TARGET_CPU_PPC := FALSE}
  127. {$setc TARGET_CPU_PPC64 := FALSE}
  128. {$setc TARGET_CPU_X86 := FALSE}
  129. {$setc TARGET_CPU_X86_64 := FALSE}
  130. {$setc TARGET_CPU_ARM := TRUE}
  131. { will require compiler define when/if other Apple devices with ARM cpus ship }
  132. {$setc TARGET_OS_MAC := FALSE}
  133. {$setc TARGET_OS_IPHONE := TRUE}
  134. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  135. {$elsec}
  136. {$error __ppc__ nor __ppc64__ nor __i386__ nor __x86_64__ nor __arm__ is defined.}
  137. {$endc}
  138. {$ifc defined __LP64__ and __LP64__ }
  139. {$setc TARGET_CPU_64 := TRUE}
  140. {$elsec}
  141. {$setc TARGET_CPU_64 := FALSE}
  142. {$endc}
  143. {$ifc defined FPC_BIG_ENDIAN}
  144. {$setc TARGET_RT_BIG_ENDIAN := TRUE}
  145. {$setc TARGET_RT_LITTLE_ENDIAN := FALSE}
  146. {$elifc defined FPC_LITTLE_ENDIAN}
  147. {$setc TARGET_RT_BIG_ENDIAN := FALSE}
  148. {$setc TARGET_RT_LITTLE_ENDIAN := TRUE}
  149. {$elsec}
  150. {$error Neither FPC_BIG_ENDIAN nor FPC_LITTLE_ENDIAN are defined.}
  151. {$endc}
  152. {$setc ACCESSOR_CALLS_ARE_FUNCTIONS := TRUE}
  153. {$setc CALL_NOT_IN_CARBON := FALSE}
  154. {$setc OLDROUTINENAMES := FALSE}
  155. {$setc OPAQUE_TOOLBOX_STRUCTS := TRUE}
  156. {$setc OPAQUE_UPP_TYPES := TRUE}
  157. {$setc OTCARBONAPPLICATION := TRUE}
  158. {$setc OTKERNEL := FALSE}
  159. {$setc PM_USE_SESSION_APIS := TRUE}
  160. {$setc TARGET_API_MAC_CARBON := TRUE}
  161. {$setc TARGET_API_MAC_OS8 := FALSE}
  162. {$setc TARGET_API_MAC_OSX := TRUE}
  163. {$setc TARGET_CARBON := TRUE}
  164. {$setc TARGET_CPU_68K := FALSE}
  165. {$setc TARGET_CPU_MIPS := FALSE}
  166. {$setc TARGET_CPU_SPARC := FALSE}
  167. {$setc TARGET_OS_UNIX := FALSE}
  168. {$setc TARGET_OS_WIN32 := FALSE}
  169. {$setc TARGET_RT_MAC_68881 := FALSE}
  170. {$setc TARGET_RT_MAC_CFM := FALSE}
  171. {$setc TARGET_RT_MAC_MACHO := TRUE}
  172. {$setc TYPED_FUNCTION_POINTERS := TRUE}
  173. {$setc TYPE_BOOL := FALSE}
  174. {$setc TYPE_EXTENDED := FALSE}
  175. {$setc TYPE_LONGLONG := TRUE}
  176. uses MacTypes,cssmtype;
  177. {$endc} {not MACOSALLINCLUDE}
  178. {$ifc TARGET_OS_MAC}
  179. {$packrecords c}
  180. type
  181. CSSM_KRSP_HANDLE = UInt32; { Key Recovery Service Provider Handle }
  182. type
  183. cssm_kr_name = record
  184. Type_: UInt8; { namespace type }
  185. Length: UInt8; { name string length }
  186. Name: CStringPtr; { name string }
  187. end;
  188. type
  189. CSSM_KR_PROFILE_PTR = ^cssm_kr_profile;
  190. CSSM_KR_PROFILEPtr = ^cssm_kr_profile;
  191. cssm_kr_profile = record
  192. UserName: CSSM_KR_NAME; { name of the user }
  193. UserCertificate: CSSM_CERTGROUP_PTR; { public key certificate of the user }
  194. KRSCertChain: CSSM_CERTGROUP_PTR; { cert chain for the KRSP coordinator }
  195. LE_KRANum: UInt8; { number of KRA cert chains in the following list }
  196. LE_KRACertChainList: CSSM_CERTGROUP_PTR; { list of Law enforcement KRA certificate chains }
  197. ENT_KRANum: UInt8; { number of KRA cert chains in the following list }
  198. ENT_KRACertChainList: CSSM_CERTGROUP_PTR; { list of Enterprise KRA certificate chains }
  199. INDIV_KRANum: UInt8; { number of KRA cert chains in the following list }
  200. INDIV_KRACertChainList: CSSM_CERTGROUP_PTR; { list of Individual KRA certificate chains }
  201. INDIV_AuthenticationInfo: CSSM_DATA_PTR; { authentication information for individual key recovery }
  202. KRSPFlags: UInt32; { flag values to be interpreted by KRSP }
  203. KRSPExtensions: CSSM_DATA_PTR; { reserved for extensions specific to KRSPs }
  204. end;
  205. type
  206. CSSM_KR_WRAPPEDPRODUCT_INFO_PTR = ^CSSM_KR_WRAPPEDPRODUCT_INFO;
  207. CSSM_KR_WRAPPEDPRODUCT_INFOPtr = ^CSSM_KR_WRAPPEDPRODUCT_INFO;
  208. CSSM_KR_WRAPPEDPRODUCT_INFO = record
  209. StandardVersion: CSSM_VERSION;
  210. StandardDescription: CSSM_STRING;
  211. ProductVersion: CSSM_VERSION;
  212. ProductDescription: CSSM_STRING;
  213. ProductVendor: CSSM_STRING;
  214. ProductFlags: UInt32;
  215. end;
  216. type
  217. CSSM_KRSUBSERVICE_PTR = ^cssm_krsubservice;
  218. CSSM_KRSUBSERVICEPtr = ^cssm_krsubservice;
  219. cssm_krsubservice = record
  220. SubServiceId: UInt32;
  221. Description: CStringPtr; { Description of this sub service }
  222. WrappedProduct: CSSM_KR_WRAPPEDPRODUCT_INFO;
  223. end;
  224. type
  225. CSSM_KR_POLICY_TYPE = UInt32;
  226. const
  227. CSSM_KR_INDIV_POLICY = $00000001;
  228. const
  229. CSSM_KR_ENT_POLICY = $00000002;
  230. const
  231. CSSM_KR_LE_MAN_POLICY = $00000003;
  232. const
  233. CSSM_KR_LE_USE_POLICY = $00000004;
  234. type
  235. CSSM_KR_POLICY_FLAGS = UInt32;
  236. const
  237. CSSM_KR_INDIV = $00000001;
  238. const
  239. CSSM_KR_ENT = $00000002;
  240. const
  241. CSSM_KR_LE_MAN = $00000004;
  242. const
  243. CSSM_KR_LE_USE = $00000008;
  244. const
  245. CSSM_KR_LE = (CSSM_KR_LE_MAN or CSSM_KR_LE_USE);
  246. const
  247. CSSM_KR_OPTIMIZE = $00000010;
  248. const
  249. CSSM_KR_DROP_WORKFACTOR = $00000020;
  250. type
  251. CSSM_KR_POLICY_LIST_ITEM_PTR = ^cssm_kr_policy_list_item;
  252. CSSM_KR_POLICY_LIST_ITEMPtr = ^cssm_kr_policy_list_item;
  253. cssm_kr_policy_list_item = record
  254. next: CSSM_KR_POLICY_LIST_ITEM_PTR;
  255. AlgorithmId: CSSM_ALGORITHMS;
  256. Mode: CSSM_ENCRYPT_MODE;
  257. MaxKeyLength: UInt32;
  258. MaxRounds: UInt32;
  259. WorkFactor: UInt8;
  260. PolicyFlags: CSSM_KR_POLICY_FLAGS;
  261. AlgClass: CSSM_CONTEXT_TYPE;
  262. end;
  263. type
  264. CSSM_KR_POLICY_INFO_PTR = ^cssm_kr_policy_info;
  265. CSSM_KR_POLICY_INFOPtr = ^cssm_kr_policy_info;
  266. cssm_kr_policy_info = record
  267. krbNotAllowed: CSSM_BOOL;
  268. numberOfEntries: UInt32;
  269. policyEntry: CSSM_KR_POLICY_LIST_ITEMPtr;
  270. end;
  271. { Key Recovery Module Mangement Operations }
  272. function CSSM_KR_SetEnterpriseRecoveryPolicy( const (*var*) RecoveryPolicyFileName: CSSM_DATA; const (*var*) OldPassPhrase: CSSM_ACCESS_CREDENTIALS; const (*var*) NewPassPhrase: CSSM_ACCESS_CREDENTIALS ): CSSM_RETURN; external name '_CSSM_KR_SetEnterpriseRecoveryPolicy';
  273. { Key Recovery Context Operations }
  274. function CSSM_KR_CreateRecoveryRegistrationContext( KRSPHandle: CSSM_KRSP_HANDLE; var NewContext: CSSM_CC_HANDLE ): CSSM_RETURN; external name '_CSSM_KR_CreateRecoveryRegistrationContext';
  275. function CSSM_KR_CreateRecoveryEnablementContext( KRSPHandle: CSSM_KRSP_HANDLE; const (*var*) LocalProfile: CSSM_KR_PROFILE; const (*var*) RemoteProfile: CSSM_KR_PROFILE; var NewContext: CSSM_CC_HANDLE ): CSSM_RETURN; external name '_CSSM_KR_CreateRecoveryEnablementContext';
  276. function CSSM_KR_CreateRecoveryRequestContext( KRSPHandle: CSSM_KRSP_HANDLE; const (*var*) LocalProfile: CSSM_KR_PROFILE; var NewContext: CSSM_CC_HANDLE ): CSSM_RETURN; external name '_CSSM_KR_CreateRecoveryRequestContext';
  277. function CSSM_KR_GetPolicyInfo( CCHandle: CSSM_CC_HANDLE; var EncryptionProhibited: CSSM_KR_POLICY_FLAGS; var WorkFactor: UInt32 ): CSSM_RETURN; external name '_CSSM_KR_GetPolicyInfo';
  278. { Key Recovery Registration Operations }
  279. function CSSM_KR_RegistrationRequest( RecoveryRegistrationContext: CSSM_CC_HANDLE; const (*var*) KRInData: CSSM_DATA; const (*var*) AccessCredentials: CSSM_ACCESS_CREDENTIALS; KRFlags: CSSM_KR_POLICY_FLAGS; var EstimatedTime: SInt32; ReferenceHandle: CSSM_HANDLE_PTR ): CSSM_RETURN; external name '_CSSM_KR_RegistrationRequest';
  280. function CSSM_KR_RegistrationRetrieve( KRSPHandle: CSSM_KRSP_HANDLE; ReferenceHandle: CSSM_HANDLE; const (*var*) AccessCredentials: CSSM_ACCESS_CREDENTIALS; var EstimatedTime: SInt32; KRProfile: CSSM_KR_PROFILE_PTR ): CSSM_RETURN; external name '_CSSM_KR_RegistrationRetrieve';
  281. { Key Recovery Enablement Operations }
  282. function CSSM_KR_GenerateRecoveryFields( KeyRecoveryContext: CSSM_CC_HANDLE; CCHandle: CSSM_CC_HANDLE; const (*var*) KRSPOptions: CSSM_DATA; KRFlags: CSSM_KR_POLICY_FLAGS; KRFields: CSSM_DATA_PTR; var NewCCHandle: CSSM_CC_HANDLE ): CSSM_RETURN; external name '_CSSM_KR_GenerateRecoveryFields';
  283. function CSSM_KR_ProcessRecoveryFields( KeyRecoveryContext: CSSM_CC_HANDLE; CryptoContext: CSSM_CC_HANDLE; const (*var*) KRSPOptions: CSSM_DATA; KRFlags: CSSM_KR_POLICY_FLAGS; const (*var*) KRFields: CSSM_DATA; var NewCryptoContext: CSSM_CC_HANDLE ): CSSM_RETURN; external name '_CSSM_KR_ProcessRecoveryFields';
  284. { Key Recovery Request Operations }
  285. function CSSM_KR_RecoveryRequest( RecoveryRequestContext: CSSM_CC_HANDLE; const (*var*) KRInData: CSSM_DATA; const (*var*) AccessCredentials: CSSM_ACCESS_CREDENTIALS; var EstimatedTime: SInt32; ReferenceHandle: CSSM_HANDLE_PTR ): CSSM_RETURN; external name '_CSSM_KR_RecoveryRequest';
  286. function CSSM_KR_RecoveryRetrieve( KRSPHandle: CSSM_KRSP_HANDLE; ReferenceHandle: CSSM_HANDLE; const (*var*) AccessCredentials: CSSM_ACCESS_CREDENTIALS; var EstimatedTime: SInt32; CacheHandle: CSSM_HANDLE_PTR; var NumberOfRecoveredKeys: UInt32 ): CSSM_RETURN; external name '_CSSM_KR_RecoveryRetrieve';
  287. function CSSM_KR_GetRecoveredObject( KRSPHandle: CSSM_KRSP_HANDLE; CacheHandle: CSSM_HANDLE; IndexInResults: UInt32; CSPHandle: CSSM_CSP_HANDLE; const (*var*) CredAndAclEntry: CSSM_RESOURCE_CONTROL_CONTEXT; Flags: UInt32; RecoveredKey: CSSM_KEY_PTR; OtherInfo: CSSM_DATA_PTR ): CSSM_RETURN; external name '_CSSM_KR_GetRecoveredObject';
  288. function CSSM_KR_RecoveryRequestAbort( KRSPHandle: CSSM_KRSP_HANDLE; CacheHandle: CSSM_HANDLE ): CSSM_RETURN; external name '_CSSM_KR_RecoveryRequestAbort';
  289. function CSSM_KR_QueryPolicyInfo( KRSPHandle: CSSM_KRSP_HANDLE; AlgorithmID: CSSM_ALGORITHMS; Mode: CSSM_ENCRYPT_MODE; Class: CSSM_CONTEXT_TYPE; var PolicyInfoData: CSSM_KR_POLICY_INFO_PTR ): CSSM_RETURN; external name '_CSSM_KR_QueryPolicyInfo';
  290. { Extensibility Functions }
  291. function CSSM_KR_PassThrough( KRSPHandle: CSSM_KRSP_HANDLE; KeyRecoveryContext: CSSM_CC_HANDLE; CryptoContext: CSSM_CC_HANDLE; PassThroughId: UInt32; InputParams: {const} UnivPtr; OutputParams: UnivPtrPtr ): CSSM_RETURN; external name '_CSSM_KR_PassThrough';
  292. {$endc} {TARGET_OS_MAC}
  293. {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE}
  294. end.
  295. {$endc} {not MACOSALLINCLUDE}