Skip to content

Commit

Permalink
improved serving of small and large (tested ~1Mb) cover images
Browse files Browse the repository at this point in the history
  • Loading branch information
Sascha committed Dec 22, 2023
1 parent b8c14cc commit 4bc601e
Showing 1 changed file with 6 additions and 10 deletions.
16 changes: 6 additions & 10 deletions src/Web.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1937,18 +1937,14 @@ static void handleCoverImageRequest(AsyncWebServerRequest *request) {
}

int imageSize = gPlayProperties.coverFileSize;
AsyncWebServerResponse *response = request->beginChunkedResponse(mimeType, [coverFile, imageSize](uint8_t *buffer, size_t maxLen, size_t index) -> size_t {
// some kind of webserver bug with actual size available, reduce the len
maxLen = maxLen >> 1;

AsyncWebServerResponse *response = request->beginResponse(mimeType, imageSize, [coverFile, imageSize](uint8_t *buffer, size_t maxLen, size_t index) -> size_t {
File file = coverFile; // local copy of file pointer
size_t leftToWrite = imageSize - index;
if (!leftToWrite) {
return 0; // end of transfer
}
size_t willWrite = (leftToWrite > maxLen) ? maxLen : leftToWrite;

// read a maximum of 2048 bytes to avoid blocking too long
size_t willWrite = min((size_t) 2048, maxLen);

file.read(buffer, willWrite);
index += willWrite;

return willWrite;
});
response->addHeader("Cache Control", "no-cache, must-revalidate");
Expand Down

0 comments on commit 4bc601e

Please sign in to comment.