BOOL OpenKasLibrary (ULONG *pStatus) { BOOL rc = FALSE; ULONG status = ERROR_DLL_NOT_FOUND; if ((++g_cReqKasLibrary) == 1) { if ( ((g_hiKasLibrary = LoadLibrary (cszLIBRARY_KAS)) == NULL) || ((kas_PrincipalGetBeginP = (kas_PrincipalGetBegin_t)GetProcAddress (g_hiKasLibrary, "kas_PrincipalGetBegin")) == NULL) || ((kas_PrincipalGetNextP = (kas_PrincipalGetNext_t)GetProcAddress (g_hiKasLibrary, "kas_PrincipalGetNext")) == NULL) || ((kas_PrincipalGetDoneP = (kas_PrincipalGetDone_t)GetProcAddress (g_hiKasLibrary, "kas_PrincipalGetDone")) == NULL) || ((kas_PrincipalGetP = (kas_PrincipalGet_t)GetProcAddress (g_hiKasLibrary, "kas_PrincipalGet")) == NULL) ) { status = GetLastError(); CloseKasLibrary(); } } if (g_hiKasLibrary) { rc = TRUE; } if (pStatus) *pStatus = status; return rc; }
DWORD _stdcall DlgProc_Browse_ThreadProc (LPARAM lp) { BROWSEDIALOGPARAMS *pbdp; if ((pbdp = (BROWSEDIALOGPARAMS *)lp) != NULL) { pbdp->fThreadActive = TRUE; PostMessage (pbdp->hDlg, WM_THREADSTART, 0, 0); UINT_PTR idClient; if ((idClient = AfsAppLib_GetAdminServerClientID()) != 0) { EnumeratePrincipalsRemotely (pbdp, idClient); } else { if (OpenClientLibrary()) { if (OpenKasLibrary()) { EnumeratePrincipalsLocally (pbdp); CloseKasLibrary(); } CloseClientLibrary(); } } pbdp->fThreadActive = FALSE; PostMessage (pbdp->hDlg, WM_THREADDONE, 0, 0); } return 0; }
BOOL AfsAppLib_IsUserAdmin (UINT_PTR hCreds, LPTSTR pszUser) { #ifndef USE_KASERVER return TRUE; #else BOOL rc = FALSE; afs_status_t status; UINT_PTR idClient; if ((idClient = AfsAppLib_GetAdminServerClientID()) != 0) { TCHAR szCell[ cchRESOURCE ]; TCHAR szUser[ cchRESOURCE ]; SYSTEMTIME stExpire; if (asc_CredentialsCrack (idClient, hCreds, szCell, szUser, &stExpire, (ULONG*)&status)) { ASID idCell; if (asc_CellOpen (idClient, hCreds, szCell, AFSADMSVR_SCOPE_USERS, &idCell, (ULONG*)&status)) { ASID idUser; if (asc_ObjectFind (idClient, idCell, TYPE_USER, pszUser, &idUser, (ULONG*)&status)) { ASOBJPROP Info; if (asc_ObjectPropertiesGet (idClient, GET_ALL_DATA, idCell, idUser, &Info, (ULONG*)&status)) { if (Info.u.UserProperties.fHaveKasInfo) { rc = Info.u.UserProperties.KASINFO.fIsAdmin; } } } asc_CellClose (idClient, idCell, (ULONG*)&status); } } } else if (OpenClientLibrary()) { if (OpenKasLibrary()) { char szUserA[ cchRESOURCE ], szUser2A[ cchRESOURCE ]; char szCellA[ cchRESOURCE ]; unsigned long dateExpire; int fHasKasToken; if (afsclient_TokenQuery (hCreds, &dateExpire, szUserA, szUser2A, szCellA, &fHasKasToken, (afs_status_p)&status)) { PVOID hCell; if (afsclient_CellOpen (szCellA, hCreds, &hCell, &status)) { kas_identity_t Identity; memset (&Identity, 0x00, sizeof(Identity)); CopyStringToAnsi (Identity.principal, pszUser); kas_principalEntry_t Entry; if (kas_PrincipalGet (hCell, NULL, &Identity, &Entry, &status)) { if (Entry.adminSetting == KAS_ADMIN) rc = TRUE; } afsclient_CellClose (hCell, (afs_status_p)&status); } } CloseKasLibrary(); } CloseClientLibrary(); } return rc; #endif /* USE_KASERVER */ }