From f13190b81de14f432b3c919f3e053d9201aab592 Mon Sep 17 00:00:00 2001 From: David Habgood Date: Wed, 8 Jan 2025 13:25:41 +1000 Subject: [PATCH] bugfix: Allow for empty Accept headers. Browsers/Curl/httpx do not by default supply empty Accept headers, postman/hopscotch etc. do. (#318) --- prez/services/objects.py | 4 ++-- tests/test_endpoints_catprez.py | 5 +++++ 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/prez/services/objects.py b/prez/services/objects.py index ef4af6c4..12146ae4 100755 --- a/prez/services/objects.py +++ b/prez/services/objects.py @@ -84,14 +84,14 @@ async def object_function( construct_tss_list=profile_nodeshape.tss_list, ).to_string() - if pmts.requested_mediatypes[0][0] == "application/sparql-query": + if pmts.requested_mediatypes and (pmts.requested_mediatypes[0][0] == "application/sparql-query"): return PlainTextResponse(query, media_type="application/sparql-query") query_start_time = time.time() item_graph, _ = await data_repo.send_queries([query], []) log.debug(f"Query time: {time.time() - query_start_time}") if settings.prez_ui_url: # If HTML or no specific media type requested - if pmts.requested_mediatypes[0][0] in ("text/html", "*/*"): + if pmts.requested_mediatypes and (pmts.requested_mediatypes[0][0] in ("text/html", "*/*")): item_uri = URIRef(profile_nodeshape.focus_node.value) await add_prez_links(item_graph, data_repo, endpoint_structure, [item_uri]) prez_link = item_graph.value( diff --git a/tests/test_endpoints_catprez.py b/tests/test_endpoints_catprez.py index d287877d..98f61244 100755 --- a/tests/test_endpoints_catprez.py +++ b/tests/test_endpoints_catprez.py @@ -30,6 +30,11 @@ def test_catalog_anot(client, a_catprez_catalog_link): assert next(response_graph.triples(expected_response)) +def test_catalog_no_mediatype(client, a_catprez_catalog_link): + r = client.get(f"{a_catprez_catalog_link}", headers={"Accept": ""}) + assert r.status_code == 200 + + def test_lower_level_listing_anot(client, a_catprez_catalog_link): r = client.get(f"{a_catprez_catalog_link}/collections?_mediatype=text/turtle") response_graph = Graph().parse(data=r.text)