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
40940438
Commit
40940438
authored
Dec 13, 2000
by
Shane Hathaway
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Made Python Scripts cacheable.
parent
2714c5ce
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
38 additions
and
4 deletions
+38
-4
lib/python/Products/PythonScripts/PythonScript.py
lib/python/Products/PythonScripts/PythonScript.py
+38
-4
No files found.
lib/python/Products/PythonScripts/PythonScript.py
View file @
40940438
...
@@ -89,7 +89,7 @@ This product provides support for Script objects containing restricted
...
@@ -89,7 +89,7 @@ This product provides support for Script objects containing restricted
Python code.
Python code.
"""
"""
__version__
=
'$Revision: 1.
3
$'
[
11
:
-
2
]
__version__
=
'$Revision: 1.
4
$'
[
11
:
-
2
]
import
sys
,
os
,
traceback
,
re
import
sys
,
os
,
traceback
,
re
from
Globals
import
MessageDialog
,
HTMLFile
,
package_home
from
Globals
import
MessageDialog
,
HTMLFile
,
package_home
...
@@ -102,11 +102,14 @@ from Bindings import Bindings, defaultBindings
...
@@ -102,11 +102,14 @@ from Bindings import Bindings, defaultBindings
from
Script
import
Script
from
Script
import
Script
from
AccessControl
import
getSecurityManager
from
AccessControl
import
getSecurityManager
from
OFS.History
import
Historical
,
html_diff
from
OFS.History
import
Historical
,
html_diff
from
OFS.Cache
import
Cacheable
from
zLOG
import
LOG
,
ERROR
,
INFO
from
zLOG
import
LOG
,
ERROR
,
INFO
_www
=
os
.
path
.
join
(
package_home
(
globals
()),
'www'
)
_www
=
os
.
path
.
join
(
package_home
(
globals
()),
'www'
)
manage_addPythonScriptForm
=
HTMLFile
(
'pyScriptAdd'
,
_www
)
manage_addPythonScriptForm
=
HTMLFile
(
'pyScriptAdd'
,
_www
)
_marker
=
[]
# Create a new marker object
def
manage_addPythonScript
(
self
,
id
,
REQUEST
=
None
):
def
manage_addPythonScript
(
self
,
id
,
REQUEST
=
None
):
"""Add a Python script to a folder.
"""Add a Python script to a folder.
"""
"""
...
@@ -123,7 +126,7 @@ def manage_addPythonScript(self, id, REQUEST=None):
...
@@ -123,7 +126,7 @@ def manage_addPythonScript(self, id, REQUEST=None):
return
''
return
''
class
PythonScript
(
Script
,
Historical
):
class
PythonScript
(
Script
,
Historical
,
Cacheable
):
"""Web-callable scripts written in a safe subset of Python.
"""Web-callable scripts written in a safe subset of Python.
The function may include standard python code, so long as it does
The function may include standard python code, so long as it does
...
@@ -141,7 +144,8 @@ class PythonScript(Script, Historical):
...
@@ -141,7 +144,8 @@ class PythonScript(Script, Historical):
)
+
Bindings
.
manage_options
+
(
)
+
Bindings
.
manage_options
+
(
{
'label'
:
'Try It'
,
'action'
:
'ZScriptHTML_tryForm'
},
{
'label'
:
'Try It'
,
'action'
:
'ZScriptHTML_tryForm'
},
{
'label'
:
'Proxy'
,
'action'
:
'manage_proxyForm'
},
{
'label'
:
'Proxy'
,
'action'
:
'manage_proxyForm'
},
)
+
Historical
.
manage_options
+
SimpleItem
.
manage_options
)
+
Historical
.
manage_options
+
SimpleItem
.
manage_options
+
\
Cacheable
.
manage_options
__ac_permissions__
=
(
__ac_permissions__
=
(
(
'View management screens'
,
(
'View management screens'
,
...
@@ -180,9 +184,11 @@ class PythonScript(Script, Historical):
...
@@ -180,9 +184,11 @@ class PythonScript(Script, Historical):
def
ZPythonScript_setTitle
(
self
,
title
):
def
ZPythonScript_setTitle
(
self
,
title
):
self
.
title
=
str
(
title
)
self
.
title
=
str
(
title
)
self
.
ZCacheable_invalidate
()
def
ZPythonScript_edit
(
self
,
params
,
body
):
def
ZPythonScript_edit
(
self
,
params
,
body
):
self
.
_validateProxy
()
self
.
_validateProxy
()
self
.
ZCacheable_invalidate
()
if
type
(
body
)
is
not
type
(
''
):
if
type
(
body
)
is
not
type
(
''
):
body
=
body
.
read
()
body
=
body
.
read
()
if
self
.
_params
<>
params
or
self
.
_body
<>
body
:
if
self
.
_params
<>
params
or
self
.
_body
<>
body
:
...
@@ -274,6 +280,7 @@ class PythonScript(Script, Historical):
...
@@ -274,6 +280,7 @@ class PythonScript(Script, Historical):
__builtins__=safebin)
__builtins__=safebin)
def _editedBindings(self):
def _editedBindings(self):
self.ZCacheable_invalidate()
f = getattr(self, '
_v_f
', None)
f = getattr(self, '
_v_f
', None)
if f is None:
if f is None:
return
return
...
@@ -284,6 +291,26 @@ class PythonScript(Script, Historical):
...
@@ -284,6 +291,26 @@ class PythonScript(Script, Historical):
Calling a Python Script is an actual function invocation.
Calling a Python Script is an actual function invocation.
"""
"""
# Retrieve the value from the cache.
keyset = None
if self.ZCacheable_isCachingEnabled():
# Prepare a cache key.
keyset = kw.copy()
asgns = self.getBindingAssignments()
name_context = asgns.getAssignedName('
name_context
', None)
if name_context:
keyset[name_context] = self.aq_parent.getPhysicalPath()
name_subpath = asgns.getAssignedName('
name_subpath
', None)
if name_subpath:
keyset[name_subpath] = self._getTraverseSubpath()
# Note: perhaps we should cache based on name_ns also.
keyset['
*
'] = args
result = self.ZCacheable_get(keywords=keyset, default=_marker)
if result is not _marker:
# Got a cached value.
return result
# Prepare the function.
f = getattr(self, '
_v_f
', None)
f = getattr(self, '
_v_f
', None)
if f is None:
if f is None:
f = self._makeFunction()
f = self._makeFunction()
...
@@ -294,10 +321,15 @@ class PythonScript(Script, Historical):
...
@@ -294,10 +321,15 @@ class PythonScript(Script, Historical):
# Updating func_globals directly *should* be thread-safe.
# Updating func_globals directly *should* be thread-safe.
f.func_globals.update(globals)
f.func_globals.update(globals)
# Execute the function in a new security context.
security=getSecurityManager()
security=getSecurityManager()
security.addContext(self)
security.addContext(self)
try:
try:
return apply(f, args, kw)
result = apply(f, args, kw)
if keyset is not None:
# Store the result in the cache.
self.ZCacheable_set(result, keywords=keyset)
return result
finally:
finally:
security.removeContext(self)
security.removeContext(self)
...
@@ -323,6 +355,7 @@ class PythonScript(Script, Historical):
...
@@ -323,6 +355,7 @@ class PythonScript(Script, Historical):
"Change Proxy Roles"
"Change Proxy Roles"
self._validateProxy(roles)
self._validateProxy(roles)
self._validateProxy()
self._validateProxy()
self.ZCacheable_invalidate()
self._proxy_roles=tuple(roles)
self._proxy_roles=tuple(roles)
if REQUEST: return MessageDialog(
if REQUEST: return MessageDialog(
title ='
Success
!
',
title ='
Success
!
',
...
@@ -340,6 +373,7 @@ class PythonScript(Script, Historical):
...
@@ -340,6 +373,7 @@ class PythonScript(Script, Historical):
def write(self, text):
def write(self, text):
self._validateProxy()
self._validateProxy()
self.ZCacheable_invalidate()
mdata = self._metadata_map()
mdata = self._metadata_map()
bindmap = self.getBindingAssignments().getAssignedNames()
bindmap = self.getBindingAssignments().getAssignedNames()
bup = 0
bup = 0
...
...
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