fune/browser/components/extensions/parent/ext-devtools-network.js
Andrew Swan e71d1d5a82 Bug 1450388 Part 1 Refactor EventManager r=kmag
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
2018-03-14 14:52:44 -07:00

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);
});
},
},
},
},
};
}
};