From ce6e47309a288f57538c1daaa4a1842f6e95bd46 Mon Sep 17 00:00:00 2001 From: "suraj.shenoy.b@gmail.com" Date: Sat, 25 Jan 2025 21:40:21 -0600 Subject: [PATCH] Update route.js --- src/app/api/transcribe/route.js | 71 +++++++++++++++------------------ 1 file changed, 32 insertions(+), 39 deletions(-) diff --git a/src/app/api/transcribe/route.js b/src/app/api/transcribe/route.js index 7341979..f313464 100644 --- a/src/app/api/transcribe/route.js +++ b/src/app/api/transcribe/route.js @@ -1,9 +1,9 @@ -import fs, {unlinkSync, existsSync } from 'fs'; -import path from 'path'; -import { config } from 'dotenv'; -import formidable from 'formidable'; -import { AxiosError } from 'axios'; -import OpenAI from 'openai'; +import fs, { unlinkSync, existsSync } from "fs"; +import path from "path"; +import { config } from "dotenv"; +import formidable from "formidable"; +import { AxiosError } from "axios"; +import OpenAI from "openai"; // Load environment variables config(); @@ -11,7 +11,7 @@ config(); const OPENAI_API_KEY = process.env.OPENAI_API_KEY; if (!OPENAI_API_KEY) { - throw new Error('OpenAI API key is missing. Set OPENAI_API_KEY in your .env.local file.'); + throw new Error("OpenAI API key is missing. Set OPENAI_API_KEY in your .env.local file."); } // Initialize OpenAI client @@ -22,25 +22,18 @@ const openaiClient = new OpenAI({ // Helper to parse multipart form data async function parseMultipartForm(req) { const form = formidable({ - multiples: false, // Single file upload - uploadDir: '/tmp', // Temporary directory + multiples: false, + uploadDir: "/tmp", keepExtensions: true, - maxFileSize: 50 * 1024 * 1024, // 50 MB + maxFileSize: 50 * 1024 * 1024, }); return new Promise((resolve, reject) => { form.parse(req, (err, fields, files) => { if (err) { - reject(err); - return; + return reject(err); } - - const file = files.file; - if (!file) { - reject(new Error('No file found in the upload.')); - return; - } - + const file = files.file[0]; resolve({ filePath: file.filepath, originalFilename: file.originalFilename || 'unknown', @@ -50,9 +43,9 @@ async function parseMultipartForm(req) { } // Main handler -export async function POST(req, res) { - if (req.method !== 'POST') { - return res.status(405).json({ error: 'Method not allowed. Use POST.' }); +export default async function handler(req, res) { + if (req.method !== "POST") { + return res.status(405).json({ error: "Method not allowed. Use POST." }); } let filePath = null; @@ -63,29 +56,29 @@ export async function POST(req, res) { filePath = tempFilePath; // Log file details - console.log('Uploaded file path:', filePath); - console.log('Original filename:', originalFilename); + console.log("Uploaded file path:", filePath); + console.log("Original filename:", originalFilename); // Validate file extension - const allowedExtensions = ['mp3', 'wav', 'm4a']; - const fileExtension = path.extname(originalFilename).toLowerCase().replace('.', ''); + const allowedExtensions = ["mp3", "wav", "m4a"]; + const fileExtension = path.extname(originalFilename).toLowerCase().replace(".", ""); if (!allowedExtensions.includes(fileExtension)) { unlinkSync(filePath); return res.status(400).json({ - error: `Invalid file format. Only ${allowedExtensions.join(', ')} are supported.`, + error: `Invalid file format. Only ${allowedExtensions.join(", ")} are supported.`, }); } - // Create file stream - const audio_file = fs.createReadStream(filePath); - - // Step 2: Get transcription from OpenAI Whisper model - console.log('Requesting transcription...'); - const transcription = await openaiClient.audio.translations.create({ - file: fs.createReadStream(audio_file), + // Get transcription from OpenAI Whisper model + console.log("Requesting transcription..."); + const transcription = await openaiClient.audio.transcriptions.create({ + file: fs.createReadStream(filePath), // Pass the file stream here model: "whisper-1", + response_format: "text", // Ensure this is set }); + console.log("Transcription:", transcription); // Log the transcription response + // Clean up temporary file if (filePath && existsSync(filePath)) { unlinkSync(filePath); @@ -94,17 +87,17 @@ export async function POST(req, res) { // Send response back to client return res.status(200).json({ transcription: transcription.text }); } catch (error) { - console.error('Error during transcription:', error); + console.error("Error during transcription:", error); if (error instanceof AxiosError) { - console.error('OpenAI API error:', error.response?.data || error.message); + console.error("OpenAI API error:", error.response?.data || error.message); return res.status(error.response?.status || 500).json({ - error: error.response?.data?.error?.message || 'OpenAI API Error.', + error: error.response?.data?.error?.message || "OpenAI API Error.", }); } return res.status(500).json({ - error: 'An unexpected error occurred.', + error: "An unexpected error occurred.", }); } finally { if (filePath) { @@ -113,7 +106,7 @@ export async function POST(req, res) { unlinkSync(filePath); } } catch (err) { - console.error('Failed to clean up temporary file:', err); + console.error("Failed to clean up temporary file:", err); } } }