From c790c34e511a29956a1cb53c337c95184a06e29e Mon Sep 17 00:00:00 2001 From: "ian%hixie.ch" Date: Fri, 30 Nov 2001 16:06:45 +0000 Subject: [PATCH] Adding error handling for the case where the user prefs editor is called with bogus user IDs. --- webtools/PLIF/PLIF/Service/Components/UserPrefs.pm | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/webtools/PLIF/PLIF/Service/Components/UserPrefs.pm b/webtools/PLIF/PLIF/Service/Components/UserPrefs.pm index acbc3e3fd8a..2ec1673b4da 100644 --- a/webtools/PLIF/PLIF/Service/Components/UserPrefs.pm +++ b/webtools/PLIF/PLIF/Service/Components/UserPrefs.pm @@ -75,17 +75,24 @@ sub cmdUserPrefs { # get the data for each user being edited my $userData = {}; + my @notifications; foreach my $userID (@userIDs) { my $targetUser = $userFactory->getUserByID($app, $userID); if (defined($targetUser)) { $userData->{$userID} = $self->populateUserPrefsHash($app, $userDataSource, $user, $targetUser, $userID, $userID == $user->userID, @rights); } else { $self->warn(2, "someone tried to get the details of invalid user $userID"); + push(@notifications, [$userID, '', 'user.noSuchUser']); } } - # put it all together - $app->output->userPrefs(\@userIDs, $userData, $self->populateUserPrefsMetaData($app, $userDataSource)); + if (not scalar(@notifications)) { + # put it all together + $app->output->userPrefs(\@userIDs, $userData, $self->populateUserPrefsMetaData($app, $userDataSource)); + } else { + $app->output->userPrefsNotification(\@notifications); + } + } sub populateUserPrefsRights {