зеркало из https://github.com/mozilla/gecko-dev.git
122 строки
3.2 KiB
JavaScript
122 строки
3.2 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/.*/
|
|
/*
|
|
* Manifest obtainer frame script implementation of:
|
|
* http://www.w3.org/TR/appmanifest/#obtaining
|
|
*
|
|
* It searches a top-level browsing context for
|
|
* a <link rel=manifest> element. Then fetches
|
|
* and processes the linked manifest.
|
|
*
|
|
* BUG: https://bugzilla.mozilla.org/show_bug.cgi?id=1083410
|
|
*/
|
|
"use strict";
|
|
|
|
var EXPORTED_SYMBOLS = ["ManifestMessagesChild"];
|
|
|
|
ChromeUtils.defineModuleGetter(
|
|
this,
|
|
"ManifestObtainer",
|
|
"resource://gre/modules/ManifestObtainer.jsm"
|
|
);
|
|
ChromeUtils.defineModuleGetter(
|
|
this,
|
|
"ManifestFinder",
|
|
"resource://gre/modules/ManifestFinder.jsm"
|
|
);
|
|
ChromeUtils.defineModuleGetter(
|
|
this,
|
|
"ManifestIcons",
|
|
"resource://gre/modules/ManifestIcons.jsm"
|
|
);
|
|
|
|
class ManifestMessagesChild extends JSWindowActorChild {
|
|
receiveMessage(message) {
|
|
switch (message.name) {
|
|
case "DOM:WebManifest:hasManifestLink":
|
|
return this.hasManifestLink();
|
|
case "DOM:ManifestObtainer:Obtain":
|
|
return this.obtainManifest(message.data);
|
|
case "DOM:WebManifest:fetchIcon":
|
|
return this.fetchIcon(message);
|
|
}
|
|
return undefined;
|
|
}
|
|
|
|
/**
|
|
* Check if the document includes a link to a web manifest.
|
|
*/
|
|
hasManifestLink() {
|
|
const response = makeMsgResponse();
|
|
response.result = ManifestFinder.contentHasManifestLink(this.contentWindow);
|
|
response.success = true;
|
|
return response;
|
|
}
|
|
|
|
/**
|
|
* Asynchronously obtains a web manifest from this window by using the
|
|
* ManifestObtainer and returns the result.
|
|
* @param {Object} checkConformance True if spec conformance messages should be collected.
|
|
*/
|
|
async obtainManifest(options) {
|
|
const { checkConformance } = options;
|
|
const response = makeMsgResponse();
|
|
try {
|
|
response.result = await ManifestObtainer.contentObtainManifest(
|
|
this.contentWindow,
|
|
{ checkConformance }
|
|
);
|
|
response.success = true;
|
|
} catch (err) {
|
|
response.result = serializeError(err);
|
|
}
|
|
return response;
|
|
}
|
|
|
|
/**
|
|
* Given a manifest and an expected icon size, ask ManifestIcons
|
|
* to fetch the appropriate icon and send along result
|
|
*/
|
|
async fetchIcon({ data: { manifest, iconSize } }) {
|
|
const response = makeMsgResponse();
|
|
try {
|
|
response.result = await ManifestIcons.contentFetchIcon(
|
|
this.contentWindow,
|
|
manifest,
|
|
iconSize
|
|
);
|
|
response.success = true;
|
|
} catch (err) {
|
|
response.result = serializeError(err);
|
|
}
|
|
return response;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Utility function to Serializes an JS Error, so it can be transferred over
|
|
* the message channel.
|
|
* FIX ME: https://bugzilla.mozilla.org/show_bug.cgi?id=1172586
|
|
* @param {Error} aError The error to serialize.
|
|
* @return {Object} The serialized object.
|
|
*/
|
|
function serializeError(aError) {
|
|
const clone = {
|
|
fileName: aError.fileName,
|
|
lineNumber: aError.lineNumber,
|
|
columnNumber: aError.columnNumber,
|
|
stack: aError.stack,
|
|
message: aError.message,
|
|
name: aError.name,
|
|
};
|
|
return clone;
|
|
}
|
|
|
|
function makeMsgResponse() {
|
|
return {
|
|
success: false,
|
|
result: undefined,
|
|
};
|
|
}
|