Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

423 lines
14 KiB

  1. /*
  2. File: ClientUAM.h
  3. Contains: Public header file for writing UAM modules
  4. Version: AppleShare X
  5. Copyright: 2000 by Apple Computer, Inc., all rights reserved.
  6. Change History (most recent first):
  7. <RASC2> 2/25/00 law more updates
  8. <1> 2/3/00 law first checked in
  9. */
  10. #ifndef __CLIENTUAM__
  11. #define __CLIENTUAM__
  12. #ifndef __CORESERVICES__
  13. #include <CoreServices/CoreServices.h>
  14. #endif
  15. //#ifndef __EVENTS__
  16. //#include <HIToolbox/Events.h>
  17. //#endif
  18. #if PRAGMA_ONCE
  19. #pragma once
  20. #endif
  21. #ifdef __cplusplus
  22. extern "C" {
  23. #endif
  24. #if PRAGMA_IMPORT
  25. #pragma import on
  26. #endif
  27. #if PRAGMA_STRUCT_ALIGN
  28. #pragma options align=mac68k
  29. #elif PRAGMA_STRUCT_PACKPUSH
  30. #pragma pack(push, 2)
  31. #elif PRAGMA_STRUCT_PACK
  32. #pragma pack(2)
  33. #endif
  34. /* Error values*/
  35. enum {
  36. kUAMError = -5002, /* afpBadUAM*/
  37. kNotForUs = -50 /* paramErr*/
  38. };
  39. /* UAM Class & Type values*/
  40. enum {
  41. kUAMStdClass = 0, /* Standard UAM */
  42. kUAMVarClearClass = 1, /* variable length cleartext password*/
  43. kUAMVarCryptClass = 2, /* variable length encrypted password*/
  44. kUAMUserDefClass = 3 /* Custom UAM*/
  45. };
  46. enum {
  47. kNoPasswd = 1, /* Class 0, No User Authentication (Guest)*/
  48. kCleartextPasswd = 2, /* Class 0, Cleartext password (8 byte password)*/
  49. kEncryptPasswd = 3, /* Class 0, RandnumExchange (8 byte password)*/
  50. kVarPasswd = 4, /* Class 1, variable length cleartext password*/
  51. kVarEncryptPasswd = 5, /* Class 2, variable length encrypted password*/
  52. kTwoWayEncryptPasswd = 6, /* Class 0, two way randnum exchange (8 byte password)*/
  53. kEncryptPasswdTransport = 7 /* Class 0, Diffie Hellman password transport (64 byte pasword)*/
  54. };
  55. /* general constants*/
  56. enum {
  57. kMaxAFPCommand = 576,
  58. kStdPWdLength = 8,
  59. kMaxPwdLength = 64
  60. };
  61. /* UAM Commands */
  62. enum {
  63. kUAMOpen = 0,
  64. kUAMPWDlog = 1,
  65. kUAMLogin = 2,
  66. kUAMVSDlog = 3,
  67. kUAMChgPassDlg = 4,
  68. kUAMChgPass = 5,
  69. kUAMGetInfoSize = 6,
  70. kUAMGetInfo = 7,
  71. kUAMClose = 8
  72. };
  73. /* config bits*/
  74. enum {
  75. kUsePWDlog = 0, /* The UAM wants to put up its own Password/PRAuth Dialog*/
  76. kUseVolDlog = 1, /* The UAM wants to put up its own Volume Selection Dialog*/
  77. kSupportsCP = 2, /* The UAM supports Changing the password*/
  78. kUseCPDlog = 3, /* The UAM wants to put up its own Change Password Dialog*/
  79. kUseUAMInfo = 4 /* The UAM supports storing authentication info in UAMInfo*/
  80. };
  81. /* All other bits are reserved and must be set to 0 */
  82. /* structs*/
  83. struct AFPName {
  84. unsigned short fNameLen; // length of the fNameData field in bytes
  85. unsigned char fNameData[765]; // 255 unicode characters in utf-8
  86. };
  87. typedef struct AFPName AFPName;
  88. struct ClientInfo {
  89. short fInfoType; /* the type of ClientInfo*/
  90. Str255 fDefaultUserName; /* a pointer to the Default User name*/
  91. };
  92. typedef struct ClientInfo ClientInfo;
  93. enum {
  94. kAFPClientInfo = 0
  95. };
  96. struct AFPClientInfo {
  97. short fInfoType; /* the type of ClientInfo (kAFPClientInfo)*/
  98. Str255 fDefaultUserName; /* a pointer to the Default User name*/
  99. AFPName fUTF8UserName; /* the utf-8 version of the username */
  100. short fConfigFlags; /* the hi short of the gestalt('afpt') response*/
  101. short fVersion; /* the low short of the gestalt('afpt') response*/
  102. short fNumAFPVersions; /* the number of afp versions supported by this client*/
  103. StringPtr * fAFPVersionStrs; /* an array of afp version strings supported by this client*/
  104. };
  105. typedef struct AFPClientInfo AFPClientInfo;
  106. /* Callbacks:*/
  107. /*
  108. this Completion routine is called with the contextPtr passed in to
  109. the OpenAFPSession() and SendRequest() calls, when one of these calls
  110. completes. The result parameter contains the AFP result.
  111. You cannot call any of the callback routines from this Completion
  112. routine, so you can't do chained completion routines. This routine
  113. will be called just like any other completion routine or notifier
  114. so the usual rules apply.
  115. */
  116. typedef CALLBACK_API( void , CompletionPtr )(void *contextPtr, OSStatus result);
  117. /* GetClientInfo()
  118. Returns information about the Client, such as which versions of AFP are
  119. supported and the various gestalt values. This call also returns the
  120. default user name. If the infoType is not avaliable it will return nil.
  121. pascal OSStatus GetClientInfo(short infoType,ClientInfo **infoPtr);
  122. */
  123. struct UAMMessage {
  124. long commandCode;
  125. long sessionRefNum;
  126. OSStatus result;
  127. unsigned char * cmdBuffer;
  128. unsigned long cmdBufferSize;
  129. unsigned char * replyBuffer;
  130. unsigned long replyBufferSize;
  131. CompletionPtr completion;
  132. void * contextPtr;
  133. UInt8 scratch[80]; /* scratch space for the client*/
  134. };
  135. typedef struct UAMMessage UAMMessage;
  136. typedef UAMMessage * UAMMessagePtr;
  137. enum {
  138. /* commandCodes (for future expansion)*/
  139. kOpenSession = FOUR_CHAR_CODE('UAOS'),
  140. kSendRequest = FOUR_CHAR_CODE('UASR')
  141. };
  142. /* OpenSession()
  143. Opens a session to the specified address. If you are using AFP, cmdBuffer MUST
  144. contain an AFP Login command. If you are using AFP the command buffer size is limited
  145. to kMaxAFPCommand (576 bytes). Set endpointString to nil if default is desired
  146. (TCP only, it is ignored for AppleTalk connections and on Mac OS X).
  147. Leave completion & contextPtr nil for sync. Session reference number
  148. is returned in the sessionRefNum field.
  149. pascal OSStatus OpenSession(struct sockaddr*, const char* endpointString, UAMMessagePtr);
  150. */
  151. /* SendRequest()
  152. Sends a command to the server. If the session is an AFP session, cmdBuffer
  153. MUST contain an AFP command. If you are using AFP the command buffer size is limited
  154. to kMaxAFPCommand (576 bytes). Leave completion & contextPtr nil for sync.
  155. the Session reference number for this connection must be in the sessionRefNum field.
  156. pascal OSStatus SendRequest(UAMMessagePtr);
  157. */
  158. /* CloseSession()
  159. Closes the session denoted by the sessRefNum;
  160. pascal OSStatus CloseSession(short sessRefNum);
  161. */
  162. /* SetMic()
  163. Sets the message integrity code key. If the connection supports using
  164. keyed HMAC-SHA1 for message integrity, the UAM may pass a key down
  165. to the network layer using this call.
  166. pascal OSStatus SetMic(short sizeInBytes, Ptr micValue);
  167. */
  168. /* EventCallback()
  169. Call this fcn with any event that you do not handle in your FilterProc if you
  170. put up a dialog. This passes the event back to the client so that update & idle
  171. events are handled correctly. Returns true if the event was handled.
  172. pascal Boolean EventCallback(EventRecord *theEvent);
  173. */
  174. #if TARGET_CPU_68K
  175. typedef CALLBACK_API( OSStatus , OpenSessionPtr )(struct sockaddr* addr, const char *endpointString, UAMMessagePtr message);
  176. typedef CALLBACK_API( OSStatus , SendRequestPtr )(UAMMessagePtr message);
  177. typedef CALLBACK_API( OSStatus , CloseSessionPtr )(long sessRefNum);
  178. typedef CALLBACK_API( OSStatus , GetClientInfoPtr )(short infoType, ClientInfo **info);
  179. typedef CALLBACK_API( OSStatus , SetMicPtr )(short sizeInBytes, Ptr micValue);
  180. typedef CALLBACK_API( Boolean , EventCallbackPtr )(EventRecord *theEvent);
  181. #else
  182. #ifdef UAM_TARGET_CARBON
  183. typedef CALLBACK_API( OSStatus , OpenSessionPtr )(OTAddress* addr, const char *endpointString, UAMMessagePtr message);
  184. typedef CALLBACK_API( OSStatus , SendRequestPtr )(UAMMessagePtr message);
  185. typedef CALLBACK_API( OSStatus , CloseSessionPtr )(long sessRefNum);
  186. typedef CALLBACK_API( OSStatus , GetClientInfoPtr )(short infoType, ClientInfo **info);
  187. typedef CALLBACK_API( OSStatus , SetMicPtr )(short sizeInBytes, Ptr micValue);
  188. typedef CALLBACK_API( Boolean , EventCallbackPtr )(EventRecord *theEvent);
  189. #else
  190. typedef UniversalProcPtr OpenSessionPtr;
  191. typedef UniversalProcPtr SendRequestPtr;
  192. typedef UniversalProcPtr CloseSessionPtr;
  193. typedef UniversalProcPtr GetClientInfoPtr;
  194. typedef UniversalProcPtr SetMicPtr;
  195. typedef UniversalProcPtr EventCallbackPtr;
  196. #endif
  197. #endif /* TARGET_CPU_68K */
  198. struct ClientUAMCallbackRec {
  199. OpenSessionPtr OpenSessionUPP;
  200. SendRequestPtr SendRequestUPP;
  201. CloseSessionPtr CloseSessionUPP;
  202. GetClientInfoPtr GetClientInfoUPP;
  203. SetMicPtr SetMicUPP;
  204. EventCallbackPtr EventCallbackUPP;
  205. };
  206. typedef struct ClientUAMCallbackRec ClientUAMCallbackRec;
  207. struct VolListElem {
  208. UInt8 volFlags; /* volume flags*/
  209. Str32 volName;
  210. };
  211. typedef struct VolListElem VolListElem;
  212. /* definitions for the volume flags*/
  213. enum {
  214. kMountFlag = 0, /* bit indicating this volume is to be mounted (set by the UAM)*/
  215. kAlreadyMounted = 1, /* bit indicating that the volume is currently mounted*/
  216. kNoRights = 2, /* bit indicating that this user has no permission to use the volume*/
  217. kHasVolPw = 7 /* bit indicating that the volume has a volume password*/
  218. };
  219. struct UAMOpenBlk { /* called for UAMOpen & UAMPrOpen*/
  220. StringPtr objectName; /* <- server or printer name*/
  221. StringPtr zoneName; /* <- zone name or nil if no zone is present*/
  222. struct sockaddr* srvrAddress; /* <- Address of the "server" */
  223. struct AFPSrvrInfo * srvrInfo; /* <- for UAMOpen this is the GetStatus reply, for Printers ???*/
  224. };
  225. typedef struct UAMOpenBlk UAMOpenBlk;
  226. struct UAMPWDlogBlk { /* for the password dialog and prAuthDlog*/
  227. StringPtr userName; /* <-> pointer to a Str64 containing the user name*/
  228. unsigned char * password; /* <- pointer to a Str64 containing the password*/
  229. AFPName* utf8Name; /* <-> pointer to an AFPName to containing the UTF-8 version of the user name */
  230. AFPName* userDomain; /* <-> pointer to an AFPName to containing the UTF-8 version of the directory to look up the user name in */
  231. };
  232. typedef struct UAMPWDlogBlk UAMPWDlogBlk;
  233. struct UAMAuthBlk { /* called for login and prAuthenticate*/
  234. StringPtr userName; /* <- pointer to a Str64 containing the user name*/
  235. unsigned char * password; /* <- pointer to a 64 byte buffer containing the password*/
  236. struct sockaddr* srvrAddress; /* <- Address of the "server" */
  237. AFPName* utf8Name; /* <-> pointer to an AFPName to containing the UTF-8 version of the user name */
  238. AFPName* userDomain; /* <-> pointer to an AFPName to containing the UTF-8 version of the directory to look up the user name in */
  239. };
  240. typedef struct UAMAuthBlk UAMAuthBlk;
  241. struct UAMVSDlogBlk { /* for the volume select dialog*/
  242. short numVolumes; /* <- number of volumes in the volume list*/
  243. VolListElem * volumes; /* <- the volume list*/
  244. };
  245. typedef struct UAMVSDlogBlk UAMVSDlogBlk;
  246. struct UAMChgPassBlk { /* for both the change password dialog and the change password call*/
  247. StringPtr userName; /* <- pointer to a Str64 containing the user name*/
  248. unsigned char * oldPass; /* <- pointer to a 64 byte buffer containing the old password*/
  249. unsigned char * newPass; /* <- pointer to a 64 byte buffer containing the new password*/
  250. };
  251. typedef struct UAMChgPassBlk UAMChgPassBlk;
  252. struct UAMArgs {
  253. short command; /* <- UAM command selector*/
  254. long sessionRefNum; /* <-> session reference number (was short in old header) */
  255. long result; /* -> command result*/
  256. void * uamInfo; /* <- pointer to a block of Auth Data*/
  257. long uamInfoSize; /* <-> size of the Auth Data*/
  258. ClientUAMCallbackRec * callbacks; /* <- Callback record */
  259. union {
  260. UAMChgPassBlk chgPass;
  261. UAMVSDlogBlk vsDlog;
  262. UAMAuthBlk auth;
  263. UAMPWDlogBlk pwDlg;
  264. UAMOpenBlk open;
  265. } Opt;
  266. };
  267. typedef struct UAMArgs UAMArgs;
  268. EXTERN_API( OSStatus )
  269. UAMCall (UAMArgs * theArgs);
  270. #if 0 // should be a conditional compile for non Mac OS X dev.
  271. /* procinfos*/
  272. enum {
  273. kOpenSessionProcInfo = kPascalStackBased
  274. | RESULT_SIZE(SIZE_CODE(sizeof(OSStatus)))
  275. | STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(OTAddress *)))
  276. | STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(const char*)))
  277. | STACK_ROUTINE_PARAMETER(3, SIZE_CODE(sizeof(UAMMessagePtr))),
  278. kSendRequestProcInfo = kPascalStackBased
  279. | RESULT_SIZE(SIZE_CODE(sizeof(OSStatus)))
  280. | STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(UAMMessagePtr))),
  281. kCloseSessionProcInfo = kPascalStackBased
  282. | RESULT_SIZE(SIZE_CODE(sizeof(OSStatus)))
  283. | STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(short))),
  284. kGetClientInfoProcInfo = kPascalStackBased
  285. | RESULT_SIZE(SIZE_CODE(sizeof(OSStatus)))
  286. | STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(short)))
  287. | STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(ClientInfo **))),
  288. kSetMicProcInfo = kPascalStackBased
  289. | RESULT_SIZE(SIZE_CODE(sizeof(OSStatus)))
  290. | STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(short)))
  291. | STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(Ptr))),
  292. kEventCallbackProcInfo = kPascalStackBased
  293. | RESULT_SIZE(SIZE_CODE(sizeof(Boolean)))
  294. | STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(EventRecord *))),
  295. kUAMCallProcInfo = kPascalStackBased
  296. | RESULT_SIZE(SIZE_CODE(sizeof(OSStatus)))
  297. | STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(UAMArgs *)))
  298. };
  299. #endif
  300. #define kUAMBundleType CFSTR("uamx")
  301. /* Resouce definitions
  302. */
  303. enum {
  304. kUAMName = 0, /* user visible name of the UAM*/
  305. kUAMProtoName = 1, /* protocol name of the UAM (sent to the server in the login cmd)*/
  306. kUAMDescription = 2, /* short description of the UAM (displayed in the dialog)*/
  307. kUAMHelpBalloon = 3 /* Str255 for the Balloon Help item*/
  308. };
  309. enum {
  310. kUAMFileType = FOUR_CHAR_CODE('uams') /* Type of the UAM file*/
  311. };
  312. /* resource types*/
  313. enum {
  314. kUAMStr = FOUR_CHAR_CODE('uamn'),
  315. kUAMCode = FOUR_CHAR_CODE('uamc'),
  316. kUAMConfig = FOUR_CHAR_CODE('uamg')
  317. };
  318. /* 'uams' resource IDs */
  319. enum {
  320. kUAMTitle = 0, /* UAM Title string (shown in the UAM list)*/
  321. kUAMProtocol = 1, /* UAM protocol name*/
  322. kUAMPWStr = 2, /* UAM description string (shown in the Password dialog)*/
  323. kUAMBallHelp = 3 /* Balloon Help string for the Password dialog.*/
  324. };
  325. #if PRAGMA_STRUCT_ALIGN
  326. #pragma options align=reset
  327. #elif PRAGMA_STRUCT_PACKPUSH
  328. #pragma pack(pop)
  329. #elif PRAGMA_STRUCT_PACK
  330. #pragma pack()
  331. #endif
  332. #ifdef PRAGMA_IMPORT_OFF
  333. #pragma import off
  334. #elif PRAGMA_IMPORT
  335. #pragma import reset
  336. #endif
  337. #ifdef __cplusplus
  338. }
  339. #endif
  340. #endif /* __CLIENTUAM__ */