diff options
| author | dakkar <dakkar@thenautilus.net> | 2024-04-11 13:22:57 +0100 |
|---|---|---|
| committer | dakkar <dakkar@thenautilus.net> | 2024-04-11 13:22:57 +0100 |
| commit | a58f4a6fedc0250e2a575eab976854d43c18d5e0 (patch) | |
| tree | da713405e987bb6e845cf1371ece9ce677712bd3 /packages/backend/src/server/FileServerService.ts | |
| parent | fix `UserEntityService` (diff) | |
| parent | merge: handle ranged requests for proxied files - fixes #494 (!490) (diff) | |
| download | sharkey-a58f4a6fedc0250e2a575eab976854d43c18d5e0.tar.gz sharkey-a58f4a6fedc0250e2a575eab976854d43c18d5e0.tar.bz2 sharkey-a58f4a6fedc0250e2a575eab976854d43c18d5e0.zip | |
Merge branch 'develop' into future-2024-03-23-post
Diffstat (limited to 'packages/backend/src/server/FileServerService.ts')
| -rw-r--r-- | packages/backend/src/server/FileServerService.ts | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/packages/backend/src/server/FileServerService.ts b/packages/backend/src/server/FileServerService.ts index 6d24898acc..3cb353f2b3 100644 --- a/packages/backend/src/server/FileServerService.ts +++ b/packages/backend/src/server/FileServerService.ts @@ -192,6 +192,7 @@ export class FileServerService { reply.header('Content-Range', `bytes ${start}-${end}/${file.file.size}`); reply.header('Accept-Ranges', 'bytes'); reply.header('Content-Length', chunksize); + reply.code(206); } else { image = { data: fs.createReadStream(file.path), @@ -261,7 +262,6 @@ export class FileServerService { const parts = range.replace(/bytes=/, '').split('-'); const start = parseInt(parts[0], 10); let end = parts[1] ? parseInt(parts[1], 10) : file.file.size - 1; - console.log(end); if (end > file.file.size) { end = file.file.size - 1; } @@ -431,6 +431,7 @@ export class FileServerService { reply.header('Content-Range', `bytes ${start}-${end}/${file.file.size}`); reply.header('Accept-Ranges', 'bytes'); reply.header('Content-Length', chunksize); + reply.code(206); } else { image = { data: fs.createReadStream(file.path), @@ -527,6 +528,9 @@ export class FileServerService { if (!file.storedInternal) { if (!(file.isLink && file.uri)) return '204'; const result = await this.downloadAndDetectTypeFromUrl(file.uri); + if (!file.size) { + file.size = (await fs.promises.stat(result.path)).size; + } return { ...result, url: file.uri, |