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
d71e3139
Commit
d71e3139
authored
May 11, 2009
by
Tres Seaver
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use more canonical interface names.
parent
21e0cb63
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
125 additions
and
110 deletions
+125
-110
src/Products/Sessions/SessionDataManager.py
src/Products/Sessions/SessionDataManager.py
+2
-2
src/Products/Sessions/SessionInterfaces.py
src/Products/Sessions/SessionInterfaces.py
+123
-108
No files found.
src/Products/Sessions/SessionDataManager.py
View file @
d71e3139
...
...
@@ -32,7 +32,7 @@ from ZPublisher.BeforeTraverse import unregisterBeforeTraverse
from
ZODB.POSException
import
ConflictError
from
zope.interface
import
implements
from
Products.Sessions.SessionInterfaces
import
SessionDataManagerInterface
from
Products.Sessions.SessionInterfaces
import
ISessionDataManager
from
Products.Sessions.SessionPermissions
import
ACCESS_CONTENTS_PERM
from
Products.Sessions.SessionPermissions
import
ACCESS_SESSIONDATA_PERM
from
Products.Sessions.SessionPermissions
import
ARBITRARY_SESSIONDATA_PERM
...
...
@@ -93,7 +93,7 @@ class SessionDataManager(Item, Implicit, Persistent, RoleManager, Owned, Tabs):
icon='
misc_
/
CoreSessionTracking
/
datamgr
.
gif
'
implements(
SessionDataManagerInterface
)
implements(
ISessionDataManager
)
manage_sessiondatamgr = DTMLFile('
dtml
/
manageDataManager
',
globals())
...
...
src/Products/Sessions/SessionInterfaces.py
View file @
d71e3139
...
...
@@ -10,11 +10,9 @@
# FOR A PARTICULAR PURPOSE
#
############################################################################
"""
Session APIs
""" Session APIs
See Also
o
See Also
- "Transient Object API":../../Transience/Help/TransienceInterfaces.py
...
...
@@ -22,36 +20,42 @@ Session APIs
from
zope.interface
import
Interface
class
BrowserIdManagerInterface
(
Interface
):
"""
Zope Browser Id Manager interface.
class
IBrowserIdManager
(
Interface
):
""" Zope Browser Id Manager interface.
A Zope Browser Id Manager is responsible for assigning ids to site
visitors, and for servicing requests from Session Data Managers
related to the browser id.
"""
def
encodeUrl
(
url
,
style
=
'querystring'
):
def
hasBrowserId
():
""" Return true if there is a browser id for the current request.
o Permission required: Access contents information
o Does *not* raise an error if the request contains a broken
browser id.
"""
Encodes a provided URL with the current request's browser id
and returns the result. Two forms of URL-encoding are supported:
'querystring' and 'inline'. 'querystring' is the default.
If the 'querystring' form is used, the browser id name/value pair
are postfixed onto the URL as a query string. If the 'inline'
form is used, the browser id name/value pair are prefixed onto
the URL as the first two path segment elements.
def
getBrowserId
(
create
=
1
):
""" Return a browser id for the current request.
For example:
o If create is false, return None if there is no browser id associated
with the current request.
The call encodeUrl('http://foo.com/amethod', style='querystring')
might return 'http://foo.com/amethod?_ZopeId=as9dfu0adfu0ad'
.
o If create is true, return a newly-created browser id if
there is no browser id associated with the current request
.
The call encodeUrl('http://foo.com/amethod, style='inline')
might return 'http://foo.com/_ZopeId/as9dfu0adfu0ad/amethod'.
o This method is useful in conjunction with 'getBrowserIdName' if you
wish to embed the browser-id-name/browser-id combination as a hidden
value in a POST-based form.
Permission required: Access contents information
o The browser id is opaque, has no business meaning, and its length,
type, and composition are subject to change.
Raises: BrowserIdManagerErr. If there is no current browser id.
o Permission required: Access contents information
o Raises BrowserIdManagerErr if an ill-formed browser id
is found in REQUEST.
"""
def
getBrowserIdName
():
...
...
@@ -63,30 +67,6 @@ class BrowserIdManagerInterface(Interface):
Permission required: Access contents information
"""
def
getBrowserId
(
create
=
1
):
"""
If create=0, returns a the current browser id or None if there
is no browser id associated with the current request. If create=1,
returns the current browser id or a newly-created browser id if
there is no browser id associated with the current request. This
method is useful in conjunction with getBrowserIdName if you wish to
embed the browser-id-name/browser-id combination as a hidden value in
a POST-based form. The browser id is opaque, has no business meaning,
and its length, type, and composition are subject to change.
Permission required: Access contents information
Raises: BrowserIdManagerErr. If ill-formed browser id
is found in REQUEST.
"""
def
hasBrowserId
():
"""
Returns true if there is a browser id for this request.
Permission required: Access contents information
"""
def
isBrowserIdNew
():
"""
Returns true if browser id is 'new'. A browser id is 'new'
...
...
@@ -98,61 +78,94 @@ class BrowserIdManagerInterface(Interface):
Raises: BrowserIdManagerErr. If there is no current browser id.
"""
def
isBrowserIdFromForm
():
"""
Returns true if browser id comes from a form variable (query
string or post).
def
isBrowserIdFromCookie
():
""" Return true if browser id comes from a cookie.
Permission required: Access contents information
o
Permission required: Access contents information
Raises: BrowserIdManagerErr. I
f there is no current browser id.
o Raise BrowserIdManagerErr i
f there is no current browser id.
"""
def
isBrowserIdFromCookie
():
def
isBrowserIdFromForm
():
""" Return true if browser id comes from a form variable.
o Variable may come from either the query string or a post.
o Permission required: Access contents information
o Raise BrowserIdManagerErr if there is no current browser id.
"""
Returns true if browser id comes from a cookie.
Permission required: Access contents information
def
isBrowserIdFromUrl
():
""" Return true if browser id comes from a cookie.
Raises: BrowserIdManagerErr. If there is no current browser id.
o Permission required: Access contents information
o Raise BrowserIdManagerErr if there is no current browser id.
"""
def
flushBrowserIdCookie
():
"""
Deletes the browser id cookie from the client browser, iff the
'cookies' browser id namespace is being used.
""" Deletes the browser id cookie from the client browser.
Permission required: Access contents information
o
Permission required: Access contents information
Raises: BrowserIdManagerErr. I
f the 'cookies' namespace isn't
a browser id namespace at the time of the call
.
o Raise BrowserIdManagerErr i
f the 'cookies' namespace isn't
a browser id namespace
.
"""
def
setBrowserIdCookieByForce
(
bid
):
"""
Sets the browser id cookie to browser id 'bid' by force.
Useful when you need to 'chain' browser id cookies across domains
"""
Sets the browser id cookie to browser id 'bid' by force.
o
Useful when you need to 'chain' browser id cookies across domains
for the same user (perhaps temporarily using query strings).
Permission required: Access contents information
o
Permission required: Access contents information
Raises: BrowserIdManagerErr. I
f the 'cookies' namespace isn't
a browser id namespace at the time of the call
.
o Raise BrowserIdManagerErr i
f the 'cookies' namespace isn't
a browser id namespace
.
"""
def
getHiddenFormField
():
"""
Returns a string in the form:
""" Return a string usable as a hidden form field for the browser id.
o String is of the form::
<input type="hidden" name="_ZopeId" value="H7HJGYUFGFyHKH*"
>
<input type="hidden" name="_ZopeId" value="H7HJGYUFGFyHKH*" /
>
Where the
name and the value represent the current browser id
o
name and the value represent the current browser id
name and current browser id.
"""
class
SessionDataManagerInterface
(
Interface
):
def
encodeUrl
(
url
,
style
=
'querystring'
):
""" Encode a given URL with the current browser id.
o Two forms of URL-encoding are supported: 'querystring' and 'inline'.
o 'querystring' is the default.
o If the 'querystring' form is used, the browser id name/value pair
are postfixed onto the URL as a query string.
o If the 'inline' form is used, the browser id name/value pair
are prefixed onto the URL as the first two path segment elements.
o For example:
- The call encodeUrl('http://foo.com/amethod', style='querystring')
might return 'http://foo.com/amethod?_ZopeId=as9dfu0adfu0ad'.
- The call encodeUrl('http://foo.com/amethod, style='inline')
might return 'http://foo.com/_ZopeId/as9dfu0adfu0ad/amethod'.
o Permission required: Access contents information
o Raise BrowserIdManagerErr if there is no current browser id.
"""
Zope Session Data Manager interface.
BrowserIdManagerInterface
=
IBrowserIdManager
# BBB
class
ISessionDataManager
(
Interface
):
""" Zope Session Data Manager interface.
A Zope Session Data Manager is responsible for maintaining Session
Data Objects, and for servicing requests from application code
...
...
@@ -160,58 +173,60 @@ class SessionDataManagerInterface(Interface):
Id Manager to provide information about browser ids.
"""
def
getBrowserIdManager
():
"""
Returns the nearest acquirable browser id manager.
""" Return the nearest acquirable browser id manager.
Raises
SessionDataManagerErr if no browser id manager can be found.
o Raise
SessionDataManagerErr if no browser id manager can be found.
Permission required: Access session data
o
Permission required: Access session data
"""
def
getSessionData
(
create
=
1
):
"""
Returns a Session Data Object associated with the current
browser id. If there is no current browser id, and create is true,
returns a new Session Data Object. If there is no current
browser id and create is false, returns None.
""" Return a Session Data Object for the current browser id.
o If there is no current browser id, and create is true,
return a new Session Data Object.
o If there is no current browser id and create is false, returns None.
Permission required: Access session data
o
Permission required: Access session data
"""
def
hasSessionData
():
"""
Returns true if a Session Data Object associated with the
current browser id is found in the Session Data Container. Does
not create a Session Data Object if one does not exist.
""" Does a Session Data Object exist for the current browser id?
o Do not create a Session Data Object if one does not exist.
Permission required: Access session data
o
Permission required: Access session data
"""
def
getSessionDataByKey
(
key
):
"""
Returns a Session Data Object associated with 'key'. If there is
no Session Data Object associated with 'key' return None.
""" Return a Session Data Object associated with 'key'.
Permission required: Access arbitrary user session data
"""
o If there is no Session Data Object associated with 'key',
return None.
class
SessionDataManagerErr
(
Interface
):
o Permission required: Access arbitrary user session data
"""
Error raised during some session data manager operations, as
explained in the API documentation of the Session Data Manager.
This exception may be caught in PythonScripts. A successful
SessionDataManagerInterface
=
ISessionDataManager
# BBB
class
SessionDataManagerErr
(
ValueError
):
""" Error raised during some session data manager operations
o See ISesseionDataManager.
o This exception may be caught in PythonScripts. A successful
import of the exception for PythonScript use would need to be::
from Products.Sessions import SessionDataManagerErr
"""
class
BrowserIdManagerErr
(
Interface
):
"""
Error raised during some browser id manager operations, as
explained in the API documentation of the Browser Id Manager
.
class
BrowserIdManagerErr
(
ValueError
):
"""
Error raised during some browser id manager operations
o See IBrowserIdManager methods
.
This exception may be caught in PythonScripts. A successful
o
This exception may be caught in PythonScripts. A successful
import of the exception for PythonScript use would need to be::
from Products.Sessions import BrowserIdManagerErr
...
...
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