version 1.86, 2008/09/29 12:37:37
|
version 1.102, 2008/10/29 12:10:05
|
Line 1
|
Line 1
|
"""CDLI extensions of the filearchive""" |
"""CDLI extensions of the filearchive""" |
from Products.versionedFile.extVersionedFile import * |
from Products.versionedFile.extVersionedFile import * |
from Products.ZCatalog.CatalogPathAwareness import CatalogAware |
from Products.ZCatalog.CatalogPathAwareness import CatalogAware |
from tempfile import mkstemp,mkdtemp |
|
import os.path |
import os.path |
import os |
import os |
from types import * |
|
import urlparse |
import urlparse |
import urllib |
import urllib |
import cgi |
import cgi |
Line 31 from BTrees.IOBTree import IOBTree
|
Line 29 from BTrees.IOBTree import IOBTree
|
import cdliSplitter |
import cdliSplitter |
from sets import Set |
from sets import Set |
import md5 |
import md5 |
|
from DownloadBasket import DownloadBasketFinallyThread |
|
from types import * |
|
|
def makelist(mySet): |
def makelist(mySet): |
x = list(mySet) |
x = list(mySet) |
Line 224 def unique(s):
|
Line 223 def unique(s):
|
class BasketContent(SimpleItem): |
class BasketContent(SimpleItem): |
"""classe fuer den Inhalt eines Baskets""" |
"""classe fuer den Inhalt eines Baskets""" |
|
|
|
def getFileAndVersionFromId(self,pnum,versionNr): |
|
|
|
obj=self.cdliRoot.getFileObject(pnum) |
|
logging.debug("obj : %s"%obj) |
|
version=obj.getVersionNr(versionNr) |
|
logging.debug("-------vs: %s"%version.getFileName()) |
|
return version,obj |
|
|
def __init__(self,content=[]): |
def __init__(self,content=[]): |
"""content""" |
"""content""" |
self.contentList=content[0:] |
|
|
|
def getContent(self): |
self.setContent(content[0:]) |
"""get content""" |
|
|
|
|
def getContent(self,filtered=True): |
return self.contentList |
return self.contentList |
|
|
|
def getContentOld(self,filtered=True): |
|
"""get content""" |
|
logging.debug("content object: content List %s"%self.contentList) |
|
ret=[] |
|
|
|
return [self.getFileAndVersionFromId(x[0],x[1]) for x in self.contentList] |
|
# |
|
# if filtered: |
|
# for x in self.contentList: |
|
# if not((x[0] is None) or (x[1] is None)): |
|
# ret.append(x) |
|
# logging.debug("content object: content List -done filtered") |
|
# return ret |
|
# |
|
# else: |
|
# logging.debug("content object: content List -done not filtered") |
|
# return self.contentList |
|
|
|
def allContent(self): |
|
"""get all content""" |
|
return self.getContent(filtered=False) |
|
|
def setContent(self,content): |
def setContent(self,content): |
self.contentList=content[0:] |
contentList=[] |
|
for x in content: |
|
if not((x[0] is None) or (x[1] is None)): |
|
|
|
contentList.append((x[1].getId(),x[0].getVersionNumber())) |
|
logging.debug("cl: %s"%contentList) |
|
self.contentList=contentList[0:] |
|
|
def numberOfItems(self): |
def numberOfItems(self): |
"""number""" |
"""number""" |
Line 401 class uploadATFfinallyThread(Thread):
|
Line 435 class uploadATFfinallyThread(Thread):
|
basketId=ob.getId() |
basketId=ob.getId() |
basket=getattr(ctx2.basketContainer,str(basketId)) |
basket=getattr(ctx2.basketContainer,str(basketId)) |
ids=os.listdir(SESSION['tmpdir']) |
ids=os.listdir(SESSION['tmpdir']) |
logging.debug("should add:"+repr(ids)) |
#logging.debug("should add:"+repr(ids)) |
basket.addObjects(ids,deleteOld=True,username=str(username)) |
basket.addObjects(ids,deleteOld=True,username=str(username)) |
|
|
logging.debug("uploadatffinallythread uploadfinally done") |
logging.debug("uploadatffinallythread uploadfinally done") |
Line 616 class CDLIBasketContainer(OrderedFolder)
|
Line 650 class CDLIBasketContainer(OrderedFolder)
|
if not basketId: |
if not basketId: |
return [] |
return [] |
|
|
ob=getattr(self,basketId).getContent() |
ob=getattr(self,basketId).getContent() #get the content of a basket |
|
|
ret=[x[0].split(".")[0] for x in ob] |
ret=[x[0].split(".")[0] for x in ob] |
|
|
Line 635 class CDLIBasketContainer(OrderedFolder)
|
Line 669 class CDLIBasketContainer(OrderedFolder)
|
return "" |
return "" |
|
|
ob=getattr(self,basketId).getLastVersion() |
ob=getattr(self,basketId).getLastVersion() |
for object in ob.getContent(): |
for pnum,versionNr in ob.getContent(): |
|
obj=self.cdliRoot.getFileObject(pnum) |
|
# logging.debug("obj : %s"%obj) |
|
# version=obj.getVersionNr(versionNr) |
|
|
if current=="no": #version as they are in the basket |
if current=="no": #version as they are in the basket |
ret+=str(object[0].getData())+"\n" |
cur= obj.getVersionNr(versionNr) |
|
ret+=str(cur.getData())+"\n" |
elif current=="yes": |
elif current=="yes": |
#search current object |
#search current object |
logging.debug("current: %s"%object[1].getId().split(".")[0]) |
#logging.debug("current: %s"%object[1].getId().split(".")[0]) |
founds=self.CDLICatalog.search({'title':object[1].getId().split(".")[0]}) |
obj.getData() |
if len(founds)>0: |
|
ret+=str(founds[0].getObject().getLastVersion().getData())+"\n" |
|
return ret |
return ret |
|
|
security.declareProtected('manage','upDateBaskets') |
security.declareProtected('manage','upDateBaskets') |
Line 659 class CDLIBasketContainer(OrderedFolder)
|
Line 696 class CDLIBasketContainer(OrderedFolder)
|
def deleteBaskets(self,ids=None): |
def deleteBaskets(self,ids=None): |
"""delete baskets, i.e. move them into trash folder""" |
"""delete baskets, i.e. move them into trash folder""" |
|
|
|
if ids is None: |
|
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','cdliError_html.zpt')).__of__(self) |
|
txt="Sorry, no basket selected!" |
|
return pt(txt=txt) |
|
|
found=self.ZopeFind(self,obj_ids=['trash']) |
found=self.ZopeFind(self,obj_ids=['trash']) |
|
|
Line 670 class CDLIBasketContainer(OrderedFolder)
|
Line 711 class CDLIBasketContainer(OrderedFolder)
|
|
|
if type(ids) is not ListType: |
if type(ids) is not ListType: |
ids=[ids] |
ids=[ids] |
|
logging.error("XERXON:"+repr(ids)) |
|
if len(ids)==0: |
|
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','cdliError_html.zpt')).__of__(self) |
|
txt="Sorry, no basket selected!" |
|
return pt(txt=txt) |
|
|
cut=self.manage_cutObjects(ids) |
cut=self.manage_cutObjects(ids) |
trash.manage_pasteObjects(cut) |
trash.manage_pasteObjects(cut) |
|
return None |
security.declareProtected('manage','manageBaskets') |
security.declareProtected('manage','manageBaskets') |
def manageBaskets(self,submit,ids=None,basket1="",basket2="",joinBasket="",subtractBasket="",REQUEST=None,RESPONSE=None): |
def manageBaskets(self,submit,ids=None,basket1="",basket2="",joinBasket="",subtractBasket="",REQUEST=None,RESPONSE=None): |
"""manage baskets, delete or copy""" |
"""manage baskets, delete or copy""" |
if submit=="delete": |
if submit=="delete": |
self.deleteBaskets(ids) |
ret= self.deleteBaskets(ids) |
|
if ret: |
|
return ret |
elif submit=="join": |
elif submit=="join": |
flag,msg=self.joinBasket(joinBasket, ids) |
flag,msg=self.joinBasket(joinBasket, ids) |
logging.info("joining %s %s"%(flag,msg)) |
logging.info("joining %s %s"%(flag,msg)) |
|
if not flag: |
|
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','cdliError_html.zpt')).__of__(self) |
|
|
|
return pt(txt=msg) |
|
|
elif submit=="subtract": |
elif submit=="subtract": |
logging.info("BBBb %s %s"%(basket1,basket2)) |
logging.info("BBBb %s %s"%(basket1,basket2)) |
Line 821 class CDLIBasketContainer(OrderedFolder)
|
Line 873 class CDLIBasketContainer(OrderedFolder)
|
@param basket2: see above |
@param basket2: see above |
|
|
""" |
""" |
|
|
logging.info("CCCCC %s %s"%(basket1,basket2)) |
logging.info("CCCCC %s %s"%(basket1,basket2)) |
|
|
try: |
try: |
Line 861 class CDLIBasketContainer(OrderedFolder)
|
Line 914 class CDLIBasketContainer(OrderedFolder)
|
@param newbasket: name of the new basket |
@param newbasket: name of the new basket |
@param oldbaskets: list of baskets to be joined |
@param oldbaskets: list of baskets to be joined |
""" |
""" |
|
if oldBaskets is None: |
|
return False, "No Baskets selected!" |
|
|
try: |
try: |
newB=self.addBasket(newBasket) |
newB=self.addBasket(newBasket) |
except: |
except: |
return False, "cannot create the new basket" |
return False, "cannot create the new basket" |
|
|
newBasketContent={} |
newBasketContent={} |
|
|
for ob in oldBaskets: |
for ob in oldBaskets: |
x= getattr(self,ob,None) |
x= getattr(self,ob,None) |
if x is None: |
if x is None: |
Line 1029 class CDLIBasket(Folder,CatalogAware):
|
Line 1086 class CDLIBasket(Folder,CatalogAware):
|
return [x[1].getId() for x in self.getLastVersion().getContent()] |
return [x[1].getId() for x in self.getLastVersion().getContent()] |
|
|
|
|
def isActual(self,obj): |
def isActual(self,obj,nummer): |
|
"""teste ob im basket die aktuelle version ist, obj kann entweder ein CDLIFile sein oder eine |
|
eine pnummer, die auf ein CDLIFile verweist""" |
|
try: |
|
#logging.debug("isActual:"+repr(obj)) |
|
if isinstance(obj, CDLIFile): |
|
actualNo=obj.getLastVersion().getVersionNumber() |
|
else: |
|
actualNo=self.cdliRoot.getFileObjectLastVersion(obj).getVersionNumber() |
|
|
|
if actualNo==nummer: |
|
return True , 0 |
|
else: |
|
return False, actualNo |
|
except: |
|
logging.error( """is actual: %s (%s %s)"""%(repr(obj),sys.exc_info()[0],sys.exc_info()[1])) |
|
logging.error(""" PARAMS: %s %s"""%(obj,nummer)) |
|
return False, -1 |
|
def isActualOld(self,obj): |
"""teste ob im basket die aktuelle version ist""" |
"""teste ob im basket die aktuelle version ist""" |
try: |
try: |
logging.debug("isActual:"+repr(obj)) |
#logging.debug("isActual:"+repr(obj)) |
actualNo=obj[1].getLastVersion().getVersionNumber() |
actualNo=obj[1].getLastVersion().getVersionNumber() |
storedNo=obj[0].getVersionNumber() |
storedNo=obj[0].getVersionNumber() |
|
|
founds=self.CDLICatalog.search({'title':obj[0].getId()}) |
|
if len(founds)>0: |
|
actualNo=founds[0].getObject().getLastVersion().getVersionNumber() |
|
|
|
if len(founds)>0 and founds[0].getObject().aq_parent.getId()==".trash": |
#actualNo=self.getFileObjectLastVersion(obj.getId()).getVersionNumber() |
return False, -1 |
|
|
#if len(founds)>0 and founds[0].getObject().aq_parent.getId()==".trash": |
|
# return False, -1 |
|
|
if actualNo==storedNo: |
if actualNo==storedNo: |
return True , 0 |
return True , 0 |
else: |
else: |
return False, actualNo |
return False, actualNo |
except: |
except: |
|
logging.error( """is actual: %s (%s %s)"""%(repr(obj),sys.exc_info()[0],sys.exc_info()[1])) |
|
|
return False, -1 |
return False, -1 |
|
|
def history(self): |
def history(self): |
Line 1196 class CDLIBasket(Folder,CatalogAware):
|
Line 1272 class CDLIBasket(Folder,CatalogAware):
|
def swap(x): |
def swap(x): |
return (x[1],x[0]) |
return (x[1],x[0]) |
|
|
|
logging.info("add to basket (%s)"%(repr(ids))) |
logging.info("add to basket (%s)"%(self.getId())) |
logging.info("add to basket (%s)"%(self.getId())) |
lastVersion=self.getLastVersion() |
lastVersion=self.getLastVersion() |
|
|
Line 1223 class CDLIBasket(Folder,CatalogAware):
|
Line 1300 class CDLIBasket(Folder,CatalogAware):
|
|
|
hash = md5.new(repr(makelist(ids))).hexdigest() # erzeuge hash als identification |
hash = md5.new(repr(makelist(ids))).hexdigest() # erzeuge hash als identification |
#logging.debug("JJJJJJJ:"+repr(self.makelist(ids))) |
#logging.debug("JJJJJJJ:"+repr(self.makelist(ids))) |
logging.debug("JJJJJJJ:"+repr(hash)) |
|
|
|
if hasattr(self.cdliRoot,'v_tmpStore') and self.cdliRoot.v_tmpStore.has_key(hash): |
|
logging.debug("from store!") |
|
newContent=Set(map(swap,self.cdliRoot.v_tmpStore[hash])) |
|
|
|
|
retrieved = self.CDLICache.retrieve(hash) |
|
if retrieved: |
|
newContent=Set(map(swap,retrieved)) |
else: |
else: |
logging.debug("not from store!") |
|
newContent=Set([(self.getFileObjectLastVersion(x),self.getFileObject(x)) for x in ids]) |
newContent=Set([(self.getFileObjectLastVersion(x),self.getFileObject(x)) for x in ids]) |
|
|
|
|
|
|
|
#remove all Elements which are not stored |
|
if (None,None) in newContent: |
|
newContent.remove((None,None)) |
content=Set(oldContent).union(newContent) |
content=Set(oldContent).union(newContent) |
added = len(content)-len(oldContent) |
added = len(content)-len(oldContent) |
if not username: |
if not username: |
Line 1253 class CDLIBasket(Folder,CatalogAware):
|
Line 1331 class CDLIBasket(Folder,CatalogAware):
|
ret=[] |
ret=[] |
|
|
lv=self.getLastVersion() |
lv=self.getLastVersion() |
for obj in lv.content.getContent(): |
#for obj in lv.content.getContent(): |
logging.info("XXXXXXXXXX %s"%repr(obj)) |
#logging.info("XXXXXXXXXX %s"%repr(obj)) |
ret.append((obj[1].getId(),obj[0].versionNumber)) |
# ret.append((obj[1].getId(),obj[0].versionNumber)) |
|
|
return ret |
return lv |
|
|
def getContentIds(self): |
def getContentIds(self): |
"""print basket content""" |
"""print basket content""" |
Line 1341 class CDLIBasketVersion(Implicit,Persist
|
Line 1419 class CDLIBasketVersion(Implicit,Persist
|
|
|
objs=self.getContent() |
objs=self.getContent() |
for obj in objs: |
for obj in objs: |
if not self.isActual(obj)[0]: |
if not self.isActual(obj[0],obj[1])[0]: |
return True |
return True |
return False |
return False |
|
|
Line 1377 class CDLIBasketVersion(Implicit,Persist
|
Line 1455 class CDLIBasketVersion(Implicit,Persist
|
|
|
return self.downloadObjectsAsOneFileFinally(lock=lock,procedure=procedure,REQUEST=REQUEST,current="no") |
return self.downloadObjectsAsOneFileFinally(lock=lock,procedure=procedure,REQUEST=REQUEST,current="no") |
|
|
def downloadObjectsAsOneFileFinally(self,lock=None,procedure=None,REQUEST=None,current="no"): |
def downloadObjectsAsOneFileFinally(self,lock=None,procedure=None,REQUEST=None,current="no",repeat=None): |
"""print do the download""" |
"""print do the download""" |
logging.debug("HIHHHH") |
|
|
|
ret="" |
ret="" |
lockedObjects={} |
lockedObjects={} |
|
|
self.temp_folder.downloadCounterBaskets+=1 |
|
self._p_changed=1 |
|
transaction.get().commit() |
|
|
|
if lock: |
|
|
|
|
if lock: |
|
logging.debug("------lock:"+repr(lock)) |
if str(self.REQUEST['AUTHENTICATED_USER'])=='Anonymous User': |
if str(self.REQUEST['AUTHENTICATED_USER'])=='Anonymous User': |
self.temp_folder.downloadCounterBaskets-=1 |
|
self._p_changed=1 |
|
transaction.get().commit() |
|
self.temp_folder.downloadCounterBaskets-=1 |
|
self._p_changed=1 |
|
transaction.get().commit() |
|
return "please login first" |
return "please login first" |
|
|
#check if a locked object exist in the basket. |
#check if a locked object exist in the basket. |
lockedObjects={} |
lockedObjects={} |
for object in self.content.getContent(): |
for object in self.content.getContent(): |
|
obj=self.getFileObject(object[0]) |
if (not str(object[1].lockedBy)=="") and (not (str(object[1].lockedBy)==str(self.REQUEST['AUTHENTICATED_USER']))): |
if (not str(obj.lockedBy)=="") and (not (str(obj.lockedBy)==str(self.REQUEST['AUTHENTICATED_USER']))): |
lockedObjects[object[1].title]=repr(object[1].lockedBy) |
lockedObjects[obj.title]=repr(obj.lockedBy) |
|
|
|
|
keys=lockedObjects.keys() |
keys=lockedObjects.keys() |
Line 1413 class CDLIBasketVersion(Implicit,Persist
|
Line 1485 class CDLIBasketVersion(Implicit,Persist
|
self.REQUEST.SESSION['lockedObjects']=lockedObjects |
self.REQUEST.SESSION['lockedObjects']=lockedObjects |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','lockedObjects.zpt')).__of__(self) |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','lockedObjects.zpt')).__of__(self) |
|
|
self.temp_folder.downloadCounterBaskets-=1 |
|
self._p_changed=1 |
|
transaction.get().commit() |
|
|
|
return pt() |
return pt() |
|
|
Line 1425 class CDLIBasketVersion(Implicit,Persist
|
Line 1494 class CDLIBasketVersion(Implicit,Persist
|
|
|
|
|
|
|
|
threadName=repeat |
|
if not threadName or threadName=="": |
|
thread=DownloadBasketFinallyThread() |
|
threadName=thread.getName()[0:] |
|
|
|
if (not hasattr(self,'_v_downloadBasket')): |
|
self._v_downloadBasket={} |
|
|
|
|
|
self._v_downloadBasket[threadName]=thread |
|
logging.debug("dwonloadfinally:"+repr(self)) |
|
|
|
if isinstance(self,CDLIBasketVersion): |
|
obj=self |
|
else: |
|
obj=self.aq_parent |
|
logging.debug("dwonloadfinally2:"+repr(obj)) |
|
logging.debug("dwonloadfinally2:"+repr(obj.aq_parent)) |
|
|
|
obj2=obj.aq_parent |
|
if not isinstance(obj2,CDLIBasket): |
|
obj2=obj2.aq_parent |
|
|
|
basketID=obj2.getId() |
|
versionNumber=obj.getId() |
|
logging.debug("dwonloadfinally2:"+repr(basketID)) |
|
logging.debug("dwonloadfinally2:"+repr(versionNumber)) |
|
|
|
|
|
if lock: |
|
logging.debug("-----start locking") |
for object in self.content.getContent(): |
for object in self.content.getContent(): |
logging.error("ret:"+repr(object[0])) |
obj=self.ctx.getFileObject(object[0]) |
logging.error(" -"+repr(procedure)) |
if obj.lockedBy =='': |
logging.error(" -"+repr(object[1].lockedBy)) |
obj.lockedBy=self.REQUEST['AUTHENTICATED_USER'] |
|
logging.debug("-----finished locking") |
|
|
if (procedure=="downloadAll") or (object[1].lockedBy=='') or (object[1].lockedBy==self.REQUEST['AUTHENTICATED_USER']): |
#obj.lockedBy=user |
logging.error("ret1") |
self._v_downloadBasket[threadName].set(lock,procedure,self.REQUEST['AUTHENTICATED_USER'],current,basketID,versionNumber) |
if current=="no": #version as they are in the basket |
|
logging.error("ret2") |
self._v_downloadBasket[threadName].start() |
ret+=str(object[0].getData())+"\n" |
|
elif current=="yes": |
|
logging.error("ret3") |
|
#search current object |
wait_template=self.aq_parent.ZopeFind(self.aq_parent,obj_ids=['wait_template']) |
founds=self.CDLICatalog.search({'title':object[1].getId().split(".")[0]}) |
|
if len(founds)>0: |
if wait_template: |
ret+=str(founds[0].getObject().getLastVersion().getData())+"\n" |
return wait_template[0][1]() |
|
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','downloadBasketWait.zpt')).__of__(self) |
|
|
|
return pt(txt=self.absolute_url()+'/downloadObjectsAsOneFileFinally',threadName=threadName, |
|
counter=self._v_downloadBasket[threadName].getCounter(), |
|
number=self._v_downloadBasket[threadName].getNumberOfFiles()) |
|
#_v_xmltrans.run() |
|
|
|
else: |
|
#recover thread, if lost |
|
if not hasattr(self,'_v_downloadBasket'): |
|
self._v_downloadBasket={} |
|
if not self._v_downloadBasket.get(threadName,None): |
|
for thread in threading.enumerate(): |
|
if threadName == thread.getName(): |
|
self._v_downloadBasket[threadName]=thread |
|
|
|
if self._v_downloadBasket.get(threadName,None) and (self._v_downloadBasket[threadName] is not None) and (not self._v_downloadBasket[threadName].end) : |
|
|
|
wait_template=self.aq_parent.ZopeFind(self.aq_parent,obj_ids=['wait_template']) |
|
if wait_template: |
|
return wait_template[0][1]() |
|
|
|
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','downloadBasketWait.zpt')).__of__(self) |
|
return pt(txt=self.absolute_url()+'/downloadObjectsAsOneFileFinally',threadName=threadName, |
|
counter=self._v_downloadBasket[threadName].getCounter(), |
|
number=self._v_downloadBasket[threadName].getNumberOfFiles()) |
|
else: |
|
|
if lock and object[1].lockedBy=='': |
|
object[1].lockedBy=self.REQUEST['AUTHENTICATED_USER'] |
logging.debug("FINISHED") |
|
if not self._v_downloadBasket.get(threadName,None): |
|
for thread in threading.enumerate(): |
|
if threadName == thread.getName(): |
|
self._v_downloadBasket[threadName]=thread |
|
|
|
#files = self._v_downloadBasket[threadName].result |
|
files=self.basketContainer.resultHash[threadName] |
|
lockedFiles=self.basketContainer.resultLockedHash[threadName] |
|
|
|
# fh=file("/var/tmp/test") |
|
#ret =fh.read() |
|
|
if (not isinstance(self.aq_parent,CDLIBasket)): |
if (not isinstance(self.aq_parent,CDLIBasket)): |
basket_name=self.aq_parent.aq_parent.title+"_V"+self.getId() |
basket_name=self.aq_parent.aq_parent.title+"_V"+self.getId() |
Line 1453 class CDLIBasketVersion(Implicit,Persist
|
Line 1592 class CDLIBasketVersion(Implicit,Persist
|
|
|
|
|
#write basketname to header of atf file |
#write basketname to header of atf file |
ret="#basket: %s\n"%basket_name+ret |
|
|
|
self.temp_folder.downloadCounterBaskets-=1 |
|
self._p_changed=1 |
|
transaction.get().commit() |
|
|
|
self.REQUEST.RESPONSE.setHeader("Content-Disposition","""attachement; filename="%s.atf" """%basket_name) |
self.REQUEST.RESPONSE.setHeader("Content-Disposition","""attachement; filename="%s.atf" """%basket_name) |
self.REQUEST.RESPONSE.setHeader("Content-Type","application/octet-stream") |
self.REQUEST.RESPONSE.setHeader("Content-Type","application/octet-stream") |
length=len(ret) |
#length=len(ret) |
self.REQUEST.RESPONSE.setHeader("Content-Length",length) |
#self.REQUEST.RESPONSE.setHeader("Content-Length",length) |
|
|
|
ret="#basket: %s\n"%basket_name |
self.REQUEST.RESPONSE.write(ret) |
self.REQUEST.RESPONSE.write(ret) |
return True |
|
|
for fileName in files: |
|
logging.debug("download: %s"%fileName) |
|
try: |
|
self.REQUEST.RESPONSE.write(file(fileName).read()) |
|
except: |
|
logging.error("downloadasonefile: cannot read %s"%fileName) |
|
|
|
|
|
self.REQUEST.RESPONSE.write("\n# locked files\n") |
|
for fileName in lockedFiles: |
|
self.REQUEST.RESPONSE.write("# %s by %s\n"%fileName) |
|
|
|
self.REQUEST.RESPONSE.write("# locked files end\n") |
|
|
|
del self.basketContainer.resultHash[threadName] |
|
del self.basketContainer.resultLockedHash[threadName] |
|
|
def numberOfItems(self): |
def numberOfItems(self): |
"""return anzahl der elemente im basket""" |
"""return anzahl der elemente im basket""" |
Line 1484 class CDLIBasketVersion(Implicit,Persist
|
Line 1637 class CDLIBasketVersion(Implicit,Persist
|
|
|
def getContent(self): |
def getContent(self): |
"""get Basket Content""" |
"""get Basket Content""" |
return self.content.getContent() |
logging.debug("retrieving content A") |
|
cnt = self.content |
|
logging.debug("retrieving content: obj %s"%cnt) |
|
tmp = self.content.getContent() |
|
logging.debug("got content") |
|
return tmp |
|
|
|
|
def __init__(self,id,user,comment="",basketContent=[]): |
def __init__(self,id,user,comment="",basketContent=[]): |
Line 1507 class CDLIBasketVersion(Implicit,Persist
|
Line 1665 class CDLIBasketVersion(Implicit,Persist
|
security.declareProtected('manage','index_html') |
security.declareProtected('manage','index_html') |
def index_html(self): |
def index_html(self): |
"""view the basket""" |
"""view the basket""" |
|
logging.debug("start index_html - Basket version") |
if self.REQUEST.get('change',False): |
if self.REQUEST.get('change',False): |
ob=self.aq_parent.updateObjects(self.REQUEST['change']) |
ob=self.aq_parent.updateObjects(self.REQUEST['change']) |
|
|
self.REQUEST.RESPONSE.redirect(ob.absolute_url())#go to new basket, because changing generates a new basket |
self.REQUEST.RESPONSE.redirect(ob.absolute_url())#go to new basket, because changing generates a new basket |
|
logging.debug("start index_html - Basket version:template") |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','BasketVersionMain.zpt')).__of__(self) |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','BasketVersionMain.zpt')).__of__(self) |
return pt() |
return pt() |
|
|
def getObjUrl(self,result): |
def getObjUrl(self,result): |
"""getUrl of the version of the object""" |
"""getUrl of the version of the object""" |
objId=result[1].getTitle() |
|
founds=self.CDLICatalog.search({'title':objId}) |
founds=self.CDLICatalog.search({'title':result}) |
if len(founds)>0: |
if len(founds)>0: |
return founds[0].getObject().getLastVersion().absolute_url() |
return founds[0].getObject().getLastVersion().absolute_url() |
|
|
else: #assume version number |
else: #assume version number |
splitted=objId.split("_") |
splitted=result.split("_") |
founds=self.CDLICatalog.search({'title':splitted[1]}) |
founds=self.CDLICatalog.search({'title':splitted[1]}) |
return founds[0].getObject().getLastVersion().absolute_url()+'/'+objId |
return founds[0].getObject().getLastVersion().absolute_url()+'/'+result |
|
|
def manage_addCDLIBasketVersion(self,user,comment="",basketContent=[],RESPONSE=None): |
def manage_addCDLIBasketVersion(self,user,comment="",basketContent=[],RESPONSE=None): |
"""add a version""" |
"""add a version""" |
Line 1568 class CDLIFileObject(CatalogAware,extVer
|
Line 1726 class CDLIFileObject(CatalogAware,extVer
|
"""Return cataloguable key for ourselves.""" |
"""Return cataloguable key for ourselves.""" |
return str(self) |
return str(self) |
|
|
|
def setAuthor(self, author): |
|
"""change the author""" |
|
self.author = author |
|
|
def makeThisVersionCurrent_html(self): |
def makeThisVersionCurrent_html(self): |
"""form for mthis version current""" |
"""form for mthis version current""" |
|
|
Line 2025 class CDLIFileFolder(extVersionedFileFol
|
Line 2187 class CDLIFileFolder(extVersionedFileFol
|
pt=getattr(self,'filelist.html') |
pt=getattr(self,'filelist.html') |
return pt(basketName=basketName,numberOfObjects=numberOfObjects) |
return pt(basketName=basketName,numberOfObjects=numberOfObjects) |
|
|
if hash is not None and hasattr(self.cdliRoot,'v_tmpStore') and self.cdliRoot.v_tmpStore.has_key(hash): |
|
|
|
logging.debug("asking for storage2") |
result =self.CDLICache.retrieve(hash) |
result =self.cdliRoot.v_tmpStore[hash] |
|
if result: |
if result: |
logging.debug("give result from storage2") |
logging.debug("give result from storage2") |
return hash,self.cdliRoot.v_tmpStore[hash] |
return hash,result |
|
|
if list is not None: # got already a list |
if list is not None: # got already a list |
|
|
Line 2058 class CDLIFileFolder(extVersionedFileFol
|
Line 2218 class CDLIFileFolder(extVersionedFileFol
|
ids = fileTree & self.v_file_ids |
ids = fileTree & self.v_file_ids |
#self.REQUEST.SESSION['fileIds']=ids#store fieldIds in session for further usage |
#self.REQUEST.SESSION['fileIds']=ids#store fieldIds in session for further usage |
l=makelist(fileTree)[0:] |
l=makelist(fileTree)[0:] |
logging.debug("l-list:"+repr(l)) |
#logging.debug("l-list:"+repr(l)) |
self.REQUEST.SESSION['fileIds']=l#store fieldIds in session for further usage |
self.REQUEST.SESSION['fileIds']=l#store fieldIds in session for further usage |
self.REQUEST.SESSION['searchList']=l |
self.REQUEST.SESSION['searchList']=l |
#self.REQUEST.SESSION['searchList']=['P000001.atf'] |
#self.REQUEST.SESSION['searchList']=['P000001.atf'] |
Line 2091 class CDLIFileFolder(extVersionedFileFol
|
Line 2251 class CDLIFileFolder(extVersionedFileFol
|
return pt(search=ids) |
return pt(search=ids) |
else: |
else: |
#self.REQUEST.SESSION['hash'] = ret # store in session |
#self.REQUEST.SESSION['hash'] = ret # store in session |
if not hasattr(self,'v_tmpStore'): |
|
self.cdliRoot.v_tmpStore={} |
|
#logging.debug("HHHHHHNEU:"+repr(self.makelist(ids))) |
#logging.debug("HHHHHHNEU:"+repr(self.makelist(ids))) |
#logging.debug("HHHHHHNEU:"+repr(hash)) |
#logging.debug("HHHHHHNEU:"+repr(hash)) |
self.cdliRoot.v_tmpStore[hash] = ret # store in session |
self.CDLICache.store(hash,ret) |
|
|
if returnHash == True: |
if returnHash == True: |
return hash,ret |
return hash,ret |
return ret |
return ret |
Line 2232 class CDLIRoot(Folder):
|
Line 2392 class CDLIRoot(Folder):
|
'graphemes':cdliSplitter.graphemeSplitter()} |
'graphemes':cdliSplitter.graphemeSplitter()} |
|
|
|
|
|
def unicodify(self,txt): |
|
return unicodify(txt) |
|
def invalidateOldCacheVersion(self): |
|
"""loescht die alte Version des Cache""" |
|
del self.v_tmpStore |
|
return "done" |
|
|
def viewATF(self,id,RESPONSE): |
def viewATF(self,id,RESPONSE): |
"""view an Object""" |
"""view an Object""" |
ob = self.CDLICatalog({'title':id}) |
ob = self.CDLICatalog({'title':id}) |
Line 2291 class CDLIRoot(Folder):
|
Line 2458 class CDLIRoot(Folder):
|
def getFileObjectLastVersion(self,fileId): |
def getFileObjectLastVersion(self,fileId): |
"""get an object""" |
"""get an object""" |
x=self.v_files_lastVersion.get(fileId) |
x=self.v_files_lastVersion.get(fileId) |
#logging.debug(x) |
#logging.debug("lastVersion: "+repr(x)) |
return x |
return x |
|
|
def showFileIds(self): |
def showFileIds(self): |
Line 2587 class CDLIRoot(Folder):
|
Line 2754 class CDLIRoot(Folder):
|
|
|
return """ 2;url=%s?repeat=%s """%(self.absolute_url()+txt,threadName) |
return """ 2;url=%s?repeat=%s """%(self.absolute_url()+txt,threadName) |
|
|
|
def refreshTxtBasket(self,txt="",threadName=None): |
|
"""txt fuer refresh""" |
|
|
|
return """ 2;url=%s?repeat=%s """%(txt,threadName) |
|
|
|
|
def getResult(self,threadName=None): |
def getResult(self,threadName=None): |
"""result of thread""" |
"""result of thread""" |