From 302ef628b235a4f882b562483c344a5ffd1cb506 Mon Sep 17 00:00:00 2001 From: Sarven Capadisli Date: Tue, 30 Jan 2024 10:40:48 +0100 Subject: [PATCH 1/2] Change translation error to not acceptable --- lib/handlers/get.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/handlers/get.js b/lib/handlers/get.js index f4aed8eeb..f4350f70f 100644 --- a/lib/handlers/get.js +++ b/lib/handlers/get.js @@ -128,8 +128,8 @@ async function handler (req, res, next) { res.send(data) return next() } catch (err) { - debug('error translating: ' + req.originalUrl + ' ' + contentType + ' -> ' + possibleRDFType + ' -- ' + 500 + ' ' + err.message) - return next(error(500, 'Error translating between RDF formats')) + debug('error translating: ' + req.originalUrl + ' ' + contentType + ' -> ' + possibleRDFType + ' -- ' + 406 + ' ' + err.message) + return next(error(406, 'Cannot serve requested type: ' + requestedType)) } } From 65b04bbff7153d601c8b7de625d27cfc4365d336 Mon Sep 17 00:00:00 2001 From: Sarven Capadisli Date: Tue, 30 Jan 2024 13:33:49 +0100 Subject: [PATCH 2/2] Check untranslatable requested type for RDF --- lib/handlers/get.js | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/handlers/get.js b/lib/handlers/get.js index f4350f70f..dd46461af 100644 --- a/lib/handlers/get.js +++ b/lib/handlers/get.js @@ -116,10 +116,9 @@ async function handler (req, res, next) { // If it is not in our RDFs we can't even translate, // Sorry, we can't help - if (!possibleRDFType) { - return next(error(406, 'Cannot serve requested type: ' + contentType)) + if (!possibleRDFType || !RDFs.includes(requestedType)) { + return next(error(406, 'Cannot serve requested type: ' + requestedType)) } - try { // Translate from the contentType found to the possibleRDFType desired const data = await translate(stream, baseUri, contentType, possibleRDFType) @@ -127,7 +126,8 @@ async function handler (req, res, next) { res.setHeader('Content-Type', possibleRDFType) res.send(data) return next() - } catch (err) { + } + catch (err) { debug('error translating: ' + req.originalUrl + ' ' + contentType + ' -> ' + possibleRDFType + ' -- ' + 406 + ' ' + err.message) return next(error(406, 'Cannot serve requested type: ' + requestedType)) }