~azzar1/unity/add-show-desktop-key

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
# IVLE
# Copyright (C) 2007-2008 The University of Melbourne
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA

# App: debuginfo
# Author: Matt Giuca
# Date: 17/12/2007

# Displays lots of internal information about IVLE's running environment,
# a la phpinfo.
# Important: This application should be removed from a production system.

from common import util
import conf
from conf import apps
import os

def handle(req):
    """Handler for the Debug Information application."""

    # Set request attributes
    req.content_type = "text/html"
    req.write_html_head_foot = True     # Have dispatch print head and foot

    # Start writing data
    req.write("<h2>IVLE Debug Information</h2>\n")

    print_table(req, "System Constants", [
        ("ivle_version", conf.ivle_version),
        ("ivle_install_dir", conf.ivle_install_dir),
        ("root_dir", conf.root_dir),
        ("jail_base", conf.jail_base),
        ("default_app", conf.default_app),
    ])

    print_table(req, "Operating System Variables", [
        ("uid", os.getuid()),
        ("euid", os.geteuid()),
        ("gid", os.getgid()),
        ("egid", os.getegid()),
    ])

    print_table(req, "Available Applications", conf.apps.app_url.items())

    print_table(req, "Request Properties", [
        ("method", req.method),
        ("uri", req.uri),
        ("app", req.app),
        ("path", req.path),
        ("username", req.username),
        ("hostname", req.hostname),
    ])

    # Violate encapsulation here to print out the hidden properties
    print_table(req, "Apache (Hidden) Request Properties", [
        ("hostname", req.apache_req.hostname),
        ("method", req.apache_req.method),
        ("unparsed_uri", req.apache_req.unparsed_uri),
        ("parsed_uri", req.apache_req.parsed_uri),
        ("uri", req.apache_req.uri),
        ("filename", req.apache_req.filename),
        ("path_info", req.apache_req.path_info),
    ])

    print_table(req, "Field Storage",
        getfieldvalues(req.get_fieldstorage().items()))
    print_table(req, "Session Variables", req.get_session().items())

    print_table(req, "HTTP Request Headers",
        req.apache_req.headers_in.items())
    print_table(req, "CGI Environment Variables",
        req.get_cgi_environ().items())
    print_table(req, "Server Environment Variables", os.environ.items())

    req.write("<h3>Removal instructions</h3>\n")
    req.write("""<p>In a production environment, debuginfo should be disabled.
    To do this, comment out or remove the debuginfo line of the app_url
    dictionary in conf/apps.py.</p>
    <p>For extra security, it may be removed completely by deleting the
    apps/debuginfo directory.</p>\n""")

def getfieldvalues(pairs):
    """Given a list of pairs of strings and fields, returns a new list with
    the 2nd elements of each pair modified to be the field's value."""
    if pairs is None: return None
    newlist = []
    for k,v in pairs:
        newlist.append((k,v.value))
    return newlist

def print_table(req, tablename, mapping):
    """Prints an HTML table with a heading.

    mapping: An associative list (a list of pairs). The pairs are printed
    using (str, repr) respectively into the two-column table."""
    req.write("<h3>%s</h3>\n" % tablename)
    req.write('<table border="1">\n')
    for (k,v) in mapping:
        req.write("<tr><th>%s</th><td>%s</td></tr>\n" % (str(k), repr(v)))
    req.write("</table>\n")