Version 1.3.1 - Modification du Bug des medias

This commit is contained in:
2025-10-06 23:24:28 +02:00
parent dc072f36bd
commit adfa2b1710

View File

@@ -2,7 +2,8 @@ const ffprobe = require('ffprobe');
const ffprobeStatic = require('ffprobe-static'); const ffprobeStatic = require('ffprobe-static');
const { getReadableDuration } = require('../utils/TimeConverter'); const { getReadableDuration } = require('../utils/TimeConverter');
const clog = require("loguix").getInstance("Song") const clog = require("loguix").getInstance("Song")
const path = require('path');
const fs = require('fs');
async function getMediaInformation(instance, media, provider) { async function getMediaInformation(instance, media, provider) {
try { try {
@@ -30,28 +31,51 @@ async function getMediaInformation(instance, media, provider) {
} }
async function getMediaInformationFromUrl(instance, url) { async function getMediaInformationFromUrl(instance, url) {
let tmpFile = null;
try { try {
const info = await ffprobe(url, { path: ffprobeStatic.path }); // 1. Vérifier si ./tmp existe, sinon le créer
const tmpDir = path.resolve("./tmp");
if (!fs.existsSync(tmpDir)) {
fs.mkdirSync(tmpDir, { recursive: true });
}
// 2. Télécharger le fichier en mémoire et lécrire en sync
const res = await fetch(url);
if (!res.ok) throw new Error(`Erreur HTTP ${res.status}`);
const buffer = Buffer.from(await res.arrayBuffer());
tmpFile = path.join(tmpDir, `${Date.now()}.mp3`);
fs.writeFileSync(tmpFile, buffer);
// 3. Lancer ffprobe sur le fichier local
const info = await ffprobe(tmpFile, { path: ffprobeStatic.path });
if (info.streams?.[0]?.duration_ts) { if (info.streams?.[0]?.duration_ts) {
instance.duration = info.streams[0].duration; instance.duration = info.streams[0].duration;
instance.readduration = getReadableDuration(instance.duration); instance.readduration = getReadableDuration(instance.duration);
} }
// Vérification pour éviter une erreur si `streams[0]` ou `tags` n'existe pas instance.thumbnail = info.streams?.[0]?.tags?.thumbnail ??
instance.thumbnail = info.streams?.[0]?.tags?.thumbnail ??
"https://radomisol.fr/wp-content/uploads/2016/08/cropped-note-radomisol-musique.png"; "https://radomisol.fr/wp-content/uploads/2016/08/cropped-note-radomisol-musique.png";
// Obtenir le titre (sinon utiliser le nom du fichier)
instance.title = info.streams?.[0]?.tags?.title ?? "Titre inconnu"; instance.title = info.streams?.[0]?.tags?.title ?? "Titre inconnu";
// Obtenir l'auteur (s'il existe)
instance.author = info.streams?.[0]?.tags?.artist ?? "Auteur inconnu"; instance.author = info.streams?.[0]?.tags?.artist ?? "Auteur inconnu";
return true; return true;
} catch (err) { } catch (err) {
clog.error("Impossible de récupérer les informations de la musique depuis l'URL : " + url); clog.error("Impossible de récupérer les informations de la musique depuis l'URL : " + url);
console.log(err) console.error(err);
clog.error(err);
return null; return null;
} finally {
// 4. Nettoyage : supprimer le fichier temporaire
if (tmpFile && fs.existsSync(tmpFile)) {
try {
fs.unlinkSync(tmpFile);
} catch (e) {
console.error("Erreur lors du unlink:", e);
}
}
} }
} }