1
0
mirror of https://github.com/snobu/destreamer.git synced 2026-01-20 23:12:16 +00:00
Files
destreamer-mirror/src/ApiClient.ts
Adrian Calinescu 0f2d902d2e Fix verbose logging when we get JSON back
Which i guess was like 99% of the time? :)
2020-11-14 19:59:11 +02:00

131 lines
4.2 KiB
TypeScript

import { logger } from './Logger';
import { Session } from './Types';
import axios, { AxiosRequestConfig, AxiosResponse, AxiosInstance, AxiosError } from 'axios';
import axiosRetry, { isNetworkOrIdempotentRequestError } from 'axios-retry';
export class ApiClient {
private static instance: ApiClient;
private axiosInstance?: AxiosInstance;
private session?: Session;
private constructor(session?: Session) {
this.session = session;
this.axiosInstance = axios.create({
baseURL: session?.ApiGatewayUri,
// timeout: 7000,
headers: { 'User-Agent': 'destreamer/3.0 (Preview)' }
});
axiosRetry(this.axiosInstance, {
// The following option is not working.
// We should open an issue on the relative GitHub
shouldResetTimeout: true,
retries: 6,
retryDelay: (retryCount: number) => {
return retryCount * 2000;
},
retryCondition: (err: AxiosError) => {
const retryCodes: Array<number> = [429, 500, 502, 503];
if (isNetworkOrIdempotentRequestError(err)) {
logger.warn(`${err}. Retrying request...`);
return true;
}
logger.warn(`Got HTTP code ${err?.response?.status ?? undefined}. Retrying request...`);
logger.verbose('Here is the error message: ');
console.dir(err.response?.data);
logger.verbose('We called this URL: ' + err.response?.config.baseURL + err.response?.config.url);
const shouldRetry: boolean = retryCodes.includes(err?.response?.status ?? 0);
return shouldRetry;
}
});
}
/**
* Used to initialize/retrive the active ApiClient
*
* @param session used if initializing
*/
public static getInstance(session?: Session): ApiClient {
if (!ApiClient.instance) {
ApiClient.instance = new ApiClient(session);
}
return ApiClient.instance;
}
public setSession(session: Session): void {
if (!ApiClient.instance) {
logger.warn("Trying to update ApiCient session when it's not initialized!");
}
this.session = session;
return;
}
/**
* Call Microsoft Stream API. Base URL is sourced from
* the session object and prepended automatically.
*/
public async callApi(
path: string,
method: AxiosRequestConfig['method'] = 'get',
payload?: any): Promise<AxiosResponse | undefined> {
const delimiter: '?' | '&' = path.split('?').length === 1 ? '?' : '&';
const headers: object = {
'Authorization': 'Bearer ' + this.session?.AccessToken
};
logger.debug(
'[ApiClient.callApi]\n' +
'path: ' + path + '\n' +
'method: ' + method + '\n' +
'payload: ' + payload + '\n'
);
return this.axiosInstance?.request({
method: method,
headers: headers,
data: payload ?? undefined,
url: path + delimiter + 'api-version=' + this.session?.ApiGatewayVersion
});
}
/**
* Call an absolute URL
*/
public async callUrl(
url: string,
method: AxiosRequestConfig['method'] = 'get',
payload?: any,
responseType: AxiosRequestConfig['responseType'] = 'json'): Promise<AxiosResponse | undefined> {
const headers: object = {
'Authorization': 'Bearer ' + this.session?.AccessToken
};
logger.debug(
'[ApiClient.callUrl]\n' +
'url: ' + url + '\n' +
'method: ' + method + '\n' +
'payload: ' + payload + '\n' +
'responseType: ' + responseType + '\n'
);
return this.axiosInstance?.request({
method: method,
headers: headers,
data: payload ?? undefined,
url: url,
responseType: responseType
});
}
}