Modif user profile

This commit is contained in:
AMAICDAX 2025-09-03 12:52:12 +02:00
parent 8942f0fff2
commit 63cec006bc

View file

@ -56,14 +56,53 @@ const handleCallback = async (req, res) => {
const getUserProfile = async (req, res) => { const getUserProfile = async (req, res) => {
try { try {
const profileResponse = await axios.get("https://api.linkedin.com/v2/me", { const token = req.session?.user?.accessToken;
if (!token) {
return res.status(401).json({ error: "Aucun accessToken en session." });
}
const url =
"https://api.linkedin.com/v2/me" +
"?projection=(id,localizedFirstName,localizedLastName,profilePicture(displayImage~:playableStreams))";
const { data } = await axios.get(url, {
headers: { headers: {
Authorization: `Bearer ${req.session.user.accessToken}`, Authorization: `Bearer ${token}`,
"X-Restli-Protocol-Version": "2.0.0", // souvent requis par les endpoints v2
Accept: "application/json",
}, },
}); });
res.json(profileResponse.data);
return res.json(data);
} catch (error) { } catch (error) {
res.status(500).send("Error retrieving user profile."); const status = error.response?.status ?? 500;
const payload = error.response?.data ?? { message: error.message };
// Log côté serveur pour diagnostiquer vite
console.error("LinkedIn API error:", status, payload);
if (status === 401) {
return res.status(401).json({
error: "Token invalide ou expiré.",
hint: "Renouvelle le token OAuth (nouvelle auth) et réessaie.",
});
}
if (status === 403) {
return res.status(403).json({
error: "Permissions insuffisantes.",
hint: "Ajoute le scope 'r_liteprofile' (et 'r_emailaddress' si besoin) et assure que ton app y est autorisée.",
});
}
if (status === 429) {
return res.status(429).json({
error: "Trop de requêtes (rate limit).",
hint: "Ajoute du retry/backoff.",
});
}
return res.status(500).json({
error: "Erreur lors de la récupération du profil.",
details: payload,
});
} }
}; };