#!/usr/bonsaitools/bin/perl -wT # -*- Mode: perl; indent-tabs-mode: nil -*- # # The contents of this file are subject to the Mozilla Public # License Version 1.1 (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): Owen Taylor # Gervase Markham # David Fallon use strict; use vars qw( %FORM $userid $template $vars ); use lib qw(.); require "CGI.pl"; ConnectToDatabase(); confirm_login(); if (Param('enablequips') eq "off") { ThrowUserError("quips_disabled"); } my $action = $::FORM{'action'} || ""; if ($action eq "show") { # Read in the entire quip list SendSQL("SELECT quip FROM quips"); my @quips; while (MoreSQLData()) { my ($quip) = FetchSQLData(); push(@quips, $quip); } $vars->{'quips'} = \@quips; $vars->{'show_quips'} = 1; } if ($action eq "edit") { if (!UserInGroup('admin')) { ThrowUserError("quips_edit_denied"); } # Read in the entire quip list SendSQL("SELECT quipid,userid,quip FROM quips"); my $quips; my @quipids; while (MoreSQLData()) { my ($quipid, $userid, $quip) = FetchSQLData(); $quips->{$quipid} = {'userid' => $userid, 'quip' => $quip}; push(@quipids, $quipid); } my $users; foreach my $quipid (@quipids) { if (not defined $users->{$userid}) { SendSQL("SELECT login_name FROM profiles WHERE userid = $userid"); $users->{$userid} = FetchSQLData(); } } $vars->{'quipids'} = \@quipids; $vars->{'quips'} = $quips; $vars->{'users'} = $users; $vars->{'edit_quips'} = 1; } if ($action eq "add") { (Param('enablequips') eq "on") || ThrowUserError("no_new_quips"); # Add the quip my $comment = $::FORM{"quip"}; $comment || ThrowUserError("need_quip"); $comment !~ m/{'added_quip'} = $comment; } if ($action eq "delete") { if (!UserInGroup('admin')) { ThrowUserError("quips_edit_denied"); } my $quipid = $::FORM{"quipid"}; ThrowCodeError("need_quipid") unless $quipid =~ /(\d+)/; $quipid = $1; SendSQL("SELECT quip FROM quips WHERE quipid = $quipid"); $vars->{'deleted_quip'} = FetchSQLData(); SendSQL("DELETE FROM quips WHERE quipid = $quipid"); } print "Content-type: text/html\n\n"; $template->process("list/quips.html.tmpl", $vars) || ThrowTemplateError($template->error());