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

« back to all changes in this revision

Viewing changes to src/console/python-console

  • Committer: drtomc
  • Date: 2007-12-19 20:48:44 UTC
  • Revision ID: svn-v3-trunk0:2b9c9e99-6f39-0410-b283-7f802c844ae2:trunk:87
First hack at the python console.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#!/usr/bin/python
 
2
 
 
3
# usage:
 
4
#   python-console <port> <magic>
 
5
 
 
6
import web
 
7
import md5
 
8
import codeop
 
9
import cjson
 
10
 
 
11
globs = {}
 
12
globs['__builtins__'] = globals()['__builtins__']
 
13
locls = {}
 
14
compiler = codeop.CommandCompiler()
 
15
curr_cmd = ''
 
16
 
 
17
def do_chat(txt):
 
18
    if curr_cmd == '':
 
19
        curr_cmd = txt
 
20
    else:
 
21
        curr_cmd = curr_cmd + '\n' + txt
 
22
    try:
 
23
        cmd = compiler(curr_cmd)
 
24
        if cmd is None:
 
25
            # The command was incomplete,
 
26
            # so send back a None, so the
 
27
            # client can print a '...'
 
28
            web.output(cjson.encode(None))
 
29
        else:
 
30
            # The command was complete,
 
31
            # so evaluate it!
 
32
            out = cStringIO.StringIO()
 
33
            sys.stdout = out
 
34
            sys.stderr = out
 
35
            signal.alarm(5)
 
36
            res = eval(cmd, globs, locls)
 
37
            signal.alarm(0)
 
38
            v = (out.getvalue(), res, None)
 
39
            web.output(json.encode(v))
 
40
            curr_cmd = ''
 
41
    except Exception, exc:
 
42
        v = (None, None, str(exc))
 
43
        web.output(json.encode(v))
 
44
        curr_cmd = ''
 
45
 
 
46
urls = (
 
47
    '/',            'index',
 
48
    '/(.*\.js)',    'jscript',
 
49
    '/chat',        'chat')
 
50
 
 
51
# The global 'magic' is the secret that the client and server share
 
52
# which is used to create and md5 digest to authenticate requests.
 
53
# It is assigned a real value at startup.
 
54
magic = ''
 
55
 
 
56
class index:
 
57
    def GET(self):
 
58
        inp = web.input()
 
59
 
 
60
        # Authenticate
 
61
        digest = md5.new('hello' + magic).digest().encode('hex')
 
62
        if inp.digest != digest:
 
63
            web.ctx.status = '401 Unauthorized'
 
64
            return
 
65
 
 
66
        # Okay, so the authentication succeeded,
 
67
        # so all we need to do is send back the static
 
68
        # HTML for the console app.
 
69
        web.output(file("index.html", "r").read())
 
70
 
 
71
class jscript:
 
72
    def GET(self, name):
 
73
        web.output(file(name, "r").read())
 
74
 
 
75
class chat:
 
76
    def POST(self):
 
77
        inp = web.input()
 
78
 
 
79
        # Authenticate
 
80
        digest = md5.new(inp.text + magic).digest().encode('hex')
 
81
        if inp.digest != digest:
 
82
            web.ctx.status = '401 Unauthorized'
 
83
            return
 
84
 
 
85
        # Okay, so the authentication succeeded,
 
86
        # so now we have the trivial matter of actually
 
87
        # executing the python....
 
88
        web.output(do_chat(inp.text))
 
89
 
 
90
if __name__ == "__main__":
 
91
    # FIXME jail!
 
92
    magic = sys.argv[2]
 
93
    web.run(urls, globals())