plebdevs/src/pages/api/get-video-url.js

59 lines
1.9 KiB
JavaScript

import { getServerSession } from "next-auth/next"
import { authOptions } from "./auth/[...nextauth]"
import { getSignedUrl } from "@aws-sdk/s3-request-presigner"
import { S3Client, GetObjectCommand } from "@aws-sdk/client-s3"
const s3Client = new S3Client({
endpoint: "https://nyc3.digitaloceanspaces.com", // DigitalOcean Spaces endpoint
region: "nyc3",
credentials: {
accessKeyId: process.env.DO_SPACES_KEY,
secretAccessKey: process.env.DO_SPACES_SECRET,
},
})
const AUTHOR_PUBKEY = process.env.AUTHOR_PUBKEY
export default async function handler(req, res) {
try {
// Check if the request method is GET
if (req.method !== 'GET') {
return res.status(405).json({ error: "Method Not Allowed" })
}
const session = await getServerSession(req, res, authOptions)
if (!session) {
return res.status(401).json({ error: "Unauthorized" })
}
const { videoKey } = req.query
if (!videoKey || typeof videoKey !== 'string') {
return res.status(400).json({ error: "Invalid or missing video key" })
}
// Check if the user is authorized to access the video
if (!session.user.role?.subscribed && session.user.pubkey !== AUTHOR_PUBKEY) {
const purchasedVideo = session.user.purchased?.find(purchase => purchase?.resource?.videoId === videoKey)
console.log("purchasedVideo", purchasedVideo)
if (!purchasedVideo) {
return res.status(403).json({ error: "Forbidden: You don't have access to this video" })
}
}
const command = new GetObjectCommand({
Bucket: "plebdevs-bucket",
Key: videoKey,
})
const signedUrl = await getSignedUrl(s3Client, command, {
expiresIn: 3600, // URL expires in 1 hour
})
res.redirect(signedUrl)
} catch (error) {
console.error("Error in get-video-url handler:", error)
res.status(500).json({ error: "Internal Server Error" })
}
}