version 1.7, 2007/09/10 16:34:16
|
version 1.24, 2008/06/27 18:20:40
|
Line 29 import os.path
|
Line 29 import os.path
|
import urllib |
import urllib |
import time |
import time |
import logging |
import logging |
|
import types |
|
|
try: |
try: |
from Products.ECHO_content.ECHO_collection import ECHO_basis |
from Products.ECHO_content.ECHO_collection import ECHO_basis |
Line 134 class extVersionedFileFolder(Folder,ECHO
|
Line 135 class extVersionedFileFolder(Folder,ECHO
|
{'label':'Generate Index.html','action':'generateIndexHTML'}, |
{'label':'Generate Index.html','action':'generateIndexHTML'}, |
{'label':'Generate Image Index.html','action':'generateIndexHTML_image'}, |
{'label':'Generate Image Index.html','action':'generateIndexHTML_image'}, |
{'label':'Generate history_template.html','action':'generateHistoryHTML'}, |
{'label':'Generate history_template.html','action':'generateHistoryHTML'}, |
{'label':'Import Folder','action':'importFolderForm'}, |
{'label':'Import directory','action':'importFolderForm'}, |
{'label':'Export Folder','action':'exportFolder'}, |
{'label':'Export as file','action':'exportFolder'}, |
|
{'label':'Import versionedFileFolder','action':'importVersionedFileFolderForm'}, |
{'label':'Position of version number','action':'changeHistoryFileNamesForm'}, |
{'label':'Position of version number','action':'changeHistoryFileNamesForm'}, |
) |
) |
|
|
Line 186 class extVersionedFileFolder(Folder,ECHO
|
Line 188 class extVersionedFileFolder(Folder,ECHO
|
return pt() |
return pt() |
|
|
def importFolder(self,path,comment="",author=None,lockedBy=None,RESPONSE=None): |
def importFolder(self,path,comment="",author=None,lockedBy=None,RESPONSE=None): |
"""importiere inhalt eines folders""" |
"""import contents of a folder on the server""" |
|
|
for fileName in os.listdir(path): |
for fileName in os.listdir(path): |
if os.path.isfile(os.path.join(path,fileName)): |
fn = os.path.join(path,fileName) |
manage_addextVersionedFile(self,fileName,'','') |
if os.path.isfile(fn): |
id=fileName |
f = file(fn) |
ob=self._getOb(fileName) |
self.addFile(vC=comment, file=f, author=author) |
ob.title=id |
|
file2=file(os.path.join(path,fileName)) |
if RESPONSE: |
|
RESPONSE.redirect(self.REQUEST['URL1']) |
|
|
obj=ob.manage_addextVersionedFileObject(id,comment,author,file2,content_type='') |
def importVersionedFileFolderForm(self): |
|
"""form fuer versionedFileFolder import""" |
|
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','importVersionedFileFolderForm.zpt')).__of__(self) |
|
return pt() |
|
|
|
def importVersionedFileFolder(self,path,RESPONSE=None): |
|
"""import contents of a versionedFileFolder on the server""" |
|
vff = getattr(self.aq_parent, path, None) |
|
if vff is None: |
|
return "SORRY, unable to import %s"%path |
|
|
|
tmpPath=tempfile.mktemp() |
|
if not os.path.exists(tempfile.tempdir): |
|
os.mkdir(tempfile.tempdir) |
|
|
|
if not os.path.exists(tmpPath): |
|
os.mkdir(tmpPath) |
|
|
|
for (vfn, vf) in vff.getVersionedFiles(): |
|
if vf.meta_type == 'versionedFile': |
|
logging.error("importvff: importing %s of type %s!"%(vfn,vf.meta_type)) |
|
title = vf.title |
|
fob = vf.getLastVersion() |
|
author = fob.getLastEditor() |
|
vc = fob.getVersionComment() |
|
# save file to filesystem |
|
savePath=os.path.join(tmpPath,title) |
|
fh=file(savePath,"w") |
|
data = vf.getLastVersion().data |
|
if isinstance(data, str): |
|
# simple data object |
|
fh.write(data) |
|
else: |
|
# chained data objects |
|
while data is not None: |
|
fh.write(data.data) |
|
data = data.next |
|
fh.close() |
|
# and read in again |
|
fh = file(savePath) |
|
logging.error("importvff: comment=%s author=%s!"%(vc,author)) |
|
self.addFile(vC=vc, file=fh, author=author) |
|
# copy more fields |
|
newfob = getattr(self, vfn).getContentObject() |
|
newfob.vComment = fob.vComment |
|
newfob.time = fob.time |
|
logging.error("importvff: vc=%s time=%s of %s!"%(fob.vComment,fob.time,fob.getId())) |
|
|
|
else: |
|
logging.error("importvff: unable to import %s of type %s!"%(vfn,vf.meta_type)) |
|
|
|
shutil.rmtree(tmpPath) |
|
|
if RESPONSE: |
if RESPONSE: |
RESPONSE.redirect(self.REQUEST['URL1']) |
RESPONSE.redirect(self.REQUEST['URL1']) |
Line 216 class extVersionedFileFolder(Folder,ECHO
|
Line 269 class extVersionedFileFolder(Folder,ECHO
|
downloadZip=generateDownloadZip(self,self.absolute_url()) |
downloadZip=generateDownloadZip(self,self.absolute_url()) |
downloadZip() |
downloadZip() |
return downloadZip.getResult() |
return downloadZip.getResult() |
|
|
## if not threadName or threadName=="": |
## if not threadName or threadName=="": |
## threadStart=generateDownloadZip(self,self.absolute_url()) |
## threadStart=generateDownloadZip(self,self.absolute_url()) |
## thread=Thread(target=threadStart) |
## thread=Thread(target=threadStart) |
Line 435 class extVersionedFileFolder(Folder,ECHO
|
Line 489 class extVersionedFileFolder(Folder,ECHO
|
return out() |
return out() |
|
|
|
|
def addFile(self,vC,file,author,newName='',content_type='',RESPONSE=None): |
def addFile(self,vC,file,author='',newName='',content_type='',RESPONSE=None): |
""" add a new file""" |
""" add a new file""" |
|
# is file is a real file or a zope download object? |
|
isRealFile = type(file) is types.FileType |
|
|
if newName=='': |
if newName=='': |
|
logging.debug("fileobject: %s real:%s"%(repr(file),repr(isRealFile))) |
|
if isRealFile: |
|
filename = file.name |
|
else: |
filename=file.filename |
filename=file.filename |
|
|
id=filename[max(filename.rfind('/'), |
id=filename[max(filename.rfind('/'), |
filename.rfind('\\'), |
filename.rfind('\\'), |
filename.rfind(':'), |
filename.rfind(':'), |
Line 447 class extVersionedFileFolder(Folder,ECHO
|
Line 509 class extVersionedFileFolder(Folder,ECHO
|
else: |
else: |
id=newName |
id=newName |
|
|
|
if vC is None: |
vC=self.REQUEST.form['vC'] |
vC=self.REQUEST.form['vC'] |
manage_addextVersionedFile(self,id,'','') |
|
#if (getattr(self,'commentNonEmpty',0)==1) and vC.strip()=="": |
|
|
|
ob=self._getOb(id) |
# get new extVersionedFile |
ob.title=id |
vf = self._newVersionedFile(id,title=id) |
file2=file |
logging.debug("addFile id=%s vf=%s of %s"%(repr(id),repr(vf),repr(self))) |
|
# add its content (and don't index) |
|
obj=vf.addContentObject(id,vC,author=author,file=file,content_type=content_type,from_tmp=isRealFile,index=False) |
|
# add file to this folder (this should do the indexing) |
|
self._setObject(id,vf) |
|
|
logging.info("ADD: %s"%repr(ob)) |
try: |
obj=ob.manage_addVersionedFileObject(id,vC,author,file2,content_type=content_type) |
self.REQUEST.SESSION['objID']=vf.getId() |
self.REQUEST.SESSION['objID']=ob.getId() |
|
self.REQUEST.SESSION['objID_parent']=None |
self.REQUEST.SESSION['objID_parent']=None |
|
except: |
|
pass |
|
|
if obj.getSize()==0: |
if obj.getSize()==0: |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','errorUploadFile')).__of__(self) |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','errorUploadFile')).__of__(self) |
return pt() |
return pt() |
|
|
|
if RESPONSE is not None: |
RESPONSE.redirect(self.REQUEST['URL1']) |
RESPONSE.redirect(self.REQUEST['URL1']) |
|
|
|
|
|
def _newVersionedFile(self, id, title='', lockedBy=None, author=None): |
|
"""factory for versioned files. to be overridden in derived classes.""" |
|
return extVersionedFile(id, title, lockedBy=lockedBy, author=author) |
|
|
|
|
def deleteEmptyObject(self,submit,RESPONSE=None): |
def deleteEmptyObject(self,submit,RESPONSE=None): |
"""deleteemptyobject""" |
"""deleteemptyobject""" |
if submit=="delete it": |
if submit=="delete it": |
Line 485 class extVersionedFileFolder(Folder,ECHO
|
Line 557 class extVersionedFileFolder(Folder,ECHO
|
"""fix last version number of all files""" |
"""fix last version number of all files""" |
for (id,vf) in self.getVersionedFiles(): |
for (id,vf) in self.getVersionedFiles(): |
vf.fixVersionNumbers() |
vf.fixVersionNumbers() |
|
# recursively |
|
for (id,vf) in self.objectItems(self.meta_type): |
|
vf.fixVersionNumbers() |
|
|
|
|
manage_addextVersionedFileFolderForm=DTMLFile('dtml/extfolderAdd', globals()) |
manage_addextVersionedFileFolderForm=DTMLFile('dtml/extfolderAdd', globals()) |
|
|
Line 537 class extVersionedFileObject(ExtFile):
|
Line 613 class extVersionedFileObject(ExtFile):
|
self.time = time |
self.time = time |
self.author = author |
self.author = author |
|
|
|
security.declareProtected('manage','changeObject') |
|
def changeObject(self,**args): |
|
"""modify any of the objects attributes""" |
|
for arg in args: |
|
if hasattr(self, arg): |
|
logging.debug("changeObject %s: %s=%s"%(repr(self),arg,args[arg])) |
|
setattr(self, arg, args[arg]) |
|
|
security.declarePublic('getTitle') |
security.declarePublic('getTitle') |
def getTitle(self): |
def getTitle(self): |
Line 616 class extVersionedFileObject(ExtFile):
|
Line 699 class extVersionedFileObject(ExtFile):
|
|
|
#self.REQUEST.close() |
#self.REQUEST.close() |
|
|
|
view = download |
|
|
security.declareProtected('AUTHENTICATED_USER','downloadLocked') |
security.declareProtected('AUTHENTICATED_USER','downloadLocked') |
def downloadLocked(self): |
def downloadLocked(self): |
"""download and lock""" |
"""download and lock""" |
Line 699 class extVersionedFile(CatalogAware,Fold
|
Line 784 class extVersionedFile(CatalogAware,Fold
|
meta_type = 'extVersionedFile' |
meta_type = 'extVersionedFile' |
# meta_type of contained objects |
# meta_type of contained objects |
content_meta_type = ['extVersionedFileObject'] |
content_meta_type = ['extVersionedFileObject'] |
|
# default catalog for extVersionedFile objects |
default_catalog = 'fileCatalog' |
default_catalog = 'fileCatalog' |
|
|
|
manage_options = Folder.manage_options+({'label':'Main Config','action':'changeVersionedFileForm'},) |
|
|
|
|
security=ClassSecurityInfo() |
security=ClassSecurityInfo() |
|
|
def __init__(self, id, title, lockedBy,author): |
def __init__(self, id, title, lockedBy,author): |
Line 794 class extVersionedFile(CatalogAware,Fold
|
Line 883 class extVersionedFile(CatalogAware,Fold
|
def getLastChangeDate(self): |
def getLastChangeDate(self): |
"""get last change date""" |
"""get last change date""" |
lv=self.getContentObject() |
lv=self.getContentObject() |
|
if lv: |
time=lv.getTime() |
time=lv.getTime() |
return time |
return time |
|
return None |
|
|
def getLastEditor(self): |
def getLastEditor(self): |
"""get last change date""" |
"""get last change date""" |
Line 847 class extVersionedFile(CatalogAware,Fold
|
Line 938 class extVersionedFile(CatalogAware,Fold
|
|
|
def getContentObject(self): |
def getContentObject(self): |
"""returns the last version object""" |
"""returns the last version object""" |
if not self.lastVersionId: |
if not getattr(self, 'lastVersionId', None): |
|
# find last version and save it |
lv = self.findLastVersion() |
lv = self.findLastVersion() |
if lv is None: |
if lv is None: |
return None |
return None |
self.lastVersionNumber = lv.getVersionNumber() |
self.lastVersionNumber = lv.getVersionNumber() |
self.lastVersionId = lv.getId() |
self.lastVersionId = lv.getId() |
|
|
return getattr(self, self.lastVersionId) |
return getattr(self, self.lastVersionId, None) |
|
|
security.declarePublic('getData') |
security.declarePublic('getData') |
def getData(self): |
def getData(self): |
Line 865 class extVersionedFile(CatalogAware,Fold
|
Line 957 class extVersionedFile(CatalogAware,Fold
|
else: |
else: |
return None |
return None |
|
|
|
security.declarePublic('view') |
|
def view(self,REQUEST=None,RESPONSE=None): |
|
"""Returns the last version's view""" |
|
ob = self.getContentObject() |
|
if ob is not None: |
|
return ob.view(REQUEST=REQUEST,RESPONSE=RESPONSE) |
|
else: |
|
return None |
|
|
def diff(self,data): |
def diff(self,data): |
"""differenz between lastversion and data""" |
"""differenz between lastversion and data""" |
d=Differ() |
d=Differ() |
Line 924 class extVersionedFile(CatalogAware,Fold
|
Line 1025 class extVersionedFile(CatalogAware,Fold
|
ret.sort(sortv) |
ret.sort(sortv) |
return ret |
return ret |
|
|
|
def getVersionList(self): |
|
"""get a list of dicts with author, comment, filename, etc, of all versions""" |
|
vl = [] |
|
for v in self.objectValues(self.content_meta_type): |
|
vl.append({'versionNumber':getattr(v,'versionNumber',0), |
|
'title':v.getTitle(), |
|
'id':v.getId(), |
|
'date':v.getTime(), |
|
'author':getattr(v,'author',''), |
|
'comment':getattr(v,'versionComment','') |
|
}) |
|
return vl |
|
|
security.declareProtected('AUTHENTICATED_USER','forceunlock') |
security.declareProtected('AUTHENTICATED_USER','forceunlock') |
def forceunlock(self,RESPONSE=None): |
def forceunlock(self,RESPONSE=None): |
"""unlock""" |
"""unlock""" |
Line 950 class extVersionedFile(CatalogAware,Fold
|
Line 1064 class extVersionedFile(CatalogAware,Fold
|
return extVersionedFileObject(id,title,versionNumber=versionNumber,versionComment=versionComment,time=time,author=author) |
return extVersionedFileObject(id,title,versionNumber=versionNumber,versionComment=versionComment,time=time,author=author) |
|
|
|
|
def addContentObject(self,id,vC,author=None,file=None,title='',changeName='no',newName='',from_tmp=False, |
def addContentObject(self,id,vC,author=None,file=None,title='',changeName='no',newName='',from_tmp=False,index=True, |
precondition='', content_type=''): |
precondition='', content_type=''): |
"""add""" |
"""add""" |
|
|
Line 998 class extVersionedFile(CatalogAware,Fold
|
Line 1112 class extVersionedFile(CatalogAware,Fold
|
self.lastVersionNumber = versNum |
self.lastVersionNumber = versNum |
self.lastVersionId = id |
self.lastVersionId = id |
|
|
logging.debug("addcontentobject: lastversion=%s"%self.getData()) |
#logging.debug("addcontentobject: lastversion=%s"%self.getData()) |
|
#logging.debug("addcontentobject: fob_data=%s"%fob.getData()) |
|
if index and self.default_catalog: |
logging.debug("reindex1: %s in %s"%(repr(self),repr(self.default_catalog))) |
logging.debug("reindex1: %s in %s"%(repr(self),repr(self.default_catalog))) |
self.reindex_object() |
self.reindex_object() |
logging.debug("addcontentobject: fob_data=%s"%fob.getData()) |
|
|
|
return fob |
return fob |
|
|
Line 1044 class extVersionedFile(CatalogAware,Fold
|
Line 1159 class extVersionedFile(CatalogAware,Fold
|
return pt() |
return pt() |
|
|
else: |
else: |
RESPONSE.redirect(self.REQUEST['URL2']) |
RESPONSE.redirect(self.absolute_url()+'/history') |
else: |
else: |
return ob |
return ob |
|
|
|
|
|
changeVersionedFileForm = PageTemplateFile('zpt/changeVersionedFile', globals()) |
|
|
|
def manage_changeVersionedFile(self,title,vC,author,comment,RESPONSE=None): |
|
"""Change VersionedFile metadata""" |
|
self.title = title |
|
self.author = author |
|
cob = self.getContentObject() |
|
if cob: |
|
if vC: |
|
cob.vComment=vC |
|
|
|
if comment=='': |
|
cob.versionComment=None |
|
else: |
|
cob.versionComment=comment |
|
|
|
if RESPONSE: |
|
RESPONSE.redirect('manage_main') |
|
|
|
|
def download(self): |
def download(self): |
"""download and lock""" |
"""download""" |
self.REQUEST.RESPONSE.setHeader("Content-Disposition","""attachement; filename=%s"""%self.getContentObject().getId()) |
self.REQUEST.RESPONSE.setHeader("Content-Disposition","""attachement; filename=%s"""%self.getContentObject().getId()) |
self.REQUEST.RESPONSE.setHeader("Content-Type","application/octet-stream") |
self.REQUEST.RESPONSE.setHeader("Content-Type","application/octet-stream") |
self.content_type="application/octet-stream" |
self.content_type="application/octet-stream" |
self.REQUEST.RESPONSE.redirect(self.REQUEST['URL1']+'/'+self.getId()+'/'+self.getContentObject().getId()) |
self.REQUEST.RESPONSE.redirect(self.REQUEST['URL1']+'/'+self.getId()+'/'+self.getContentObject().getId()) |
|
|
|
|
security.declareProtected('AUTHENTICATED_USER','downloadLocked') |
security.declareProtected('AUTHENTICATED_USER','downloadLocked') |
def downloadLocked(self): |
def downloadLocked(self): |
"""download and lock""" |
"""download and lock""" |