From 239aacfa0353b4aac96959f88751c06273b2b401 Mon Sep 17 00:00:00 2001 From: Jeremy Ruston Date: Tue, 10 Dec 2024 10:36:08 +0000 Subject: [PATCH] Fix streaming of attachment tiddlers from recipe URIs --- .../routes/handlers/get-recipe-tiddler.js | 25 ++++++++++++------- 1 file changed, 16 insertions(+), 9 deletions(-) diff --git a/plugins/tiddlywiki/multiwikiserver/modules/routes/handlers/get-recipe-tiddler.js b/plugins/tiddlywiki/multiwikiserver/modules/routes/handlers/get-recipe-tiddler.js index 8b23184ad..037f7489d 100644 --- a/plugins/tiddlywiki/multiwikiserver/modules/routes/handlers/get-recipe-tiddler.js +++ b/plugins/tiddlywiki/multiwikiserver/modules/routes/handlers/get-recipe-tiddler.js @@ -41,16 +41,23 @@ exports.handler = function(request,response,state) { return; } else { // This is not a JSON API request, we should return the raw tiddler content - var type = tiddlerInfo.tiddler.type || "text/plain"; - if(!response.headersSent) { - response.writeHead(200, "OK",{ - Etag: state.makeTiddlerEtag(tiddlerInfo), - "Content-Type": type - }); - response.write(tiddlerInfo.tiddler.text || "",($tw.config.contentTypeInfo[type] ||{encoding: "utf8"}).encoding); - response.end(); + const result = $tw.mws.store.getBagTiddlerStream(title,tiddlerInfo.bag_name); + if(result) { + if(!response.headersSent){ + response.writeHead(200, "OK",{ + Etag: state.makeTiddlerEtag(result), + "Content-Type": result.type + }); + } + result.stream.pipe(response); + return; + } else { + if(!response.headersSent){ + response.writeHead(404); + response.end(); + } + return; } - return; } } else { if(!response.headersSent) {