Files
JellySport/ProjectSourceCode/src/resources/routes/league-pages/get-current-league-information.js

44 lines
1.5 KiB
JavaScript
Raw Normal View History

2024-04-11 08:49:19 -06:00
const axios = require('axios');
// Middleware function to fetch leagues data
const fetchLeaguesData = async (req, res, next) => {
2024-04-11 08:49:19 -06:00
try {
// Extract league ID from the URL
const leagueID = req.params.leagueID;
2024-04-11 08:49:19 -06:00
// Make GET request to the API endpoint using the league ID
const response = await axios.get(`http://api.football-data.org/v4/competitions/${leagueID}/standings?season`, {
headers: {
'X-Auth-Token': '0aa1ed31245d4a36b1ef5a79150324b3', // Add your API key here
},
});
2024-04-11 08:49:19 -06:00
// Extract relevant data from the API response
const leagueData = response.data;
2024-04-11 08:49:19 -06:00
// Attach the data to res.locals
res.locals.leagues = [{
competition: {
league_id: leagueData.competition.id,
league_name: leagueData.competition.name,
league_emblem: leagueData.competition.emblem
},
standings: leagueData.standings[0].table.map(team => ({
table: {
league_position: team.position,
team_id: team.team.id,
team_name: team.team.name,
team_crest: team.team.crest
2024-04-11 08:49:19 -06:00
},
})),
}];
2024-04-11 08:49:19 -06:00
next();
} catch (error) {
console.error('Error fetching leagues data:', error);
2024-04-11 08:49:19 -06:00
res.locals.leagues = []; // Set an empty array if there's an error
next(); // Call next middleware or route handler
}
};
module.exports = fetchLeaguesData;