/usr/lib/python2.7/dist-packages/sprox/metadata.py is in python-sprox 0.9.6-1build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 | """
matadata Module
This contains the class which defines the generic interface for metadata.
Basically, it provides an interface for how data is extracted from the provider
for widget generation.
Copyright (c) 2008 Christopher Perkins
Original Version by Christopher Perkins 2007
Released under MIT license.
"""
from sprox.iprovider import IProvider
class MetadataError(Exception):pass
class NotFoundError(Exception):pass
class Metadata(dict):
"""Base Metadata class
Metadatas are dictionary-like. They map attributes
of the entity they wrap, so that attributes of the entity
can be examined without being explicitly set. Elements
of a metadata can be set if they are not already part of the
wrapped entity. This allows for customization of the
metadata without modification to the wrapped metadata.
"""
def __init__(self, provider, entity=None):
self.provider = provider
self.entity = entity
def __setitem__(self, key, value):
self._do_check_set_item(key, value)
dict.__setitem__(self, key, value)
def _do_get_item(self, item):
raise NotImplementedError
def _do_keys(sekf):
raise NotImplementedError
def _do_check_set_item(self, key, value):
raise NotImplementedError
def __getitem__(self, item):
try:
value = self._do_get_item(item)
return value
except NotFoundError:
return dict.__getitem__(self, item)
def keys(self):
r = self._do_keys()
r.extend(dict.keys(self))
return r
class EntitiesMetadata(Metadata):
"""A class to extract entities from a database definition.
"""
def _do_get_item(self, name):
if name in self.provider.get_entities():
return self.provider.get_entity(name)
raise NotFoundError
def _do_keys(self):
entities = sorted(self.provider.get_entities())
return entities
class FieldsMetadata(Metadata):
"""A class to extract fields from an entity.
"""
def __init__(self, provider, entity):
Metadata.__init__(self, provider, entity)
self.provider = provider
self.entity = entity
def _do_check_set_item(self, key, value):
if key in self.provider.get_fields(self.entity):
raise MetadataError('%s is already found in entity: %s'%(key, self.entity))
def _do_get_item(self, item):
try:
return self.provider.get_field(self.entity, item)
except AttributeError:
#XXX I'm not sure if we should change the type,but we shouldn't swallow with except:
if dict.__contains__(self, item):
return dict.get(self, item)
raise NotFoundError(self.entity,item)
def _do_keys(self):
return self.provider.get_fields(self.entity)
class FieldMetadata(Metadata):
"""In the future, if the Field attributes need to be extracted, this is where it will happen.
"""
pass
|