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
2f63d12a
Commit
2f63d12a
authored
Sep 24, 1998
by
Jim Fulton
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
added Draft objects
parent
c8788e84
Changes
12
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
247 additions
and
454 deletions
+247
-454
lib/python/Products/OFSP/Draft.py
lib/python/Products/OFSP/Draft.py
+105
-0
lib/python/Products/OFSP/DraftFolder.py
lib/python/Products/OFSP/DraftFolder.py
+0
-240
lib/python/Products/OFSP/DraftFolderSupervisor.dtml
lib/python/Products/OFSP/DraftFolderSupervisor.dtml
+0
-131
lib/python/Products/OFSP/Session.py
lib/python/Products/OFSP/Session.py
+24
-3
lib/python/Products/OFSP/Setup
lib/python/Products/OFSP/Setup
+4
-4
lib/python/Products/OFSP/Version.py
lib/python/Products/OFSP/Version.py
+24
-3
lib/python/Products/OFSP/__init__.py
lib/python/Products/OFSP/__init__.py
+15
-16
lib/python/Products/OFSP/draftAdd.dtml
lib/python/Products/OFSP/draftAdd.dtml
+37
-0
lib/python/Products/OFSP/draftApprove.dtml
lib/python/Products/OFSP/draftApprove.dtml
+34
-0
lib/python/Products/OFSP/draftFolderAdd.dtml
lib/python/Products/OFSP/draftFolderAdd.dtml
+0
-53
lib/python/Products/OFSP/session.dtml
lib/python/Products/OFSP/session.dtml
+2
-2
lib/python/Products/OFSP/version.dtml
lib/python/Products/OFSP/version.dtml
+2
-2
No files found.
lib/python/Products/OFSP/Draft.py
0 → 100644
View file @
2f63d12a
#!/bin/env python
##############################################################################
#
# Copyright
#
# Copyright 1996 Digital Creations, L.C., 910 Princess Anne
# Street, Suite 300, Fredericksburg, Virginia 22401 U.S.A. All
# rights reserved.
#
##############################################################################
import
Globals
,
AccessControl
.
User
from
Globals
import
Persistent
from
Acquisition
import
Implicit
from
OFS
import
SimpleItem
from
string
import
rfind
manage_addPrincipiaDraftForm
=
Globals
.
HTMLFile
(
'draftAdd'
,
globals
())
def
manage_addPrincipiaDraft
(
self
,
id
,
baseid
,
PATH_INFO
,
REQUEST
=
None
):
"Add a draft object"
self
.
_setObject
(
id
,
Draft
(
id
,
baseid
,
PATH_INFO
))
if
REQUEST
is
not
None
:
return
self
.
manage_main
(
self
,
REQUEST
)
class
Draft
(
Persistent
,
Implicit
,
SimpleItem
.
Item
):
"Daft objects"
_refid
=
''
_session
=
'/session'
icon
=
'misc_/OFSP/draft'
meta_type
=
'Principia Draft'
__ac_permissions__
=
(
(
'Approve draft changes'
,
[
'manage_approve__draft__'
,
'manage_Save__draft__'
,
'manage_Discard__draft__'
]
),
)
def
__init__
(
self
,
id
,
baseid
,
PATH_INFO
):
self
.
id
=
id
self
.
_refid
=
baseid
session
=
PATH_INFO
l
=
rfind
(
session
,
'/'
)
if
l
>=
0
:
session
=
session
[:
l
]
self
.
_session
=
"%s/%s"
%
(
session
,
id
)
self
.
users__draft__
=
uf
=
AccessControl
.
User
.
UserFolder
()
self
.
__allow_groups__
=
uf
def
icon
(
self
):
return
getattr
(
self
.
aq_parent
.
aq_base
,
self
.
_refid
).
icon
def
manage_options
(
self
):
return
getattr
(
self
.
aq_parent
.
aq_base
,
self
.
_refid
).
manage_options
def
title
(
self
):
return
'draft of '
+
self
.
_refid
def
title_and_id
(
self
):
nonempty
=
self
.
nonempty
()
if
nonempty
:
return
(
'draft of %s (%s)'
'</a> <a href="%s/users__draft__/manage_main">[Users]'
'</a> <a href="%s/manage_approve__draft__">[Approve]'
%
(
self
.
_refid
,
self
.
id
,
self
.
id
,
self
.
id
,
))
else
:
return
(
'draft of %s (%s)'
'</a> <a href="%s/users__draft__/manage_main">[Users]'
%
(
self
.
_refid
,
self
.
id
,
self
.
id
,
))
def
__bobo_traverse__
(
self
,
REQUEST
,
name
):
if
name
[
-
9
:]
==
'__draft__'
:
return
getattr
(
self
,
name
)
dself
=
getdraft
(
self
,
self
.
_session
)
ref
=
getattr
(
dself
.
aq_parent
.
aq_base
,
dself
.
_refid
).
aq_base
.
__of__
(
dself
)
if
hasattr
(
ref
,
name
):
return
dself
,
ref
,
getattr
(
ref
,
name
)
return
getattr
(
self
,
name
)
def
nonempty
(
self
):
return
Globals
.
SessionBase
[
self
.
_session
].
nonempty
()
manage_approve__draft__
=
Globals
.
HTMLFile
(
'draftApprove'
,
globals
())
def
manage_Save__draft__
(
self
,
remark
,
REQUEST
=
None
):
"""Make session changes permanent"""
Globals
.
SessionBase
[
self
.
_session
].
commit
(
remark
)
if
REQUEST
:
REQUEST
[
'RESPONSE'
].
redirect
(
REQUEST
[
'URL2'
]
+
'/manage_main'
)
def
manage_Discard__draft__
(
self
,
REQUEST
=
None
):
'Discard changes made during the session'
Globals
.
SessionBase
[
self
.
_session
].
abort
()
if
REQUEST
:
REQUEST
[
'RESPONSE'
].
redirect
(
REQUEST
[
'URL2'
]
+
'/manage_main'
)
def
getdraft
(
ob
,
session
):
if
hasattr
(
ob
,
'aq_parent'
):
return
getdraft
(
ob
.
aq_self
,
session
).
__of__
(
getdraft
(
ob
.
aq_parent
,
session
))
if
hasattr
(
ob
,
'_p_oid'
):
ob
=
Globals
.
SessionBase
[
session
].
jar
[
ob
.
_p_oid
]
return
ob
lib/python/Products/OFSP/DraftFolder.py
deleted
100644 → 0
View file @
c8788e84
#!/bin/env python
##############################################################################
#
# Copyright
#
# Copyright 1996 Digital Creations, L.C., 910 Princess Anne
# Street, Suite 300, Fredericksburg, Virginia 22401 U.S.A. All
# rights reserved.
#
##############################################################################
__doc__
=
'''
\
Provide an area where people can work without others seeing their changes.
A Draft folder is a surrogate for a folder. It get
\
'
s subobjects by
gettingthem from a session copy of a base folder.
$Id: DraftFolder.py,v 1.10 1998/01/02 18:35:04 jim Exp $'''
__version__
=
'$Revision: 1.10 $'
[
11
:
-
2
]
import
time
,
OFS
.
SimpleItem
,
AccessControl
.
Role
,
App
.
Management
,
App
.
Undo
import
AccessControl.User
import
Persistence
,
Acquisition
,
Globals
import
AccessControl.User
,
Session
from
string
import
rfind
from
Globals
import
HTMLFile
from
string
import
rfind
addForm
=
HTMLFile
(
'draftFolderAdd'
,
globals
())
def
add
(
self
,
id
,
baseid
,
title
=
''
,
REQUEST
=
None
):
"""Add a new Folder object"""
i
=
DraftFolder
()
i
.
_init
(
id
,
baseid
,
title
,
self
,
REQUEST
)
self
.
_setObject
(
id
,
i
)
if
REQUEST
is
not
None
:
return
self
.
manage_main
(
self
,
REQUEST
)
def
hack
(
self
):
return
({
'icon'
:
icon
,
'label'
:
'Contents'
,
'action'
:
'manage_main'
,
'target'
:
'manage_main'
},
{
'icon'
:
'OFS/Properties_icon.gif'
,
'label'
:
'Properties'
,
'action'
:
'manage_propertiesForm'
,
'target'
:
'manage_main'
},
{
'icon'
:
''
,
'label'
:
'Security'
,
'action'
:
'manage_access'
,
'target'
:
'manage_main'
},
{
'icon'
:
'App/undo_icon.gif'
,
'label'
:
'Undo'
,
'action'
:
'manage_UndoForm'
,
'target'
:
'manage_main'
},
{
'icon'
:
'OFS/DraftFolderControl.gif'
,
'label'
:
'Supervise'
,
'action'
:
'manage_Supervise'
,
'target'
:
'manage_main'
},
)
class
DraftFolder
(
Persistence
.
Persistent
,
AccessControl
.
Role
.
RoleManager
,
OFS
.
SimpleItem
.
Item
,
Acquisition
.
Implicit
,
App
.
Management
.
Navigation
,
App
.
Undo
.
UndoSupport
,
):
""" """
meta_type
=
'Draft Folder'
icon
=
'misc_/OFSP/DraftFolderIcon'
isPrincipiaFolderish
=
1
manage_options
=
(
{
'label'
:
'Contents'
,
'action'
:
'manage_main'
,
'target'
:
'manage_main'
},
{
'label'
:
'Properties'
,
'action'
:
'manage_propertiesForm'
,
'target'
:
'manage_main'
},
{
'label'
:
'Security'
,
'action'
:
'manage_access'
,
'target'
:
'manage_main'
},
{
'label'
:
'Undo'
,
'action'
:
'manage_UndoForm'
,
'target'
:
'manage_main'
},
{
'label'
:
'Supervise'
,
'action'
:
'manage_Supervise'
,
'target'
:
'manage_main'
},
)
def
__init__
(
self
,
id
,
baseid
,
title
,
parent
,
REQUEST
):
if
hasattr
(
parent
,
'aq_self'
):
parent
=
parent
.
aq_self
if
not
hasattr
(
parent
,
baseid
):
raise
'Input Error'
,
(
'The specified base folder, %s, does not exist'
%
baseid
)
self
.
id
=
id
self
.
baseid
=
baseid
self
.
title
=
title
cookie
=
REQUEST
[
'PATH_INFO'
]
if
cookie
[:
1
]
!=
'/'
:
cookie
=
'/'
+
cookie
l
=
rfind
(
cookie
,
'/'
)
if
l
>=
0
:
cookie
=
cookie
[:
l
]
self
.
cookie
=
"%s/%s"
%
(
cookie
,
id
)
self
.
cookie_name
=
"%s-Draft-Folder-%s"
%
(
id
,
baseid
)
self
.
__allow_groups__
=
Supervisor
()
def
title_and_id
(
self
):
r
=
DraftFolder
.
inheritedAttribute
(
'title_and_id'
)(
self
)
r
=
'%s *'
%
r
try
:
base
=
getattr
(
self
.
aq_parent
,
self
.
baseid
)
except
:
base
=
None
if
base
is
not
None
:
r
=
"%s Draft Folder: %s"
%
(
base
.
title_or_id
(),
r
)
return
r
def
_base
(
self
,
cookie
):
# Check for base object
if
hasattr
(
self
,
'aq_parent'
):
parent
=
self
.
aq_parent
else
:
parent
=
None
if
hasattr
(
parent
,
'aq_self'
):
ps
=
parent
.
aq_self
else
:
ps
=
parent
baseid
=
self
.
baseid
if
not
hasattr
(
ps
,
baseid
):
raise
'Draft Folder Error'
,
(
'''The base folder for the draft folder, <em>%s</em>,
does not exist.'''
%
self
.
cookie
)
base
=
getattr
(
parent
,
baseid
)
pd
=
Globals
.
SessionBase
[
cookie
]
oids
=
[
base
.
_p_oid
]
while
hasattr
(
base
,
'aq_parent'
):
base
=
base
.
aq_parent
if
hasattr
(
base
,
'_p_oid'
):
oids
.
append
(
base
.
_p_oid
)
else
:
break
while
oids
:
oid
=
oids
[
-
1
]
del
oids
[
-
1
]
base
=
pd
.
jar
[
oid
].
__of__
(
base
)
return
base
def
__bobo_traverse__
(
self
,
REQUEST
,
name
):
cookie_name
=
self
.
cookie_name
cookie
=
''
if
REQUEST
.
has_key
(
cookie_name
):
if
REQUEST
[
cookie_name
]
==
self
.
cookie
:
cookie
=
self
.
cookie
else
:
# Oops, the cookie is broken, better erase it:
RESPONSE
=
REQUEST
[
'RESPONSE'
]
RESPONSE
.
setCookie
(
self
.
cookie_name
,
'No longer active'
,
expires
=
"Mon, 27-Aug-84 23:59:59 GMT"
,
path
=
REQUEST
[
'SCRIPT_NAME'
]
+
self
.
cookie
,
)
REQUEST
[
self
.
cookie_name
]
=
''
PATH_INFO
=
REQUEST
[
'PATH_INFO'
]
if
PATH_INFO
[:
1
]
!=
'/'
:
PATH_INFO
=
'/'
+
PATH_INFO
if
PATH_INFO
==
self
.
cookie
+
'/manage'
:
if
not
cookie
:
return
self
.
manage
return
App
.
Management
.
Navigation
.
manage
if
PATH_INFO
==
self
.
cookie
+
'/manage_menu'
:
return
self
.
manage_menu
if
name
==
'manage_Supervise'
:
raise
'Redirect'
,
(
"%s/manage_draftFolder-%s/manage"
%
(
REQUEST
[
'URL2'
],
self
.
id
))
if
not
cookie
:
# Just set cookie here, rather than redirect!
cookie
=
self
.
cookie
cookie_name
=
self
.
cookie_name
REQUEST
[
'RESPONSE'
].
setCookie
(
cookie_name
,
cookie
,
expires
=
"Mon, 27-Dec-99 23:59:59 GMT"
,
path
=
REQUEST
[
'SCRIPT_NAME'
]
+
cookie
,)
REQUEST
[
cookie_name
]
=
cookie
__traceback_info__
=
PATH_INFO
,
cookie
,
self
.
cookie
self
=
self
.
_base
(
cookie
)
try
:
v
=
getattr
(
self
,
name
)
if
hasattr
(
v
,
'isDocTemp'
)
and
v
.
isDocTemp
and
(
PATH_INFO
==
"%s/%s"
%
(
cookie
,
name
)
or
PATH_INFO
==
cookie
and
name
==
'index_html'
):
def
v
(
REQUEST
,
_dt_
=
v
,
_self_
=
self
):
"Damn, need this so template gets called with right thing"
return
_dt_
(
_self_
,
REQUEST
)
return
v
except
AttributeError
:
try
:
return
self
[
name
]
except
KeyError
:
raise
'NotFound'
,(
"Sorry, the requested document does not exist.<p>"
"
\
n
<!--
\
n
%s
\
n
%s
\
n
-->"
%
(
name
,
REQUEST
[
'REQUEST_METHOD'
]))
def
manage_supervisor
(
self
):
return
self
.
__allow_groups__
def
parentObject
(
self
):
try
:
return
(
self
.
aq_parent
,)
except
:
return
()
class
Supervisor
(
AccessControl
.
User
.
UserFolder
,
Session
.
Session
):
manage
=
manage_main
=
HTMLFile
(
'DraftFolderSupervisor'
,
globals
())
manage_options
=
()
def
__init__
(
self
):
AccessConreol
.
User
.
UserFolder
.
__init__
(
self
)
##############################################################################
#
# $Log: DraftFolder.py,v $
# Revision 1.10 1998/01/02 18:35:04 jim
# Factored old Management mix-in into Navigation and Tabs.
#
# Revision 1.9 1998/01/02 17:41:19 brian
# Made undo available only in folders
#
# Revision 1.8 1997/12/31 19:27:10 jim
# *** empty log message ***
#
# Revision 1.7 1997/12/31 17:17:04 brian
# Security update
#
# Revision 1.6 1997/12/19 17:06:20 jim
# moved Sessions and Daft folders here.
#
# Revision 1.5 1997/12/18 16:45:40 jeffrey
# changeover to new ImageFile and HTMLFile handling
#
# Revision 1.4 1997/12/12 21:49:42 brian
# ui update
#
# Revision 1.3 1997/12/05 20:33:02 brian
# *** empty log message ***
#
# Revision 1.2 1997/11/11 21:25:28 brian
# Added copy/paste support, restricted unpickling, fixed DraftFolder bug
#
# Revision 1.1 1997/11/11 21:05:44 jim
# Draft Folders
#
#
lib/python/Products/OFSP/DraftFolderSupervisor.dtml
deleted
100644 → 0
View file @
c8788e84
<HTML>
<HEAD>
<TITLE>Draft Supervisor</TITLE>
</HEAD>
<BODY BGCOLOR="#FFFFFF" LINK="#000099" VLINK="#555555" ALINK="#77003B">
<H2>Draft Supervision</H2>
<h3>Draft Folder Approval</h3>
<!--#if nonempty-->
<p><form action=save>
You can make work done in <!--#var title_and_id--> permanent by
entering a remark in the space below and then
clicking on the "Save" button.<br>
<textarea name=remark rows=10 cols=50></textarea><br>
<input type=submit value="Save">
</form>
<hr>
<p><form action=discard>
You can throw away work done in <!--#var title_and_id--> by
clicking on the "Discard" button.
<input type=submit value="Discard">
</form>
<!--#else-->
<p>No work has been done in <!--#var title_and_id--> yet.</p>
<!--#/if-->
<hr>
<h3>Draft Folder Users</h3>
<!--#if userNames-->
<FORM ACTION="manage_editForm" METHOD="POST">
The following users have been defined. To edit a user,
select a user and click "Edit".
<BR>
<SELECT NAME="name">
<!--#in userNames-->
<OPTION VALUE="<!--#var sequence-item-->"> <!--#var sequence-item-->
<!--#/in userNames-->
</SELECT>
<BR>
<INPUT TYPE="SUBMIT" VALUE=" Change ">
</FORM>
<!--#else userNames-->
<EM>There are no users defined.</EM>
<!--#/if userNames-->
<P>
<TABLE>
<TR>
<TD COLSPAN="2" VALIGN="TOP">
To add a new user, enter the name, password, confirmation and
roles for the new user and click "Add".
</TD>
</TR>
<TR>
<TD COLSPAN="2" VALIGN="TOP">
<FORM ACTION="manage_addUser" METHOD="POST">
<TABLE>
<TR>
<TD VALIGN="TOP">
<STRONG>Name</STRONG>
</TD>
<TD VALIGN="TOP">
<INPUT TYPE="TEXT" NAME="name" SIZE="20">
</TD>
</TR>
<TR>
<TD VALIGN="TOP">
<STRONG>Password</STRONG>
</TD>
<TD VALIGN="TOP">
<INPUT TYPE="PASSWORD" NAME="password" SIZE="20">
</TD>
</TR>
<TR>
<TD VALIGN="TOP">
<STRONG>(Confirm)</STRONG>
</TD>
<TD VALIGN="TOP">
<INPUT TYPE="PASSWORD" NAME="confirm" SIZE="20">
</TD>
</TR>
<TR>
<TD VALIGN="TOP">
<STRONG>Roles</STRONG>
</TD>
<TD VALIGN="TOP">
<SELECT NAME="roles:list" SIZE="5" MULTIPLE>
<!--#if roleNames-->
<!--#in roleNames-->
<OPTION><!--#var sequence-item-->
<!--#/in roleNames-->
<!--#/if roleNames-->
</SELECT>
<BR>
<INPUT TYPE="SUBMIT" VALUE=" Add ">
</TD>
</TR>
</TABLE>
</FORM>
</TD>
</TR>
</TABLE>
<P>
<!--#if userNames-->
<FORM ACTION="manage_deleteUser" METHOD="POST">
To delete users, select one or more users and click "Delete".
<BR>
<SELECT NAME="names:list" MULTIPLE SIZE="4" >
<!--#in userNames-->
<OPTION><!--#var sequence-item-->
<!--#/in userNames-->
</SELECT>
<BR>
<INPUT TYPE="SUBMIT" VALUE="Delete">
</FORM>
<!--#/if userNames-->
</BODY>
</HTML>
lib/python/Products/OFSP/Session.py
View file @
2f63d12a
"""Session object"""
"""Session object"""
__version__
=
'$Revision: 1.
19
$'
[
11
:
-
2
]
__version__
=
'$Revision: 1.
20
$'
[
11
:
-
2
]
import
Globals
,
time
import
Globals
,
time
from
AccessControl.Role
import
RoleManager
from
AccessControl.Role
import
RoleManager
...
@@ -9,7 +9,8 @@ from Persistence import Persistent
...
@@ -9,7 +9,8 @@ from Persistence import Persistent
from
Acquisition
import
Implicit
from
Acquisition
import
Implicit
from
OFS.SimpleItem
import
Item
from
OFS.SimpleItem
import
Item
from
string
import
rfind
from
string
import
rfind
from
Globals
import
HTML
from
App.Dialogs
import
MessageDialog
manage_addSessionForm
=
Globals
.
HTMLFile
(
'sessionAdd'
,
globals
())
manage_addSessionForm
=
Globals
.
HTMLFile
(
'sessionAdd'
,
globals
())
...
@@ -68,6 +69,15 @@ class Session(Persistent,Implicit,RoleManager,Item):
...
@@ -68,6 +69,15 @@ class Session(Persistent,Implicit,RoleManager,Item):
#expires="Mon, 27-Dec-99 23:59:59 GMT",
#expires="Mon, 27-Dec-99 23:59:59 GMT",
path
=
REQUEST
[
'SCRIPT_NAME'
],
path
=
REQUEST
[
'SCRIPT_NAME'
],
)
)
if
(
REQUEST
.
has_key
(
'SERVER_SOFTWARE'
)
and
REQUEST
[
'SERVER_SOFTWARE'
][:
9
]
==
'Microsoft'
):
# IIS doesn't handle redirect headers correctly
return
MessageDialog
(
action
=
REQUEST
[
'URL1'
]
+
'/manage_main'
,
message
=
(
'If cookies are enabled by your browser, then '
'you should have joined session %s.'
%
self
.
id
)
)
return
RESPONSE
.
redirect
(
REQUEST
[
'URL1'
]
+
'/manage_main'
)
return
RESPONSE
.
redirect
(
REQUEST
[
'URL1'
]
+
'/manage_main'
)
def
leave
(
self
,
REQUEST
,
RESPONSE
):
def
leave
(
self
,
REQUEST
,
RESPONSE
):
...
@@ -77,6 +87,15 @@ class Session(Persistent,Implicit,RoleManager,Item):
...
@@ -77,6 +87,15 @@ class Session(Persistent,Implicit,RoleManager,Item):
expires
=
"Mon, 27-Aug-84 23:59:59 GMT"
,
expires
=
"Mon, 27-Aug-84 23:59:59 GMT"
,
path
=
REQUEST
[
'SCRIPT_NAME'
],
path
=
REQUEST
[
'SCRIPT_NAME'
],
)
)
if
(
REQUEST
.
has_key
(
'SERVER_SOFTWARE'
)
and
REQUEST
[
'SERVER_SOFTWARE'
][:
9
]
==
'Microsoft'
):
# IIS doesn't handle redirect headers correctly
return
MessageDialog
(
action
=
REQUEST
[
'URL1'
]
+
'/manage_main'
,
message
=
(
'If cookies are enabled by your browser, then '
'you should have left session %s.'
%
self
.
id
)
)
return
RESPONSE
.
redirect
(
REQUEST
[
'URL1'
]
+
'/manage_main'
)
return
RESPONSE
.
redirect
(
REQUEST
[
'URL1'
]
+
'/manage_main'
)
def
leave_another
(
self
,
REQUEST
,
RESPONSE
):
def
leave_another
(
self
,
REQUEST
,
RESPONSE
):
...
@@ -97,7 +116,6 @@ class Session(Persistent,Implicit,RoleManager,Item):
...
@@ -97,7 +116,6 @@ class Session(Persistent,Implicit,RoleManager,Item):
import
__init__
import
__init__
__init__
.
need_license
=
1
__init__
.
need_license
=
1
...
@@ -105,6 +123,9 @@ __init__.need_license=1
...
@@ -105,6 +123,9 @@ __init__.need_license=1
##############################################################################
##############################################################################
#
#
# $Log: Session.py,v $
# $Log: Session.py,v $
# Revision 1.20 1998/09/24 19:21:52 jim
# added Draft objects
#
# Revision 1.19 1998/05/20 22:07:32 jim
# Revision 1.19 1998/05/20 22:07:32 jim
# Updated permissions.
# Updated permissions.
#
#
...
...
lib/python/Products/OFSP/Setup
View file @
2f63d12a
# install DraftFolder.py
# install DraftFolderSupervisor.dtml
# install Session.py
# install __init__.py
# install __init__.py
# install draftFolderAdd.dtml
# install Draft.py
# install draftAdd.dtml
# install draftApprove.dtml
# install Session.py
# install session.dtml
# install session.dtml
# install sessionAdd.dtml
# install sessionAdd.dtml
# install sessionEdit.dtml
# install sessionEdit.dtml
...
...
lib/python/Products/OFSP/Version.py
View file @
2f63d12a
"""Session object"""
"""Session object"""
__version__
=
'$Revision: 1.
19
$'
[
11
:
-
2
]
__version__
=
'$Revision: 1.
20
$'
[
11
:
-
2
]
import
Globals
,
time
import
Globals
,
time
from
AccessControl.Role
import
RoleManager
from
AccessControl.Role
import
RoleManager
...
@@ -9,7 +9,8 @@ from Persistence import Persistent
...
@@ -9,7 +9,8 @@ from Persistence import Persistent
from
Acquisition
import
Implicit
from
Acquisition
import
Implicit
from
OFS.SimpleItem
import
Item
from
OFS.SimpleItem
import
Item
from
string
import
rfind
from
string
import
rfind
from
Globals
import
HTML
from
App.Dialogs
import
MessageDialog
manage_addSessionForm
=
Globals
.
HTMLFile
(
'sessionAdd'
,
globals
())
manage_addSessionForm
=
Globals
.
HTMLFile
(
'sessionAdd'
,
globals
())
...
@@ -68,6 +69,15 @@ class Session(Persistent,Implicit,RoleManager,Item):
...
@@ -68,6 +69,15 @@ class Session(Persistent,Implicit,RoleManager,Item):
#expires="Mon, 27-Dec-99 23:59:59 GMT",
#expires="Mon, 27-Dec-99 23:59:59 GMT",
path
=
REQUEST
[
'SCRIPT_NAME'
],
path
=
REQUEST
[
'SCRIPT_NAME'
],
)
)
if
(
REQUEST
.
has_key
(
'SERVER_SOFTWARE'
)
and
REQUEST
[
'SERVER_SOFTWARE'
][:
9
]
==
'Microsoft'
):
# IIS doesn't handle redirect headers correctly
return
MessageDialog
(
action
=
REQUEST
[
'URL1'
]
+
'/manage_main'
,
message
=
(
'If cookies are enabled by your browser, then '
'you should have joined session %s.'
%
self
.
id
)
)
return
RESPONSE
.
redirect
(
REQUEST
[
'URL1'
]
+
'/manage_main'
)
return
RESPONSE
.
redirect
(
REQUEST
[
'URL1'
]
+
'/manage_main'
)
def
leave
(
self
,
REQUEST
,
RESPONSE
):
def
leave
(
self
,
REQUEST
,
RESPONSE
):
...
@@ -77,6 +87,15 @@ class Session(Persistent,Implicit,RoleManager,Item):
...
@@ -77,6 +87,15 @@ class Session(Persistent,Implicit,RoleManager,Item):
expires
=
"Mon, 27-Aug-84 23:59:59 GMT"
,
expires
=
"Mon, 27-Aug-84 23:59:59 GMT"
,
path
=
REQUEST
[
'SCRIPT_NAME'
],
path
=
REQUEST
[
'SCRIPT_NAME'
],
)
)
if
(
REQUEST
.
has_key
(
'SERVER_SOFTWARE'
)
and
REQUEST
[
'SERVER_SOFTWARE'
][:
9
]
==
'Microsoft'
):
# IIS doesn't handle redirect headers correctly
return
MessageDialog
(
action
=
REQUEST
[
'URL1'
]
+
'/manage_main'
,
message
=
(
'If cookies are enabled by your browser, then '
'you should have left session %s.'
%
self
.
id
)
)
return
RESPONSE
.
redirect
(
REQUEST
[
'URL1'
]
+
'/manage_main'
)
return
RESPONSE
.
redirect
(
REQUEST
[
'URL1'
]
+
'/manage_main'
)
def
leave_another
(
self
,
REQUEST
,
RESPONSE
):
def
leave_another
(
self
,
REQUEST
,
RESPONSE
):
...
@@ -97,7 +116,6 @@ class Session(Persistent,Implicit,RoleManager,Item):
...
@@ -97,7 +116,6 @@ class Session(Persistent,Implicit,RoleManager,Item):
import
__init__
import
__init__
__init__
.
need_license
=
1
__init__
.
need_license
=
1
...
@@ -105,6 +123,9 @@ __init__.need_license=1
...
@@ -105,6 +123,9 @@ __init__.need_license=1
##############################################################################
##############################################################################
#
#
# $Log: Version.py,v $
# $Log: Version.py,v $
# Revision 1.20 1998/09/24 19:21:52 jim
# added Draft objects
#
# Revision 1.19 1998/05/20 22:07:32 jim
# Revision 1.19 1998/05/20 22:07:32 jim
# Updated permissions.
# Updated permissions.
#
#
...
...
lib/python/Products/OFSP/__init__.py
View file @
2f63d12a
...
@@ -8,10 +8,10 @@
...
@@ -8,10 +8,10 @@
#
#
##############################################################################
##############################################################################
__doc__
=
'''Base Principia
__doc__
=
'''Base Principia
$Id: __init__.py,v 1.1
5 1998/05/21 13:52:2
3 jim Exp $'''
$Id: __init__.py,v 1.1
6 1998/09/24 19:21:5
3 jim Exp $'''
__version__
=
'$Revision: 1.1
5
$'
[
11
:
-
2
]
__version__
=
'$Revision: 1.1
6
$'
[
11
:
-
2
]
import
Session
,
Draft
Folder
import
Session
,
Draft
from
ImageFile
import
ImageFile
from
ImageFile
import
ImageFile
import
OFS.Image
,
OFS
.
Document
,
OFS
.
Folder
,
AccessControl
.
User
import
OFS.Image
,
OFS
.
Document
,
OFS
.
Folder
,
AccessControl
.
User
...
@@ -22,13 +22,13 @@ classes=('Session.Session', 'OFS.Image.File',
...
@@ -22,13 +22,13 @@ classes=('Session.Session', 'OFS.Image.File',
klasses
=
(
'OFS.Folder.Folder'
,
'AccessControl.User.UserFolder'
)
klasses
=
(
'OFS.Folder.Folder'
,
'AccessControl.User.UserFolder'
)
meta_types
=
(
meta_types
=
(
# {'name':'Draft Folder', 'action':'manage_addDraftFolder
Form'},
{
'name'
:
Draft
.
Draft
.
meta_type
,
'action'
:
'manage_addPrincipiaDraft
Form'
},
{
'name'
:
'User Folder'
,
'action'
:
'manage_addUserFolder'
},
{
'name'
:
'User Folder'
,
'action'
:
'manage_addUserFolder'
},
{
'name'
:
'Session'
,
'action'
:
'manage_addSessionForm'
},
{
'name'
:
'Session'
,
'action'
:
'manage_addSessionForm'
},
{
'name'
:
'File'
,
'action'
:
'manage_addFileForm'
},
{
'name'
:
'File'
,
'action'
:
'manage_addFileForm'
},
{
'name'
:
'Image'
,
'action'
:
'manage_addImageForm'
},
{
'name'
:
'Image'
,
'action'
:
'manage_addImageForm'
},
{
'name'
:
'Folder'
,
'action'
:
'manage_addFolderForm'
},
{
'name'
:
'Folder'
,
'action'
:
'manage_addFolderForm'
},
{
'name'
:
'Document'
,
'action'
:
'manage_addDocumentForm'
},
{
'name'
:
'Document'
,
'action'
:
'manage_addDocumentForm'
},
)
)
...
@@ -50,15 +50,11 @@ methods={
...
@@ -50,15 +50,11 @@ methods={
'PUT'
:
PUT
,
'PUT'
:
PUT
,
'PUT__roles__'
:
(
'Manager'
,),
'PUT__roles__'
:
(
'Manager'
,),
'manage_addUserFolder'
:
AccessControl
.
User
.
manage_addUserFolder
,
'manage_addUserFolder'
:
AccessControl
.
User
.
manage_addUserFolder
,
'manage_addPrincipiaDraftForm'
:
Draft
.
manage_addPrincipiaDraftForm
,
'manage_addPrincipiaDraft'
:
Draft
.
manage_addPrincipiaDraft
,
# 'manage_addDraftFolderForm': DraftFolder.addForm,
# 'manage_addDraftFolder': DraftFolder.add,
}
}
misc_
=
{
misc_
=
{
'draft'
:
ImageFile
(
'images/DraftFolder.gif'
,
globals
()),
'sup'
:
ImageFile
(
'images/DraftFolderControl.gif'
,
globals
()),
'session'
:
ImageFile
(
'images/session.gif'
,
globals
()),
'session'
:
ImageFile
(
'images/session.gif'
,
globals
()),
}
}
...
@@ -86,6 +82,9 @@ __ac_permissions__=(
...
@@ -86,6 +82,9 @@ __ac_permissions__=(
##############################################################################
##############################################################################
#
#
# $Log: __init__.py,v $
# $Log: __init__.py,v $
# Revision 1.16 1998/09/24 19:21:53 jim
# added Draft objects
#
# Revision 1.15 1998/05/21 13:52:23 jim
# Revision 1.15 1998/05/21 13:52:23 jim
# Updated permissions.
# Updated permissions.
#
#
...
...
lib/python/Products/OFSP/draftAdd.dtml
0 → 100644
View file @
2f63d12a
<HTML>
<HEAD>
<TITLE>Add Draft</TITLE>
</HEAD>
<BODY BGCOLOR="#FFFFFF" LINK="#000099" VLINK="#555555">
<H2>Add Draft Object</H2>
<FORM ACTION="manage_addPrincipiaDraft" METHOD="POST">
<TABLE CELLSPACING="2">
<TR>
<TH ALIGN="LEFT" VALIGN="TOP">Id</TH>
<TD ALIGN="LEFT" VALIGN="TOP"><INPUT TYPE="TEXT" NAME="id" SIZE="40"></TD>
</TR>
<TR>
<TH ALIGN="LEFT" VALIGN="TOP">Base Object</TD>
<TD ALIGN="LEFT" VALIGN="TOP">
<SELECT NAME=baseid size=7>
<!--#in objectValues sort=title_or_id-->
<!--#unless "meta_type in ('Session', 'Principia Draft', 'User Folder')"-->
<OPTION VALUE="<!--#var id-->">
<!--#if title-->
<!--#var title size=25--> (<!--#var id-->)
<!--#else-->
<!--#var id-->
<!--#endif-->
</OPTION>
<!--#/unless-->
<!--#/in-->
</SELECT>
</TD>
</TR>
<TR><TD></TD><TD><INPUT TYPE="SUBMIT" VALUE=" Add "></TD></TR>
</TABLE>
</FORM>
</BODY>
</HTML>
lib/python/Products/OFSP/draftApprove.dtml
0 → 100644
View file @
2f63d12a
<HTML>
<HEAD>
<TITLE><!--#var title_or_id--></TITLE>
</HEAD>
<BODY BGCOLOR="#FFFFFF" LINK="#000099" VLINK="#555555">
<!--#var manage_tabs-->
<!--#if nonempty-->
<h2>Approve</h2>
<p><form action=manage_Save__draft__>
You can make work done in <!--#var id--> (<!--#var title-->) permanent by
entering a remark in the space below and then
clicking on the "Approve" button.<br>
<textarea name=remark rows=10 cols=50></textarea><br>
<input type=submit value="Approve">
</form>
<h2>Discard</h2>
<p><form action=manage_Discard__draft__>
You can throw away work done in <!--#var id--> (<!--#var title-->) by
clicking on the "Discard" button.<br>
<input type=submit value="Discard">
</form>
<!--#else-->
There is nothing to approve. Nothing has been changed yet.
<!--#endif-->
</body> </html>
lib/python/Products/OFSP/draftFolderAdd.dtml
deleted
100644 → 0
View file @
c8788e84
<HTML>
<HEAD>
<TITLE>Add Draft Folder</TITLE>
</HEAD>
<BODY BGCOLOR="#FFFFFF" LINK="#000099" VLINK="#555555">
<H2>Add Draft Folder</H2>
<FORM ACTION="manage_addDraftFolder" METHOD="POST">
<TABLE CELLSPACING="2">
<TR>
<TD ALIGN="LEFT" VALIGN="TOP">
<STRONG>Id</STRONG>
</TD>
<TD ALIGN="LEFT" VALIGN="TOP">
<INPUT TYPE="TEXT" NAME="id" SIZE="40">
</TD>
</TR>
<TR>
<TD ALIGN="LEFT" VALIGN="TOP">
<EM><STRONG>Title</STRONG></EM>
</TD>
<TD ALIGN="LEFT" VALIGN="TOP">
<INPUT TYPE="TEXT" NAME="title" SIZE="40">
</TD>
</TR>
<TR>
<TD ALIGN="LEFT" VALIGN="TOP">
<EM><STRONG>Base Folder</STRONG></EM>
</TD>
<TD ALIGN="LEFT" VALIGN="TOP">
<SELECT NAME=baseid>
<!--#in folderValues-->
<OPTION VALUE="<!--#var id-->">
<!--#if title-->
<!--#var title size=25--> (<!--#var id-->)
<!--#else-->
<!--#var id-->
<!--#endif-->
<!--#/in folderValues-->
</SELECT>
</TD>
</TR>
<TR>
<TD></TD>
<TD>
<BR><INPUT TYPE="SUBMIT" VALUE=" Add ">
</TD>
</TR>
</TABLE>
</FORM>
</BODY>
</HTML>
lib/python/Products/OFSP/session.dtml
View file @
2f63d12a
...
@@ -45,7 +45,7 @@
...
@@ -45,7 +45,7 @@
<hr>
<hr>
<p><form action=
save
>
<p><form action=
manage_draftSave__
>
You can make work done in <!--#var title_and_id--> permanent by
You can make work done in <!--#var title_and_id--> permanent by
entering a remark in the space below and then
entering a remark in the space below and then
clicking on the "Save" button.<br>
clicking on the "Save" button.<br>
...
@@ -55,7 +55,7 @@
...
@@ -55,7 +55,7 @@
<hr>
<hr>
<p><form action=
discard
>
<p><form action=
manage_draftDiscard__
>
You can throw away work done in <!--#var title_and_id--> by
You can throw away work done in <!--#var title_and_id--> by
clicking on the "Discard" button.
clicking on the "Discard" button.
<input type=submit value="Discard">
<input type=submit value="Discard">
...
...
lib/python/Products/OFSP/version.dtml
View file @
2f63d12a
...
@@ -45,7 +45,7 @@
...
@@ -45,7 +45,7 @@
<hr>
<hr>
<p><form action=
save
>
<p><form action=
manage_draftSave__
>
You can make work done in <!--#var title_and_id--> permanent by
You can make work done in <!--#var title_and_id--> permanent by
entering a remark in the space below and then
entering a remark in the space below and then
clicking on the "Save" button.<br>
clicking on the "Save" button.<br>
...
@@ -55,7 +55,7 @@
...
@@ -55,7 +55,7 @@
<hr>
<hr>
<p><form action=
discard
>
<p><form action=
manage_draftDiscard__
>
You can throw away work done in <!--#var title_and_id--> by
You can throw away work done in <!--#var title_and_id--> by
clicking on the "Discard" button.
clicking on the "Discard" button.
<input type=submit value="Discard">
<input type=submit value="Discard">
...
...
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