AuthorizationDB.pas 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365
  1. {
  2. * Copyright (c) 2003 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. { Pascal Translation: Gorazd Krosl <[email protected]>, October 2009 }
  24. { Pascal Translation Update: Jonas Maebe <[email protected]>, October 2012 }
  25. { Pascal Translation Update: Jonas Maebe <[email protected]>, August 2015 }
  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. {$modeswitch cblocks}
  34. {$packenum 1}
  35. {$macro on}
  36. {$inline on}
  37. {$calling mwpascal}
  38. {$IFNDEF FPC_DOTTEDUNITS}
  39. unit AuthorizationDB;
  40. {$ENDIF FPC_DOTTEDUNITS}
  41. interface
  42. {$setc UNIVERSAL_INTERFACES_VERSION := $0400}
  43. {$setc GAP_INTERFACES_VERSION := $0308}
  44. {$ifc not defined USE_CFSTR_CONSTANT_MACROS}
  45. {$setc USE_CFSTR_CONSTANT_MACROS := TRUE}
  46. {$endc}
  47. {$ifc defined CPUPOWERPC and defined CPUI386}
  48. {$error Conflicting initial definitions for CPUPOWERPC and CPUI386}
  49. {$endc}
  50. {$ifc defined FPC_BIG_ENDIAN and defined FPC_LITTLE_ENDIAN}
  51. {$error Conflicting initial definitions for FPC_BIG_ENDIAN and FPC_LITTLE_ENDIAN}
  52. {$endc}
  53. {$ifc not defined __ppc__ and defined CPUPOWERPC32}
  54. {$setc __ppc__ := 1}
  55. {$elsec}
  56. {$setc __ppc__ := 0}
  57. {$endc}
  58. {$ifc not defined __ppc64__ and defined CPUPOWERPC64}
  59. {$setc __ppc64__ := 1}
  60. {$elsec}
  61. {$setc __ppc64__ := 0}
  62. {$endc}
  63. {$ifc not defined __i386__ and defined CPUI386}
  64. {$setc __i386__ := 1}
  65. {$elsec}
  66. {$setc __i386__ := 0}
  67. {$endc}
  68. {$ifc not defined __x86_64__ and defined CPUX86_64}
  69. {$setc __x86_64__ := 1}
  70. {$elsec}
  71. {$setc __x86_64__ := 0}
  72. {$endc}
  73. {$ifc not defined __arm__ and defined CPUARM}
  74. {$setc __arm__ := 1}
  75. {$elsec}
  76. {$setc __arm__ := 0}
  77. {$endc}
  78. {$ifc not defined __arm64__ and defined CPUAARCH64}
  79. {$setc __arm64__ := 1}
  80. {$elsec}
  81. {$setc __arm64__ := 0}
  82. {$endc}
  83. {$ifc defined cpu64}
  84. {$setc __LP64__ := 1}
  85. {$elsec}
  86. {$setc __LP64__ := 0}
  87. {$endc}
  88. {$ifc defined __ppc__ and __ppc__ and defined __i386__ and __i386__}
  89. {$error Conflicting definitions for __ppc__ and __i386__}
  90. {$endc}
  91. {$ifc defined __ppc__ and __ppc__}
  92. {$setc TARGET_CPU_PPC := TRUE}
  93. {$setc TARGET_CPU_PPC64 := FALSE}
  94. {$setc TARGET_CPU_X86 := FALSE}
  95. {$setc TARGET_CPU_X86_64 := FALSE}
  96. {$setc TARGET_CPU_ARM := FALSE}
  97. {$setc TARGET_CPU_ARM64 := FALSE}
  98. {$setc TARGET_OS_MAC := TRUE}
  99. {$setc TARGET_OS_IPHONE := FALSE}
  100. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  101. {$setc TARGET_OS_EMBEDDED := FALSE}
  102. {$elifc defined __ppc64__ and __ppc64__}
  103. {$setc TARGET_CPU_PPC := FALSE}
  104. {$setc TARGET_CPU_PPC64 := TRUE}
  105. {$setc TARGET_CPU_X86 := FALSE}
  106. {$setc TARGET_CPU_X86_64 := FALSE}
  107. {$setc TARGET_CPU_ARM := FALSE}
  108. {$setc TARGET_CPU_ARM64 := FALSE}
  109. {$setc TARGET_OS_MAC := TRUE}
  110. {$setc TARGET_OS_IPHONE := FALSE}
  111. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  112. {$setc TARGET_OS_EMBEDDED := FALSE}
  113. {$elifc defined __i386__ and __i386__}
  114. {$setc TARGET_CPU_PPC := FALSE}
  115. {$setc TARGET_CPU_PPC64 := FALSE}
  116. {$setc TARGET_CPU_X86 := TRUE}
  117. {$setc TARGET_CPU_X86_64 := FALSE}
  118. {$setc TARGET_CPU_ARM := FALSE}
  119. {$setc TARGET_CPU_ARM64 := FALSE}
  120. {$ifc defined iphonesim}
  121. {$setc TARGET_OS_MAC := FALSE}
  122. {$setc TARGET_OS_IPHONE := TRUE}
  123. {$setc TARGET_IPHONE_SIMULATOR := TRUE}
  124. {$elsec}
  125. {$setc TARGET_OS_MAC := TRUE}
  126. {$setc TARGET_OS_IPHONE := FALSE}
  127. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  128. {$endc}
  129. {$setc TARGET_OS_EMBEDDED := FALSE}
  130. {$elifc defined __x86_64__ and __x86_64__}
  131. {$setc TARGET_CPU_PPC := FALSE}
  132. {$setc TARGET_CPU_PPC64 := FALSE}
  133. {$setc TARGET_CPU_X86 := FALSE}
  134. {$setc TARGET_CPU_X86_64 := TRUE}
  135. {$setc TARGET_CPU_ARM := FALSE}
  136. {$setc TARGET_CPU_ARM64 := FALSE}
  137. {$ifc defined iphonesim}
  138. {$setc TARGET_OS_MAC := FALSE}
  139. {$setc TARGET_OS_IPHONE := TRUE}
  140. {$setc TARGET_IPHONE_SIMULATOR := TRUE}
  141. {$elsec}
  142. {$setc TARGET_OS_MAC := TRUE}
  143. {$setc TARGET_OS_IPHONE := FALSE}
  144. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  145. {$endc}
  146. {$setc TARGET_OS_EMBEDDED := FALSE}
  147. {$elifc defined __arm__ and __arm__}
  148. {$setc TARGET_CPU_PPC := FALSE}
  149. {$setc TARGET_CPU_PPC64 := FALSE}
  150. {$setc TARGET_CPU_X86 := FALSE}
  151. {$setc TARGET_CPU_X86_64 := FALSE}
  152. {$setc TARGET_CPU_ARM := TRUE}
  153. {$setc TARGET_CPU_ARM64 := FALSE}
  154. {$setc TARGET_OS_MAC := FALSE}
  155. {$setc TARGET_OS_IPHONE := TRUE}
  156. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  157. {$setc TARGET_OS_EMBEDDED := TRUE}
  158. {$elifc defined __arm64__ and __arm64__}
  159. {$setc TARGET_CPU_PPC := FALSE}
  160. {$setc TARGET_CPU_PPC64 := FALSE}
  161. {$setc TARGET_CPU_X86 := FALSE}
  162. {$setc TARGET_CPU_X86_64 := FALSE}
  163. {$setc TARGET_CPU_ARM := FALSE}
  164. {$setc TARGET_CPU_ARM64 := TRUE}
  165. {$ifc defined ios}
  166. {$setc TARGET_OS_MAC := FALSE}
  167. {$setc TARGET_OS_IPHONE := TRUE}
  168. {$setc TARGET_OS_EMBEDDED := TRUE}
  169. {$elsec}
  170. {$setc TARGET_OS_MAC := TRUE}
  171. {$setc TARGET_OS_IPHONE := FALSE}
  172. {$setc TARGET_OS_EMBEDDED := FALSE}
  173. {$endc}
  174. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  175. {$elsec}
  176. {$error __ppc__ nor __ppc64__ nor __i386__ nor __x86_64__ nor __arm__ nor __arm64__ is defined.}
  177. {$endc}
  178. {$ifc defined __LP64__ and __LP64__ }
  179. {$setc TARGET_CPU_64 := TRUE}
  180. {$elsec}
  181. {$setc TARGET_CPU_64 := FALSE}
  182. {$endc}
  183. {$ifc defined FPC_BIG_ENDIAN}
  184. {$setc TARGET_RT_BIG_ENDIAN := TRUE}
  185. {$setc TARGET_RT_LITTLE_ENDIAN := FALSE}
  186. {$elifc defined FPC_LITTLE_ENDIAN}
  187. {$setc TARGET_RT_BIG_ENDIAN := FALSE}
  188. {$setc TARGET_RT_LITTLE_ENDIAN := TRUE}
  189. {$elsec}
  190. {$error Neither FPC_BIG_ENDIAN nor FPC_LITTLE_ENDIAN are defined.}
  191. {$endc}
  192. {$setc ACCESSOR_CALLS_ARE_FUNCTIONS := TRUE}
  193. {$setc CALL_NOT_IN_CARBON := FALSE}
  194. {$setc OLDROUTINENAMES := FALSE}
  195. {$setc OPAQUE_TOOLBOX_STRUCTS := TRUE}
  196. {$setc OPAQUE_UPP_TYPES := TRUE}
  197. {$setc OTCARBONAPPLICATION := TRUE}
  198. {$setc OTKERNEL := FALSE}
  199. {$setc PM_USE_SESSION_APIS := TRUE}
  200. {$setc TARGET_API_MAC_CARBON := TRUE}
  201. {$setc TARGET_API_MAC_OS8 := FALSE}
  202. {$setc TARGET_API_MAC_OSX := TRUE}
  203. {$setc TARGET_CARBON := TRUE}
  204. {$setc TARGET_CPU_68K := FALSE}
  205. {$setc TARGET_CPU_MIPS := FALSE}
  206. {$setc TARGET_CPU_SPARC := FALSE}
  207. {$setc TARGET_OS_UNIX := FALSE}
  208. {$setc TARGET_OS_WIN32 := FALSE}
  209. {$setc TARGET_RT_MAC_68881 := FALSE}
  210. {$setc TARGET_RT_MAC_CFM := FALSE}
  211. {$setc TARGET_RT_MAC_MACHO := TRUE}
  212. {$setc TYPED_FUNCTION_POINTERS := TRUE}
  213. {$setc TYPE_BOOL := FALSE}
  214. {$setc TYPE_EXTENDED := FALSE}
  215. {$setc TYPE_LONGLONG := TRUE}
  216. {$IFDEF FPC_DOTTEDUNITS}
  217. uses MacOsApi.MacTypes,MacOsApi.Authorization,MacOsApi.CFBase,MacOsApi.CFDictionary,MacOsApi.CFString,MacOsApi.CFBundle;
  218. {$ELSE FPC_DOTTEDUNITS}
  219. uses MacTypes,Authorization,CFBase,CFDictionary,CFString,CFBundle;
  220. {$ENDIF FPC_DOTTEDUNITS}
  221. {$endc} {not MACOSALLINCLUDE}
  222. {$ifc TARGET_OS_MAC}
  223. {$ALIGN POWER}
  224. {
  225. * AuthorizationDB.h -- APIs for managing the authorization policy database
  226. * and daemons.
  227. }
  228. {!
  229. @header AuthorizationDB
  230. Version 1.0
  231. This API allows for any programs to get, modify, delete and add new right definitions to the policy database. Meta-rights specify whether and what authorization is required to make these modifications.
  232. AuthorizationRightSet(authRef, "com.ifoo.ifax.send", CFSTR(kRuleIsAdmin), CFSTR("You must authenticate to send a fax."), NULL, NULL)
  233. add a rule for letting admins send faxes using a canned rule, delegating to a pre-specified rule that authorizes everyone who is an admin.
  234. AuthorizationRightSet(authRef, "com.ifoo.ifax.send", [[CFSTR(kRightRule), CFSTR(kRuleIsAdmin)], [CFSTR(kRightComment), CFSTR("authorizes sending of 1 fax message")]], CFSTR("Authorize sending of a fax"), NULL, NULL)
  235. add identical rule, but specify additional attributes this time.
  236. Keep in mind while specifying a comment to be specific about what you need to authorize for (1 fax), in terms of a general message for user. The means of proof required for kRuleIsAdmin (enter username/password for example) should not be included here, since it could be configured differently. Also note that the "authRef" variable used in each of the above examples must be a vaild AuthorizationRef obtained from AuthorizationCreate().
  237. }
  238. {! @define kRightRule
  239. rule delegation key. Instead of specifying exact behavior some canned rules
  240. are shipped that may be switched by configurable security.
  241. }
  242. const
  243. kAuthorizationRightRule = 'rule';
  244. {! @defined kRuleIsAdmin
  245. canned rule values for use with rule delegation definitions: require user to be an admin.
  246. }
  247. const
  248. kAuthorizationRuleIsAdmin = 'is-admin';
  249. {! @defined kRuleAuthenticateAsSessionUser
  250. canned rule value for use with rule delegation definitions: require user to authenticate as the session owner (logged-in user).
  251. }
  252. const
  253. kAuthorizationRuleAuthenticateAsSessionUser = 'authenticate-session-owner';
  254. {! @defined kRuleAuthenticateAsAdmin
  255. Canned rule value for use with rule delegation definitions: require user to authenticate as admin.
  256. }
  257. const
  258. kAuthorizationRuleAuthenticateAsAdmin = 'authenticate-admin';
  259. {! @defined kAuthorizationRuleClassAllow
  260. Class that allows anything.
  261. }
  262. const
  263. kAuthorizationRuleClassAllow = 'allow';
  264. {! @defined kAuthorizationRuleClassDeny
  265. Class that denies anything.
  266. }
  267. const
  268. kAuthorizationRuleClassDeny = 'deny';
  269. {! @defined kAuthorizationComment
  270. comments for the administrator on what is being customized here;
  271. as opposed to (localized) descriptions presented to the user.
  272. }
  273. const
  274. kAuthorizationComment = 'comment';
  275. {!
  276. @function AuthorizationRightGet
  277. Retrieves a right definition as a dictionary. There are no restrictions to keep anyone from retrieving these definitions.
  278. @param rightName (input) the rightname (ASCII). Wildcard rightname definitions are okay.
  279. @param rightDefinition (output/optional) the dictionary with all keys defining the right. See documented keys. Passing in NULL will just check if there is a definition. The caller is responsible for releasing the returned dictionary.
  280. @result errAuthorizationSuccess 0 No error.
  281. errAuthorizationDenied -60005 No definition found.
  282. }
  283. function AuthorizationRightGet( rightName: ConstCStringPtr; rightDefinition: CFDictionaryRefPtr ): OSStatus; external name '_AuthorizationRightGet';
  284. {!
  285. @function AuthorizationRightSet
  286. Create or update a right entry. Only normal rights can be registered (wildcard rights are denied); wildcard rights are considered to be put in by an administrator putting together a site configuration.
  287. @param authRef (input) authRef to authorize modifications.
  288. @param rightName (input) the rightname (ASCII). Wildcard rightnames are not okay.
  289. @param rightDefinition (input) a CFString of the name of a rule to use (delegate) or CFDictionary containing keys defining one.
  290. @param descriptionKey (input/optional) a CFString to use as a key for looking up localized descriptions. If no localization is found this will be the description itself.
  291. @param bundle (input/optional) a bundle to get localizations from if not the main bundle.
  292. @param localeTableName (input/optional) stringtable name to get localizations from.
  293. @result errAuthorizationSuccess 0 added right definition successfully.
  294. errAuthorizationDenied -60005 Unable to create or update right definition.
  295. errAuthorizationCanceled -60006 Authorization was canceled by user.
  296. errAuthorizationInteractionNotAllowed -60007 Interaction was required but not possible.
  297. }
  298. function AuthorizationRightSet( authRef: AuthorizationRef; rightName: ConstCStringPtr; rightDefinition: CFTypeRef; descriptionKey: CFStringRef; bundle: CFBundleRef; localeTableName: CFStringRef ): OSStatus; external name '_AuthorizationRightSet';
  299. {!
  300. @function AuthorizationRightRemove
  301. Request to remove a right from the policy database.
  302. @param authRef (input) authRef, to be used to authorize this action.
  303. @param rightName (input) the rightname (ASCII). Wildcard rightnames are not okay.
  304. }
  305. function AuthorizationRightRemove( authRef: AuthorizationRef; rightName: ConstCStringPtr ): OSStatus; external name '_AuthorizationRightRemove';
  306. {$endc} {TARGET_OS_MAC}
  307. {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE}
  308. end.
  309. {$endc} {not MACOSALLINCLUDE}