source: TI05-delivery/ows_framework/trunk/ows_server/ows_server/controllers/retrieve.py @ 2800

Subversion URL: http://proj.badc.rl.ac.uk/svn/ndg/TI05-delivery/ows_framework/trunk/ows_server/ows_server/controllers/retrieve.py@2800
Revision 2800, 6.6 KB checked in by lawrence, 14 years ago (diff)

Changing to the new tab layout ... (incomplete)

Line 
1
2from ows_server.lib.base import *
3from ows_server.models import ndgObject,  Utilities
4from paste.request import parse_querystring
5from ows_server.models import stubB,DIF
6from ows_server.lib import mailer
7from ows_server.lib.ndgInterface import interface
8from xml.parsers.expat import ExpatError
9#from ows_server.models import ndgRetrieve
10
11class RetrieveController(BaseController):
12    ''' Provides the pylons controller for retrieving NDG documents. The simple model
13    is now that an attempt to retrieve/uri will parse the uri, read the config file,
14    and if the local server name is not the same as the uri server name. '''
15   
16    def __setup(self,uri):
17        ''' Common setup stuff for all the actions on this controller '''
18        try:
19            self.uri=ndgObject.ndgObject(uri)
20        except ValueError,e:
21            return e
22        self.cf=request.environ['ndgConfig']
23        self.uri.setConfig(self.cf)
24        self.requestor=request.environ['REMOTE_ADDR']
25        self.logger=0
26        if logger: self.logger=logger
27        self.inputs=dict(parse_querystring(request.environ))
28        # it's kind of unfortunate that format=(xml,html) is what we expect in the
29        # url but at the retrieval level format is the schema ... oh well ...
30        self.format=''
31        if 'original' in self.inputs:
32            self.format={'0':'','1':'original'}[self.inputs['original']]
33        return 0
34       
35    def index(self,uri):
36        ''' Returns the document unadorned in anyway, i.e. the raw xml'''
37        status=self.__setup(uri)
38        if status:
39            c.xml='<p>%s</p>'%status
40            return render_response('error')
41        status,x=interface(self.uri,self.cf,logger=self.logger,format=self.format)
42       
43        if status:
44            #(the return object x is an xmlHandler object)
45            c.xml=x.tohtml()
46            return Response(c.xml)
47        else:
48            return Response(x) 
49       
50    def view(self,uri):
51        ''' Returns either an html marked up version of the xml, or a properly laid
52        out version of the document '''
53        c.doc=None
54        status=self.__setup(uri)
55        if status:
56            c.xml='<p>%s</p>'%status
57            return render_response('error')
58        status,x=interface.GetXML(uri)
59        c.title='Viewing [%s]'%self.uri
60       
61        if status:
62            #(the return object x is an xmlHandler object)
63            print self.uri.schema
64            if self.uri.schema=='NDG-B1':
65                r='stubB'
66                c.doc=stubB.stubB(x.tree,self.cf)
67                c.tbinfo=self.__mytb(c.doc.name)
68                name=c.doc.abbreviation
69            elif self.uri.schema=='NDG-A0':
70                r='csml'
71                name=self.uri.localID
72                if 'format' not in self.inputs: self.inputs['format']='xml'
73            elif self.uri.schema=='DIF':
74                r='dif'
75                c.doc=DIF.DIF(x.tree,et=1,ndgObj=self.uri)
76                name=c.doc.name
77                print c.doc.ndgObject
78            elif self.uri.schema=='NumSim':
79                r='numsim'
80                c.xmlh=x
81                c.tbinfo=self.__mytb('')
82                name=x.getText('NS_Model/NS_Name')
83            else:
84                c.xml=x.tohtml()
85                r='content'
86            if 'format' in self.inputs:
87                #override previous output choice if format is xml
88                if self.inputs['format']=='xml': 
89                    c.xml=x.tohtml()
90                    r='content'
91            #f=file('debug.xml','w')
92            #f.write(x.tohtml())
93            #f.close()
94            #g=file('debug2.xml','w')
95            #g.write(str(x))
96            #g.close()       
97        else: 
98            c.xml='<div class="error">%s</div>'%x
99            r='error'
100       
101        if status: session['lastViewed']=h.current_url()
102       
103        if status and 'ndgSec' in session:
104            #we can update the history
105            if 'history' not in session:
106                session['history']=[(name,uri),]
107            else:
108                rb=Utilities.RingBuffer(10)
109                for i in session['history']: rb.append(i)
110                #delete it first, so we get to the top of the queue.
111                if (name,uri) in rb: rb.remove((name,uri))
112                rb.append((name,uri))
113                session['history']=rb.tolist()
114       
115        if status: session.save()
116       
117        if r=='content':
118            #we're showing an xml document ... but it could go wrong if
119            #we have crap content ...
120            try:
121                resp=render_response(r)
122            except ExpatError,e:
123                c.xml='<p> XML content is not well formed </p>'
124                c.doc=str(x)
125                resp=render_response('error')
126        else:
127            resp=render_response(r)
128        return resp
129   
130    def askCorrect(self,uri):
131        ''' Provide a form (ajaxaciously) so that a user can correct a metadata record'''
132        status=self.__setup(uri)
133        c.uri=self.uri
134        if status: return Response(status)
135        return render_response('correct',fragment=True)
136
137   
138    def correct(self,uri):
139        ''' Receive a correction form to update a record and post it to the holder '''
140        status=self.__setup(uri)
141        if 'ndgSec' not in session:
142            return Response('Not Logged In')
143        body='Metadata Change Request for %s'%uri
144        payload='<Change><uri>%s</uri><from>%s</from><Contents>%s</Contents></Change>'%(
145            self.inputs['Identifier'],self.inputs['Submitter'],self.inputs['Comment'])
146        name='ChangeRequestFor_%s.xml'%uri
147        status,message=mailer.mailHandler([self.cf.get('DEFAULT','metadataMaintainer'),],
148                       body,body,xmlAttachments=[(payload,name),],
149                       server=self.cf.get('DEFAULT','mailserver'))
150        if status:
151            c.xml='<p>Success: Mail sent to metadata maintainer</p>'
152        else:
153            c.xml=message
154        return render_response('content')
155       
156
157    def __mytb(self,name):
158        ''' Get the trackback info for this page
159        (can't do it in Kid because it doesn't do substutions in comments) '''
160        s='''<!--
161        <rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
162             xmlns:dc="http://purl.org/dc/elements/1.1/"
163             xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/">
164        <rdf:Description
165            rdf:about="%s"
166            dc:identifier="%s"
167            dc:title="%s"
168            trackback:ping="%s" />
169        </rdf:RDF>
170        -->'''%(self.uri,g.server+h.url_for(),name,g.server+h.url_for(controller="trackback"))
171        return s
Note: See TracBrowser for help on using the repository browser.