Improve logging and handle errors beter

This commit is contained in:
calli
2025-04-28 17:55:31 +03:00
parent 4fc97d473e
commit c986884ed5
10 changed files with 631 additions and 59 deletions

View File

@@ -1,6 +1,7 @@
import { AccessToken } from "@/types";
import { NextApiRequest, NextApiResponse } from "next";
import crypto from "crypto-js";
import logger from "@/utils/logger";
const EVE_SSO_REVOKE_URL = "https://login.eveonline.com/v2/oauth/revoke";
const EVE_SSO_CLIENT_ID = process.env.EVE_SSO_CLIENT_ID ?? "";
@@ -9,6 +10,14 @@ const EVE_SSO_SECRET = process.env.EVE_SSO_SECRET ?? "";
const handler = async (req: NextApiRequest, res: NextApiResponse) => {
if (req.method === "POST") {
const accessToken: AccessToken = req.body;
logger.info({
event: 'token_revoke_start',
character: {
name: accessToken.character.name,
characterId: accessToken.character.characterId
}
});
const params = new URLSearchParams({
grant_type: "refresh_token",
refresh_token: crypto.AES.decrypt(
@@ -27,24 +36,42 @@ const handler = async (req: NextApiRequest, res: NextApiResponse) => {
};
try {
await fetch(EVE_SSO_REVOKE_URL, {
const response = await fetch(EVE_SSO_REVOKE_URL, {
method: "POST",
body: params,
headers,
}).then((res) => res.json());
});
console.log(
"Revoke",
accessToken.character.name,
accessToken.character.characterId
);
if (!response.ok) {
throw new Error(`HTTP error! status: ${response.status}`);
}
logger.info({
event: 'token_revoke_success',
character: {
name: accessToken.character.name,
characterId: accessToken.character.characterId
}
});
return res.end();
} catch (e) {
console.log(e);
logger.error({
event: 'token_revoke_failed',
error: e,
character: {
name: accessToken.character.name,
characterId: accessToken.character.characterId
}
});
return res.status(500).end();
}
} else {
logger.warn({
event: 'invalid_method',
method: req.method,
path: req.url
});
res.status(404).end();
}
};