Prevent access to the /lib/ directory
[WebKit-https.git] / Websites / bugs.webkit.org / index.cgi
1 #!/usr/bin/env perl -wT
2 # -*- Mode: perl; indent-tabs-mode: nil -*-
3 #
4 # The contents of this file are subject to the Mozilla Public
5 # License Version 1.1 (the "License"); you may not use this file
6 # except in compliance with the License. You may obtain a copy of
7 # the License at http://www.mozilla.org/MPL/
8 #
9 # Software distributed under the License is distributed on an "AS
10 # IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
11 # implied. See the License for the specific language governing
12 # rights and limitations under the License.
13 #
14 # The Original Code is the Bugzilla Bug Tracking System.
15 #
16 # The Initial Developer of the Original Code is Netscape Communications
17 # Corporation. Portions created by Netscape are
18 # Copyright (C) 1998 Netscape Communications Corporation. All
19 # Rights Reserved.
20 #
21 # Contributor(s): Jacob Steenhagen <jake@bugzilla.org>
22 #                 Frédéric Buclin <LpSolit@gmail.com>
23
24 ###############################################################################
25 # Script Initialization
26 ###############################################################################
27
28 # Make it harder for us to do dangerous things in Perl.
29 use strict;
30
31 # Include the Bugzilla CGI and general utility library.
32 use lib qw(. lib);
33
34 use Bugzilla;
35 use Bugzilla::Constants;
36 use Bugzilla::Error;
37 use Bugzilla::Update;
38
39 # Check whether or not the user is logged in
40 my $user = Bugzilla->login(LOGIN_OPTIONAL);
41 my $cgi = Bugzilla->cgi;
42 my $template = Bugzilla->template;
43 my $vars = {};
44
45 # And log out the user if requested. We do this first so that nothing
46 # else accidentally relies on the current login.
47 if ($cgi->param('logout')) {
48     Bugzilla->logout();
49     $user = Bugzilla->user;
50     $vars->{'message'} = "logged_out";
51     # Make sure that templates or other code doesn't get confused about this.
52     $cgi->delete('logout');
53 }
54
55 ###############################################################################
56 # Main Body Execution
57 ###############################################################################
58
59 # Return the appropriate HTTP response headers.
60 print $cgi->header();
61
62 if ($user->in_group('admin')) {
63     # If 'urlbase' is not set, display the Welcome page.
64     unless (Bugzilla->params->{'urlbase'}) {
65         $template->process('welcome-admin.html.tmpl')
66           || ThrowTemplateError($template->error());
67         exit;
68     }
69     # Inform the administrator about new releases, if any.
70     $vars->{'release'} = Bugzilla::Update::get_notifications();
71 }
72
73 # Generate and return the UI (HTML page) from the appropriate template.
74 $template->process("index.html.tmpl", $vars)
75   || ThrowTemplateError($template->error());