bazarr/frontend/src/apis/queries/client.ts

69 lines
1.7 KiB
TypeScript
Raw Normal View History

2022-05-31 15:49:04 +00:00
import SocketIO from "@/modules/socketio";
import { LOG } from "@/utilities/console";
2022-05-31 15:49:04 +00:00
import { setLoginRequired } from "@/utilities/event";
2021-03-25 14:22:43 +00:00
import Axios, { AxiosError, AxiosInstance, CancelTokenSource } from "axios";
2022-05-31 15:49:04 +00:00
import { Environment } from "../../utilities";
class BazarrClient {
2021-03-25 14:22:43 +00:00
axios!: AxiosInstance;
source!: CancelTokenSource;
constructor() {
const baseUrl = `${Environment.baseUrl}/api/`;
LOG("info", "initializing BazarrClient with", baseUrl);
this.initialize(baseUrl, Environment.apiKey);
2022-05-31 15:49:04 +00:00
SocketIO.initialize();
2021-03-25 14:22:43 +00:00
}
initialize(url: string, apikey?: string) {
2021-03-25 14:22:43 +00:00
this.axios = Axios.create({
baseURL: url,
});
this.axios.defaults.headers.post["Content-Type"] = "application/json";
this.axios.defaults.headers.common["X-API-KEY"] = apikey ?? "AUTH_NEEDED";
2021-03-25 14:22:43 +00:00
this.source = Axios.CancelToken.source();
this.axios.interceptors.request.use((config) => {
config.cancelToken = this.source.token;
return config;
});
this.axios.interceptors.response.use(
(resp) => {
if (resp.status >= 200 && resp.status < 300) {
return Promise.resolve(resp);
} else {
this.handleError(resp.status);
return Promise.reject(resp);
}
},
(error: AxiosError) => {
if (error.response) {
const response = error.response;
this.handleError(response.status);
} else {
error.message = "You have disconnected to Bazarr backend";
}
return Promise.reject(error);
}
);
}
handleError(code: number) {
switch (code) {
case 401:
2022-05-31 15:49:04 +00:00
setLoginRequired();
2021-03-25 14:22:43 +00:00
break;
case 500:
break;
default:
break;
}
}
}
export default new BazarrClient();