mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com>
52 lines
1.4 KiB
TypeScript
52 lines
1.4 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 logErrorInjectable from "../../log-error.injectable";
|
|
import { isPromise } from "../is-promise/is-promise";
|
|
|
|
export type WithErrorLoggingFor = (
|
|
getErrorMessage: (error: unknown) => string
|
|
) => <T extends (...args: any[]) => any>(
|
|
toBeDecorated: T
|
|
) => (...args: Parameters<T>) => ReturnType<T>;
|
|
|
|
const withErrorLoggingInjectable = getInjectable({
|
|
id: "with-error-logging",
|
|
|
|
instantiate: (di): WithErrorLoggingFor => {
|
|
const logError = di.inject(logErrorInjectable);
|
|
|
|
return (getErrorMessage) =>
|
|
(toBeDecorated) =>
|
|
(...args) => {
|
|
let returnValue: ReturnType<typeof toBeDecorated>;
|
|
|
|
try {
|
|
returnValue = toBeDecorated(...args);
|
|
} catch (e) {
|
|
const errorMessage = getErrorMessage(e);
|
|
|
|
logError(errorMessage, e);
|
|
|
|
throw e;
|
|
}
|
|
|
|
if (isPromise(returnValue)) {
|
|
return returnValue.catch((e: unknown) => {
|
|
const errorMessage = getErrorMessage(e);
|
|
|
|
logError(errorMessage, e);
|
|
|
|
throw e;
|
|
});
|
|
}
|
|
|
|
return returnValue;
|
|
};
|
|
},
|
|
});
|
|
|
|
export default withErrorLoggingInjectable;
|