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

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

Adjust templates to use new, selectedItem object.
Extend scripts to cope with multiple KML and WMC URLs - these are
presented in the selections table on separate rows allowing their
individual selection when creating aggregated KML/WMC docs. NB,
selected docs which don't have relevant KML/WMC info are ignored.

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
29
30        # NB: we could have two types of query string argument:
31        #   format= (raw,html) and
32        #   outputSchema=(original, someSchema)
33        self.format=''
34        if 'format' in self.inputs: self.format=self.inputs['format']
35        self.outputSchema=''
36        if 'outputSchema' in self.inputs: self.outputSchema=self.inputs['outputSchema']
37
38        # Add selected granules to context
39        #c.selectedGranules = [g_uri for g_uri, g_name in session.get('selection', [])]
40                             
41
42        return 0
43       
44    def index(self,uri):
45        ''' Returns the document unadorned in anyway, i.e. the raw xml'''
46        status=self.__setup(uri)
47        if status:
48            c.xml='<p>%s</p>'%status
49            return Response(render('error'),code=400)
50       
51        status,x=interface.GetXML(uri,outputSchema=self.outputSchema)
52        if status:
53            #(the return object x is an xmlHandler object)
54            c.xml=x.xmls
55            return Response(c.xml,'application/xml')
56        else:
57            e=404
58            if x.startswith('<p> Access'): e=401
59            return Response(render('error'),code=e)
60       
61    def view(self,uri):
62        ''' Returns either an html marked up version of the xml, or a properly laid
63        out version of the document '''
64        c.doc=None
65        status=self.__setup(uri)
66        if status:
67            c.xml='<p>%s</p>'%status
68            return Response(render('error'),code=400)
69        status,x=interface.GetXML(uri,outputSchema=self.outputSchema)
70        c.title='Viewing [%s]'%self.uri
71       
72        if status:
73            #(the return object x is an xmlHandler object)
74            viewFormat=self.uri.schema
75            if self.outputSchema!='': viewFormat=self.outputSchema
76            if self.format not in ('xml','raw'):
77                if viewFormat=='NDG-B1':
78                    r='stubB'
79                    c.doc=stubB.stubB(x.tree,self.cf)
80                    c.tbinfo=self.__mytb(c.doc.name)
81                    name=c.doc.abbreviation
82                elif viewFormat=='NDG-A0':
83                    r='csml'
84                    name=self.uri.localID
85                    #for now we'll handle as pretty print xml
86                    c.xml=x.tohtml()
87                    r='content'
88                    c.tab='Display'
89                elif viewFormat=='DIF':
90                    r='dif'
91                    c.doc=DIF.DIF(x.tree,et=1,ndgObj=self.uri)
92                    name=c.doc.name
93                    print c.doc.ndgObject
94                elif viewFormat=='NumSim':
95                    r='numsim'
96                    c.xmlh=x
97                    c.tbinfo=self.__mytb('')
98                    name=x.getText('NS_Name')
99                    c.name=name
100                else:
101                    c.xml=x.tohtml()
102                    r='content'
103            else:
104                name=str(self.uri)
105                if self.format=='xml':
106                    c.xml=x.tohtml()
107                    r='content'
108                    c.tab='Display'
109                elif self.format=='raw':
110                    c.xml=x.xmls
111                    return Response(c.xml,'application/xml')
112           
113            needed=0
114            if 'lastViewed' not in session: needed=1
115            session['lastViewed']=h.current_url()
116            if needed: c.pageTabs.append(('Display',session['lastViewed']))
117           
118            if 'ndgSec' in session:
119                #we can update the history
120                if 'history' not in session:
121                    session['history']=[(name,uri),]
122                else:
123                    rb=Utilities.RingBuffer(10)
124                    for i in session['history']: rb.append(i)
125                    #delete it first, so we get to the top of the queue.
126                    if (name,uri) in rb: rb.remove((name,uri))
127                    rb.append((name,uri))
128                    session['history']=rb.tolist()
129            session.save()
130            code=200
131        else:
132            if x.startswith('<p> Access Denied'):
133                code=401
134            else: code=400
135            c.xml='<div class="error">%s</div>'%x
136            r='error'
137            print c.xml
138           
139        if r=='content':
140            #we're showing an xml document ... but it could go wrong if
141            #we have crap content ...
142            try:
143                resp=render(r)
144            except ExpatError,e:
145                c.xml='<p> XML content is not well formed </p>'
146                c.doc=str(x)
147                resp=render('error')
148                code=400
149            resp=Response(resp,code=code)
150        else:
151            #resp=Response(render(r),code=code)
152            try:
153                resp=Response(render(r),code=code)
154            except Exception,e:
155                c.xml='<p> Unexpected error [%s] viewing [%s] </p>'%(str(e),uri)
156                c.doc=''
157                code=400
158                resp=Response(render('error'),code=code)
159        return resp
160   
161    def askCorrect(self,uri):
162        ''' Provide a form (ajaxaciously) so that a user can correct a metadata record'''
163        status=self.__setup(uri)
164        c.uri=self.uri
165        if status: return Response(status)
166        return render_response('correct',fragment=True)
167
168   
169    def correct(self,uri):
170        ''' Receive a correction form to update a record and post it to the holder '''
171        status=self.__setup(uri)
172        if 'ndgSec' not in session:
173            return Response('Not Logged In')
174        body='Metadata Change Request for %s'%uri
175        payload='<Change><uri>%s</uri><from>%s</from><Contents>%s</Contents></Change>'%(
176            self.inputs['Identifier'],self.inputs['Submitter'],self.inputs['Comment'])
177        name='ChangeRequestFor_%s.xml'%uri
178        status,message=mailer.mailHandler([self.cf.get('DEFAULT','metadataMaintainer'),],
179                       body,body,xmlAttachments=[(payload,name),],
180                       server=self.cf.get('DEFAULT','mailserver'))
181        if status:
182            c.xml='<p>Success: Mail sent to metadata maintainer</p>'
183        else:
184            c.xml=message
185        return render_response('content')
186       
187
188    def __mytb(self,name):
189        ''' Get the trackback info for this page
190        (can't do it in Kid because it doesn't do substutions in comments) '''
191        s='''<!--
192        <rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
193             xmlns:dc="http://purl.org/dc/elements/1.1/"
194             xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/">
195        <rdf:Description
196            rdf:about="%s"
197            dc:identifier="%s"
198            dc:title="%s"
199            trackback:ping="%s" />
200        </rdf:RDF>
201        -->'''%(self.uri,g.server+h.url_for(),name,g.server+h.url_for(controller="trackback"))
202        return s
Note: See TracBrowser for help on using the repository browser.