aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormkanat%kerio.com <>2005-02-25 10:34:10 +0000
committermkanat%kerio.com <>2005-02-25 10:34:10 +0000
commit65f999de859324507eb40e934bc6b647f143511a (patch)
tree0965cbeaf58c9210a82309b2f322dd0b3720a386 /userprefs.cgi
parentBug (None): Fix for checkin from Bug 280493, fix a trailing comma in Bug.pm (diff)
downloadbugzilla-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-xuserprefs.cgi53
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();
}