Source code of Windows XP (NT5)
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.

0 lines
8.7 KiB

  1. // =========================================================================== // UAMDialogs.c � 1997 Microsoft Corp. All rights reserved. // =========================================================================== // General dialog utilities used by the Microsoft User Authentication Method. // // =========================================================================== #include <Sound.h> #include "UAMDebug.h" #include "UAMDialogs.h" #include "UAMUtils.h" #include "UAMMain.h" #include "UAMNetwork.h" #include "UAMDSNetwork.h" #include "UAMListBox.h" #include "UAMDLOGUtils.h" #include "UAMKeychain.h" extern Str32 gServerName; extern ModalFilterUPP gDialogFilter; extern UserItemUPP gLineItem; extern long gSupportedUAMs; // --------------------------------------------------------------------------- // � UAM_ReportError() // --------------------------------------------------------------------------- // Reports an error to the user by displaying an alert box. This routine looks // in the resource file for a resource of type 'ESTR' with the same res ID as // the error code. If found, the message contained in the resource is displayed // to the user. // // Note that we go out our way here by putting up and maintaining our own error // alert box instead of using one of the Alert routines. This is because other // dialogs in the UAM use ParamText() to set string information. If we have // an error, then the strings will be replaced by the alert strings. Not a // good scenario... #define DITEM_MsgText 3 void UAM_ReportError(OSStatus inError) { Str255 theMsg; short theItem; StringHandle theString; DialogPtr theDialog = NULL; GrafPtr theSavePort = NULL; Assert_(gDialogFilter != NULL); if (inError != noErr) { GetPort(&theSavePort); InitCursor(); UAM_PStrCopy("\p", theMsg); theString = (StringHandle)Get1Resource('STR ', inError); if (theString) { HLock((Handle)theString); UAM_PStrCopy(*theString, theMsg); HUnlock((Handle)theString); ReleaseResource((Handle)theString); } theDialog = UAM_NewDialog(DLOG_GeneralError, true); Assert_(theDialog != NULL); if (theDialog != NULL) { SysBeep(1); UAM_SetText(theDialog, DITEM_MsgText, theMsg); do { ModalDialog(gDialogFilter, &theItem); }while(theItem != 1); UAM_DisposeDialog(theDialog); SetPort(theSavePort); } } } // --------------------------------------------------------------------------- // � UAM_ChangePwd() // --------------------------------------------------------------------------- // Puts up and handles the change password dialog and calls the appropriate // routines to change the password. // // Unless there is an error, we'll usually return one of: // // #define CHNGPSWD_UPDATE_KEYCHAIN 1000 // #define CHNGPSWD_USER_CANCELED 1001 // #define CHNGPSWD_NOERR noErr #define DITEM_Icon 3 #define DITEM_OldPassword 6 #define DITEM_NewPassword 8 #define DITEM_VerifyPwd 10 #define DITEM_LineItem 11 OSStatus UAM_ChangePwd(UAMArgs *inUAMArgs) { GrafPtr theSavePort; short theItem; OSStatus theError; Str255 theNewPwd, theVerPwd; CursHandle theCursor; DialogPtr theDialog = NULL; Boolean theDoLoop = true; KCItemRef theKCItemRef = NULL; Assert_(gDialogFilter != NULL); Assert_(gLineItem != NULL); GetPort(&theSavePort); ParamText(inUAMArgs->Opt.pwDlg.userName, gServerName, NULL, NULL); theDialog = UAM_NewDialog(DLOG_ChangePwd, true); if (theDialog == NULL) { UAM_ReportError(resNotFound); return(resNotFound); } // //Set up the line at the top of the dialog. // UAM_SetUpUserItem(theDialog, DITEM_LineItem, gLineItem, userItem); // //All three fields in this dialog are bullet protected. // UAM_SetBulletItem(theDialog, DITEM_OldPassword, UAM_CLRTXTPWDLEN); UAM_SetBulletItem(theDialog, DITEM_NewPassword, UAM_CLRTXTPWDLEN); UAM_SetBulletItem(theDialog, DITEM_VerifyPwd, UAM_CLRTXTPWDLEN); if (inUAMArgs->Opt.pwDlg.password[0] != 0) { UAM_SetBulletText( theDialog, DITEM_OldPassword, inU