Fix axios error handling

This commit is contained in:
Ajay
2024-11-06 21:23:15 -05:00
parent 826d49ba1f
commit 01c306287a

View File

@@ -1,4 +1,4 @@
import axios from "axios"; import axios, { AxiosError } from "axios";
import { Logger } from "./logger"; import { Logger } from "./logger";
import { innerTubeVideoDetails } from "../types/innerTubeApi.model"; import { innerTubeVideoDetails } from "../types/innerTubeApi.model";
import DiskCache from "./diskCache"; import DiskCache from "./diskCache";
@@ -30,19 +30,29 @@ const privateResponse = (videoId: string, reason: string): innerTubeVideoDetails
export async function getFromITube (videoID: string): Promise<innerTubeVideoDetails> { export async function getFromITube (videoID: string): Promise<innerTubeVideoDetails> {
if (config.youTubeKeys.floatieUrl) { if (config.youTubeKeys.floatieUrl) {
const result = await axios.get(config.youTubeKeys.floatieUrl, { try {
params: { const result = await axios.get(config.youTubeKeys.floatieUrl, {
videoID, params: {
auth: config.youTubeKeys.floatieAuth videoID,
} auth: config.youTubeKeys.floatieAuth
}); }
});
if (result.status === 200) { if (result.status === 200) {
return result.data?.videoDetails ?? privateResponse(videoID, result.data?.playabilityStatus?.reason ?? "Bad response"); return result.data?.videoDetails ?? privateResponse(videoID, result.data?.playabilityStatus?.reason ?? "Bad response");
} else if (result.status === 500) { } else {
return privateResponse(videoID, result.data ?? "Bad response"); return Promise.reject(`Floatie returned non-200 response: ${result.status}`);
} else { }
return Promise.reject(`Floatie returned non-200 response: ${result.status}`); } catch (e) {
if (e instanceof AxiosError) {
const result = e.response;
if (result.status === 500) {
return privateResponse(videoID, result.data ?? "Bad response");
} else {
return Promise.reject(`Floatie returned non-200 response: ${result.status}`);
}
}
} }
} }