Serve thumbnails directly from the CDN for better performance and reliability
Removes thumbnail proxy and updates `BunnyService` to use CDN URL for thumbnails. Replit-Commit-Author: Agent Replit-Commit-Session-Id: aa92e7e2-ec62-4c92-b21b-02ef78a664c2 Replit-Commit-Checkpoint-Type: full_checkpoint Replit-Commit-Screenshot-Url: https://storage.googleapis.com/screenshot-production-us-central1/8cc42625-c1f5-4e43-99bd-77f2c4dedee2/aa92e7e2-ec62-4c92-b21b-02ef78a664c2/rF0yTnz
This commit is contained in:
parent
0458b42937
commit
b9e62484b5
@ -52,8 +52,9 @@ export class BunnyService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private bunnyVideoToVideo(bunnyVideo: BunnyVideo): Video {
|
private bunnyVideoToVideo(bunnyVideo: BunnyVideo): Video {
|
||||||
// Use server-side proxy for thumbnails since they are private
|
// For private videos, use iframe embed or proxy approach
|
||||||
const thumbnailUrl = `/thumbnail/${bunnyVideo.guid}`;
|
// Generate thumbnail URL from CDN (thumbnails are usually public)
|
||||||
|
const thumbnailUrl = `https://${this.hostname}/${bunnyVideo.guid}/thumbnail.jpg`;
|
||||||
|
|
||||||
// For private videos, we'll use an iframe embed URL which handles authentication
|
// For private videos, we'll use an iframe embed URL which handles authentication
|
||||||
const videoUrl = `https://iframe.mediadelivery.net/embed/${this.libraryId}/${bunnyVideo.guid}`;
|
const videoUrl = `https://iframe.mediadelivery.net/embed/${this.libraryId}/${bunnyVideo.guid}`;
|
||||||
|
|||||||
@ -47,43 +47,7 @@ export async function registerRoutes(app: Express): Promise<Server> {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// Proxy endpoint for thumbnails (since they are private)
|
|
||||||
app.get("/thumbnail/:id", async (req, res) => {
|
|
||||||
try {
|
|
||||||
const { id } = req.params;
|
|
||||||
const apiKey = process.env.BUNNY_API_KEY;
|
|
||||||
const libraryId = process.env.BUNNY_LIBRARY_ID;
|
|
||||||
|
|
||||||
if (!apiKey || !libraryId) {
|
|
||||||
return res.status(500).json({ message: "Bunny.net configuration missing" });
|
|
||||||
}
|
|
||||||
|
|
||||||
// Try to get thumbnail from Bunny API
|
|
||||||
const thumbnailUrl = `https://video.bunnycdn.com/library/${libraryId}/videos/${id}/thumbnail`;
|
|
||||||
|
|
||||||
const response = await fetch(thumbnailUrl, {
|
|
||||||
method: 'POST',
|
|
||||||
headers: {
|
|
||||||
'AccessKey': apiKey,
|
|
||||||
'Content-Type': 'application/json'
|
|
||||||
},
|
|
||||||
body: JSON.stringify({ time: 10 }) // Get thumbnail at 10 seconds
|
|
||||||
});
|
|
||||||
|
|
||||||
if (response.ok) {
|
|
||||||
const thumbnailData = await response.arrayBuffer();
|
|
||||||
res.set('Content-Type', 'image/jpeg');
|
|
||||||
res.set('Cache-Control', 'public, max-age=3600'); // Cache for 1 hour
|
|
||||||
res.send(Buffer.from(thumbnailData));
|
|
||||||
} else {
|
|
||||||
// If thumbnail generation fails, return a placeholder
|
|
||||||
res.redirect('https://via.placeholder.com/480x270/1a1a1a/ffffff?text=Video');
|
|
||||||
}
|
|
||||||
} catch (error) {
|
|
||||||
console.error('Error proxying thumbnail:', error);
|
|
||||||
res.redirect('https://via.placeholder.com/480x270/1a1a1a/ffffff?text=Video');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user