forked from mirrors/gecko-dev
As we add more behaviors to EventManager, the signature of the constructor is going to get really clumsy. Head that off by converting it to take a general parameters object. This introduces a compatibility problem for existing webextension experiments, put in a backward-compatibility shim for now. MozReview-Commit-ID: 72QDfiwRm5j --HG-- extra : rebase_source : 31c3fd561f373a5d75c4336de830aa5a2abfe797
78 lines
2.4 KiB
JavaScript
78 lines
2.4 KiB
JavaScript
/* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */
|
|
/* vim: set sts=2 sw=2 et tw=80: */
|
|
"use strict";
|
|
|
|
var {
|
|
SpreadArgs,
|
|
} = ExtensionCommon;
|
|
|
|
var {
|
|
ExtensionError,
|
|
} = ExtensionUtils;
|
|
|
|
this.devtools_network = class extends ExtensionAPI {
|
|
getAPI(context) {
|
|
return {
|
|
devtools: {
|
|
network: {
|
|
onNavigated: new EventManager({
|
|
context,
|
|
name: "devtools.onNavigated",
|
|
register: fire => {
|
|
let listener = data => {
|
|
fire.async(data.url);
|
|
};
|
|
|
|
let targetPromise = getDevToolsTargetForContext(context);
|
|
targetPromise.then(target => {
|
|
target.on("navigate", listener);
|
|
});
|
|
return () => {
|
|
targetPromise.then(target => {
|
|
target.off("navigate", listener);
|
|
});
|
|
};
|
|
},
|
|
}).api(),
|
|
|
|
getHAR: function() {
|
|
return context.devToolsToolbox.getHARFromNetMonitor();
|
|
},
|
|
|
|
onRequestFinished: new EventManager({
|
|
context,
|
|
name: "devtools.network.onRequestFinished",
|
|
register: fire => {
|
|
const listener = (data) => {
|
|
fire.async(data);
|
|
};
|
|
|
|
const toolbox = context.devToolsToolbox;
|
|
toolbox.addRequestFinishedListener(listener);
|
|
|
|
return () => {
|
|
toolbox.removeRequestFinishedListener(listener);
|
|
};
|
|
},
|
|
}).api(),
|
|
|
|
// The following method is used internally to allow the request API
|
|
// piece that is running in the child process to ask the parent process
|
|
// to fetch response content from the back-end.
|
|
Request: {
|
|
async getContent(requestId) {
|
|
return context.devToolsToolbox.fetchResponseContent(requestId)
|
|
.then(({content}) => new SpreadArgs([content.text, content.mimeType]))
|
|
.catch(err => {
|
|
const debugName = context.extension.policy.debugName;
|
|
const errorMsg = "Unexpected error while fetching response content";
|
|
Cu.reportError(`${debugName}: ${errorMsg} for ${requestId}: ${err}`);
|
|
throw new ExtensionError(errorMsg);
|
|
});
|
|
},
|
|
},
|
|
},
|
|
},
|
|
};
|
|
}
|
|
};
|