]> git.ipfire.org Git - thirdparty/bugzilla.git/commitdiff
Added new pages to edit existing components.
authorterry%netscape.com <>
Fri, 12 Mar 1999 06:48:41 +0000 (06:48 +0000)
committerterry%netscape.com <>
Fri, 12 Mar 1999 06:48:41 +0000 (06:48 +0000)
doeditcomponents.cgi [new file with mode: 0755]
editcomponents.cgi [new file with mode: 0755]
query.cgi

diff --git a/doeditcomponents.cgi b/doeditcomponents.cgi
new file mode 100755 (executable)
index 0000000..048ec11
--- /dev/null
@@ -0,0 +1,149 @@
+#!/usr/bonsaitools/bin/perl -w
+# -*- Mode: perl; indent-tabs-mode: nil -*-
+#
+# The contents of this file are subject to the Mozilla Public License
+# Version 1.0 (the "License"); you may not use this file except in
+# compliance with the License. You may obtain a copy of the License at
+# http://www.mozilla.org/MPL/
+# 
+# Software distributed under the License is distributed on an "AS IS"
+# basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
+# License for the specific language governing rights and limitations
+# under the License.
+# 
+# The Original Code is the Bugzilla Bug Tracking System.
+# 
+# The Initial Developer of the Original Code is Netscape Communications
+# Corporation. Portions created by Netscape are Copyright (C) 1998
+# Netscape Communications Corporation. All Rights Reserved.
+# 
+# Contributor(s): Sam Ziegler <sam@ziegler.org>
+# Terry Weissman <terry@mozilla.org>
+
+# Code derived from doeditowners.cgi
+
+
+use diagnostics;
+use strict;
+
+require "CGI.pl";
+
+
+# Shut up misguided -w warnings about "used only once":
+
+use vars @::legal_product;
+
+
+confirm_login();
+
+print "Content-type: text/html\n\n";
+
+# foreach my $i (sort(keys %::FORM)) {
+#     print value_quote("$i $::FORM{$i}") . "<BR>\n";
+# }
+
+if (!UserInGroup("editcomponents")) {
+    print "<H1>Sorry, you aren't a member of the 'editcomponents' group.</H1>\n";
+    print "And so, you aren't allowed to edit the owners.\n";
+    exit;
+}
+
+
+sub Check {
+    my ($code1, $code2) = (@_);
+    if ($code1 ne $code2) {
+        print "<H1>A race error has occurred.</H1>";
+        print "It appears that someone else has been changing the database\n";
+        print "while you've been editing it.  I'm afraid you will have to\n";
+        print "start all over.  Sorry! <P>\n";
+        print "<p><a href=query.cgi>Go back to the query page</a>\n";
+        exit;
+    }
+}
+
+
+my @cmds;
+
+sub DoOne {
+    my ($oldvalue, $field, $where, $checkemail) = (@_);
+    if (!defined $::FORM{$field}) {
+        print "ERROR -- $field not defined!";
+        exit;
+    }
+    if ($oldvalue ne $::FORM{$field}) {
+        my $name = $field;
+        $name =~ s/^.*-//;
+        my $table = "products";
+        if ($field =~ /^P\d+-C\d+-/) {
+            $table = "components";
+        }
+        push @cmds, "update $table set $name=" .
+            SqlQuote($::FORM{$field}) . "where $where";
+        print "Changed $name for $where <P>";
+        if ($checkemail) {
+            DBNameToIdAndCheck($::FORM{$field});
+        }
+    }
+}
+            
+
+
+PutHeader("Saving new component info");
+
+unlink "data/versioncache";
+GetVersionTable();
+
+my $prodcode = "P0";
+
+foreach my $product (@::legal_product) {
+    SendSQL("select description, milestoneurl, disallownew from products where product='$product'");
+    my @row = FetchSQLData();
+    if (!@row) {
+        next;
+    }
+    my ($description, $milestoneurl, $disallownew) = (@row);
+    $prodcode++;
+    Check($product, $::FORM{"prodcode-$prodcode"});
+
+    my $where = "product=" . SqlQuote($product);
+    DoOne($description, "$prodcode-description", $where);
+    if (Param('usetargetmilestone')) {
+        DoOne($milestoneurl, "$prodcode-milestoneurl", $where);
+    }
+    DoOne($disallownew, "$prodcode-disallownew", $where);
+
+    SendSQL("select value, initialowner, initialqacontact, description from components where program=" . SqlQuote($product) . " order by value");
+    my $c = 0;
+    while (my @row = FetchSQLData()) {
+        my ($component, $initialowner, $initialqacontact, $description) =
+            (@row);
+        $c++;
+        my $compcode = $prodcode . "-" . "C$c";
+
+       Check($component, $::FORM{"compcode-$compcode"});
+
+        my $where = "program=" . SqlQuote($product) . " and value=" .
+            SqlQuote($component);
+
+        DoOne($initialowner, "$compcode-initialowner", $where, 1);
+        if (Param('useqacontact')) {
+            DoOne($initialqacontact, "$compcode-initialqacontact", $where,
+                  1);
+        }
+        DoOne($description, "$compcode-description", $where);
+    }
+
+}
+
+print "Saving changes.<P>\n";
+
+foreach my $cmd (@cmds) {
+    print "$cmd <BR>";
+    SendSQL($cmd);
+}
+
+unlink "data/versioncache";
+
+print "OK, done.<p>\n";
+print "<a href=editcomponents.cgi>Edit the components some more.</a><p>\n";
+print "<a href=query.cgi>Go back to the query page.</a>\n";
diff --git a/editcomponents.cgi b/editcomponents.cgi
new file mode 100755 (executable)
index 0000000..f198945
--- /dev/null
@@ -0,0 +1,117 @@
+#!/usr/bonsaitools/bin/perl -w
+# -*- Mode: perl; indent-tabs-mode: nil -*-
+#
+# The contents of this file are subject to the Mozilla Public License
+# Version 1.0 (the "License"); you may not use this file except in
+# compliance with the License. You may obtain a copy of the License at
+# http://www.mozilla.org/MPL/
+# 
+# Software distributed under the License is distributed on an "AS IS"
+# basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
+# License for the specific language governing rights and limitations
+# under the License.
+# 
+# The Original Code is the Bugzilla Bug Tracking System.
+# 
+# The Initial Developer of the Original Code is Netscape Communications
+# Corporation. Portions created by Netscape are Copyright (C) 1998
+# Netscape Communications Corporation. All Rights Reserved.
+# 
+# Contributor(s): Sam Ziegler <sam@ziegler.org>
+# Terry Weissman <terry@mozilla.org>
+
+# Code derived from editparams.cgi, editowners.cgi
+
+use diagnostics;
+use strict;
+
+require "CGI.pl";
+
+# Shut up misguided -w warnings about "used only once":
+
+use vars @::legal_product;
+
+confirm_login();
+
+print "Content-type: text/html\n\n";
+
+if (!UserInGroup("editcomponents")) {
+    print "<H1>Sorry, you aren't a member of the 'editcomponents' group.</H1>\n";
+    print "And so, you aren't allowed to edit the owners.\n";
+    exit;
+}
+
+
+PutHeader("Edit Components");
+
+print "This lets you edit the program components of bugzilla.\n";
+
+print "<form method=post action=doeditcomponents.cgi>\n";
+
+my $rowbreak = "<tr><td colspan=2><hr></td></tr>";
+
+unlink "data/versioncache";
+GetVersionTable();
+
+my $prodcode = "P0";
+
+foreach my $product (@::legal_product) {
+    SendSQL("select description, milestoneurl, disallownew from products where product='$product'");
+    my @row = FetchSQLData();
+    if (!@row) {
+        next;
+    }
+    my ($description, $milestoneurl, $disallownew) = (@row);
+    $prodcode++;
+    print "<input type=hidden name=prodcode-$prodcode value=\"" .
+        value_quote($product) . "\">\n";
+    print "<table><tr><th align=left valign=top>$product</th><td></td></tr>\n";
+    print "<tr><th align=right>Description:</th>\n";
+    print "<td><input size=80 name=$prodcode-description value=\"" .
+        value_quote($description) . "\"></td></tr>\n";
+    if (Param('usetargetmilestone')) {
+        print "<tr><th align=right>MilestoneURL:</th>\n";
+        print "<td><input size=80 name=$prodcode-milestoneurl value=\"" .
+            value_quote($milestoneurl) . "\"></td></tr>\n";
+    }
+    my $check0 = !$disallownew ? " SELECTED" : "";
+    my $check1 = $disallownew ? " SELECTED" : "";
+    print "<tr><td colspan=2><select name=$prodcode-disallownew>\n";
+    print "<option value=0$check0>Open; new bugs may be submitted against this project\n";
+    print "<option value=1$check1>Closed; no new bugs may be submitted against this project\n";
+    print "</select></td></tr>\n";
+
+    print "<tr><td colspan=2>Components:</td></tr></table>\n";
+    print "<table>\n";
+    
+    SendSQL("select value, initialowner, initialqacontact, description from components where program=" . SqlQuote($product) . " order by value");
+    my $c = 0;
+    while (my @row = FetchSQLData()) {
+        my ($component, $initialowner, $initialqacontact, $description) =
+            (@row);
+        $c++;
+        my $compcode = $prodcode . "-" . "C$c";
+        print "<input type=hidden name=compcode-$compcode value=\"" .
+            value_quote($component) . "\">\n";
+        print "<tr><th>$component</th><th align=right>Description:</th>\n";
+        print "<td><input size=80 name=$compcode-description value=\"" .
+        value_quote($description) . "\"></td></tr>\n";
+        print "<tr><td></td><th align=right>Initial owner:</th>\n";
+        print "<td><input size=60 name=$compcode-initialowner value=\"" .
+        value_quote($initialowner) . "\"></td></tr>\n";
+        if (Param('useqacontact')) {
+            print "<tr><td></td><th align=right>Initial QA contact:</th>\n";
+            print "<td><input size=60 name=$compcode-initialqacontact value=\"" .
+                value_quote($initialqacontact) . "\"></td></tr>\n";
+        }
+    }
+
+    print "</table><hr>\n";
+
+}
+
+print "<input type=submit value=\"Submit changes\">\n";
+
+print "</form>\n";
+
+print "<p><a href=query.cgi>Skip all this, and go back to the query page</a>\n";
index 2f8e1bef4b3c5486cb8fa8dda82e265ea619303d..66a1f5b54de49c7f7152184dc3c09b4db6fc1981 100755 (executable)
--- a/query.cgi
+++ b/query.cgi
@@ -383,7 +383,7 @@ if (UserInGroup("tweakparams")) {
     print "<a href=editparams.cgi>Edit Bugzilla operating parameters</a><br>\n";
 }
 if (UserInGroup("editcomponents")) {
-    print "<a href=editowners.cgi>Edit Bugzilla component owners</a><br>\n";
+    print "<a href=editcomponents.cgi>Edit Bugzilla components</a><br>\n";
 }
 if (defined $::COOKIE{"Bugzilla_login"}) {
     print "<a href=relogin.cgi>Log in as someone besides <b>$::COOKIE{'Bugzilla_login'}</b></a><br>\n";