| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 | /**
 * 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;
 |