Fix issue when streaming through Cloudflare
This commit is contained in:
parent
8a75d7d677
commit
ec11bda449
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "immich-public-proxy",
|
"name": "immich-public-proxy",
|
||||||
"version": "1.3.8",
|
"version": "1.3.9",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "ts-node src/index.ts",
|
"dev": "ts-node src/index.ts",
|
||||||
"build": "npx tsc",
|
"build": "npx tsc",
|
||||||
|
@ -15,14 +15,17 @@ class Render {
|
|||||||
*/
|
*/
|
||||||
async assetBuffer (req: IncomingShareRequest, res: Response, asset: Asset, size?: ImageSize) {
|
async assetBuffer (req: IncomingShareRequest, res: Response, asset: Asset, size?: ImageSize) {
|
||||||
// Prepare the request
|
// Prepare the request
|
||||||
|
const headerList = ['content-type', 'content-length', 'last-modified', 'etag']
|
||||||
size = size === ImageSize.thumbnail ? ImageSize.thumbnail : ImageSize.original
|
size = size === ImageSize.thumbnail ? ImageSize.thumbnail : ImageSize.original
|
||||||
const subpath = asset.type === AssetType.video ? '/video/playback' : '/' + size
|
const subpath = asset.type === AssetType.video ? '/video/playback' : '/' + size
|
||||||
const headers = { range: '' }
|
const headers = { range: '' }
|
||||||
if (asset.type === AssetType.video && req.range) {
|
if (asset.type === AssetType.video) {
|
||||||
const start = req.range.replace(/bytes=/, '').split('-')[0]
|
const start = (req.range || '').replace(/bytes=/, '').split('-')[0]
|
||||||
const startByte = parseInt(start, 10) || 0
|
const startByte = parseInt(start, 10) || 0
|
||||||
const endByte = startByte + 2499999
|
const endByte = startByte + 2499999
|
||||||
headers.range = `bytes=${startByte}-${endByte}`
|
headers.range = `bytes=${startByte}-${endByte}`
|
||||||
|
headerList.push('accept-ranges', 'cache-control', 'content-range')
|
||||||
|
res.status(206) // Partial Content
|
||||||
}
|
}
|
||||||
const url = immich.buildUrl(immich.apiUrl() + '/assets/' + encodeURIComponent(asset.id) + subpath, {
|
const url = immich.buildUrl(immich.apiUrl() + '/assets/' + encodeURIComponent(asset.id) + subpath, {
|
||||||
key: asset.key,
|
key: asset.key,
|
||||||
@ -33,12 +36,10 @@ class Render {
|
|||||||
// Return the response to the client
|
// Return the response to the client
|
||||||
if (data.status >= 200 && data.status < 300) {
|
if (data.status >= 200 && data.status < 300) {
|
||||||
// Populate the response headers
|
// Populate the response headers
|
||||||
['content-type', 'content-length', 'last-modified', 'etag', 'content-range']
|
headerList.forEach(header => {
|
||||||
.forEach(header => {
|
const value = data.headers.get(header)
|
||||||
const value = data.headers.get(header)
|
if (value) res.setHeader(header, value)
|
||||||
if (value) res.setHeader(header, value)
|
})
|
||||||
})
|
|
||||||
if (headers.range) res.status(206) // Partial Content
|
|
||||||
// Return the body
|
// Return the body
|
||||||
await data.body?.pipeTo(
|
await data.body?.pipeTo(
|
||||||
new WritableStream({
|
new WritableStream({
|
||||||
|
Loading…
Reference in New Issue
Block a user