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
c7b3ce26
Commit
c7b3ce26
authored
Nov 20, 2001
by
Chris McDonough
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added 'setBrowserIdCookieByForce' method (thanks to Richard Jones).
parent
04d96d0d
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
55 additions
and
8 deletions
+55
-8
lib/python/Products/Sessions/BrowserIdManager.py
lib/python/Products/Sessions/BrowserIdManager.py
+10
-1
lib/python/Products/Sessions/SessionInterfaces.py
lib/python/Products/Sessions/SessionInterfaces.py
+12
-0
lib/python/Products/Sessions/help/SessionInterfaces.py
lib/python/Products/Sessions/help/SessionInterfaces.py
+12
-0
lib/python/Products/Sessions/tests/testBrowserIdManager.py
lib/python/Products/Sessions/tests/testBrowserIdManager.py
+21
-7
No files found.
lib/python/Products/Sessions/BrowserIdManager.py
View file @
c7b3ce26
...
@@ -75,7 +75,7 @@
...
@@ -75,7 +75,7 @@
#
#
############################################################################
############################################################################
__version__
=
'$Revision: 1.
4
$'
[
11
:
-
2
]
__version__
=
'$Revision: 1.
5
$'
[
11
:
-
2
]
import
Globals
import
Globals
from
Persistence
import
Persistent
from
Persistence
import
Persistent
from
ZODB
import
TimeStamp
from
ZODB
import
TimeStamp
...
@@ -219,6 +219,15 @@ class BrowserIdManager(Item, Persistent, Implicit, RoleManager, Owned, Tabs):
...
@@ -219,6 +219,15 @@ class BrowserIdManager(Item, Persistent, Implicit, RoleManager, Owned, Tabs):
'browserid cookie cannot be flushed.')
'browserid cookie cannot be flushed.')
self._setCookie('deleted', self.REQUEST, remove=1)
self._setCookie('deleted', self.REQUEST, remove=1)
security.declareProtected(ACCESS_CONTENTS_PERM,'setBrowserIdCookieByForce')
def setBrowserIdCookieByForce(self, bid):
"""
"""
if 'cookies' not in self.browserid_namespaces:
raise BrowserIdManagerErr,('Cookies are not now being used as a '
'browser id namespace, thus the '
'browserid cookie cannot be forced.')
self._setCookie(bid, self.REQUEST)
security.declareProtected(ACCESS_CONTENTS_PERM, 'isBrowserIdFromCookie')
security.declareProtected(ACCESS_CONTENTS_PERM, 'isBrowserIdFromCookie')
def isBrowserIdFromCookie(self):
def isBrowserIdFromCookie(self):
"""
returns
true
if
browser
id
is
from
REQUEST
.
cookies
"""
"""
returns
true
if
browser
id
is
from
REQUEST
.
cookies
"""
...
...
lib/python/Products/Sessions/SessionInterfaces.py
View file @
c7b3ce26
...
@@ -184,6 +184,18 @@ class BrowserIdManagerInterface(
...
@@ -184,6 +184,18 @@ class BrowserIdManagerInterface(
a browser id namespace at the time of the call.
a browser id namespace at the time of the call.
"""
"""
def
setBrowserIdCookieByForce
(
self
,
bid
):
"""
Sets the browser id cookie to browser id 'bid' by force.
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
Raises: BrowserIdManagerErr. If the 'cookies' namespace isn't
a browser id namespace at the time of the call.
"""
class
SessionDataManagerInterface
(
class
SessionDataManagerInterface
(
Interface
.
Base
Interface
.
Base
):
):
...
...
lib/python/Products/Sessions/help/SessionInterfaces.py
View file @
c7b3ce26
...
@@ -180,6 +180,18 @@ class BrowserIdManagerInterface(
...
@@ -180,6 +180,18 @@ class BrowserIdManagerInterface(
a browser id namespace at the time of the call.
a browser id namespace at the time of the call.
"""
"""
def
setBrowserIdCookieByForce
(
self
,
bid
):
"""
Sets the browser id cookie to browser id 'bid' by force.
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
Raises: BrowserIdManagerErr. If the 'cookies' namespace isn't
a browser id namespace at the time of the call.
"""
class
SessionDataManagerInterface
(
class
SessionDataManagerInterface
(
Interface
.
Base
Interface
.
Base
):
):
...
...
lib/python/Products/Sessions/tests/testBrowserIdManager.py
View file @
c7b3ce26
...
@@ -85,9 +85,9 @@
...
@@ -85,9 +85,9 @@
"""
"""
Test suite for session id manager.
Test suite for session id manager.
$Id: testBrowserIdManager.py,v 1.
3 2001/11/17 16:07:41
chrism Exp $
$Id: testBrowserIdManager.py,v 1.
4 2001/11/20 16:08:10
chrism Exp $
"""
"""
__version__
=
"$Revision: 1.
3
$"
[
11
:
-
2
]
__version__
=
"$Revision: 1.
4
$"
[
11
:
-
2
]
import
sys
import
sys
if
__name__
==
"__main__"
:
if
__name__
==
"__main__"
:
...
@@ -258,12 +258,12 @@ class TestBrowserIdManager(TestCase):
...
@@ -258,12 +258,12 @@ class TestBrowserIdManager(TestCase):
b
=
self
.
m
.
REQUEST
.
RESPONSE
.
cookies
[
tokenkey
]
b
=
self
.
m
.
REQUEST
.
RESPONSE
.
cookies
[
tokenkey
]
assert
a
==
b
[
'value'
],
(
a
,
b
)
assert
a
==
b
[
'value'
],
(
a
,
b
)
def
testHas
Token
(
self
):
def
testHas
BrowserId
(
self
):
assert
not
self
.
m
.
hasBrowserId
()
assert
not
self
.
m
.
hasBrowserId
()
a
=
self
.
m
.
getBrowserId
()
a
=
self
.
m
.
getBrowserId
()
assert
self
.
m
.
hasBrowserId
()
assert
self
.
m
.
hasBrowserId
()
def
test
Token
IsNew
(
self
):
def
test
BrowserId
IsNew
(
self
):
a
=
self
.
m
.
getBrowserId
()
a
=
self
.
m
.
getBrowserId
()
assert
self
.
m
.
isBrowserIdNew
()
assert
self
.
m
.
isBrowserIdNew
()
...
@@ -287,7 +287,7 @@ class TestBrowserIdManager(TestCase):
...
@@ -287,7 +287,7 @@ class TestBrowserIdManager(TestCase):
a
=
self
.
m
.
getBrowserId
()
a
=
self
.
m
.
getBrowserId
()
assert
self
.
m
.
isBrowserIdFromForm
()
assert
self
.
m
.
isBrowserIdFromForm
()
def
testIs
Token
FromCookieOnly
(
self
):
def
testIs
BrowserId
FromCookieOnly
(
self
):
token
=
self
.
m
.
getBrowserId
()
token
=
self
.
m
.
getBrowserId
()
self
.
m
.
REQUEST
.
browser_id_
=
token
self
.
m
.
REQUEST
.
browser_id_
=
token
self
.
m
.
REQUEST
.
browser_id_ns_
=
'cookies'
self
.
m
.
REQUEST
.
browser_id_ns_
=
'cookies'
...
@@ -298,7 +298,7 @@ class TestBrowserIdManager(TestCase):
...
@@ -298,7 +298,7 @@ class TestBrowserIdManager(TestCase):
assert
self
.
m
.
isBrowserIdFromCookie
()
assert
self
.
m
.
isBrowserIdFromCookie
()
assert
not
self
.
m
.
isBrowserIdFromForm
()
assert
not
self
.
m
.
isBrowserIdFromForm
()
def
testIs
Token
FromFormOnly
(
self
):
def
testIs
BrowserId
FromFormOnly
(
self
):
token
=
self
.
m
.
getBrowserId
()
token
=
self
.
m
.
getBrowserId
()
self
.
m
.
REQUEST
.
browser_id_
=
token
self
.
m
.
REQUEST
.
browser_id_
=
token
self
.
m
.
REQUEST
.
browser_id_ns_
=
'form'
self
.
m
.
REQUEST
.
browser_id_ns_
=
'form'
...
@@ -309,7 +309,7 @@ class TestBrowserIdManager(TestCase):
...
@@ -309,7 +309,7 @@ class TestBrowserIdManager(TestCase):
assert
not
self
.
m
.
isBrowserIdFromCookie
()
assert
not
self
.
m
.
isBrowserIdFromCookie
()
assert
self
.
m
.
isBrowserIdFromForm
()
assert
self
.
m
.
isBrowserIdFromForm
()
def
testFlush
Token
Cookie
(
self
):
def
testFlush
BrowserId
Cookie
(
self
):
token
=
self
.
m
.
getBrowserId
()
token
=
self
.
m
.
getBrowserId
()
self
.
m
.
REQUEST
.
browser_id_
=
token
self
.
m
.
REQUEST
.
browser_id_
=
token
self
.
m
.
REQUEST
.
browser_id_ns_
=
'cookies'
self
.
m
.
REQUEST
.
browser_id_ns_
=
'cookies'
...
@@ -322,6 +322,20 @@ class TestBrowserIdManager(TestCase):
...
@@ -322,6 +322,20 @@ class TestBrowserIdManager(TestCase):
c
=
self
.
m
.
REQUEST
.
RESPONSE
.
cookies
[
tokenkey
]
c
=
self
.
m
.
REQUEST
.
RESPONSE
.
cookies
[
tokenkey
]
assert
c
[
'value'
]
==
'deleted'
,
c
assert
c
[
'value'
]
==
'deleted'
,
c
def
testSetBrowserIdCookieByForce
(
self
):
token
=
self
.
m
.
getBrowserId
()
self
.
m
.
REQUEST
.
browser_id_
=
token
self
.
m
.
REQUEST
.
browser_id_ns_
=
'cookies'
tokenkey
=
self
.
m
.
getBrowserIdName
()
self
.
m
.
REQUEST
.
cookies
[
tokenkey
]
=
token
a
=
self
.
m
.
getBrowserId
()
assert
a
==
token
,
repr
(
a
)
assert
self
.
m
.
isBrowserIdFromCookie
()
token
=
'abcdefghijk'
self
.
m
.
setBrowserIdCookieByForce
(
token
)
c
=
self
.
m
.
REQUEST
.
RESPONSE
.
cookies
[
tokenkey
]
assert
c
[
'value'
]
==
token
,
c
def
testEncodeUrl
(
self
):
def
testEncodeUrl
(
self
):
keystring
=
self
.
m
.
getBrowserIdName
()
keystring
=
self
.
m
.
getBrowserIdName
()
key
=
self
.
m
.
getBrowserId
()
key
=
self
.
m
.
getBrowserId
()
...
...
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