/** * This utility class defines custom onerror and onunhandledrejection functions. * The custom error handlers respect the previously-defined error handlers. * GlobalOnErrorHandler class provides utilities to add many custom error * handlers and to execute the error handlers directly. */ /** * List with global error handlers that will be executed. */ const handlers = []; // If an old handler exists, also fire its events. const oldOnErrorHandler = window.onerror; /** * Custom error handler that calls the old global error handler and executes * all handlers that were previously added. */ function JitsiGlobalErrorHandler(message, source, lineno, colno, error) { handlers.forEach(function(handler) { handler(message, source, lineno, colno, error); }); if (oldOnErrorHandler) { oldOnErrorHandler(message, source, lineno, colno, error); } } // If an old handler exists, also fire its events. const oldOnUnhandledRejection = window.onunhandledrejection; /** * Custom handler that calls the old global handler and executes all handlers * that were previously added. This handler handles rejected Promises. */ function JitsiGlobalUnhandledRejection(event) { handlers.forEach(function(handler) { handler(null, null, null, null, event.reason); }); if(oldOnUnhandledRejection) { oldOnUnhandledRejection(event); } } // Setting the custom error handlers. window.onerror = JitsiGlobalErrorHandler; window.onunhandledrejection = JitsiGlobalUnhandledRejection; const GlobalOnErrorHandler = { /** * Adds new error handlers. * @param handler the new handler. */ addHandler(handler) { handlers.push(handler); }, /** * Calls the global error handler if there is one. * @param error the error to pass to the error handler */ callErrorHandler(error) { const errHandler = window.onerror; if(!errHandler) { return; } errHandler(null, null, null, null, error); }, /** * Calls the global rejection handler if there is one. * @param error the error to pass to the rejection handler. */ callUnhandledRejectionHandler(error) { const errHandler = window.onunhandledrejection; if(!errHandler) { return; } errHandler(error); } }; module.exports = GlobalOnErrorHandler;