I have 2 parts of this code, I am not sure where the error comes from or how to diagnose it, my code works fine on my localhost and returns the data correctly and it shows up on my front end without issue.
When I deployed the server to render.com (free plan) I got this issue
[Error: The request timed out.]
I tried fixing the root of the server like so
const server = app.listen(port, () => {
console.log(`Running server at port: ${port}`);
});
server.setTimeout(120000); // 120 seconds timeout
Then on the api endpoint there’s 2 functions, added axios timeout functionality because of the issue, for ffmepg I am not sure how to fix it
router.post("/", async (req, res) => {
var videoUrl = req.body.video;
const videoResponse = await axios.get(videoUrl, {
responseType: 'arraybuffer',
});
const formData = new FormData();
formData.append('file', Buffer.from(videoResponse.data), {
filename: 'video.mp4',
});
formData.append('model', model);
formData.append('response_format', 'srt');
const headers = {
'Authorization': `Bearer ${token}`,
...formData.getHeaders(),
};
const response = await axios.post('https://example.com', formData, {
headers,
timeout: 1200000
});
fs.writeFileSync('transcription.srt', response.data);
console.log('Transcription saved to transcription.srt');
const subtitlePath = "./transcription.srt";
console.log('subtitlePath :', subtitlePath);
const randomNum = Math.floor(100000000000 + Math.random() * 900000000000);
const fileName = `video_${randomNum}.mp4`;
const outputPath = `./${fileName}`;
// Execute the ffmpeg command to burn the subtitles into the video
const ffmpeg = spawn("ffmpeg", [
"-i",
"pipe:0",
"-vf",
`subtitles=${subtitlePath}:force_style='Alignment=10,OutlineColour=&H100000000,BorderStyle=3,Outline=1,Shadow=0,Fontsize=10'`,
"-c:a",
"copy",
"-progress", "pipe:1",
outputPath,
]);
// Pipe the videoResponse array buffer to FFmpeg
ffmpeg.stdin.write(videoResponse.data);
ffmpeg.stdin.end();
// Send the output file as a response once the process is complete
ffmpeg.on("close", () => {
fs.readFile(outputPath, (err, data) => {
if (err) {
console.error(err);
res.status(500).send("Failed to read the file");
} else {
res.set({
"Content-Disposition": `attachment; filename=${outputPath}`,
"Content-Type": "application/octet-stream",
});
res.send(data);
console.log("File sent successfully");
// Delete the output file once it has been sent
fs.unlinkSync(outputPath);
}
});
});
});
module.exports = router;
On my react native app, I added promise and some timeout code just to make sure the error it’s not originated from there but still facing the same issue
testing = (downloadURL) => {
const timeoutPromise = new Promise((_, reject) => {
setTimeout(() => {
reject(new Error('Request timed out'));
}, 120000); // 120 seconds timeout
});
this.setState({ loading: true, uploading: false });
RNFetchBlob.config({
fileCache: true,
appendExt: 'mp4',
})
.fetch('POST', 'https://example.com/api/v1/test', {
'Accept': 'application/octet-stream',
'Content-Type': 'application/json',
}, JSON.stringify({
video: downloadURL,
}))
.then(response => {
const videoPath = response.path();
const videoUrl = `file://${videoPath}`;
console.log('videoUrl :', videoUrl);
this.setState({ loading: false, success: true, render: videoUrl, downloadURL: null });
})
.catch(error => {
console.log(error);
this.setState({
error: error.message,
loading: false,
});
})
.finally(() => {
clearTimeout(timeoutId);
});
const timeoutId = setTimeout(() => {
console.log('Request timed out');
this.setState({
error: 'Request timed out',
loading: false,
});
}, 120000); // 120 seconds timeout
Promise.race([timeoutPromise])
.catch(error => {
console.log(error);
this.setState({
error: error.message,
loading: false,
});
});
};
Now to describe the problem, after triggering the endpoint the api is running fine then start the axios post request, this part is very fast and get done in about 2-3 seconds, the file then is moved to ffmpeg for converting, I have the code below that allows me to check conversion status progress, usually from what I see is when percentage is about to hit 100% I got the error timed out on my fronend and on the server it shows
POST /api/v1/test – – ms – –
No error on console log whatesover
// Listen to stderr and stdout data events to check the progress of the conversion
let progress = 0;
let duration = 0;
ffmpeg.stderr.on('data', (data) => {
// Search for the "Duration" line to get the total duration
const durationMatch = /Duration: (d{2}):(d{2}):(d{2})/.exec(data.toString());
if (durationMatch) {
duration = (parseInt(durationMatch[1]) * 3600) + (parseInt(durationMatch[2]) * 60) + parseInt(durationMatch[3]);
}
// Search for the "time=" line to get the current time
const timeMatch = /time=(d{2}):(d{2}):(d{2})/.exec(data.toString());
if (timeMatch) {
const currentTime = (parseInt(timeMatch[1]) * 3600) + (parseInt(timeMatch[2]) * 60) + parseInt(timeMatch[3]);
progress = Math.floor((currentTime / duration) * 100);
console.log(`FFmpeg : ${progress}%`);
}
});
Please help. Any suggestions appreciated