Files
tubestation/toolkit/components/payments/content/paymentDialogFrameScript.js
Matthew Noorenberghe 12ab72b8a0 Bug 1444949 - Pref-controlled console logging for unprivileged code. r=sfoster
* Default log implementation for unprivileged content
* Export methods of a ConsoleAPI instance into the content frame to replace the default log
* Initialize the content logger when the "initializeRequest" message is received

MozReview-Commit-ID: 8hiaIqf2ChX
2018-03-19 21:57:13 -07:00

85 lines
2.5 KiB
JavaScript

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
/**
* This frame script only exists to mediate communications between the
* unprivileged frame in a content process and the privileged dialog wrapper
* in the UI process on the main thread.
*
* `paymentChromeToContent` messages from the privileged wrapper are converted
* into DOM events of the same name.
* `paymentContentToChrome` custom DOM events from the unprivileged frame are
* converted into messages of the same name.
*
* Business logic should stay out of this shim.
*/
"use strict";
/* eslint-env mozilla/frame-script */
ChromeUtils.import("resource://gre/modules/XPCOMUtils.jsm");
let PaymentFrameScript = {
init() {
XPCOMUtils.defineLazyGetter(this, "log", () => {
let {ConsoleAPI} = ChromeUtils.import("resource://gre/modules/Console.jsm", {});
return new ConsoleAPI({
maxLogLevelPref: "dom.payments.loglevel",
prefix: "paymentDialogFrameScript",
});
});
addEventListener("paymentContentToChrome", this, false, true);
addMessageListener("paymentChromeToContent", this);
},
handleEvent(event) {
this.sendToChrome(event);
},
receiveMessage({data: {messageType, data}}) {
this.sendToContent(messageType, data);
},
setupContentConsole() {
let privilegedLogger = content.window.console.createInstance({
maxLogLevelPref: "dom.payments.loglevel",
prefix: "paymentDialogContent",
});
let contentLogObject = Cu.waiveXrays(content).log;
for (let name of ["error", "warn", "info", "debug"]) {
Cu.exportFunction(privilegedLogger[name].bind(privilegedLogger), contentLogObject, {
defineAs: name,
});
}
},
sendToChrome({detail}) {
let {messageType} = detail;
if (messageType == "initializeRequest") {
this.setupContentConsole();
}
this.log.debug("sendToChrome:", messageType, detail);
this.sendMessageToChrome(messageType, detail);
},
sendToContent(messageType, detail = {}) {
this.log.debug("sendToContent", messageType, detail);
let response = Object.assign({messageType}, detail);
let event = new content.CustomEvent("paymentChromeToContent", {
detail: Cu.cloneInto(response, content),
});
content.dispatchEvent(event);
},
sendMessageToChrome(messageType, data = {}) {
sendAsyncMessage("paymentContentToChrome", Object.assign(data, {messageType}));
},
};
PaymentFrameScript.init();