source: ndgCommon/trunk/ndg/common/src/lib/ndgresources.py @ 6487

Subversion URL: http://proj.badc.rl.ac.uk/svn/ndg/ndgCommon/trunk/ndg/common/src/lib/ndgresources.py@6487
Revision 6487, 5.2 KB checked in by sdonegan, 10 years ago (diff)

Added handling of new xqueries to convert ISO19139 to DIF & DC

Line 
1'''
2Utility class providing access to various static resource files - e.g.
3xqueries and xsd schema docs
4
5 @author: C Byrom, Tessella, Feb 09
6'''
7import pkg_resources
8import re, logging
9from ndg.common.src.models.ndgObject import ndgObject as no
10
11# these are the different schemas needed to validate atom docs - NB, the main
12# one is molesAtom1.0 - this imports the others
13ATOM_MOLES_SCHEMA = "molesAtom1.0"
14MOLES_SCHEMA = "moles2.0"
15ATOM_SCHEMA = "atom1.0"
16
17class ndgResources(object):
18   
19    def __init__(self, directory='xmldb/'):
20        '''
21        Loads up resources from the internal package directory
22        @keyword directory: root directory from which to retrieve docs from.
23        Default is 'xmldb/'
24        '''
25        logging.debug("Initialising ndgResources")
26        self.__loadResources(directory)
27
28        # provide mapping between ndgObject URI doc type name and xquery name
29        # TODO: if we're going to replace the old moles1.3 entirely with the
30        # atom based format, will need to implement atom2dif, atom2dc and atom2iso
31        # queries
32        self.knownQueries={no.DIF_DOC_TYPE:'moles2dif',
33                           no.DC_DOC_TYPE:'moles2DC',
34                           no.ISO_DOC_TYPE:'moles2iso19139',
35                           no.NDGB0_DOC_TYPE:'moles',
36                           no.NDGB1_DOC_TYPE:'molesObjectType',
37                           no.MDIP_DOC_TYPE:'moles2mdip', 
38                           no.NDGA0_DOC_TYPE:'csml',
39                           no.NUMSIM_DOC_TYPE:'numsim', 
40                           no.ATOM_DOC_TYPE:'atom', 
41                           no.ATOM_BACKUP_DOC_TYPE:'atom', 
42                           no.ASSOCIATED_ATOM_DOC_TYPE:'atomTypeList',
43                           no.BROWSE_DC_DOC_TYPE:'DIF2DC',
44                           no.BROWSE_DIF_DOC_TYPE:'dif',
45                                                   no.DIF2stubISO:'dif2stubISO',
46                                                   no.ISO2DIF:'ISO2DIF',
47                                                   no.ISO2DC:'ISO2DC'
48                                                   }
49        logging.debug("ndgResources initialised")
50
51
52    def __loadResources(self, directory):
53        '''
54        Load the various resources
55        @keyword directory: root directory from which to retrieve docs from.
56        '''
57        xqueryDir = directory + 'xquery'
58        files=pkg_resources.resource_listdir('ndg.common', xqueryDir)
59        # this next bit to get rid of .svn and anything else in testing
60        self.xq = {}
61        for f in files:
62            if f.endswith('.xq'):
63                self.xq[re.sub('.xq\Z','',f)] = \
64                    pkg_resources.resource_string('ndg.common','%s/%s'%(xqueryDir,f))
65
66        schemaDir = directory + 'schema'
67        files=pkg_resources.resource_listdir('ndg.common', schemaDir)
68        self.xsd = {}
69        for f in files:
70            if f.endswith('.xsd'):
71                self.xsd[re.sub('.xsd\Z','',f)] = \
72                    pkg_resources.resource_string('ndg.common','%s/%s'%(schemaDir, f))
73                         
74        # add the various xquery libraries, too
75        self.xqlib = {}
76        for dir in ['Vocabs', 'Utilities', 'StubB']:
77            xqueryLibDir = xqueryDir + '/lib/' + dir
78            files = pkg_resources.resource_listdir('ndg.common', xqueryLibDir)
79            for f in files:
80                if f.endswith('.xquery'): 
81                    fullPath = '%s/%s'%(xqueryLibDir,f)
82                    partPath = '/%s/%s' %(dir, f)
83                    self.xqlib[partPath] = pkg_resources.resource_string('ndg.common', fullPath)
84       
85        # also add the organisation data files - NB, this class should be generalised
86        # to make more sense...
87        resourceDir = directory + 'resources'
88        files = pkg_resources.resource_listdir('ndg.common', resourceDir)
89        self.resources = {}
90        for f in files:
91            if f.endswith('.xml'): 
92                self.resources[f] = \
93                    pkg_resources.resource_string('ndg.common','%s/%s' %(resourceDir, f))
94
95        # lastly, add the indexes
96        self.indexes = {}
97        for dir in ['eXist']:
98            indexDir = directory + 'indexing' + '/' + dir
99            files = pkg_resources.resource_listdir('ndg.common', indexDir)
100            for f in files:
101                if f.endswith('.xconf'): 
102                    self.indexes[f] = \
103                        pkg_resources.resource_string('ndg.common','%s/%s'%(indexDir,f))
104       
105       
106    def createXQuery(self, key, targetCollection, repositoryID, localID):
107        '''
108        Return an actual xquery targetted for a specific localID, repositoryID and
109        targetCollection
110        @param key: name of xquery to use
111        @param targetCollection: target collection to use with xquery
112        @param repositoryID: ID of the repository to use with the xquery
113        @param localID: local ID of doc to lookup with xquery
114        @raise ValueError: if key is not a valid xquery
115        @return xquery as a string
116        '''
117        logging.debug("Setting up %s xquery" %key)
118        if not self.xq.has_key(key):
119            raise ValueError("Unrecognised xquery type: '%s'" %key)
120       
121        xq=self.xq[key]
122        xq=xq.replace('RepositoryID',repositoryID)
123        xq=xq.replace('LocalID',localID)
124        xq=xq.replace('TargetCollection',targetCollection)
125        logging.debug("Xquery set up - returning")
126        return xq
Note: See TracBrowser for help on using the repository browser.