Skip to content

Commit

Permalink
Merge pull request #21 from seung-lab/table_metadata
Browse files Browse the repository at this point in the history
feat: add endpoint to return all valid versions metadata
  • Loading branch information
dlbrittain authored Apr 12, 2021
2 parents bdd05e6 + a091b29 commit cbbc7d5
Showing 1 changed file with 25 additions and 0 deletions.
25 changes: 25 additions & 0 deletions materializationengine/blueprints/client/api.py
Original file line number Diff line number Diff line change
Expand Up @@ -220,6 +220,31 @@ def get(self, datastack_name: str, version: int):
schema = AnalysisVersionSchema()
return schema.dump(response), 200

@client_bp.route("/datastack/<string:datastack_name>/metadata")
class DatastackMetadata(Resource):
@reset_auth
@auth_required
@client_bp.doc("all valid version metadata", security="apikey")
def get(self, datastack_name: str):
"""get materialized metadata for all valid versions
Args:
datastack_name (str): datastack name
Returns:
list: list of metadata dictionaries
"""
aligned_volume_name, pcg_table_name = get_relevant_datastack_info(datastack_name)
session = sqlalchemy_cache.get(aligned_volume_name)
response = (
session.query(AnalysisVersion)
.filter(AnalysisVersion.datastack == datastack_name)
.filter(AnalysisVersion.valid == True)
.all()
)
if response is None:
return "No valid versions found", 404
schema = AnalysisVersionSchema()
return schema.dump(response, many=True), 200

@client_bp.route("/datastack/<string:datastack_name>/version/<int:version>/tables")
class FrozenTableVersions(Resource):
@reset_auth
Expand Down

0 comments on commit cbbc7d5

Please sign in to comment.