source: TI07-MOLES/trunk/PythonCode/wsgi/DIF.py @ 1905

Subversion URL: http://proj.badc.rl.ac.uk/svn/ndg/TI07-MOLES/trunk/PythonCode/wsgi/DIF.py@1905
Revision 1905, 4.9 KB checked in by lawrence, 13 years ago (diff)

Working discovery within paste-deploy context ...

Line 
1# python class to support methods on a DIF ... to conform with
2# renderEntity etc ...
3#
4from xml.etree import ElementTree as ET
5from Utilities import *
6from geoUtilities import *
7from People import *
8from ServiceBinding import ServiceBinding
9from AccessControl import AccessControl
10from renderEntity import renderEntity
11from ETxmlView import loadET, nsdumb
12
13
14class DIF:
15    ''' Supports the NASA GCMD DIF format for python operations,
16    note ... not a complete implementation, currently minimum to
17    show a reasonable piece of content '''
18    def __init__(self,xml,config,et=0):
19        '''Initialise a python dif instance based on an xml document (expected
20        to be an input string if et=0, otherwise an ElementTree instance) '''
21        self.metadataType='DIF'
22        self.debug=1
23        if et:
24            self.tree=xml
25            self.xml=ET.tostring(xml)
26        else:
27            try:
28                self.tree=loadET(xml)
29                self.xml=xml
30            except:
31                # for some reason we can't parse the document ...
32                self.tree=None
33                self.xml=None
34           
35        if self.tree is None: return None
36        helper=nsdumb(self.tree)
37        self.type='DIF'
38        if self.tree.tag!=self.type: self.tree=self.tree.find('.//%s'%self.type)
39        if self.tree is None: raise TypeError, self.xml
40        self.entryID=helper.getText(self.tree,'Entry_ID')
41        self.abstract=helper.getText(self.tree,'Summary')
42        self.name=helper.getText(self.tree,'Entry_Title')
43        self.abbreviation=self.name[0:min(5,len(self.name))]
44        self.binding=ServiceBinding(config,n=self.abbreviation,
45                    entryID=self.entryID)
46        #Note that entity.constraints.html is about access control on the metadata,
47        #and so we don't populate this here ...
48        self.constraints=AccessControl(None)
49       
50        #need entity.parameters, entity.bbox, entity.timeCoverage, entity.curator, entity.creators
51
52        self.parameters=[]
53        for parameter in helper.findall(self.tree,'Parameters'):
54            name=''
55            for level in ['Category','Topic','Term','Variable','Detailed_Variable']:
56                name+=helper.getText(parameter,level)+'/'
57            self.parameters.append(name.rstrip('/'))
58           
59
60        #load up information about spatial bounding box
61        self.bbox=Bounding(self.tree,entity='DIF')
62       
63        #load up information about temporal extent
64        self.timeCoverage=(
65            helper.getText(self.tree,'Temporal_Coverage/Start_Date'),
66            helper.getText(self.tree,'Temporal_Coverage/Stop_Date'),
67            helper.getText(self.tree,'Data_Set_Progress') )
68           
69        #Data curator information
70        self.centre=DIFcontact(helper.find(self.tree,'Data_Center'),ctype='centre',helper=helper)
71        self.curator=DIFcontact(self.tree)
72
73        #Data Creators
74        self.creators=[]
75        # use author here because a full dif entry for creator wont necessarily exist in citation ...
76        self.authors=helper.getText(self.tree,'Data_Set_Citation/Dataset_Creator')
77        self.date=dateParse(helper.getText(self.tree,'Data_Set_Citation/Dataset_Release_Date'),'YYYY')
78        self.title=helper.getText(self.tree,'Data_Set_Citation/Dataset_Title')
79        self.briefCitation=None
80        if (self.authors!='' and self.date!='' and self.title!=''):
81            self.briefCitation='%s (%s): %s'%(self.authors,self.date,self.title)
82
83        #services
84        self.services=[]
85        for item in helper.findall(self.tree,'Related_URL'):
86            n=ServiceBinding(config,self.name)
87            self.services.append(n.fromRelated(item,self.entryID,helper=helper))
88         
89        if self.debug:
90           f=open('difs.log','a')
91           f.write('%s##\n%s\n##################################\n'%(self.entryID,self.xml))
92           f.close()
93           
94           
95    def toHTML(self,config):
96        if self.tree is not None:
97            renderer=renderEntity(config)
98            return renderer.render(self)
99        else:
100            return '<p>No Valid DIF</p>'
101           
102if __name__=="__main__":
103   
104    #f=file('../../../exampleD/spade.xml')
105    f=file('difeg.xml')
106    g=file('../../../exampleD/ucar.xml')
107    dif1xml=f.read()
108    dif2xml=g.read()
109    config=myConfig('browse.config')
110    D=DIF(dif1xml,config)
111    G=DIF(dif2xml,config)
112    y='''<?xml version="1.0" encoding="UTF-8"?>
113                <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
114                <html xmlsns="http://www.w3.org/1999/xhtml" xml:lang="en">
115                        <head>
116                                <META http-equiv="Content-Type" content="text/xhtml; charset=iso-8859-1"/>
117                                <title>%s</title>
118                                <LINK media="all, screen" href="../layout/style.css" type="text/css" rel="stylesheet"/>
119                        </head> '''%D.name+D.toHTML(config)+G.toHTML(config)
120    f.close()
121    f=file('output.html','wb')
122    f.write(y)
123    print str(D.binding),D.binding.url
124   
125   
126       
127       
128       
129       
130       
Note: See TracBrowser for help on using the repository browser.