Initial commit — Sistema Generador de Guiones V4.0
Pipeline completo: URL → Whisper → GPT-4o → pgvector → Supabase Frontend Vue 3 + Tailwind, Backend Express + Vercel serverless functions
This commit is contained in:
54
backend/lib/extractor.js
Normal file
54
backend/lib/extractor.js
Normal file
@ -0,0 +1,54 @@
|
||||
// ============================================================
|
||||
// EXTRACTOR — Social Download All In One (RapidAPI)
|
||||
// Devuelve la URL del audio MP3 y metadata del video
|
||||
// ============================================================
|
||||
|
||||
const RAPIDAPI_HOST = 'social-download-all-in-one.p.rapidapi.com'
|
||||
const RAPIDAPI_URL = `https://${RAPIDAPI_HOST}/v1/social/autolink`
|
||||
|
||||
/**
|
||||
* @param {string} url URL del video (TikTok, Reels, YouTube Shorts)
|
||||
* @returns {{ audioUrl: string, duracion: number, titulo: string, thumbnail: string, plataforma: string }}
|
||||
*/
|
||||
export async function extraerAudio(url) {
|
||||
const response = await fetch(RAPIDAPI_URL, {
|
||||
method: 'POST',
|
||||
headers: {
|
||||
'Content-Type': 'application/json',
|
||||
'x-rapidapi-host': RAPIDAPI_HOST,
|
||||
'x-rapidapi-key': process.env.RAPIDAPI_KEY,
|
||||
},
|
||||
body: JSON.stringify({ url }),
|
||||
})
|
||||
|
||||
if (!response.ok) {
|
||||
throw new Error(`Social Download API error: ${response.status} ${response.statusText}`)
|
||||
}
|
||||
|
||||
const data = await response.json()
|
||||
|
||||
if (data.error) {
|
||||
throw new Error(`Social Download API devolvió error para la URL: ${url}`)
|
||||
}
|
||||
|
||||
// Buscar el media de tipo audio
|
||||
const audioMedia = data.medias?.find(m => m.type === 'audio')
|
||||
if (!audioMedia?.url) {
|
||||
throw new Error('La API no devolvió un archivo de audio para esta URL')
|
||||
}
|
||||
|
||||
return {
|
||||
audioUrl: audioMedia.url,
|
||||
duracion: data.duration ?? null,
|
||||
titulo: data.title ?? null,
|
||||
thumbnail: data.thumbnail ?? null,
|
||||
plataforma: detectarPlataforma(url),
|
||||
}
|
||||
}
|
||||
|
||||
function detectarPlataforma(url) {
|
||||
if (url.includes('tiktok.com')) return 'tiktok'
|
||||
if (url.includes('instagram.com')) return 'reels'
|
||||
if (url.includes('youtube.com') || url.includes('youtu.be')) return 'shorts'
|
||||
return 'tiktok' // fallback
|
||||
}
|
||||
Reference in New Issue
Block a user