2 * Copyright 2000, International Business Machines Corporation and others.
5 * This software has been released under the terms of the IBM Public
6 * License. For details, see the LICENSE file in the top-level source
7 * directory or online at http://www.openafs.org/dl/license10.html
11 #include <afs/param.h>
13 #include <afs/afskfw.h>
14 #include "ipaddrchg.h"
20 * DEFINITIONS ________________________________________________________________
24 #define ID_REMIND_TIMER 1000
25 #define ID_SERVICE_TIMER 1001
27 #define cREALLOC_TABS 4
29 #define dwTABPARAM_MOUNT (LPTSTR)0
30 #define dwTABPARAM_ADVANCED (LPTSTR)1
31 #define ISCELLTAB(_psz) ((HIWORD((LONG)(_psz))) != 0)
35 * PROTOTYPES _________________________________________________________________
39 void Main_OnInitDialog (HWND hDlg);
40 void Main_OnCheckMenuRemind (void);
41 void Main_OnRemindTimer (void);
42 void Main_OnMouseOver (void);
43 void Main_OnSelectTab (void);
44 void Main_OnCheckTerminate (void);
45 HWND Main_CreateTabDialog (HWND hTab, size_t iTab);
47 BOOL CALLBACK Terminate_DlgProc (HWND hDlg, UINT msg, WPARAM wp, LPARAM lp);
48 void Terminate_OnInitDialog (HWND hDlg);
49 void Terminate_OnOK (HWND hDlg);
53 * ROUTINES ___________________________________________________________________
57 BOOL CALLBACK Main_DlgProc (HWND hDlg, UINT msg, WPARAM wp, LPARAM lp)
59 static UINT msgCheckTerminate = 0;
60 if (msgCheckTerminate == 0)
61 msgCheckTerminate = RegisterWindowMessage (TEXT("AfsCredsCheckTerminate"));
63 if (msg == msgCheckTerminate)
65 Main_OnCheckTerminate();
71 Main_OnInitDialog (hDlg);
75 Creds_CloseLibraries();
76 ChangeTrayIcon (NIM_DELETE);
82 Main_RepopulateTabs (FALSE);
95 if (g.fIsWinNT || IsServiceRunning())
97 if (!lp) // Got here from "/show" parameter? switch tabs.
99 HWND hTab = GetDlgItem (g.hMain, IDC_TABS);
100 TabCtrl_SetCurSel (hTab, 0);
107 Message (MB_ICONHAND, IDS_UNCONFIG_TITLE_95, IDS_UNCONFIG_DESC_95);
112 if (g.fIsWinNT && IsServiceRunning())
113 ModalDialog (IDD_TERMINATE, NULL, (DLGPROC)Terminate_DlgProc);
115 ModalDialog (IDD_TERMINATE_SMALL, NULL, (DLGPROC)Terminate_DlgProc);
116 else // (!g.fIsWinNT)
117 ModalDialog (IDD_TERMINATE_SMALL_95, NULL, (DLGPROC)Terminate_DlgProc);
120 case M_TERMINATE_NOW:
125 Main_OnCheckMenuRemind();
131 Main_OnRemindTimer();
135 switch (((NMHDR*)lp)->code)
147 if (IsServiceRunning() || !IsServiceConfigured())
149 else if (!g.fIsWinNT)
150 Message (MB_ICONHAND, IDS_UNCONFIG_TITLE_95, IDS_UNCONFIG_DESC_95);
157 if ((hm = TaLocale_LoadMenu (MENU_TRAYICON)) != 0)
162 HMENU hmDummy = CreateMenu();
163 InsertMenu (hmDummy, 0, MF_POPUP, (UINT)hm, NULL);
165 BOOL fRemind = FALSE;
166 lock_ObtainMutex(&g.credsLock);
167 for (size_t iCreds = 0; iCreds < g.cCreds; ++iCreds)
169 if (g.aCreds[ iCreds ].fRemind)
172 lock_ReleaseMutex(&g.credsLock);
173 CheckMenuItem (hm, M_REMIND, MF_BYCOMMAND | ((fRemind) ? MF_CHECKED : MF_UNCHECKED));
175 TrackPopupMenu (GetSubMenu (hmDummy, 0),
176 TPM_RIGHTALIGN | TPM_RIGHTBUTTON,
177 pt.x, pt.y, NULL, hDlg, NULL);
179 DestroyMenu (hmDummy);
188 case WM_OBTAIN_TOKENS:
189 if ( InterlockedIncrement (&g.fShowingMessage) != 1 )
190 InterlockedDecrement (&g.fShowingMessage);
192 ShowObtainCreds (wp, (char *)lp);
193 GlobalFree((void *)lp);
196 case WM_START_SERVICE:
199 if ((hManager = OpenSCManager ( NULL, NULL,
201 SC_MANAGER_ENUMERATE_SERVICE |
202 SC_MANAGER_QUERY_LOCK_STATUS)) != NULL)
205 if ((hService = OpenService ( hManager, TEXT("TransarcAFSDaemon"),
206 SERVICE_QUERY_STATUS | SERVICE_START)) != NULL)
208 if (StartService (hService, 0, 0))
209 TestAndDoMapShare(SERVICE_START_PENDING);
210 if ( KFW_is_available() && KFW_AFS_wait_for_service_start() ) {
212 KFW_import_windows_lsa();
213 #endif /* USE_MS2MIT */
214 KFW_AFS_renew_tokens_for_all_cells();
217 CloseServiceHandle (hService);
220 CloseServiceHandle (hManager);
222 KFW_AFS_wait_for_service_start();
223 ObtainTokensFromUserIfNeeded(g.hMain);
232 void Main_Show (BOOL fShow)
236 ShowWindow (g.hMain, SW_SHOW);
237 SetWindowPos (g.hMain, HWND_TOP, 0, 0, 0, 0, SWP_NOMOVE | SWP_NOSIZE);
238 SetForegroundWindow (g.hMain);
242 SetWindowPos (g.hMain, HWND_BOTTOM, 0, 0, 0, 0, SWP_NOMOVE | SWP_NOSIZE | SWP_HIDEWINDOW);
247 void Main_OnInitDialog (HWND hDlg)
252 GetString (szTitle, IDS_TITLE_95);
253 SetWindowText (hDlg, szTitle);
256 TCHAR szVersion[256];
259 GetString (szVersion, IDS_UNKNOWN);
260 GetString (szUser, IDS_UNKNOWN);
263 if (RegOpenKey (HKEY_LOCAL_MACHINE, REGSTR_PATH_AFS, &hk) == 0)
265 DWORD dwSize = sizeof(szVersion);
266 DWORD dwType = REG_SZ;
267 RegQueryValueEx (hk, REGVAL_AFS_VERSION, NULL, &dwType, (PBYTE)szVersion, &dwSize);
269 dwSize = sizeof(dwPatch);
271 RegQueryValueEx (hk, REGVAL_AFS_PATCH, NULL, &dwType, (PBYTE)&dwPatch, &dwSize);
275 BOOL fFoundUserName = FALSE;
276 if (RegOpenKey (HKEY_LOCAL_MACHINE, TEXT("Software\\Microsoft\\Windows NT\\CurrentVersion\\Explorer"), &hk) == 0)
278 DWORD dwSize = sizeof(szUser);
279 DWORD dwType = REG_SZ;
280 if (RegQueryValueEx (hk, TEXT("Logon User Name"), NULL, &dwType, (PBYTE)szUser, &dwSize) == 0)
281 fFoundUserName = TRUE;
284 if (!fFoundUserName )
286 if (RegOpenKey (HKEY_LOCAL_MACHINE, TEXT("Software\\Microsoft\\Windows NT\\CurrentVersion\\Winlogon"), &hk) == 0)
288 DWORD dwSize = sizeof(szUser);
289 DWORD dwType = REG_SZ;
290 if (RegQueryValueEx (hk, TEXT("DefaultUserName"), NULL, &dwType, (PBYTE)szUser, &dwSize) == 0)
291 fFoundUserName = TRUE;
297 if (RegOpenKey (HKEY_LOCAL_MACHINE, TEXT("Network\\Logon"), &hk) == 0)
299 DWORD dwSize = sizeof(szUser);
300 DWORD dwType = REG_SZ;
301 if (RegQueryValueEx (hk, TEXT("UserName"), NULL, &dwType, (PBYTE)szUser, &dwSize) == 0)
302 fFoundUserName = TRUE;
307 TCHAR szSource[ cchRESOURCE ];
308 TCHAR szTarget[ cchRESOURCE ];
310 GetString (szSource, (dwPatch) ? IDS_TITLE_VERSION : IDS_TITLE_VERSION_NOPATCH);
311 wsprintf (szTarget, szSource, szVersion, dwPatch);
312 SetDlgItemText (hDlg, IDC_TITLE_VERSION, szTarget);
314 GetDlgItemText (hDlg, IDC_TITLE_NT, szSource, cchRESOURCE);
315 wsprintf (szTarget, szSource, szUser);
316 SetDlgItemText (hDlg, IDC_TITLE_NT, szTarget);
320 void Main_OnCheckMenuRemind (void)
322 BOOL fRemind = FALSE;
323 lock_ObtainMutex(&g.credsLock);
324 for (size_t iCreds = 0; iCreds < g.cCreds; ++iCreds)
326 if (g.aCreds[ iCreds ].fRemind)
331 for (iCreds = 0; iCreds < g.cCreds; ++iCreds)
333 if (g.aCreds[ iCreds ].fRemind != fRemind)
335 g.aCreds[ iCreds ].fRemind = fRemind;
339 lock_ReleaseMutex(&g.credsLock);
341 // Check the active tab, and fix its checkbox if necessary
343 HWND hTab = GetDlgItem (g.hMain, IDC_TABS);
344 LPTSTR pszTab = (LPTSTR)GetTabParam (hTab, TabCtrl_GetCurSel(hTab));
345 if (ISCELLTAB(pszTab) && (*pszTab))
347 HWND hDlg = GetTabChild (hTab);
349 CheckDlgButton (hDlg, IDC_CREDS_REMIND, fRemind);
352 // Make sure the reminder timer is going
354 Main_EnableRemindTimer (fRemind);
358 void Main_OnRemindTimer (void)
360 Main_RepopulateTabs (TRUE);
362 // See if anything is close to expiring; if so, display a warning
363 // dialog. Make sure we never display a warning more than once.
366 if ((iExpired = Main_FindExpiredCreds()) != -1)
368 if (InterlockedIncrement (&g.fShowingMessage) != 1)
369 InterlockedDecrement (&g.fShowingMessage);
371 ShowObtainCreds (TRUE, g.aCreds[ iExpired ].szCell);
376 void Main_OnMouseOver (void)
378 if ((GetTickCount() - g.tickLastRetest) > cmsecMOUSEOVER)
380 Main_RepopulateTabs (TRUE);
385 void Main_OnSelectTab (void)
387 HWND hTab = GetDlgItem (g.hMain, IDC_TABS);
388 size_t iTab = TabCtrl_GetCurSel (hTab);
390 HWND hDlgOld = GetTabChild (hTab);
393 if ((hDlgNew = Main_CreateTabDialog (hTab, iTab)) != NULL)
394 ShowWindow (hDlgNew, SW_SHOW);
397 DestroyWindow (hDlgOld);
401 void Main_OnCheckTerminate (void)
405 if (RegOpenKey (HKEY_CURRENT_USER, REGSTR_PATH_OPENAFS_CLIENT, &hk) == 0)
407 DWORD dwSize = sizeof(g.fStartup);
408 DWORD dwType = REG_DWORD;
409 RegQueryValueEx (hk, TEXT("ShowTrayIcon"), NULL, &dwType, (PBYTE)&g.fStartup, &dwSize);
412 else if (RegOpenKey (HKEY_LOCAL_MACHINE, REGSTR_PATH_OPENAFS_CLIENT, &hk) == 0)
414 DWORD dwSize = sizeof(g.fStartup);
415 DWORD dwType = REG_DWORD;
416 RegQueryValueEx (hk, TEXT("ShowTrayIcon"), NULL, &dwType, (PBYTE)&g.fStartup, &dwSize);
420 Shortcut_FixStartup (cszSHORTCUT_NAME, g.fStartup);
427 HWND Main_CreateTabDialog (HWND hTab, size_t iTab)
433 memset (&Item, 0x00, sizeof(Item));
434 Item.mask = TCIF_PARAM;
435 if (TabCtrl_GetItem (hTab, iTab, &Item))
437 psz = (LPTSTR)(Item.lParam);
440 if (psz == dwTABPARAM_ADVANCED) // Advanced tab
442 hDlg = ModelessDialog (IDD_TAB_ADVANCED, hTab, (DLGPROC)Advanced_DlgProc);
444 else if (psz == dwTABPARAM_MOUNT) // Mount Points tab
446 hDlg = ModelessDialog (IDD_TAB_MOUNT, hTab, (DLGPROC)Mount_DlgProc);
448 else if (ISCELLTAB(psz) && !*psz) // No Creds tab
450 hDlg = ModelessDialogParam (IDD_TAB_NOCREDS, hTab, (DLGPROC)Creds_DlgProc, (LPARAM)psz);
452 else if (ISCELLTAB(psz) && *psz) // Creds tab for a particular cell
454 hDlg = ModelessDialogParam (IDD_TAB_CREDS, hTab, (DLGPROC)Creds_DlgProc, (LPARAM)psz);
461 void Main_RepopulateTabs (BOOL fDestroyInvalid)
463 static BOOL fInHere = FALSE;
468 if (IsWindowVisible (g.hMain))
469 fDestroyInvalid = FALSE;
471 // First we'll have to look around and see what credentials we currently
472 // have. This call just updates g.aCreds[]; it doesn't do anything else.
474 (void)GetCurrentCredentials();
476 // We want one tab on the main dialog for each g.aCredentials entry,
477 // and one tab for Advanced.
479 HWND hTab = GetDlgItem (g.hMain, IDC_TABS);
481 // Generate a list of the lParams we'll be giving tabs...
483 LPTSTR *aTabs = NULL;
488 lock_ObtainMutex(&g.credsLock);
489 for (size_t iCreds = 0; iCreds < g.cCreds; ++iCreds)
491 if (g.aCreds[ iCreds ].szCell[0])
496 fDestroyInvalid = TRUE;
499 if (!fDestroyInvalid)
501 int nTabs = TabCtrl_GetItemCount(hTab);
502 for (int iTab = 0; iTab < nTabs; ++iTab)
504 LPTSTR pszTab = (LPTSTR)GetTabParam (hTab, iTab);
505 if (ISCELLTAB(pszTab) && (*pszTab))
507 if (REALLOC (aTabs, cTabs, 1+iTabOut, cREALLOC_TABS))
508 aTabs[ iTabOut++ ] = CloneString(pszTab);
515 if (REALLOC (aTabs, cTabs, 1+iTabOut, cREALLOC_TABS))
516 aTabs[ iTabOut++ ] = CloneString (TEXT(""));
518 else for (iCreds = 0; iCreds < g.cCreds; ++iCreds)
520 if (g.aCreds[ iCreds ].szCell[0])
522 for (size_t ii = 0; ii < iTabOut; ++ii)
524 if (!ISCELLTAB (aTabs[ii]))
526 if (!lstrcmpi (g.aCreds[ iCreds ].szCell, aTabs[ ii ]))
531 if (REALLOC (aTabs, cTabs, 1+iTabOut, cREALLOC_TABS))
532 aTabs[ iTabOut++ ] = CloneString (g.aCreds[ iCreds ].szCell);
536 lock_ReleaseMutex(&g.credsLock);
538 if (REALLOC (aTabs, cTabs, 1+iTabOut, cREALLOC_TABS))
539 aTabs[ iTabOut++ ] = dwTABPARAM_MOUNT;
543 if (REALLOC (aTabs, cTabs, 1+iTabOut, cREALLOC_TABS))
544 aTabs[ iTabOut++ ] = dwTABPARAM_ADVANCED;
547 // Now erase the current tabs, and re-add new ones. Remember which tab is
548 // currently selected, so we can try to go back to it later.
551 if (TabCtrl_GetItemCount(hTab))
553 LPTSTR pszTabSel = (LPTSTR)GetTabParam (hTab, TabCtrl_GetCurSel(hTab));
554 for (size_t iSel = 0; iSel < iTabOut; ++iSel)
556 if ((!ISCELLTAB(pszTabSel)) && (!ISCELLTAB(aTabs[iSel])) && (pszTabSel == aTabs[iSel]))
558 else if (ISCELLTAB(pszTabSel) && ISCELLTAB(aTabs[iSel]) && !lstrcmpi (pszTabSel, aTabs[iSel]))
563 int nTabs = TabCtrl_GetItemCount(hTab);
564 for (int iTab = 0; iTab < nTabs; ++iTab)
566 LPTSTR pszTab = (LPTSTR)GetTabParam (hTab, iTab);
567 if (ISCELLTAB(pszTab))
570 TabCtrl_DeleteAllItems (hTab);
572 for (size_t ii = 0; ii < iTabOut; ++ii)
574 TCHAR szTitle[cchRESOURCE];
575 if (aTabs[ii] == dwTABPARAM_ADVANCED)
576 GetString (szTitle, IDS_ADVANCED);
577 else if (aTabs[ii] == dwTABPARAM_MOUNT)
578 GetString (szTitle, IDS_MOUNT);
579 else if ((nCreds <= 1) || (aTabs[ii][0] == TEXT('\0')))
580 GetString (szTitle, IDS_CREDENTIALS);
582 lstrcpy (szTitle, aTabs[ii]);
585 memset (&Item, 0x00, sizeof(Item));
586 Item.mask = TCIF_PARAM | TCIF_TEXT;
587 Item.pszText = szTitle;
588 Item.cchTextMax = cchRESOURCE;
589 Item.lParam = (LPARAM)(aTabs[ii]);
591 TabCtrl_InsertItem (hTab, ii, &Item);
597 TabCtrl_SetCurSel (hTab, iTabSel);
605 void Main_EnableRemindTimer (BOOL fEnable)
607 static BOOL bEnabled = FALSE;
609 if ( fEnable == FALSE && bEnabled == TRUE ) {
610 KillTimer (g.hMain, ID_REMIND_TIMER);
612 } else if ( fEnable == TRUE && bEnabled == FALSE ) {
613 SetTimer (g.hMain, ID_REMIND_TIMER, (ULONG)cmsec1MINUTE * cminREMIND_TEST, NULL);
619 size_t Main_FindExpiredCreds (void)
621 size_t retval = (size_t) -1;
622 lock_ObtainMutex(&g.expirationCheckLock);
623 if ( KFW_is_available() )
624 KFW_AFS_renew_expiring_tokens();
625 lock_ObtainMutex(&g.credsLock);
626 for (size_t iCreds = 0; iCreds < g.cCreds; ++iCreds)
628 if (!g.aCreds[ iCreds ].szCell[0])
630 if (!g.aCreds[ iCreds ].fRemind)
634 GetLocalTime (&stNow);
637 SystemTimeToFileTime (&stNow, &ftNow);
640 SystemTimeToFileTime (&g.aCreds[ iCreds ].stExpires, &ftExpires);
642 LONGLONG llNow = (((LONGLONG)ftNow.dwHighDateTime) << 32) + (LONGLONG)(ftNow.dwLowDateTime);
643 LONGLONG llExpires = (((LONGLONG)ftExpires.dwHighDateTime) << 32) + (LONGLONG)(ftExpires.dwLowDateTime);
645 llNow /= c100ns1SECOND;
646 llExpires /= c100ns1SECOND;
648 if (llExpires <= (llNow + (LONGLONG)cminREMIND_WARN * csec1MINUTE))
650 if ( KFW_is_available() &&
651 KFW_AFS_renew_token_for_cell(g.aCreds[ iCreds ].szCell) )
653 retval = (size_t) iCreds;
658 lock_ReleaseMutex(&g.credsLock);
659 lock_ReleaseMutex(&g.expirationCheckLock);
665 BOOL CALLBACK Terminate_DlgProc (HWND hDlg, UINT msg, WPARAM wp, LPARAM lp)
670 Terminate_OnInitDialog (hDlg);
677 Terminate_OnOK (hDlg);
681 EndDialog (hDlg, IDCANCEL);
691 void Terminate_OnInitDialog (HWND hDlg)
693 BOOL fPersistent = IsServicePersistent();
695 CheckDlgButton (hDlg, IDC_STARTUP, g.fStartup);
696 CheckDlgButton (hDlg, IDC_LEAVE, fPersistent);
697 CheckDlgButton (hDlg, IDC_STOP, !fPersistent);
701 void Terminate_OnOK (HWND hDlg)
703 if (IsServiceRunning())
705 if (IsDlgButtonChecked (hDlg, IDC_STOP))
708 if ((hManager = OpenSCManager (NULL, NULL,
710 SC_MANAGER_ENUMERATE_SERVICE |
711 SC_MANAGER_QUERY_LOCK_STATUS)) != NULL)
714 if ((hService = OpenService (hManager, TEXT("TransarcAFSDaemon"),
715 SERVICE_QUERY_STATUS | SERVICE_START)) != NULL)
717 SERVICE_STATUS Status;
718 ControlService (hService, SERVICE_CONTROL_STOP, &Status);
720 CloseServiceHandle (hService);
723 CloseServiceHandle (hManager);
728 g.fStartup = IsDlgButtonChecked (hDlg, IDC_STARTUP);
731 if (RegCreateKey (HKEY_CURRENT_USER, REGSTR_PATH_OPENAFS_CLIENT, &hk) == 0)
733 DWORD dwSize = sizeof(g.fStartup);
734 DWORD dwType = REG_DWORD;
735 RegSetValueEx (hk, TEXT("ShowTrayIcon"), NULL, dwType, (PBYTE)&g.fStartup, dwSize);
739 Shortcut_FixStartup (cszSHORTCUT_NAME, g.fStartup);
742 EndDialog (hDlg, IDOK);