Use db value
This commit is contained in:
parent
31147014a0
commit
6dd506eb6e
2 changed files with 64 additions and 14 deletions
|
|
@ -1,21 +1,32 @@
|
|||
const axios = require('axios');
|
||||
const config = require('../../config/radarr');
|
||||
const Settings = require('../models/Settings');
|
||||
|
||||
// Client API pour Radarr
|
||||
const radarrClient = axios.create({
|
||||
baseURL: config.baseURL,
|
||||
headers: {
|
||||
'X-Api-Key': config.apiKey
|
||||
// Fonction pour créer un client Radarr pour un utilisateur spécifique
|
||||
const createRadarrClient = async (userId) => {
|
||||
const settings = await Settings.findOne({ user: userId });
|
||||
if (!settings || !settings.radarr || !settings.radarr.url || !settings.radarr.apiKey) {
|
||||
throw new Error('Paramètres Radarr non configurés');
|
||||
}
|
||||
});
|
||||
|
||||
return axios.create({
|
||||
baseURL: settings.radarr.url,
|
||||
headers: {
|
||||
'X-Api-Key': settings.radarr.apiKey
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
// Récupérer tous les films
|
||||
exports.getAllMovies = async (req, res) => {
|
||||
try {
|
||||
const radarrClient = await createRadarrClient(req.user.id);
|
||||
const response = await radarrClient.get('/movie');
|
||||
res.json(response.data);
|
||||
} catch (error) {
|
||||
console.error('Erreur lors de la récupération des films:', error);
|
||||
if (error.message === 'Paramètres Radarr non configurés') {
|
||||
return res.status(400).json({ message: error.message });
|
||||
}
|
||||
res.status(500).json({ message: 'Erreur lors de la récupération des films' });
|
||||
}
|
||||
};
|
||||
|
|
@ -23,11 +34,15 @@ exports.getAllMovies = async (req, res) => {
|
|||
// Récupérer les films manquants
|
||||
exports.getMissingMovies = async (req, res) => {
|
||||
try {
|
||||
const radarrClient = await createRadarrClient(req.user.id);
|
||||
const response = await radarrClient.get('/movie');
|
||||
const missingMovies = response.data.filter(movie => !movie.hasFile);
|
||||
res.json(missingMovies);
|
||||
} catch (error) {
|
||||
console.error('Erreur lors de la récupération des films manquants:', error);
|
||||
if (error.message === 'Paramètres Radarr non configurés') {
|
||||
return res.status(400).json({ message: error.message });
|
||||
}
|
||||
res.status(500).json({ message: 'Erreur lors de la récupération des films manquants' });
|
||||
}
|
||||
};
|
||||
|
|
@ -35,6 +50,7 @@ exports.getMissingMovies = async (req, res) => {
|
|||
// Récupérer les films à venir
|
||||
exports.getUpcomingMovies = async (req, res) => {
|
||||
try {
|
||||
const radarrClient = await createRadarrClient(req.user.id);
|
||||
const today = new Date();
|
||||
const response = await radarrClient.get('/movie');
|
||||
|
||||
|
|
@ -46,6 +62,9 @@ exports.getUpcomingMovies = async (req, res) => {
|
|||
res.json(upcomingMovies);
|
||||
} catch (error) {
|
||||
console.error('Erreur lors de la récupération des films à venir:', error);
|
||||
if (error.message === 'Paramètres Radarr non configurés') {
|
||||
return res.status(400).json({ message: error.message });
|
||||
}
|
||||
res.status(500).json({ message: 'Erreur lors de la récupération des films à venir' });
|
||||
}
|
||||
};
|
||||
|
|
@ -53,10 +72,14 @@ exports.getUpcomingMovies = async (req, res) => {
|
|||
// Récupérer l'historique des téléchargements
|
||||
exports.getHistory = async (req, res) => {
|
||||
try {
|
||||
const radarrClient = await createRadarrClient(req.user.id);
|
||||
const response = await radarrClient.get('/history');
|
||||
res.json(response.data);
|
||||
} catch (error) {
|
||||
console.error('Erreur lors de la récupération de l\'historique:', error);
|
||||
if (error.message === 'Paramètres Radarr non configurés') {
|
||||
return res.status(400).json({ message: error.message });
|
||||
}
|
||||
res.status(500).json({ message: 'Erreur lors de la récupération de l\'historique' });
|
||||
}
|
||||
};
|
||||
|
|
@ -64,6 +87,7 @@ exports.getHistory = async (req, res) => {
|
|||
// Récupérer le calendrier
|
||||
exports.getCalendar = async (req, res) => {
|
||||
try {
|
||||
const radarrClient = await createRadarrClient(req.user.id);
|
||||
const { start, end } = req.query;
|
||||
const startDate = start || new Date().toISOString();
|
||||
const endDate = end || new Date(Date.now() + 30 * 24 * 60 * 60 * 1000).toISOString();
|
||||
|
|
@ -78,6 +102,9 @@ exports.getCalendar = async (req, res) => {
|
|||
res.json(response.data);
|
||||
} catch (error) {
|
||||
console.error('Erreur lors de la récupération du calendrier:', error);
|
||||
if (error.message === 'Paramètres Radarr non configurés') {
|
||||
return res.status(400).json({ message: error.message });
|
||||
}
|
||||
res.status(500).json({ message: 'Erreur lors de la récupération du calendrier' });
|
||||
}
|
||||
};
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue