From 1a36543d0b1b9175d29a76597b33feec81b5acf1 Mon Sep 17 00:00:00 2001 From: Munyoki Kilyungi Date: Wed, 2 Jul 2025 15:41:33 +0300 Subject: Update list_diffs to filter by change_type, remove auth check. Signed-off-by: Munyoki Kilyungi --- gn3/api/case_attributes.py | 35 ++++++++++++++--------------------- 1 file changed, 14 insertions(+), 21 deletions(-) (limited to 'gn3/api/case_attributes.py') diff --git a/gn3/api/case_attributes.py b/gn3/api/case_attributes.py index 1934ec0..2714ad8 100644 --- a/gn3/api/case_attributes.py +++ b/gn3/api/case_attributes.py @@ -233,27 +233,20 @@ def edit_case_attributes(inbredset_id: int, auth_token=None) -> tuple[Response, }), 201 -@caseattr.route("//diff/list", methods=["GET"]) -@require_token -def list_diffs(inbredset_id: int, auth_token=None) -> tuple[Response, int]: - """List any changes that have not been approved/rejected.""" - try: - required_access(auth_token, - inbredset_id, - ("system:inbredset:edit-case-attribute", - "system:inbredset:apply-case-attribute-edit")) - with (database_connection(current_app.config["SQL_URI"]) as conn, - conn.cursor(cursorclass=DictCursor) as cursor): - directory = (Path(current_app.config["LMDB_DATA_PATH"]) / - "case-attributes" / str(inbredset_id)) - changes = get_changes(cursor, directory=directory) - return jsonify( - changes - ), 200 - except AuthorisationError as _auth_err: - return jsonify({ - "message": ("You are not authorised to list diffs."), - }), 401 +@caseattr.route("//diffs/", methods=["GET"]) +def list_diffs(inbredset_id: int, change_type: str) -> tuple[Response, int]: + """List any changes that have been made by change_type.""" + with (database_connection(current_app.config["SQL_URI"]) as conn, + conn.cursor(cursorclass=DictCursor) as cursor): + directory = (Path(current_app.config["LMDB_DATA_PATH"]) / + "case-attributes" / str(inbredset_id)) + return jsonify( + get_changes( + cursor=cursor, + change_type=EditStatus[change_type], + directory=directory + ) + ), 200 @caseattr.route("//approve/", methods=["POST"]) -- cgit 1.4.1