summaryrefslogtreecommitdiffstats
path: root/toolkit/components/extensions/ext-c-storage.js
diff options
context:
space:
mode:
authorMatt A. Tobin <email@mattatobin.com>2018-02-09 11:10:00 -0500
committerMatt A. Tobin <email@mattatobin.com>2018-02-09 11:10:00 -0500
commitf164d9124708b50789dbb6959e1de96cc5697c48 (patch)
tree6dffd12e08c5383130df0252fb69cd6d6330794f /toolkit/components/extensions/ext-c-storage.js
parent30de4018913f0cdaea19d1dd12ecd8209e2ed08e (diff)
downloadUXP-f164d9124708b50789dbb6959e1de96cc5697c48.tar
UXP-f164d9124708b50789dbb6959e1de96cc5697c48.tar.gz
UXP-f164d9124708b50789dbb6959e1de96cc5697c48.tar.lz
UXP-f164d9124708b50789dbb6959e1de96cc5697c48.tar.xz
UXP-f164d9124708b50789dbb6959e1de96cc5697c48.zip
Rename Toolkit's webextensions component directory to better reflect what it is.
Diffstat (limited to 'toolkit/components/extensions/ext-c-storage.js')
-rw-r--r--toolkit/components/extensions/ext-c-storage.js62
1 files changed, 0 insertions, 62 deletions
diff --git a/toolkit/components/extensions/ext-c-storage.js b/toolkit/components/extensions/ext-c-storage.js
deleted file mode 100644
index e8d53058f..000000000
--- a/toolkit/components/extensions/ext-c-storage.js
+++ /dev/null
@@ -1,62 +0,0 @@
-"use strict";
-
-XPCOMUtils.defineLazyModuleGetter(this, "ExtensionStorage",
- "resource://gre/modules/ExtensionStorage.jsm");
-Cu.import("resource://gre/modules/Services.jsm");
-
-function storageApiFactory(context) {
- function sanitize(items) {
- // The schema validator already takes care of arrays (which are only allowed
- // to contain strings). Strings and null are safe values.
- if (typeof items != "object" || items === null || Array.isArray(items)) {
- return items;
- }
- // If we got here, then `items` is an object generated by `ObjectType`'s
- // `normalize` method from Schemas.jsm. The object returned by `normalize`
- // lives in this compartment, while the values live in compartment of
- // `context.contentWindow`. The `sanitize` method runs with the principal
- // of `context`, so we cannot just use `ExtensionStorage.sanitize` because
- // it is not allowed to access properties of `items`.
- // So we enumerate all properties and sanitize each value individually.
- let sanitized = {};
- for (let [key, value] of Object.entries(items)) {
- sanitized[key] = ExtensionStorage.sanitize(value, context);
- }
- return sanitized;
- }
- return {
- storage: {
- local: {
- get: function(keys) {
- keys = sanitize(keys);
- return context.childManager.callParentAsyncFunction("storage.local.get", [
- keys,
- ]);
- },
- set: function(items) {
- items = sanitize(items);
- return context.childManager.callParentAsyncFunction("storage.local.set", [
- items,
- ]);
- },
- },
-
- sync: {
- get: function(keys) {
- keys = sanitize(keys);
- return context.childManager.callParentAsyncFunction("storage.sync.get", [
- keys,
- ]);
- },
- set: function(items) {
- items = sanitize(items);
- return context.childManager.callParentAsyncFunction("storage.sync.set", [
- items,
- ]);
- },
- },
- },
- };
-}
-extensions.registerSchemaAPI("storage", "addon_child", storageApiFactory);
-extensions.registerSchemaAPI("storage", "content_child", storageApiFactory);