diff options
author | mkanat%kerio.com <> | 2005-02-25 10:34:10 +0000 |
---|---|---|
committer | mkanat%kerio.com <> | 2005-02-25 10:34:10 +0000 |
commit | 65f999de859324507eb40e934bc6b647f143511a (patch) | |
tree | 0965cbeaf58c9210a82309b2f322dd0b3720a386 /userprefs.cgi | |
parent | Bug (None): Fix for checkin from Bug 280493, fix a trailing comma in Bug.pm (diff) | |
download | bugzilla-65f999de859324507eb40e934bc6b647f143511a.tar.gz bugzilla-65f999de859324507eb40e934bc6b647f143511a.tar.bz2 bugzilla-65f999de859324507eb40e934bc6b647f143511a.zip |
Bug 281550: Remove RelationSet from userprefs.cgi (and thus fix non-ANSI INSERT)
Patch By Max Kanat-Alexander <mkanat@kerio.com> r=LpSolit, a=myk
Diffstat (limited to 'userprefs.cgi')
-rwxr-xr-x | userprefs.cgi | 53 |
1 files changed, 33 insertions, 20 deletions
diff --git a/userprefs.cgi b/userprefs.cgi index 72f7232ae..974791d52 100755 --- a/userprefs.cgi +++ b/userprefs.cgi @@ -33,8 +33,6 @@ use Bugzilla::User; require "CGI.pl"; -use Bugzilla::RelationSet; - # Use global template variables. use vars qw($template $vars $userid); @@ -142,11 +140,14 @@ sub SaveAccount { sub DoEmail { + my $dbh = Bugzilla->dbh; + if (Param("supportwatchers")) { - my $watcheduserSet = new Bugzilla::RelationSet; - $watcheduserSet->mergeFromDB("SELECT watched FROM watch WHERE" . - " watcher=$userid"); - $vars->{'watchedusers'} = $watcheduserSet->toString(); + my $watched_ref = $dbh->selectcol_arrayref( + "SELECT profiles.login_name FROM watch, profiles" + . " WHERE watcher = ? AND watch.watched = profiles.userid", + undef, $userid); + $vars->{'watchedusers'} = join(',', @$watched_ref); } SendSQL("SELECT emailflags FROM profiles WHERE userid = $userid"); @@ -232,20 +233,32 @@ sub SaveEmail { $dbh->bz_lock_tables('watch WRITE', 'profiles READ'); # what the db looks like now - my $origWatchedUsers = new Bugzilla::RelationSet; - $origWatchedUsers->mergeFromDB("SELECT watched FROM watch WHERE" . - " watcher=$userid"); - - # Update the database to look like the form - my $newWatchedUsers = new Bugzilla::RelationSet($cgi->param('watchedusers')); - my @CCDELTAS = $origWatchedUsers->generateSqlDeltas( - $newWatchedUsers, - "watch", - "watcher", - $userid, - "watched"); - ($CCDELTAS[0] eq "") || SendSQL($CCDELTAS[0]); - ($CCDELTAS[1] eq "") || SendSQL($CCDELTAS[1]); + my $old_watch_ids = + $dbh->selectcol_arrayref("SELECT watched FROM watch" + . " WHERE watcher = ?", undef, $userid); + + # The new information given to us by the user. + my @new_watch_names = split(/[,\s]+/, $cgi->param('watchedusers')); + my @new_watch_ids = (); + foreach my $username (@new_watch_names) { + my $watched_userid = DBNameToIdAndCheck(trim($username)); + push(@new_watch_ids, $watched_userid); + } + my ($removed, $added) = diff_arrays($old_watch_ids, \@new_watch_ids); + + # Remove people who were removed. + my $delete_sth = $dbh->prepare('DELETE FROM watch WHERE watched = ?' + . ' AND watcher = ?'); + foreach my $remove_me (@$removed) { + $delete_sth->execute($remove_me, $userid); + } + + # Add people who were added. + my $insert_sth = $dbh->prepare('INSERT INTO watch (watched, watcher)' + . ' VALUES (?, ?)'); + foreach my $add_me (@$added) { + $insert_sth->execute($add_me, $userid); + } $dbh->bz_unlock_tables(); } |