- Consolidated duplicate UndoManagers to single instance - Fixed connection promise to only resolve on 'connected' status - Fixed WebSocketProvider import (WebsocketProvider) - Added proper doc.destroy() cleanup - Renamed isPresenceInitialized property to avoid conflict Co-Authored-By: Paperclip <noreply@paperclip.ing>
131 lines
4.0 KiB
JavaScript
131 lines
4.0 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true,
|
|
});
|
|
exports.default = createDevMiddleware;
|
|
var _InspectorProxy = _interopRequireDefault(
|
|
require("./inspector-proxy/InspectorProxy"),
|
|
);
|
|
var _openDebuggerMiddleware = _interopRequireDefault(
|
|
require("./middleware/openDebuggerMiddleware"),
|
|
);
|
|
var _DefaultToolLauncher = _interopRequireDefault(
|
|
require("./utils/DefaultToolLauncher"),
|
|
);
|
|
var _debuggerFrontend = _interopRequireDefault(
|
|
require("@react-native/debugger-frontend"),
|
|
);
|
|
var _connect = _interopRequireDefault(require("connect"));
|
|
var _path = _interopRequireDefault(require("path"));
|
|
var _serveStatic = _interopRequireDefault(require("serve-static"));
|
|
function _interopRequireDefault(e) {
|
|
return e && e.__esModule ? e : { default: e };
|
|
}
|
|
function createDevMiddleware({
|
|
serverBaseUrl,
|
|
logger,
|
|
unstable_eventReporter,
|
|
unstable_experiments: experimentConfig = {},
|
|
unstable_toolLauncher = _DefaultToolLauncher.default,
|
|
unstable_customInspectorMessageHandler,
|
|
unstable_trackInspectorProxyEventLoopPerf = false,
|
|
}) {
|
|
const normalizedServerBaseUrl = new URL(serverBaseUrl);
|
|
const experiments = getExperiments(experimentConfig);
|
|
const eventReporter = createWrappedEventReporter(
|
|
unstable_eventReporter,
|
|
logger,
|
|
experiments,
|
|
);
|
|
const inspectorProxy = new _InspectorProxy.default(
|
|
normalizedServerBaseUrl,
|
|
eventReporter,
|
|
experiments,
|
|
logger,
|
|
unstable_customInspectorMessageHandler,
|
|
unstable_trackInspectorProxyEventLoopPerf,
|
|
);
|
|
const middleware = (0, _connect.default)()
|
|
.use(
|
|
"/open-debugger",
|
|
(0, _openDebuggerMiddleware.default)({
|
|
serverBaseUrl: normalizedServerBaseUrl,
|
|
inspectorProxy,
|
|
toolLauncher: unstable_toolLauncher,
|
|
eventReporter,
|
|
experiments,
|
|
logger,
|
|
}),
|
|
)
|
|
.use(
|
|
"/debugger-frontend/embedder-static/embedderScript.js",
|
|
(_req, res) => {
|
|
res.setHeader("Content-Type", "application/javascript");
|
|
res.end("");
|
|
},
|
|
)
|
|
.use(
|
|
"/debugger-frontend",
|
|
(0, _serveStatic.default)(_path.default.join(_debuggerFrontend.default), {
|
|
fallthrough: false,
|
|
}),
|
|
)
|
|
.use((...args) => inspectorProxy.processRequest(...args));
|
|
return {
|
|
middleware,
|
|
websocketEndpoints: inspectorProxy.createWebSocketListeners(),
|
|
};
|
|
}
|
|
function getExperiments(config) {
|
|
return {
|
|
enableOpenDebuggerRedirect: config.enableOpenDebuggerRedirect ?? false,
|
|
enableNetworkInspector: config.enableNetworkInspector ?? false,
|
|
enableStandaloneFuseboxShell: config.enableStandaloneFuseboxShell ?? true,
|
|
};
|
|
}
|
|
function createWrappedEventReporter(reporter, logger, experiments) {
|
|
return {
|
|
logEvent(event) {
|
|
switch (event.type) {
|
|
case "profiling_target_registered":
|
|
logger?.info(
|
|
"Profiling build target '%s' registered for debugging",
|
|
event.appId ?? "unknown",
|
|
);
|
|
break;
|
|
case "fusebox_shell_preparation_attempt":
|
|
switch (event.result.code) {
|
|
case "success":
|
|
case "not_implemented":
|
|
break;
|
|
case "unexpected_error": {
|
|
let message =
|
|
event.result.humanReadableMessage ??
|
|
"An unknown error occurred while installing React Native DevTools.";
|
|
if (event.result.verboseInfo != null) {
|
|
message += ` Details:\n\n${event.result.verboseInfo}`;
|
|
} else {
|
|
message += ".";
|
|
}
|
|
logger?.error(message);
|
|
break;
|
|
}
|
|
case "possible_corruption":
|
|
case "platform_not_supported":
|
|
case "likely_offline":
|
|
logger?.warn(
|
|
event.result.humanReadableMessage ??
|
|
`An error of type ${event.result.code} occurred while installing React Native DevTools.`,
|
|
);
|
|
break;
|
|
default:
|
|
event.result.code;
|
|
break;
|
|
}
|
|
}
|
|
reporter?.logEvent(event);
|
|
},
|
|
};
|
|
}
|