1: from OFS.Folder import Folder
2: from OFS.Image import File
3: from OFS.Image import cookId
4: from Globals import DTMLFile, InitializeClass,package_home
5: from Products.PageTemplates.PageTemplateFile import PageTemplateFile
6: from AccessControl import getSecurityManager
7: from Products.PageTemplates.PageTemplate import PageTemplate
8: from Products.PageTemplates.ZopePageTemplate import ZopePageTemplate
9: from AccessControl import ClassSecurityInfo
10: import os.path
11:
12: import time
13: try:
14: from Products.ECHO_content.ECHO_collection import ECHO_basis
15: except:
16: print "ECHO Elements not imported"
17: class ECHO_basis:
18: """leer"""
19: manage_options=()
20:
21:
22: def sortv(x,y):
23: return cmp(x[0],y[0])
24:
25: class versionedFileFolder(Folder,ECHO_basis):
26: """Folder with versioned files"""
27:
28:
29: meta_type = "versionedFileFolder"
30:
31: security= ClassSecurityInfo()
32: security.declareProtected('AUTHENTICATED_USER','addFileForm')
33:
34: if ECHO_basis:
35: optTMP= Folder.manage_options+ECHO_basis.manage_options
36: else:
37: optTMP= Folder.manage_options
38:
39: manage_options =optTMP+(
40: {'label':'Generate Index.html','action':'generateIndexHTML'},
41: {'label':'Generate history_template.html','action':'generateHistoryHTML'},
42: )
43:
44:
45:
46: def helpDownload(self):
47: """download help"""
48:
49: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','helpDownload')).__of__(self)
50: return pt()
51:
52: def generateIndexHTML(self,RESPONSE=None):
53: """lege standard index.html an"""
54:
55:
56:
57:
58: if not hasattr(self,'index.html'):
59: zt=ZopePageTemplate('index.html')
60: self._setObject('index.html',zt)
61: default_content_fn = os.path.join(package_home(globals()),
62: 'zpt/versionFileFolderMain.zpt')
63: text = open(default_content_fn).read()
64: zt.pt_edit(text, 'text/html')
65:
66: else:
67: return "already exists!"
68:
69: if RESPONSE is not None:
70: RESPONSE.redirect('manage_main')
71:
72:
73: def generateHistoryHTML(self,RESPONSE=None):
74: """lege standard index.html an"""
75:
76:
77:
78:
79: if not hasattr(self,'history_template.html'):
80: zt=ZopePageTemplate('history_template.html')
81: self._setObject('history_template.html',zt)
82: default_content_fn = os.path.join(package_home(globals()),
83: 'zpt/versionHistory.zpt')
84: text = open(default_content_fn).read()
85: zt.pt_edit(text, 'text/html')
86:
87: else:
88: return "already exists!"
89:
90: if RESPONSE is not None:
91: RESPONSE.redirect('manage_main')
92:
93: def getVersionedFiles(self,sortField='title'):
94: """get all versioned files"""
95:
96: def sortName(x,y):
97: return cmp(x[1].title.lower(),y[1].title.lower())
98:
99: def sortDate(x,y):
100: return cmp(y[1].getLastVersion().getTime(),x[1].getLastVersion().getTime())
101:
102: def sortAuthor(x,y):
103:
104: return cmp(x[1].getLastVersion().lastEditor(),y[1].getLastVersion().lastEditor())
105:
106: versionedFiles=self.ZopeFind(self,obj_metatypes=['versionedFile'])
107:
108: if sortField=='title':
109: versionedFiles.sort(sortName)
110: elif sortField=='date':
111: versionedFiles.sort(sortDate)
112: elif sortField=='author':
113: versionedFiles.sort(sortAuthor)
114:
115: return versionedFiles
116:
117:
118: def header_html(self):
119: """zusätzlicher header"""
120: ext=self.ZopeFind(self,obj_ids=["header.html"])
121: if ext:
122: return ext[0][1]()
123: else:
124: return ""
125:
126: def index_html(self):
127: """main"""
128: ext=self.ZopeFind(self,obj_ids=["index.html"])
129: if ext:
130: return ext[0][1]()
131:
132: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','versionFileFolderMain')).__of__(self)
133: return pt()
134:
135:
136: def addFileForm(self):
137: """add a file"""
138: ext=self.ZopeFind(self,obj_ids=["addFileForm.dtml"])
139: if ext:
140: return ext[0][1]('',globals(),version='1',AUTHENTICATED_USER=self.REQUEST.AUTHENTICATED_USER)
141:
142: out=DTMLFile('dtml/newFileAdd', globals(),Kind='VersionedFileObject',kind='versionedFileObject',version='1').__of__(self)
143: return out()
144:
145:
146: def addFile(self,vC,file,author,newName='',content_type='',RESPONSE=None):
147: """ add a new file"""
148: if newName=='':
149: id=file.filename
150: else:
151: id=newName
152:
153: vC=self.REQUEST.form['vC']
154: manage_addVersionedFile(self,id,'','')
155: #if (getattr(self,'commentNonEmpty',0)==1) and vC.strip()=="":
156:
157:
158: ob=self._getOb(id)
159: ob.title=id
160: file2=file
161: ob.manage_addVersionedFileObject(id,vC,author,file2,content_type=content_type)
162:
163: RESPONSE.redirect(self.REQUEST['URL1'])
164:
165:
166: manage_addVersionedFileFolderForm=DTMLFile('dtml/folderAdd', globals())
167:
168:
169: def manage_addVersionedFileFolder(self, id, title='',
170: createPublic=0,
171: createUserF=0,
172: REQUEST=None):
173: """Add a new Folder object with id *id*.
174:
175: If the 'createPublic' and 'createUserF' parameters are set to any true
176: value, an 'index_html' and a 'UserFolder' objects are created respectively
177: in the new folder.
178: """
179: ob=versionedFileFolder()
180: ob.id=str(id)
181: ob.title=title
182: self._setObject(id, ob)
183: ob=self._getOb(id)
184:
185: checkPermission=getSecurityManager().checkPermission
186:
187: if createUserF:
188: if not checkPermission('Add User Folders', ob):
189: raise Unauthorized, (
190: 'You are not authorized to add User Folders.'
191: )
192: ob.manage_addUserFolder()
193:
194:
195: if REQUEST is not None:
196: return self.manage_main(self, REQUEST, update_menu=1)
197:
198:
199:
200: class versionedFileObject(File):
201: """File Object im Folder"""
202:
203: meta_type = "versionedFileObject"
204:
205: manage_editForm =DTMLFile('dtml/fileEdit',globals(),
206: Kind='File',kind='file')
207: manage_editForm._setName('manage_editForm')
208:
209: def getTime(self):
210: """getTime"""
211: #return self.bobobase_modification_time().ISO()
212: if hasattr(self,'time'):
213: return time.strftime("%Y-%m-%d %H:%M:%S",self.time)
214: elif hasattr(self,'timefixed'):
215: return self.timefixed
216: else:
217: setattr(self,'timefixed',self.bobobase_modification_time().ISO())
218: return self.bobobase_modification_time().ISO()
219:
220:
221:
222:
223:
224: def download(self):
225: """download and lock"""
226:
227:
228: self.content_type="application/octet-stream"
229: self.REQUEST.RESPONSE.redirect(self.absolute_url())
230:
231: def downloadLocked(self):
232: """download and lock"""
233:
234:
235: if self.REQUEST['AUTHENTICATED_USER']=='Anonymous User':
236: return "please login first"
237: if not self.aq_parent.lockedBy=="":
238: return "cannot be locked because is already locked by %s"%self.lockedBy
239: self.aq_parent.lockedBy=self.REQUEST['AUTHENTICATED_USER']
240:
241: self.content_type="application/octet-stream"
242: self.REQUEST.RESPONSE.redirect(self.absolute_url())
243:
244: def setVersionNumber(self,versionNumber):
245: """set version"""
246: self.versionNumber=versionNumber
247:
248: def getVersionNumber(self):
249: """get version"""
250: return self.versionNumber
251:
252: def lastEditor(self):
253: """last Editor"""
254: if hasattr(self,'author'):
255: return self.author
256: else:
257: jar=self._p_jar
258: oid=self._p_oid
259:
260: if jar is None or oid is None: return None
261:
262: return jar.db().history(oid)[0]['user_name']
263:
264:
265:
266:
267: manage_addVersionedFileObjectForm=DTMLFile('dtml/fileAdd', globals(),Kind='VersionedFileObject',kind='versionedFileObject', version='1')
268:
269: def manage_addVersionedFileObject(self,id,vC='',author='', file='',title='',precondition='', content_type='',
270: REQUEST=None):
271: """Add a new File object.
272:
273: Creates a new File object 'id' with the contents of 'file'"""
274:
275: id=str(id)
276: title=str(title)
277: content_type=str(content_type)
278: precondition=str(precondition)
279:
280: id, title = cookId(id, title, file)
281:
282: self=self.this()
283:
284: # First, we create the file without data:
285: self._setObject(id, versionedFileObject(id,title,'',content_type, precondition))
286: self._getOb(id).versionComment=str(vC)
287: self._getOb(id).time=time.localtime()
288:
289: setattr(self._getOb(id),'author',author)
290:
291: # Now we "upload" the data. By doing this in two steps, we
292: # can use a database trick to make the upload more efficient.
293: if file:
294: self._getOb(id).manage_upload(file)
295: if content_type:
296: self._getOb(id).content_type=content_type
297:
298: if REQUEST is not None:
299: REQUEST['RESPONSE'].redirect(self.absolute_url()+'/manage_main')
300:
301:
302:
303:
304: class versionedFile(Folder):
305: """Versioniertes File"""
306:
307: def __init__(self, id, title, lockedBy,author):
308: """init"""
309: self.id=id
310: self.title=title
311: self.lockedBy=lockedBy
312: self.author=author
313:
314:
315: meta_type="versionedFile"
316:
317:
318: def getLastVersion(self):
319: """Last Version"""
320: tmp=0
321: lastVersion=None
322:
323: for version in self.ZopeFind(self):
324:
325: if hasattr(version[1],'versionNumber'):
326:
327: if int(version[1].versionNumber) > tmp:
328: tmp=int(version[1].versionNumber,)
329: lastVersion=version[1]
330: return lastVersion
331:
332: def index_html(self):
333: """main view"""
334: lastVersion=self.getLastVersion()
335: #return "File:"+self.title+" Version:%i"%lastVersion.versionNumber," modified:",lastVersion.bobobase_modification_time()," size:",lastVersion.getSize(),"modified by:",lastVersion.lastEditor()
336: return "File: %s Version:%i modified:%s size:%s modified by:%s"%(self.title,lastVersion.versionNumber,lastVersion.getTime(),lastVersion.getSize(),lastVersion.lastEditor())
337:
338: def getVersion(self):
339: tmp=0
340: for version in self.ZopeFind(self):
341:
342: if hasattr(version[1],'versionNumber'):
343:
344: if int(version[1].versionNumber) > tmp:
345: tmp=int(version[1].versionNumber,)
346: return tmp+1
347:
348: security= ClassSecurityInfo()
349: security.declareProtected('AUTHENTICATED_USER','unlock')
350:
351: def history(self):
352: """history"""
353:
354: ext=self.ZopeFind(self.aq_parent,obj_ids=["history_template.html"])
355: if ext:
356: return getattr(self,ext[0][1].getId())()
357:
358: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','versionHistory')).__of__(self)
359: return pt()
360:
361: def getVersions(self):
362: """get all versions"""
363: ret=[]
364: for version in self.ZopeFind(self):
365: if hasattr(version[1],'versionNumber'):
366: ret.append((version[1].versionNumber,version[1]))
367: ret.sort(sortv)
368: return ret
369:
370: security.declareProtected('AUTHENTICATED_USER','unlock')
371: def unlock(self,RESPONSE):
372: """unlock"""
373: if str(self.lockedBy) in [str(self.REQUEST['AUTHENTICATED_USER'])]:
374: self.lockedBy=''
375: RESPONSE.redirect(self.REQUEST['URL2'])
376: else:
377: return "Sorry, not locked by you! (%s,%s)"%(self.lockedBy,self.REQUEST['AUTHENTICATED_USER'])
378:
379:
380: security.declareProtected('AUTHENTICATED_USER','addVersionedFileObjectForm')
381:
382: def addVersionedFileObjectForm(self):
383: """add a new version"""
384:
385: if str(self.REQUEST['AUTHENTICATED_USER']) in ["Anonymous User"]:
386: return "please login first"
387: if (self.lockedBy==self.REQUEST['AUTHENTICATED_USER']) or (self.lockedBy==''):
388: out=DTMLFile('dtml/fileAdd', globals(),Kind='VersionedFileObject',kind='versionedFileObject',version=self.getVersion()).__of__(self)
389: return out()
390: else:
391: return "Sorry file is locked by somebody else"
392:
393: def manage_addVersionedFileObject(self,id,vC,author,file='',title='',precondition='', content_type='',changeName='no',newName='', RESPONSE=None):
394: """add"""
395:
396: vC=self.REQUEST['vC']
397: author=self.REQUEST['author']
398:
399: if changeName=="yes":
400: self.title=file.filename[0:]
401:
402: if not newName=='':
403: self.title=newName[0:]
404:
405: id="V%i"%self.getVersion()+"_"+self.title
406: manage_addVersionedFileObject(self,id,vC,author,file,"V%i"%self.getVersion()+"_"+self.title,precondition, content_type)
407: objs=self.ZopeFind(self,obj_ids=[id])[0][1].setVersionNumber(int(self.getVersion()))
408:
409: if RESPONSE:
410: RESPONSE.redirect(self.REQUEST['URL2'])
411:
412: security.declareProtected('AUTHENTICATED_USER','downloadLocked')
413:
414: def download(self):
415: """download and lock"""
416: self.getLastVersion().content_type="application/octet-stream"
417: self.REQUEST.RESPONSE.redirect(self.REQUEST['URL1']+'/'+self.getId()+'/'+self.getLastVersion().getId())
418:
419: def downloadLocked(self):
420: """download and lock"""
421: if self.REQUEST['AUTHENTICATED_USER']=='Anonymous User':
422: return "please login first"
423: if not self.lockedBy=="":
424: return "cannot be locked because is already locked by %s"%self.lockedBy
425: self.lockedBy=self.REQUEST['AUTHENTICATED_USER']
426: self.getLastVersion().content_type="application/octet-stream"
427: self.REQUEST.RESPONSE.redirect(self.REQUEST['URL1']+'/'+self.getId()+'/'+self.getLastVersion().getId())
428:
429: def manage_addVersionedFileForm(self):
430: """interface for adding the OSAS_root"""
431: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','addVersionedFile.zpt')).__of__(self)
432: return pt()
433:
434: def manage_addVersionedFile(self,id,title,lockedBy, author=None, RESPONSE=None):
435: """add the OSAS_root"""
436: newObj=versionedFile(id,title,lockedBy,author)
437: self._setObject(id,newObj)
438:
439: if RESPONSE is not None:
440: RESPONSE.redirect('manage_main')
441:
442:
443: InitializeClass(versionedFile)
444: InitializeClass(versionedFileFolder)
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>