X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=manifold%2Fmetadata.py;h=de9bf2ebbe82a9b2bce21667835ddbc3e291b8d7;hb=804932e8a431ddbf0d7c56457625457967b48d4c;hp=8aed12689b52a3fa9eacc5fbeb66db1e81a9a7d8;hpb=50612381c5cdf81a87fd6d8c7b4ae864dba49db6;p=myslice.git diff --git a/manifold/metadata.py b/manifold/metadata.py index 8aed1268..de9bf2eb 100644 --- a/manifold/metadata.py +++ b/manifold/metadata.py @@ -1,30 +1,62 @@ import json +import os.path +from manifold.manifoldresult import ManifoldResult from manifold.manifoldapi import ManifoldAPI +from django.contrib import messages + +debug=False +#debug=True + class MetaData: def __init__ (self, auth): self.auth=auth - self.hash_by_subject={} + self.hash_by_object={} - def fetch (self): + def fetch (self, request): manifold_api = ManifoldAPI(self.auth) - fields = ['table', 'column.column', - 'column.description','column.header', 'column.title', - 'column.unit', 'column.info_type', - 'column.resource_type', 'column.value_type', - 'column.allowed_values', 'column.platforms.platform', - 'column.platforms.platform_url'] - results = manifold_api.Get('metadata:table', [], [], fields) - self.hash_by_subject = dict ( [ (result['table'], result) for result in results ] ) + fields = ['table', 'column.name', 'column.qualifier', 'column.type', + 'column.is_array', 'column.description', 'column.default', 'key', 'capability'] + #fields = ['table', 'column.column', + # 'column.description','column.header', 'column.title', + # 'column.unit', 'column.info_type', + # 'column.resource_type', 'column.value_type', + # 'column.allowed_values', 'column.platforms.platform', + # 'column.platforms.platform_url'] + request={ 'action': 'get', + 'object': 'local:object', # proposed to replace metadata:table + 'fields': fields , + } + result = manifold_api.forward(request) + + # xxx need a way to export error messages to the UI + if result['code'] == 1: # warning + # messages.warning(request, result['description']) + print ("METADATA WARNING -",request,result['description']) + elif result['code'] == 2: + # messages.error(request, result['description']) + print ("METADATA ERROR -",request,result['description']) + # XXX FAIL HERE XXX + return + + rows = result.ok_value() +# API errors will be handled by the outer logic +# if not rows: +# print "Failed to retrieve metadata",rows_result.error() +# rows=[] + self.hash_by_object = dict ( [ (row['table'], row) for row in rows ] ) def to_json(self): - return json.dumps(self.hash_by_subject) + return json.dumps(self.hash_by_object) - def details_by_subject (self, subject): - return self.hash_by_subject[subject] + def details_by_object (self, object): + return self.hash_by_object[object] - def sorted_fields_by_subject (self, subject): - return self.hash_by_subject[subject]['columns'].sort() + def sorted_fields_by_object (self, object): + return self.hash_by_object[object]['column'].sort() + def get_field_type(self, object, field): + if debug: print "Temp fix for metadata::get_field_type() -> consider moving to manifold.core.metadata soon" + return field