annotate docs.html @ 24:c2c369402a2e

Added more docs, fixed edge cases.
author Atul Varma <varmaa@toolness.com>
date Thu, 10 Sep 2009 22:32:45 -0700
parents 7cbbec55aef6
children 351819baecd1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
21
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
1 <?xml version="1.0" encoding="utf-8" ?>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
3 <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
4 <head>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
5 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
6 <meta name="generator" content="Docutils 0.4: http://docutils.sourceforge.net/" />
22
915fdf283ac5 Moved docs out to a separate file.
Atul Varma <varmaa@toolness.com>
parents: 21
diff changeset
7 <title>Pydertron</title>
21
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
8 <link rel="stylesheet" href="docs.css" type="text/css" />
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
9 </head>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
10 <body>
22
915fdf283ac5 Moved docs out to a separate file.
Atul Varma <varmaa@toolness.com>
parents: 21
diff changeset
11 <div class="document" id="pydertron">
915fdf283ac5 Moved docs out to a separate file.
Atul Varma <varmaa@toolness.com>
parents: 21
diff changeset
12 <h1 class="title">Pydertron</h1>
21
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
13 <p>Pydertron is a high-level wrapper for <a class="reference" href="http://code.google.com/p/pydermonkey">Pydermonkey</a> that
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
14 provides convenient, secure object wrapping between JS and Python
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
15 space.</p>
24
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
16 <p>Note that Pydertron is just one example of a high-level interface
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
17 between Python and JavaScript: it assumes, for instance, that the JS
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
18 code it executes isn't trusted, which affects the nature of the
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
19 inter-language interaction.</p>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
20 <div class="section">
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
21 <h1><a id="the-basics" name="the-basics">The Basics</a></h1>
21
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
22 <p>The <tt class="docutils literal"><span class="pre">JsSandbox</span></tt> class encapsulates a JavaScript runtime, context, global
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
23 object, and a simple <a class="reference" href="http://wiki.commonjs.org/wiki/CommonJS/Modules/SecurableModules">SecurableModule</a> implementation that complies
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
24 with the <a class="reference" href="http://wiki.commonjs.org/wiki/CommonJS">CommonJS</a> standard. It also provides a high-level bridge between
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
25 Python and JavaScript so that you don't need to deal with any of the
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
26 low-level details of the Pydermonkey API.</p>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
27 <p>For instance, here we'll create a <tt class="docutils literal"><span class="pre">JsSandbox</span></tt> whose module root
23
7cbbec55aef6 Minor modifications.
Atul Varma <varmaa@toolness.com>
parents: 22
diff changeset
28 points to the <a class="reference" href="http://interoperablejs.googlecode.com/svn/trunk/compliance/monkeys/">monkeys</a> SecurableModule compliance test over HTTP:</p>
21
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
29 <blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
30 <pre class="doctest-block">
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
31 &gt;&gt;&gt; url = (&quot;http://interoperablejs.googlecode.com/svn/trunk/&quot;
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
32 ... &quot;compliance/monkeys/&quot;)
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
33 &gt;&gt;&gt; sandbox = JsSandbox(HttpFileSystem(url))
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
34 </pre>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
35 </blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
36 <p>This compliance test requires a global <tt class="docutils literal"><span class="pre">sys</span></tt> object that contains one
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
37 method, <tt class="docutils literal"><span class="pre">print()</span></tt>, that takes two arguments. First, we'll create the
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
38 <tt class="docutils literal"><span class="pre">print()</span></tt> function and prepare it for exposure to JS code:</p>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
39 <blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
40 <pre class="doctest-block">
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
41 &gt;&gt;&gt; &#64;jsexposed
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
42 ... def jsprint(message, label):
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
43 ... print message, label
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
44 </pre>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
45 </blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
46 <p>Note the use of the <tt class="docutils literal"><span class="pre">&#64;jsexposed</span></tt> decorator: all this does is set
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
47 the function's <tt class="docutils literal"><span class="pre">__jsexposed__</span></tt> attribute to <tt class="docutils literal"><span class="pre">True</span></tt>. This is
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
48 done for security purposes: only Python callables satisfying this
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
49 criteria will be exposed to JavaScript code, to ensure that
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
50 untrusted JS can't accidentally gain access to privileged Python
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
51 functionality.</p>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
52 <p>Creating a JS object can be done like this:</p>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
53 <blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
54 <pre class="doctest-block">
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
55 &gt;&gt;&gt; system = sandbox.new_object()
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
56 </pre>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
57 </blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
58 <p>We can now access and set properties on this object via either
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
59 item or attribute lookup, just like in JavaScript. Because
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
60 <tt class="docutils literal"><span class="pre">print</span></tt> is a reserved word in Python, though, we'll use item
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
61 lookup to set the property here:</p>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
62 <blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
63 <pre class="doctest-block">
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
64 &gt;&gt;&gt; system['print'] = jsprint
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
65 </pre>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
66 </blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
67 <p>Now we tell the sandbox that we want the <tt class="docutils literal"><span class="pre">sys</span></tt> object to be a
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
68 global:</p>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
69 <blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
70 <pre class="doctest-block">
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
71 &gt;&gt;&gt; sandbox.set_globals(sys = system)
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
72 </pre>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
73 </blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
74 <p>And finally, we execute the compliance test by running a one-line
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
75 script that imports the 'program' module, like so:</p>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
76 <blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
77 <pre class="doctest-block">
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
78 &gt;&gt;&gt; sandbox.run_script(&quot;require('program');&quot;)
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
79 PASS monkeys permitted pass
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
80 DONE info
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
81 0
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
82 </pre>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
83 </blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
84 <p>Note the <tt class="docutils literal"><span class="pre">0</span></tt> in the last line: this is the return value of
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
85 <tt class="docutils literal"><span class="pre">sandbox.run_script()</span></tt>, which returns <tt class="docutils literal"><span class="pre">0</span></tt> on success, and
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
86 <tt class="docutils literal"><span class="pre">-1</span></tt> if an exception was raised. For instance, the output of bad
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
87 code looks like this:</p>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
88 <blockquote>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
89 <pre class="doctest-block">
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
90 &gt;&gt;&gt; sandbox.run_script(&quot;(function foo() { bar(); })();&quot;,
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
91 ... stderr=sys.stdout)
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
92 Traceback (most recent call last):
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
93 File &quot;&lt;string&gt;&quot;, line 1, in &lt;module&gt;
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
94 File &quot;&lt;string&gt;&quot;, line 1, in foo
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
95 ReferenceError: bar is not defined
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
96 -1
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
97 </pre>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
98 </blockquote>
24
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
99 <p>Note that the traceback displayed is actually referring to JavaScript
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
100 code: one of Pydertron's aims is to make debugging JS code as much
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
101 like debugging Python code as possible.</p>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
102 </div>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
103 <div class="section">
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
104 <h1><a id="exceptions" name="exceptions">Exceptions</a></h1>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
105 <p>Any exceptions raised by wrapped Python functions need to be of type
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
106 <tt class="docutils literal"><span class="pre">pydermonkey.error</span></tt> to be propagated into calling JavaScript code;
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
107 if they're not, then for security purposes, the entire JavaScript call
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
108 stack is unrolled.</p>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
109 <p>For example, here's a function that's bound to fail:</p>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
110 <blockquote>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
111 <pre class="doctest-block">
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
112 &gt;&gt;&gt; &#64;jsexposed
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
113 ... def fail():
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
114 ... o()
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
115 &gt;&gt;&gt; sandbox.root.fail = fail
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
116 </pre>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
117 </blockquote>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
118 <p>Now, even though the following JS code calls the function in a
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
119 try-catch block, the JS code doesn't catch anything and its execution
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
120 is simply halted:</p>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
121 <blockquote>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
122 <pre class="doctest-block">
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
123 &gt;&gt;&gt; sandbox.run_script(&quot;try { fail(); } catch (e) {}&quot;,
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
124 ... stderr=sys.stdout) #doctest: +ELLIPSIS
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
125 An internal error occurred.
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
126 Traceback (most recent call last):
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
127 ...
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
128 NameError: global name 'o' is not defined
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
129 -1
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
130 </pre>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
131 </blockquote>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
132 <p>Note that a <tt class="docutils literal"><span class="pre">KeyboardInterrupt</span></tt> triggered while JS is executing will
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
133 have similar effect.</p>
c2c369402a2e Added more docs, fixed edge cases.
Atul Varma <varmaa@toolness.com>
parents: 23
diff changeset
134 </div>
22
915fdf283ac5 Moved docs out to a separate file.
Atul Varma <varmaa@toolness.com>
parents: 21
diff changeset
135 </div>
915fdf283ac5 Moved docs out to a separate file.
Atul Varma <varmaa@toolness.com>
parents: 21
diff changeset
136 <div class="footer">
915fdf283ac5 Moved docs out to a separate file.
Atul Varma <varmaa@toolness.com>
parents: 21
diff changeset
137 <hr class="footer" />
915fdf283ac5 Moved docs out to a separate file.
Atul Varma <varmaa@toolness.com>
parents: 21
diff changeset
138 <a class="reference" href="docs.txt">View document source</a>.
915fdf283ac5 Moved docs out to a separate file.
Atul Varma <varmaa@toolness.com>
parents: 21
diff changeset
139
21
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
140 </div>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
141 </body>
cb73bb169b67 Added html docs.
Atul Varma <varmaa@toolness.com>
parents:
diff changeset
142 </html>