Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Z
Zope
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
Zope
Commits
55a1f96e
Commit
55a1f96e
authored
Dec 07, 2000
by
Evan Simpson
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added details
parent
2cb1d1f1
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
51 additions
and
22 deletions
+51
-22
lib/python/Products/PythonScripts/help/PythonScript.py
lib/python/Products/PythonScripts/help/PythonScript.py
+51
-22
No files found.
lib/python/Products/PythonScripts/help/PythonScript.py
View file @
55a1f96e
...
@@ -92,9 +92,9 @@ class PythonScript:
...
@@ -92,9 +92,9 @@ class PythonScript:
o Calling the script through the web by going to its location with a
o Calling the script through the web by going to its location with a
web browser.
web browser.
o Calling the script from another script object
s
.
o Calling the script from another script object.
o Calling the script from a method object.
o Calling the script from a method object
, such as a DTML Method
.
Python scripts can contain a "safe" subset of the python language.
Python scripts can contain a "safe" subset of the python language.
Python Scripts must be safe because they can be potentially edited by
Python Scripts must be safe because they can be potentially edited by
...
@@ -122,7 +122,9 @@ class PythonScript:
...
@@ -122,7 +122,9 @@ class PythonScript:
o math
o math
o XXX
o whrandom and random
o Products.PythonScripts.standard
o Because it allows you to execute arbitrary python code, the python
o Because it allows you to execute arbitrary python code, the python
"exec" statement is not allowed in Python methods.
"exec" statement is not allowed in Python methods.
...
@@ -131,9 +133,15 @@ class PythonScript:
...
@@ -131,9 +133,15 @@ class PythonScript:
Python builtin functions are not allowed or are restricted. The
Python builtin functions are not allowed or are restricted. The
following Python builtins are not allowed:
following Python builtins are not allowed:
o open
o open, input, raw_input
o eval, execfile, compile
o type, coerce, intern
o XXX
o dir, globals, locals, vars
o buffer, reduce
Other builtins are restricted in nature. The following builtins
Other builtins are restricted in nature. The following builtins
are restricted:
are restricted:
...
@@ -142,15 +150,29 @@ class PythonScript:
...
@@ -142,15 +150,29 @@ class PythonScript:
range builtin is restricted to creating ranges less than 10,000
range builtin is restricted to creating ranges less than 10,000
elements long.
elements long.
getattr -- Because getattr may enable Python code to circumvent
filter, map, tuple, list -- For the same reason, builtins
Zope's security system, the getattr builtin is replaced with a
that construct lists from sequences do not operate on strings.
custom, security constrained version.
getattr, setattr, delattr -- Because these may enable Python
code to circumvent Zope's security system, they are replaced with
custom, security constrained versions.
o In order to be consistent with the Python expressions
available to DTML, the builtin functions are augmented with a
small number of functions and a class:
o test, namespace, render
XXX -- XXX
o same_type
o XXX
o DateTime
XXX
o Because the "print" statement cannot operate normally in Zope,
its effect has been changed. Rather than sending text to
stdout, "print" appends to an internal variable. The special
builtin name "printed" evaluates to the concatenation of all
text printed so far during the current execution of the
script.
"""
"""
...
@@ -168,9 +190,9 @@ class PythonScript:
...
@@ -168,9 +190,9 @@ class PythonScript:
params -- The new value of the Python Script's parameters. Must
params -- The new value of the Python Script's parameters. Must
be a comma seperated list of values in valid python function
be a comma seperated list of values in valid python function
signature syntax. If it does not contain a valid signature
signature syntax. If it does not contain a valid signature
string, a
XXX
Error is raised.
string, a
Syntax
Error is raised.
body -- T
H
e new value of the Python Script's body. Must contain
body -- T
h
e new value of the Python Script's body. Must contain
valid Python syntax. If it does not contain valid Python syntax,
valid Python syntax. If it does not contain valid Python syntax,
a SyntaxError is raised.
a SyntaxError is raised.
...
@@ -194,9 +216,9 @@ class PythonScript:
...
@@ -194,9 +216,9 @@ class PythonScript:
params -- The new value of the Python Script's parameters. Must
params -- The new value of the Python Script's parameters. Must
be a comma seperated list of values in valid python function
be a comma seperated list of values in valid python function
signature syntax. If it does not contain a valid signature
signature syntax. If it does not contain a valid signature
string, a
XXX
Error is raised.
string, a
Syntax
Error is raised.
body -- T
H
e new value of the Python Script's body. Must contain
body -- T
h
e new value of the Python Script's body. Must contain
valid Python syntax. If it does not contain valid Python syntax,
valid Python syntax. If it does not contain valid Python syntax,
a SyntaxError is raised.
a SyntaxError is raised.
...
@@ -205,7 +227,7 @@ class PythonScript:
...
@@ -205,7 +227,7 @@ class PythonScript:
def
ZPythonScriptHTML_upload
(
REQUEST
,
file
=
''
):
def
ZPythonScriptHTML_upload
(
REQUEST
,
file
=
''
):
"""
"""
Replace the body of the script with the text in file
.
Pass the text in file to the 'write' method
.
"""
"""
...
@@ -213,8 +235,8 @@ class PythonScript:
...
@@ -213,8 +235,8 @@ class PythonScript:
def
ZScriptHTML_tryParams
(
self
):
def
ZScriptHTML_tryParams
(
self
):
"""
"""
This method returns a list containing the required parameters
to
Return a list of the required parameters with which
to
test the script
with
.
test the script.
"""
"""
...
@@ -222,21 +244,28 @@ class PythonScript:
...
@@ -222,21 +244,28 @@ class PythonScript:
def
read
(
self
):
def
read
(
self
):
"""
"""
XXX
Return the body of the Python Script, with a special comment
block prepended. This block contains meta-data in the form of
comment lines as expected by the 'write' method.
"""
"""
def
params
(
self
):
def
write
(
self
,
text
):
"""
"""
XXX
Change the script by parsing the text argument into parts.
Leading lines that begin with '##' are stripped off, and if
they are of the form '##name=value', they are used to set
meta-data such as the title and parameters. The remainder of
the text is set as the body of the Python Script.
"""
"""
def
document_src
(
REQUEST
=
None
,
RESPONSE
=
None
):
def
document_src
(
REQUEST
=
None
,
RESPONSE
=
None
):
"""
"""
Return unprocessed document source.
Return the text of the 'read' method, with content type
'text/plain' set on the RESPONSE.
"""
"""
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment