mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-06 00:07:44 +01:00
9ea67a74b4
## About the changes This uses log-level warning so we can turn off the log without turning off all error logs. This could potentially be tweaked further by using log categories in the log configuration. Closes #2057
70 lines
1.9 KiB
TypeScript
70 lines
1.9 KiB
TypeScript
import fetch from 'make-fetch-happen';
|
|
import { addonDefinitionSchema } from './addon-schema';
|
|
import { IUnleashConfig } from '../types/option';
|
|
import { Logger } from '../logger';
|
|
import { IAddonDefinition } from '../types/model';
|
|
import { IEvent } from '../types/events';
|
|
|
|
export default abstract class Addon {
|
|
logger: Logger;
|
|
|
|
_name: string;
|
|
|
|
_definition: IAddonDefinition;
|
|
|
|
constructor(
|
|
definition: IAddonDefinition,
|
|
{ getLogger }: Pick<IUnleashConfig, 'getLogger'>,
|
|
) {
|
|
this.logger = getLogger(`addon/${definition.name}`);
|
|
const { error } = addonDefinitionSchema.validate(definition);
|
|
if (error) {
|
|
this.logger.warn(
|
|
`Could not load addon provider ${definition.name}`,
|
|
error,
|
|
);
|
|
throw error;
|
|
}
|
|
this._name = definition.name;
|
|
this._definition = definition;
|
|
}
|
|
|
|
get name(): string {
|
|
return this._name;
|
|
}
|
|
|
|
get definition(): IAddonDefinition {
|
|
return this._definition;
|
|
}
|
|
|
|
async fetchRetry(
|
|
url: string,
|
|
options: any = {},
|
|
retries: number = 1,
|
|
): Promise<Response> {
|
|
let res;
|
|
try {
|
|
res = await fetch(url, {
|
|
retry: {
|
|
retries,
|
|
},
|
|
...options,
|
|
});
|
|
return res;
|
|
} catch (e) {
|
|
const { method } = options;
|
|
this.logger.warn(
|
|
`Error querying ${url} with method ${
|
|
method || 'GET'
|
|
} status code ${e.code}`,
|
|
e,
|
|
);
|
|
res = { statusCode: e.code, ok: false };
|
|
}
|
|
return res;
|
|
}
|
|
|
|
// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
|
|
abstract handleEvent(event: IEvent, parameters: any): Promise<void>;
|
|
}
|