Diff for /ECHO_content/ECHO_xslt.py between versions 1.1 and 1.9

version 1.1, 2005/04/07 21:01:10 version 1.9, 2006/09/10 22:57:38
Line 1 Line 1
 ### XSLT Class ###  ### XSLT Class ###
 ### setzt 4 suite vorraus ###  ### setzt 4 suite vorraus ###
   from Acquisition import Implicit
 from Products.PageTemplates.PageTemplateFile import PageTemplateFile  from Products.PageTemplates.PageTemplateFile import PageTemplateFile
 from Globals import DTMLFile  from Globals import DTMLFile
 from ECHO_Nav import ECHO_pageTemplate  from ECHO_Nav import ECHO_pageTemplate
   from threading import Thread,Timer
   import threading
   from ECHO_helpers import *
   import ECHO_language
   import sys
   import urllib
   import urlparse
   from Ft.Xml.Domlette import Print, PrettyPrint
   from StringIO import StringIO
   from types import *
 from Globals import package_home  from Globals import package_home
   import transaction
   
 import os.path  import os.path
   
Line 13  import urllib Line 23  import urllib
   
 try:  try:
     from Ft.Xml.Xslt.Processor import Processor      from Ft.Xml.Xslt.Processor import Processor
     from Ft.Xml import InputSource      from Ft.Xml import InputSource, EMPTY_NAMESPACE,Parse
       
 except:  except:
     print "4suite has to be installed"      print "4suite has to be installed"
   
   
 class ECHO_xslt(ECHO_pageTemplate):  class getXML(Implicit):
       """get XML thread"""
   
       def set(self,qs,xsl,result):
           """set"""
      
           self._v_qs=qs
           self.xsl=xsl
           self.result=None        
   
   #    def acquireLock(self):
   #    
   #         lock=getattr(self, "_v_lock", None)
   #         if not lock:
   #             self._v_lock=threading.Lock()
   #             lock=self._v_lock
   #         lock.acquire()
   #
   #    def releaseLock(self):
   #         # acquire() should have been called
   #         # about one second before. This means the volatile lock
   #         # should still be there
   #    
   #         self._v_lock.release()
   #        
     
       def __call__(self):
           """wait"""
           return True
       
       def run(self):
           """call it"""
           xml=""
   
           try:
     
               urlH=urllib.urlopen(self._v_qs)
               xml=urlH.read()
               urlH.close()
               xsltproc=Processor()
               document = InputSource.DefaultFactory.fromString(xml)
               
               stylesheet = InputSource.DefaultFactory.fromUri(self.xsl)
               
               xsltproc.appendStylesheet(stylesheet)
               
           
               #print self.xsl
               #print xsltproc.run(document)
               tmp=xsltproc.run(document)
               
               self.result=tmp[0:]
               
           
           except:
                  
                  self.result="<html>error: %s %s<br>"%sys.exc_info()[0:2]
                  self.result+=xml
                  self.result+="</html>"
           
           
       
       def getResult(self):
   
           return self.result
   
   from ZODB import DB
   from ZODB.FileStorage import FileStorage
   class ECHO_cache:
       def __init__(self):
           """init the storage"""
           self.storage=FileStorage("/var/tmp/echo_cache.fs")
           self.db=DB(self.storage)    
           self.connection=self.db.open()
           self.root=self.connection.root()
       
       def deleteObject(self,name,pn=None):
           """delete an object from cache"""
           fileStore=self.root.get(name,None)
           if fileStore:
               if not pn:
                   del(self.root[name])
               else:
                   if self.root[name].get(pn,None):
                       del(self.root[name][pn])
                       
           
       def storeObject(self,name,pn,object):
           """store an object"""
           
           if not self.root.get(name,None):
               self.root[name]={}
               
   
           #following is necessary to make clear that object has really changed for ZODB
           tmp=self.root[name]
           tmp[pn]=object
           self.root[name]=tmp
           transaction.get().commit()
           return True
      
       def retrieveObject(self,name,pn):
           """retrieve it"""
           
           fileStore=self.root.get(name,None)
           if not fileStore:
               return None
           else:
               return self.root[name].get(pn,None)
           
   
   class ECHO_xslt(ECHO_pageTemplate,ECHO_language.ECHO_language):
     """ECHO_xslt classe"""      """ECHO_xslt classe"""
   
     meta_type="ECHO_xslt"      meta_type="ECHO_xslt"
   
       cache=ECHO_cache()
       
       results={}
       manage_options=ECHO_pageTemplate.manage_options+(
        {'label':'Change xml-ressource','action':'change_ECHO_xsltForm'},)
        
       def refreshTxt(self):
           """txt fuer refresh"""
           return """ 2;url=%s?repeat=%s """%(self.absolute_url(),self.threadName)
   
     def xslt(self):      def xslt(self):
           """xslt"""
   
           return self.document_src()
   
       def change_ECHO_xsltForm(self):
           """change form"""
           pt=zptFile(self, 'zpt/ChangeECHO_xsltForm.zpt')
           return pt()
   
       def addChanges(self,cgiUrl,RESPONSE=None):
           """change the xslt, ueberschriebt addChanges in ECHO_PageTemplate"""
           if urlparse.urlparse(cgiUrl)[0]=="":#relative url in absolute
               self.cgiUrl=urlparse.urljoin(self.absolute_url(), cgiUrl)
           else:
               self.cgiUrl=cgiUrl
               
           if RESPONSE:
               RESPONSE.redirect("manage_main")
           
       def index_html(self,repeat=None):
         """standard ausgabe"""          """standard ausgabe"""
   
         self.cgiUrl="http://nausikaa2.mpiwg-berlin.mpg.de/cgi-bin/search/q1"          threadName=repeat
           
           if not threadName or threadName=="":
               
               #abwaertskompatibilitŠt mit altem nivht konfigurierbaren prototypen
               
               if getattr(self,'cgiUrl','')=='':
                   self.cgiUrl="http://medea.mpiwg-berlin.mpg.de/cgi-bin/search/q1"
                   
               qs="%s%s"%(self.cgiUrl,self.REQUEST['QUERY_STRING'])
               xsl=self.absolute_url()+"/xslt"
               self._v_xmltrans=getXML().__of__(self)
               #self._xmltrans.start()
               thread=Thread(target=self._v_xmltrans)
               thread.start()
               self._v_xmltrans.set(qs,xsl,None)
               self._v_xmltrans.run()
               
               
               self.threadName=thread.getName()[0:]
               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','xsltWait.zpt')).__of__(self)
               return pt()
               #_v_xmltrans.run()
   
         qs="%s?%s"%(self.cgiUrl,self.REQUEST['QUERY_STRING'])          else:
               
               if (self._v_xmltrans.getResult()==None):
   
                   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','xsltWait.zpt')).__of__(self)
                   return pt()
               else:
                   return self._v_xmltrans.getResult()
   
       
   
       def deleteCache(self):
           """deletefrom cache"""
           fn=self.REQUEST['fn']
           self.cache.deleteObject(fn)
           
       def getPageLex(self,_pn="1",_caching="yes"):
           """getpage mit lexikalischer analyse und xslt transform
           if _caching=yes dann wird die lwxikalisch analysierte seite in einem cache abgespeichert
           """
          
           fn=self.REQUEST['fn']
   
           
           fromCache=self.cache.retrieveObject(fn,_pn)
   
           if fromCache and _caching=="yes":
               print "retrieve",fn,_pn 
               txt = fromCache
           else:
               txt=self.tagLex(nr=_pn)   
               print "store",fn,_pn 
               self.cache.storeObject(fn,_pn,txt[0:])
   
         #urlH=urllib.urlopen(qs)          xsl=self.xslt()
         #xml=urlH.read()  
         #urlH.close()  
         #print xml  
         #return xml  
           
         xsltproc=Processor()          xsltproc=Processor()
         document = InputSource.DefaultFactory.fromUri(qs)          if type(txt)==UnicodeType:
         stylesheet = InputSource.DefaultFactory.fromUri(self.absolute_url())              document = InputSource.DefaultFactory.fromString(txt.encode('utf-8'))
           else:
               document = InputSource.DefaultFactory.fromString(txt)
           stylesheet = InputSource.DefaultFactory.fromString(xsl)
         xsltproc.appendStylesheet(stylesheet)          xsltproc.appendStylesheet(stylesheet)
           tmp=xsltproc.run(document)
           
           return tmp[0:]
               
   
       def getPage(self,_pn,REQUEST=None):
           """get a page from an xml"""
           pn=int(_pn)-1
           if pn<0:
               if REQUEST:
                   return "Sorry, pagenumbers have to be greater than 0"
               else:
                   return None
           impl=xml.dom.getDOMImplementation()
           newDoc=impl.createDocument(EMPTY_NAMESPACE,None,None
                                      )
           root=newDoc.createElement('page')
           newDoc.appendChild(root)
           
           
           qs="%s%s"%(self.cgiUrl,self.REQUEST['QUERY_STRING'])
           
           
        
           xmlt=urllib.urlopen(qs).read()
           dom=Parse(xmlt)
          
           pbs=dom.xpath("//pb")
           if pn > len(pbs):
               if REQUEST:
                   return "Sorry, pagenumber %s does not exit"%pn+1
               else:
                   return None
               
           beginNode=pbs[pn] #take the n'th pb
   
           if not (pn==len(pbs)-1): # nicht die letzte Seite
               endNode=pbs[pn+1]
           else:
               endNode=None
           
              
   #        follower=beginNode.xpath('following::node()')
   #        #root.appendChild(beginNode)
   #        found=[]
   #       
   #        for node in endNode.xpath('preceding::node()'):
   #            if node in follower:
   #                found.append(node)
   #    
           
      
           #rempove all children of parents which are also in the list
   #        for x in found:
   #            for child in x.xpath(".//*"):
   #                try:
   #                  
   #                    nr=found.index(child)
   #               
   #                    del(found[nr])
   #                except:
   #                    pass
   #
   #        found.append(endNode)
   #       
           deleteNodes=beginNode.xpath('preceding::node()')
           if endNode:
               deleteNodes+=endNode.xpath('following::node()')
           for node in deleteNodes:
               try:
                   parent=node.xpath("..")
              
                   if parent:
                       parent[0].removeChild(node)
               except:
                   zLOG.LOG("ECHO_Resource (getAccessRightMD)", zLOG.INFO,"%s (%s)"%sys.exc_info()[0:2])
           strio = StringIO()
           PrettyPrint(dom,strio) 
           xmlstr = strio.getvalue()
   
         html=xsltproc.run(document)          return xmlstr
                                           
         return html  
   
   
 def manage_addECHO_xsltForm(self):  def manage_addECHO_xsltForm(self):
Line 55  def manage_addECHO_xsltForm(self): Line 343  def manage_addECHO_xsltForm(self):
 from urllib import quote  from urllib import quote
   
   
 def manage_addECHO_xslt(self, id, label, weight= 0,contentType=0,title=None, text=None,  def manage_addECHO_xslt(self, id, label, weight= 0,contentType=0,title=None, text=None, cgiUrl=None,
                            REQUEST=None, submit=None):                             REQUEST=None, submit=None):
     "Add a Page Template with optional file content."      "Add a Page Template with optional file content."
   
Line 70  def manage_addECHO_xslt(self, id, label, Line 358  def manage_addECHO_xslt(self, id, label,
         if title:          if title:
             ob.pt_setTitle(title)              ob.pt_setTitle(title)
         return ob          return ob
           setattr(ob,'cgiUrl',cgiUrl)
     else:      else:
         file = REQUEST.form.get('file')          file = REQUEST.form.get('file')
         headers = getattr(file, 'headers', None)          headers = getattr(file, 'headers', None)
Line 82  def manage_addECHO_xslt(self, id, label, Line 371  def manage_addECHO_xslt(self, id, label,
         ob = getattr(self, id)          ob = getattr(self, id)
         setattr(ob,'weight',weight)          setattr(ob,'weight',weight)
         setattr(ob,'label',label)          setattr(ob,'label',label)
           setattr(ob,'cgiUrl',cgiUrl)
         if title:          if title:
             ob.pt_setTitle(title)              ob.pt_setTitle(title)
                   

Removed from v.1.1  
changed lines
  Added in v.1.9


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>