X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Fmanagers%2Fregistry_manager.py;h=d1a4c6f5db35468e9d5ebf17b4365e7dbd4417ff;hb=dbd15819d950b69d0c6ba5527660969d0754ad29;hp=b5a63a92f675bb86ec0b29984825af2ab73763bc;hpb=16680664b5da5b104900911bed9b51d3ab095073;p=sfa.git diff --git a/sfa/managers/registry_manager.py b/sfa/managers/registry_manager.py index b5a63a92..d1a4c6f5 100644 --- a/sfa/managers/registry_manager.py +++ b/sfa/managers/registry_manager.py @@ -20,6 +20,9 @@ from sfa.trust.gid import create_uuid from sfa.storage.model import make_record, RegRecord, RegAuthority, RegUser, RegSlice, RegKey, \ augment_with_sfa_builtins from sfa.storage.alchemy import dbsession +### the types that we need to exclude from sqlobjects before being able to dump +# them on the xmlrpc wire +from sqlalchemy.orm.collections import InstrumentedList class RegistryManager: @@ -152,7 +155,7 @@ class RegistryManager: local_records = dbsession.query(RegRecord).filter(RegRecord.hrn.in_(local_hrns)) if type: local_records = local_records.filter_by(type=type) - local_records=local_records.all() + local_records=local_records.all() for local_record in local_records: augment_with_sfa_builtins (local_record) @@ -174,12 +177,11 @@ class RegistryManager: record.url=neighbour_dict[hrn].get_url() return for record in local_records: solve_neighbour_url (record) - # convert local record objects to dicts for xmlrpc # xxx somehow here calling dict(record) issues a weird error # however record.todict() seems to work fine # records.extend( [ dict(record) for record in local_records ] ) - records.extend( [ record.todict(exclude_types=[RegRecord,RegKey]) for record in local_records ] ) + records.extend( [ record.todict(exclude_types=[InstrumentedList]) for record in local_records ] ) if not records: raise RecordNotFound(str(hrns)) @@ -228,7 +230,7 @@ class RegistryManager: records = dbsession.query(RegRecord).filter_by(authority=hrn) # so that sfi list can show more than plain names... for record in records: augment_with_sfa_builtins (record) - record_dicts=[ record.todict(exclude_types=[RegRecord,RegKey]) for record in records ] + record_dicts=[ record.todict(exclude_types=[InstrumentedList]) for record in records ] return record_dicts