X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Fstorage%2Fmodel.py;h=163380953da152cec872e4c61b6353650bca9428;hb=cdc7dd0cbb5e3e428bc9111f3cf476cbe15a4530;hp=64da316d971652c1c6a948f86d3e6087ad1ea975;hpb=bcfe3fa55dd1c6ba6929cc327043c3dfecf7fd18;p=sfa.git diff --git a/sfa/storage/model.py b/sfa/storage/model.py index 64da316d..16338095 100644 --- a/sfa/storage/model.py +++ b/sfa/storage/model.py @@ -1,7 +1,7 @@ from types import StringTypes from datetime import datetime -from sqlalchemy import Column, Integer, String, DateTime +from sqlalchemy import Integer, String, DateTime from sqlalchemy import Table, Column, MetaData, join, ForeignKey from sqlalchemy.orm import relationship, backref from sqlalchemy.orm import column_property @@ -361,3 +361,35 @@ def make_record_xml (xml): logger.info("load from xml, keys=%s"%xml_dict.keys()) return make_record_dict (xml_dict) +#################### +# augment local records with data from builtin relationships +# expose related objects as a list of hrns +# we pick names that clearly won't conflict with the ones used in the old approach, +# were the relationships data came from the testbed side +# for each type, a dict of the form {:} +# so after that, an 'authority' record will e.g. have a 'reg-pis' field with the hrns of its pi-users +augment_map={'authority': {'reg-pis':'reg_pis',}, + 'slice': {'reg-researchers':'reg_researchers',}, + 'user': {'reg-pi-authorities':'reg_authorities_as_pi', + 'reg-slices':'reg_slices_as_researcher',}, + } + +def augment_with_sfa_builtins (local_record): + # don't ruin the import of that file in a client world + from sfa.util.xrn import Xrn + # add a 'urn' field + setattr(local_record,'reg-urn',Xrn(xrn=local_record.hrn,type=local_record.type).urn) + # users have keys and this is needed to synthesize 'users' sent over to CreateSliver + if local_record.type=='user': + user_keys = [ key.key for key in local_record.reg_keys ] + setattr(local_record, 'reg-keys', user_keys) + # search in map according to record type + type_map=augment_map.get(local_record.type,{}) + # use type-dep. map to do the job + for (field_name,attribute) in type_map.items(): + # get related objects + related_records = getattr(local_record,attribute,[]) + hrns = [ r.hrn for r in related_records ] + setattr (local_record, field_name, hrns) + +