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/fs_utils.h>
16 #include "afs_config.h"
17 #include <WINNT\afsreg.h>
19 #include <lanahelper.h>
22 * DEFINITIONS ________________________________________________________________
25 static DRIVEMAPLIST GlobalDrives;
26 static TCHAR szHostName[128];
28 // DefineDosDrive actions
29 enum DDDACTION { DDD_ADD, DDD_REMOVE };
31 #define DRIVE_LETTER_INDEX 2
35 * PROTOTYPES _________________________________________________________________
38 void AutoMap_OnInitDialog (HWND hDlg);
39 void AutoMap_OnAdd (HWND hDlg);
40 void AutoMap_OnSelect (HWND hDlg);
41 void AutoMap_OnEdit (HWND hDlg);
42 void AutoMap_OnRemove (HWND hDlg);
44 void ShowDriveList(HWND hDlg, DRIVEMAPLIST& drives);
45 void AddToDriveList(DRIVEMAPLIST& DriveMapList, DRIVEMAP& DriveMap);
46 void RemoveFromDriveList(DRIVEMAPLIST& DriveMapList, DRIVEMAP& DriveMap);
47 DRIVEMAP *GetSelectedDrive(HWND hDlg, HLISTITEM *pItem = 0);
48 BOOL DefineDosDrive(DRIVEMAP *pDrive, DDDACTION dddAction = DDD_ADD);
50 BOOL CALLBACK AutoMapEdit_DlgProc (HWND hDlg, UINT msg, WPARAM wp, LPARAM lp);
51 void AutoMapEdit_OnInitDialog (HWND hDlg);
52 void AutoMapEdit_OnOK (HWND hDlg);
53 void AutoMapEdit_Enable (HWND hDlg);
57 * ROUTINES ___________________________________________________________________
61 BOOL CALLBACK AutoMap_DlgProc (HWND hDlg, UINT msg, WPARAM wp, LPARAM lp)
66 AutoMap_OnInitDialog (hDlg);
69 case WM_CTLCOLORSTATIC:
70 if ((HWND)lp == GetDlgItem (hDlg, IDC_CHUNK_SIZE))
72 if (IsWindowEnabled ((HWND)lp))
74 static HBRUSH hbrStatic = CreateSolidBrush (GetSysColor (COLOR_WINDOW));
75 SetTextColor ((HDC)wp, GetSysColor (COLOR_WINDOWTEXT));
76 SetBkColor ((HDC)wp, GetSysColor (COLOR_WINDOW));
77 return (BOOL)hbrStatic;
86 AutoMap_DlgProc (hDlg, WM_HELP, 0, 0);
90 EndDialog(hDlg, IDOK);
94 EndDialog(hDlg, IDCANCEL);
102 AutoMap_OnEdit(hDlg);
106 AutoMap_OnRemove(hDlg);
112 switch (((LPNMHDR)lp)->code)
115 AutoMap_OnSelect (hDlg);
119 if (IsWindowEnabled (GetDlgItem (hDlg, IDC_EDIT)))
120 AutoMap_OnEdit (hDlg);
126 WinHelp (hDlg, g.szHelpFile, HELP_CONTEXT, IDH_AFSCONFIG_ADVANCED_AUTOMAP);
134 void AddToDriveList(DRIVEMAPLIST& DriveMapList, DRIVEMAP& DriveMap)
136 int nCurDrive = DriveMap.chDrive - TEXT('A');
138 memcpy(&DriveMapList.aDriveMap[nCurDrive], &DriveMap, sizeof(DRIVEMAP));
142 void RemoveFromDriveList(DRIVEMAPLIST& DriveMapList, DRIVEMAP& DriveMap)
144 int nCurDrive = DriveMap.chDrive - TEXT('A');
146 memset(&DriveMapList.aDriveMap[nCurDrive], 0, sizeof(DRIVEMAP));
150 void AutoMap_OnInitDialog (HWND hDlg)
152 // Prepare the columns
153 HWND hList = GetDlgItem (hDlg, IDC_GLOBAL_DRIVE_LIST);
155 FASTLISTCOLUMN Column;
156 Column.dwFlags = FLCF_JUSTIFY_LEFT;
158 GetString (Column.szText, IDS_DRIVE);
159 FastList_SetColumn (hList, 0, &Column);
161 Column.dwFlags = FLCF_JUSTIFY_LEFT;
162 Column.cxWidth = 266;
163 GetString (Column.szText, IDS_SUBCOL_PATH);
164 FastList_SetColumn (hList, 1, &Column);
166 gethostname(szHostName, sizeof(szHostName));
168 Config_GetGlobalDriveList(&GlobalDrives);
170 ShowDriveList(hDlg, GlobalDrives);
174 void ShowDriveList(HWND hDlg, DRIVEMAPLIST& drives)
176 // Prepare the columns
177 HWND hList = GetDlgItem (hDlg, IDC_GLOBAL_DRIVE_LIST);
179 // Fill in the list of drives
180 FastList_Begin (hList);
182 FastList_RemoveAll(hList);
184 for (size_t ii = 0; ii < 26; ++ii) {
185 if (!GlobalDrives.aDriveMap[ ii ].chDrive)
188 HWND hList = GetDlgItem (hDlg, IDC_GLOBAL_DRIVE_LIST);
191 memset (&ai, 0x00, sizeof(FASTLISTADDITEM));
192 ai.iFirstImage = IMAGE_NOIMAGE;
193 ai.iSecondImage = IMAGE_NOIMAGE;
194 // There must be DRIVE_LETTER_INDEX number of spaces before the ? character
195 ai.pszText = _tcsdup(TEXT(" ?:"));
196 ai.pszText[DRIVE_LETTER_INDEX] = GlobalDrives.aDriveMap[ ii ].chDrive;
199 HLISTITEM hItem = FastList_AddItem (hList, &ai);
201 TCHAR szAfsPath[ MAX_PATH ];
202 AdjustAfsPath (szAfsPath, GlobalDrives.aDriveMap[ ii ].szMapping, TRUE, FALSE);
204 FastList_SetItemText (hList, hItem, 1, szAfsPath);
207 FastList_End (hList);
211 BOOL UpdateRegistry(DRIVEMAP *pDrive, BOOL bRemove)
213 TCHAR szKeyName[128];
214 TCHAR szValueName[128];
222 _stprintf(szKeyName, TEXT("%s\\GlobalAutoMapper"), TEXT(AFSREG_CLT_SVC_PARAM_SUBKEY));
224 if (RegCreateKeyEx(HKEY_LOCAL_MACHINE, szKeyName, 0, NULL, REG_OPTION_NON_VOLATILE, KEY_SET_VALUE, NULL, &hKey, &dwDispo) != ERROR_SUCCESS)
227 _stprintf(szValueName, TEXT("%c:"), pDrive->chDrive);
230 result = RegDeleteValue(hKey, szValueName);
232 result = RegSetValueEx(hKey, szValueName, 0, REG_SZ, (BYTE *)pDrive->szSubmount, lstrlen(pDrive->szSubmount) + 1);
236 return (result == ERROR_SUCCESS);
240 BOOL DefineDosDrive(DRIVEMAP *pDrive, DDDACTION dddAction)
242 // TCHAR szAfsPath[MAX_PATH];
243 // TCHAR szDrive[3] = TEXT("?:");
244 BOOL fResult = FALSE;
249 if (dddAction == DDD_REMOVE) {
250 if (!(fResult=(DisMountDOSDrive(pDrive->chDrive)==NO_ERROR)))
251 Message (MB_OK | MB_ICONHAND, IDS_ERROR_UNMAP, IDS_ERROR_UNMAP_DESC, TEXT("%08lX"), GetLastError());
252 } else if (dddAction == DDD_ADD) {
253 if (!(fResult=(MountDOSDrive(pDrive->chDrive, pDrive->szSubmount,FALSE)==NO_ERROR)))
254 Message (MB_OK | MB_ICONHAND, IDS_ERROR_MAP, IDS_ERROR_MAP_DESC, TEXT("%08lX"), GetLastError());
257 Replace this code with Drive mapping routine that doesn't require different formats for each OS
258 szDrive[0] = pDrive->chDrive;
259 _stprintf(szAfsPath, TEXT("\\Device\\LanmanRedirector\\%s\\%s-AFS\\%s"), szDrive, szHostName, pDrive->szSubmount);
261 if (dddAction == DDD_REMOVE) {
262 fResult = DefineDosDevice(DDD_RAW_TARGET_PATH | DDD_REMOVE_DEFINITION | DDD_EXACT_MATCH_ON_REMOVE, szDrive, szAfsPath);
264 Message (MB_OK | MB_ICONHAND, IDS_ERROR_UNMAP, IDS_ERROR_UNMAP_DESC, TEXT("%08lX"), GetLastError());
265 } else if (dddAction == DDD_ADD) {
266 fResult = DefineDosDevice(DDD_RAW_TARGET_PATH, szDrive, szAfsPath);
268 Message (MB_OK | MB_ICONHAND, IDS_ERROR_MAP, IDS_ERROR_MAP_DESC, TEXT("%08lX"), GetLastError());
273 UpdateRegistry(pDrive, dddAction == DDD_REMOVE);
279 void AutoMap_OnAdd(HWND hDlg)
282 memset(&DriveMap, 0, sizeof(DRIVEMAP));
284 if (ModalDialogParam (IDD_GLOBAL_DRIVES_ADDEDIT, hDlg, (DLGPROC)AutoMapEdit_DlgProc, (LPARAM)&DriveMap) != IDOK)
287 if (DriveMap.chDrive) {
288 if (DefineDosDrive(&DriveMap)) {
289 AddToDriveList(GlobalDrives, DriveMap);
290 ShowDriveList(hDlg, GlobalDrives);
294 AutoMap_OnSelect(hDlg);
298 void AutoMap_OnSelect (HWND hDlg)
300 HWND hList = GetDlgItem (hDlg, IDC_GLOBAL_DRIVE_LIST);
302 BOOL bEnable = FastList_FindFirstSelected (hList) != NULL;
304 EnableWindow (GetDlgItem (hDlg, IDC_REMOVE), bEnable);
305 EnableWindow (GetDlgItem (hDlg, IDC_CHANGE), bEnable);
309 DRIVEMAP *GetSelectedDrive(HWND hDlg, HLISTITEM *pItem)
311 static DRIVEMAP DriveMap;
314 HWND hList = GetDlgItem (hDlg, IDC_GLOBAL_DRIVE_LIST);
319 if ((*pItem = FastList_FindFirstSelected (hList)) == NULL)
322 LPCTSTR pszDrive = FastList_GetItemText (hList, *pItem, 0);
323 int nCurDrive = pszDrive[DRIVE_LETTER_INDEX] - TEXT('A');
325 memcpy(&DriveMap, &GlobalDrives.aDriveMap[nCurDrive], sizeof(DRIVEMAP));
331 void AutoMap_OnEdit (HWND hDlg)
333 DRIVEMAP *pOldDrive = GetSelectedDrive(hDlg);
338 memcpy(&NewDrive, pOldDrive, sizeof(DRIVEMAP));
340 if (ModalDialogParam (IDD_GLOBAL_DRIVES_ADDEDIT, hDlg, (DLGPROC)AutoMapEdit_DlgProc, (LPARAM)&NewDrive) != IDOK)
343 if (DefineDosDrive(pOldDrive, DDD_REMOVE)) {
344 RemoveFromDriveList(GlobalDrives, *pOldDrive);
346 if (DefineDosDrive(&NewDrive))
347 AddToDriveList(GlobalDrives, NewDrive);
349 ShowDriveList(hDlg, GlobalDrives);
352 AutoMap_OnSelect(hDlg);
356 void AutoMap_OnRemove (HWND hDlg)
360 HWND hList = GetDlgItem (hDlg, IDC_GLOBAL_DRIVE_LIST);
362 DRIVEMAP *pDrive = GetSelectedDrive(hDlg, &hItem);
366 if (DefineDosDrive(pDrive, DDD_REMOVE)) {
367 RemoveFromDriveList(GlobalDrives, *pDrive);
368 FastList_RemoveItem (hList, hItem);
371 AutoMap_OnSelect(hDlg);
375 BOOL CALLBACK AutoMapEdit_DlgProc (HWND hDlg, UINT msg, WPARAM wp, LPARAM lp)
380 SetWindowLongPtr (hDlg, DWLP_USER, lp);
381 AutoMapEdit_OnInitDialog (hDlg);
388 AutoMapEdit_OnOK (hDlg);
392 EndDialog (hDlg, IDCANCEL);
396 AutoMapEdit_Enable (hDlg);
400 AutoMapEdit_DlgProc (hDlg, WM_HELP, 0, 0);
406 WinHelp (hDlg, g.szHelpFile, HELP_CONTEXT, IDH_AFSCONFIG_ADVANCED_AUTOMAP_ADDEDIT);
413 void AutoMapEdit_OnInitDialog (HWND hDlg)
415 PDRIVEMAP pMap = (PDRIVEMAP)GetWindowLongPtr (hDlg, DWLP_USER);
417 DWORD dwDrives = GetLogicalDrives() | 0x07; // Always pretend A,B,C: are used
419 // Fill in the combo box
422 if (pMap->chDrive != 0)
423 dwDrives &= ~( 1 << (pMap->chDrive - chDRIVE_A) );
426 HWND hCombo = GetDlgItem (hDlg, IDC_DRIVE);
427 SendMessage (hCombo, WM_SETREDRAW, FALSE, 0);
429 for (int ii = 0; ii < 26; ++ii)
431 if (!(dwDrives & (1<<ii)))
433 TCHAR szText[ cchRESOURCE ];
434 GetString (szText, IDS_MAP_LETTER);
437 if ((pch = (LPTSTR)lstrchr (szText, TEXT('*'))) != NULL)
438 *pch = TEXT('A') + ii;
440 int iItem = SendMessage (hCombo, CB_ADDSTRING, 0, (LPARAM)szText);
441 SendMessage (hCombo, CB_SETITEMDATA, iItem, ii);
442 if (pMap->chDrive && (ii == pMap->chDrive - chDRIVE_A))
444 else if ((!pMap->chDrive) && (iItemSel == -1))
449 SendMessage (hCombo, WM_SETREDRAW, TRUE, 0);
450 SendMessage (hCombo, CB_SETCURSEL, iItemSel, 0);
452 TCHAR szMapping[ MAX_PATH ];
453 AdjustAfsPath (szMapping, ((pMap->szMapping[0]) ? pMap->szMapping : cm_slash_mount_root), TRUE, FALSE);
454 SetDlgItemText (hDlg, IDC_PATH, szMapping);
455 SetDlgItemText (hDlg, IDC_DESC, pMap->szSubmount);
457 CheckDlgButton (hDlg, IDC_PERSISTENT, (pMap->chDrive == 0) ? TRUE : (pMap->fPersistent));
459 AutoMapEdit_Enable (hDlg);
463 void AutoMapEdit_OnOK (HWND hDlg)
465 PDRIVEMAP pMap = (PDRIVEMAP)GetWindowLongPtr (hDlg, DWLP_USER);
467 int iItem = SendDlgItemMessage (hDlg, IDC_DRIVE, CB_GETCURSEL, 0, 0);
468 int iDrive = SendDlgItemMessage (hDlg, IDC_DRIVE, CB_GETITEMDATA, iItem, 0);
470 pMap->chDrive = chDRIVE_A + iDrive;
471 GetDlgItemText (hDlg, IDC_PATH, pMap->szMapping, MAX_PATH);
472 GetDlgItemText (hDlg, IDC_DESC, pMap->szSubmount, MAX_PATH);
473 pMap->fPersistent = IsDlgButtonChecked (hDlg, IDC_PERSISTENT);
475 if (pMap->szSubmount[0] && !IsValidSubmountName (pMap->szSubmount))
477 Message (MB_ICONHAND, GetErrorTitle(), IDS_BADSUB_DESC);
481 if ( (lstrncmpi (pMap->szMapping, cm_slash_mount_root, lstrlen(cm_slash_mount_root))) &&
482 (lstrncmpi (pMap->szMapping, cm_back_slash_mount_root, lstrlen(cm_back_slash_mount_root))) )
484 Message (MB_ICONHAND, GetErrorTitle(), IDS_BADMAP_DESC);
488 // First get a proper submount
489 if (pMap->szSubmount[0]) {
490 TCHAR szNewSubmount[MAX_PATH];
491 PathToSubmount (szNewSubmount, pMap->szMapping, pMap->szSubmount, 0);
492 if (lstrcmp(szNewSubmount, pMap->szSubmount) != 0) {
493 Message (MB_OK | MB_ICONASTERISK, GetCautionTitle(), IDS_NEWSUB_DESC);
496 } else { // If no submount was specified, then get a new one
497 if (!PathToSubmount (pMap->szSubmount, pMap->szMapping, 0, 0)) {
502 EndDialog (hDlg, IDOK);
506 void AutoMapEdit_Enable (HWND hDlg)
508 TCHAR szPath[ MAX_PATH ];
509 GetDlgItemText (hDlg, IDC_PATH, szPath, MAX_PATH);
510 EnableWindow (GetDlgItem (hDlg, IDOK), (szPath[0] != TEXT('\0')));