1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00
lens/src/common/utils/with-error-logging/with-error-logging.injectable.ts
Iku-turso 06851d9961 Introduce higher order function to log errors in decorated functions
Co-authored-by: Janne Savolainen <janne.savolainen@live.fi>

Signed-off-by: Iku-turso <mikko.aspiala@gmail.com>
2022-05-24 11:13:16 +03:00

40 lines
1.1 KiB
TypeScript

/**
* Copyright (c) OpenLens Authors. All rights reserved.
* Licensed under MIT License. See LICENSE in root directory for more information.
*/
import { getInjectable } from "@ogre-tools/injectable";
import loggerInjectable from "../../logger.injectable";
const withErrorLoggingInjectable = getInjectable({
id: "with-error-logging",
instantiate: (di) => {
const logger = di.inject(loggerInjectable);
return (getErrorMessage: (error: Error) => string) =>
<T extends (...args: any[]) => any>(toBeDecorated: T) =>
(...args: Parameters<T>): ReturnType<T> => {
try {
const returnValue = toBeDecorated(...args);
if (isPromise(returnValue)) {
returnValue.catch((e: Error) => {
logger.error(getErrorMessage(e as Error), e);
});
}
return returnValue;
} catch (e) {
logger.error(getErrorMessage(e as Error), e);
throw e;
}
};
},
});
export default withErrorLoggingInjectable;
function isPromise(reference: any): reference is Promise<any> {
return !!reference?.then;
}