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

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

put right typo

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        logging.debug("ndgResources initialised")
46
47
48    def __loadResources(self, directory):
49        '''
50        Load the various resources
51        @keyword directory: root directory from which to retrieve docs from.
52        '''
53        xqueryDir = directory + 'xquery'
54        files=pkg_resources.resource_listdir('ndg.common', xqueryDir)
55        # this next bit to get rid of .svn and anything else in testing
56        self.xq = {}
57        for f in files:
58            if f.endswith('.xq'):
59                self.xq[re.sub('.xq\Z','',f)] = \
60                    pkg_resources.resource_string('ndg.common','%s/%s'%(xqueryDir,f))
61
62        schemaDir = directory + 'schema'
63        files=pkg_resources.resource_listdir('ndg.common', schemaDir)
64        self.xsd = {}
65        for f in files:
66            if f.endswith('.xsd'):
67                self.xsd[re.sub('.xsd\Z','',f)] = \
68                    pkg_resources.resource_string('ndg.common','%s/%s'%(schemaDir, f))
69                         
70        # add the various xquery libraries, too
71        self.xqlib = {}
72        for dir in ['Vocabs', 'Utilities', 'StubB']:
73            xqueryLibDir = xqueryDir + '/lib/' + dir
74            files = pkg_resources.resource_listdir('ndg.common', xqueryLibDir)
75            for f in files:
76                if f.endswith('.xquery'): 
77                    fullPath = '%s/%s'%(xqueryLibDir,f)
78                    partPath = '/%s/%s' %(dir, f)
79                    self.xqlib[partPath] = pkg_resources.resource_string('ndg.common', fullPath)
80       
81        # also add the organisation data files - NB, this class should be generalised
82        # to make more sense...
83        resourceDir = directory + 'resources'
84        files = pkg_resources.resource_listdir('ndg.common', resourceDir)
85        self.resources = {}
86        for f in files:
87            if f.endswith('.xml'): 
88                self.resources[f] = \
89                    pkg_resources.resource_string('ndg.common','%s/%s' %(resourceDir, f))
90
91        # lastly, add the indexes
92        self.indexes = {}
93        for dir in ['eXist']:
94            indexDir = directory + 'indexing' + '/' + dir
95            files = pkg_resources.resource_listdir('ndg.common', indexDir)
96            for f in files:
97                if f.endswith('.xconf'): 
98                    self.indexes[f] = \
99                        pkg_resources.resource_string('ndg.common','%s/%s'%(indexDir,f))
100       
101       
102    def createXQuery(self, key, targetCollection, repositoryID, localID):
103        '''
104        Return an actual xquery targetted for a specific localID, repositoryID and
105        targetCollection
106        @param key: name of xquery to use
107        @param targetCollection: target collection to use with xquery
108        @param repositoryID: ID of the repository to use with the xquery
109        @param localID: local ID of doc to lookup with xquery
110        @raise ValueError: if key is not a valid xquery
111        @return xquery as a string
112        '''
113        logging.debug("Setting up %s xquery" %key)
114        if not self.xq.has_key(key):
115            raise ValueError("Unrecognised xquery type: '%s'" %key)
116       
117        xq=self.xq[key]
118        xq=xq.replace('RepositoryID',repositoryID)
119        xq=xq.replace('LocalID',localID)
120        xq=xq.replace('TargetCollection',targetCollection)
121        logging.debug("Xquery set up - returning")
122        return xq
Note: See TracBrowser for help on using the repository browser.