mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-07 09:54:42 +00:00
Bug 1336934 - Added option to remove all session cookies for a specific domain r=miker
MozReview-Commit-ID: Anm6aHQOlkO --HG-- extra : rebase_source : aba29ba0173e0176f8e9676aa0a6e17b70b0eae9
This commit is contained in:
parent
b9d70cdb70
commit
bb40d6bc77
@ -9,3 +9,6 @@
|
||||
|
||||
<!-- LOCALIZATION NOTE : Label of popup menu action to delete all storage items. -->
|
||||
<!ENTITY storage.popupMenu.deleteAllLabel "Delete All">
|
||||
|
||||
<!-- LOCALIZATION NOTE : Label of popup menu action to delete all session cookies. -->
|
||||
<!ENTITY storage.popupMenu.deleteAllSessionCookiesLabel "Delete All Session Cookies">
|
||||
|
@ -27,6 +27,8 @@
|
||||
<menupopup id="storage-tree-popup">
|
||||
<menuitem id="storage-tree-popup-delete-all"
|
||||
label="&storage.popupMenu.deleteAllLabel;"/>
|
||||
<menuitem id="storage-tree-popup-delete-all-session-cookies"
|
||||
label="&storage.popupMenu.deleteAllSessionCookiesLabel;"/>
|
||||
<menuitem id="storage-tree-popup-delete"/>
|
||||
</menupopup>
|
||||
<menupopup id="storage-table-popup">
|
||||
@ -35,6 +37,8 @@
|
||||
<menuitem id="storage-table-popup-delete-all-from"/>
|
||||
<menuitem id="storage-table-popup-delete-all"
|
||||
label="&storage.popupMenu.deleteAllLabel;"/>
|
||||
<menuitem id="storage-table-popup-delete-all-session-cookies"
|
||||
label="&storage.popupMenu.deleteAllSessionCookiesLabel;"/>
|
||||
</menupopup>
|
||||
</popupset>
|
||||
|
||||
|
@ -29,15 +29,22 @@ const testCases = [
|
||||
getCookieId("c1", "test1.example.org", "/browser"),
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("c3", "test1.example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/")
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/")
|
||||
]
|
||||
],
|
||||
[
|
||||
["cookies", "https://sectest1.example.org"],
|
||||
[
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/"),
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("sc1", "sectest1.example.org", "/browser/devtools/client/storage/test/")
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("sc1", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/"),
|
||||
getCookieId("sc2", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/")
|
||||
]
|
||||
],
|
||||
[["localStorage", "http://test1.example.org"],
|
||||
|
@ -14,15 +14,22 @@ const testCases = [
|
||||
getCookieId("c1", "test1.example.org", "/browser"),
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("c3", "test1.example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/")
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/")
|
||||
]
|
||||
],
|
||||
[
|
||||
["cookies", "https://sectest1.example.org"],
|
||||
[
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/"),
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("sc1", "sectest1.example.org", "/browser/devtools/client/storage/test/")
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("sc1", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/"),
|
||||
getCookieId("sc2", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/")
|
||||
]
|
||||
],
|
||||
[["localStorage", "http://test1.example.org"],
|
||||
|
@ -34,15 +34,20 @@ const testCases = [
|
||||
getCookieId("c1", "test1.example.org", "/browser"),
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("c3", "test1.example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/")
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/")
|
||||
]
|
||||
],
|
||||
[
|
||||
["cookies", "https://sectest1.example.org"],
|
||||
[
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/"),
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("sc1", "sectest1.example.org", "/browser/devtools/client/storage/test/")
|
||||
getCookieId("sc1", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/"),
|
||||
getCookieId("sc2", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/")
|
||||
]
|
||||
],
|
||||
[["localStorage", "http://test1.example.org"],
|
||||
|
@ -8,11 +8,13 @@
|
||||
|
||||
// Test deleting all cookies
|
||||
|
||||
function* performDelete(store, rowName, deleteAll) {
|
||||
function* performDelete(store, rowName, action) {
|
||||
let contextMenu = gPanelWindow.document.getElementById(
|
||||
"storage-table-popup");
|
||||
let menuDeleteAllItem = contextMenu.querySelector(
|
||||
"#storage-table-popup-delete-all");
|
||||
let menuDeleteAllSessionCookiesItem = contextMenu.querySelector(
|
||||
"#storage-table-popup-delete-all-session-cookies");
|
||||
let menuDeleteAllFromItem = contextMenu.querySelector(
|
||||
"#storage-table-popup-delete-all-from");
|
||||
|
||||
@ -25,13 +27,19 @@ function* performDelete(store, rowName, deleteAll) {
|
||||
|
||||
yield waitForContextMenu(contextMenu, cells.name, () => {
|
||||
info(`Opened context menu in ${storeName}, row '${rowName}'`);
|
||||
if (deleteAll) {
|
||||
menuDeleteAllItem.click();
|
||||
} else {
|
||||
menuDeleteAllFromItem.click();
|
||||
let hostName = cells.host.value;
|
||||
ok(menuDeleteAllFromItem.getAttribute("label").includes(hostName),
|
||||
switch (action) {
|
||||
case "deleteAll":
|
||||
menuDeleteAllItem.click();
|
||||
break;
|
||||
case "deleteAllSessionCookies":
|
||||
menuDeleteAllSessionCookiesItem.click();
|
||||
break;
|
||||
case "deleteAllFrom":
|
||||
menuDeleteAllFromItem.click();
|
||||
let hostName = cells.host.value;
|
||||
ok(menuDeleteAllFromItem.getAttribute("label").includes(hostName),
|
||||
`Context menu item label contains '${hostName}'`);
|
||||
break;
|
||||
}
|
||||
});
|
||||
|
||||
@ -48,15 +56,21 @@ add_task(function* () {
|
||||
getCookieId("c1", "test1.example.org", "/browser"),
|
||||
getCookieId("c3", "test1.example.org", "/"),
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/")
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/")
|
||||
]
|
||||
],
|
||||
[
|
||||
["cookies", "https://sectest1.example.org"], [
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("sc1", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/"),
|
||||
getCookieId("uc1", ".example.org", "/")
|
||||
getCookieId("sc2", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/"),
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/")
|
||||
]
|
||||
],
|
||||
]);
|
||||
@ -64,7 +78,7 @@ add_task(function* () {
|
||||
info("delete all from domain");
|
||||
// delete only cookies that match the host exactly
|
||||
let id = getCookieId("c1", "test1.example.org", "/browser");
|
||||
yield performDelete(["cookies", "http://test1.example.org"], id, false);
|
||||
yield performDelete(["cookies", "http://test1.example.org"], id, "deleteAllFrom");
|
||||
|
||||
info("test state after delete all from domain");
|
||||
yield checkState([
|
||||
@ -73,24 +87,57 @@ add_task(function* () {
|
||||
["cookies", "http://test1.example.org"],
|
||||
[
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/")
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/")
|
||||
]
|
||||
],
|
||||
[
|
||||
["cookies", "https://sectest1.example.org"],
|
||||
[
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/"),
|
||||
getCookieId("sc1", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/"),
|
||||
getCookieId("sc2", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/")
|
||||
]
|
||||
],
|
||||
]);
|
||||
|
||||
info("delete all session cookies");
|
||||
// delete only session cookies
|
||||
id = getCookieId("cs2", ".example.org", "/");
|
||||
yield performDelete(["cookies", "http://sectest1.example.org"], id,
|
||||
"deleteAllSessionCookies");
|
||||
|
||||
info("test state after delete all session cookies");
|
||||
yield checkState([
|
||||
// Cookies with expiry date must not be deleted.
|
||||
[
|
||||
["cookies", "http://test1.example.org"],
|
||||
[
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/")
|
||||
]
|
||||
],
|
||||
[
|
||||
["cookies", "https://sectest1.example.org"],
|
||||
[
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/"),
|
||||
getCookieId("sc2", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/")
|
||||
]
|
||||
],
|
||||
]);
|
||||
|
||||
info("delete all");
|
||||
// delete all cookies for host, including domain cookies
|
||||
id = getCookieId("uc1", ".example.org", "/");
|
||||
yield performDelete(["cookies", "http://sectest1.example.org"], id, true);
|
||||
id = getCookieId("uc2", ".example.org", "/");
|
||||
yield performDelete(["cookies", "http://sectest1.example.org"], id, "deleteAll");
|
||||
|
||||
info("test state after delete all");
|
||||
yield checkState([
|
||||
|
@ -23,7 +23,9 @@ add_task(function* () {
|
||||
getCookieId("c1", "test1.example.org", "/browser"),
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("c3", "test1.example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/")
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/")
|
||||
]
|
||||
],
|
||||
[["localStorage", "http://test1.example.org"], ["ls1", "ls2"]],
|
||||
|
@ -32,15 +32,22 @@ const storageItemsForDefault = [
|
||||
getCookieId("c1", "test1.example.org", "/browser"),
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("c3", "test1.example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/")
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/")
|
||||
]
|
||||
],
|
||||
[
|
||||
["cookies", "https://sectest1.example.org"],
|
||||
[
|
||||
getCookieId("uc1", ".example.org", "/"),
|
||||
getCookieId("uc2", ".example.org", "/"),
|
||||
getCookieId("cs2", ".example.org", "/"),
|
||||
getCookieId("sc1", "sectest1.example.org", "/browser/devtools/client/storage/test/")
|
||||
getCookieId("c4", ".example.org", "/"),
|
||||
getCookieId("sc1", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/"),
|
||||
getCookieId("sc2", "sectest1.example.org",
|
||||
"/browser/devtools/client/storage/test/")
|
||||
]
|
||||
],
|
||||
[["localStorage", "http://test1.example.org"],
|
||||
|
@ -20,7 +20,10 @@ document.cookie = "c1=foobar; expires=" +
|
||||
new Date(cookieExpiresTime1).toGMTString() + "; path=/browser";
|
||||
document.cookie = "cs2=sessionCookie; path=/; domain=" + partialHostname;
|
||||
document.cookie = "c3=foobar-2; expires=" +
|
||||
new Date(cookieExpiresTime2).toGMTString() + "; path=/";
|
||||
new Date(cookieExpiresTime1).toGMTString() + "; path=/";
|
||||
document.cookie = "c4=foobar-3; expires=" +
|
||||
new Date(cookieExpiresTime2).toGMTString() + "; path=/; domain=" +
|
||||
partialHostname;
|
||||
// ... and some local storage items ..
|
||||
localStorage.setItem("ls1", "foobar");
|
||||
localStorage.setItem("ls2", "foobar-2");
|
||||
|
@ -9,7 +9,10 @@ Iframe for testing multiple host detetion in storage actor
|
||||
<body>
|
||||
<script type="application/javascript">
|
||||
"use strict";
|
||||
let cookieExpiresTime = 2000000000000;
|
||||
document.cookie = "sc1=foobar;";
|
||||
document.cookie = "sc2=foobar-2; expires=" +
|
||||
new Date(cookieExpiresTime).toGMTString() + ";";
|
||||
localStorage.setItem("iframe-s-ls1", "foobar");
|
||||
sessionStorage.setItem("iframe-s-ss1", "foobar-2");
|
||||
dump("added cookies and storage from secured iframe\n");
|
||||
|
@ -9,7 +9,10 @@ Iframe for testing multiple host detetion in storage actor
|
||||
<body>
|
||||
<script>
|
||||
"use strict";
|
||||
let cookieExpiresTime = 2000000000000;
|
||||
document.cookie = "uc1=foobar; domain=.example.org; path=/";
|
||||
document.cookie = "uc2=foobar-2; expires=" +
|
||||
new Date(cookieExpiresTime).toGMTString() + "; path=/; domain=.example.org";
|
||||
localStorage.setItem("iframe-u-ls1", "foobar");
|
||||
sessionStorage.setItem("iframe-u-ss1", "foobar1");
|
||||
sessionStorage.setItem("iframe-u-ss2", "foobar2");
|
||||
|
@ -173,6 +173,7 @@ function StorageUI(front, target, panelWin, toolbox) {
|
||||
this.onRemoveItem = this.onRemoveItem.bind(this);
|
||||
this.onRemoveAllFrom = this.onRemoveAllFrom.bind(this);
|
||||
this.onRemoveAll = this.onRemoveAll.bind(this);
|
||||
this.onRemoveAllSessionCookies = this.onRemoveAllSessionCookies.bind(this);
|
||||
this.onRemoveTreeItem = this.onRemoveTreeItem.bind(this);
|
||||
|
||||
this._addButton = this._panelDoc.getElementById("add-button");
|
||||
@ -195,10 +196,20 @@ function StorageUI(front, target, panelWin, toolbox) {
|
||||
"storage-table-popup-delete-all");
|
||||
this._tablePopupDeleteAll.addEventListener("command", this.onRemoveAll);
|
||||
|
||||
this._tablePopupDeleteAllSessionCookies = this._panelDoc.getElementById(
|
||||
"storage-table-popup-delete-all-session-cookies");
|
||||
this._tablePopupDeleteAllSessionCookies.addEventListener("command",
|
||||
this.onRemoveAllSessionCookies);
|
||||
|
||||
this._treePopupDeleteAll = this._panelDoc.getElementById(
|
||||
"storage-tree-popup-delete-all");
|
||||
this._treePopupDeleteAll.addEventListener("command", this.onRemoveAll);
|
||||
|
||||
this._treePopupDeleteAllSessionCookies = this._panelDoc.getElementById(
|
||||
"storage-tree-popup-delete-all-session-cookies");
|
||||
this._treePopupDeleteAllSessionCookies.addEventListener("command",
|
||||
this.onRemoveAllSessionCookies);
|
||||
|
||||
this._treePopupDelete = this._panelDoc.getElementById("storage-tree-popup-delete");
|
||||
this._treePopupDelete.addEventListener("command", this.onRemoveTreeItem);
|
||||
}
|
||||
@ -234,12 +245,16 @@ StorageUI.prototype = {
|
||||
this._addButton.removeEventListener("command", this.onAddItem);
|
||||
this._tablePopupAddItem.removeEventListener("command", this.onAddItem);
|
||||
this._treePopupDeleteAll.removeEventListener("command", this.onRemoveAll);
|
||||
this._treePopupDeleteAllSessionCookies.removeEventListener("command",
|
||||
this.onRemoveAllSessionCookies);
|
||||
this._treePopupDelete.removeEventListener("command", this.onRemoveTreeItem);
|
||||
|
||||
this._tablePopup.removeEventListener("popupshowing", this.onTablePopupShowing);
|
||||
this._tablePopupDelete.removeEventListener("command", this.onRemoveItem);
|
||||
this._tablePopupDeleteAllFrom.removeEventListener("command", this.onRemoveAllFrom);
|
||||
this._tablePopupDeleteAll.removeEventListener("command", this.onRemoveAll);
|
||||
this._tablePopupDeleteAllSessionCookies.removeEventListener("command",
|
||||
this.onRemoveAllSessionCookies);
|
||||
},
|
||||
|
||||
setupToolbar: function () {
|
||||
@ -578,6 +593,8 @@ StorageUI.prototype = {
|
||||
yield this._target.actorHasMethod(type, "removeItem");
|
||||
this.actorSupportsRemoveAll =
|
||||
yield this._target.actorHasMethod(type, "removeAll");
|
||||
this.actorSupportsRemoveAllSessionCookies =
|
||||
yield this._target.actorHasMethod(type, "removeAllSessionCookies");
|
||||
|
||||
yield this.resetColumns(type, host, subType);
|
||||
}
|
||||
@ -1114,6 +1131,17 @@ StorageUI.prototype = {
|
||||
|
||||
this._treePopupDeleteAll.hidden = !showDeleteAll;
|
||||
|
||||
// The delete all session cookies action is displayed for cookie object stores
|
||||
// (level 2 of tree)
|
||||
let showDeleteAllSessionCookies = false;
|
||||
if (this.actorSupportsRemoveAllSessionCookies) {
|
||||
if (type === "cookies" && selectedItem.length === 2) {
|
||||
showDeleteAllSessionCookies = true;
|
||||
}
|
||||
}
|
||||
|
||||
this._treePopupDeleteAllSessionCookies.hidden = !showDeleteAllSessionCookies;
|
||||
|
||||
// The delete action is displayed for:
|
||||
// - IndexedDB databases (level 3 of the tree)
|
||||
// - Cache objects (level 3 of the tree)
|
||||
@ -1175,6 +1203,19 @@ StorageUI.prototype = {
|
||||
front.removeAll(host, name);
|
||||
},
|
||||
|
||||
/**
|
||||
* Handles removing all session cookies from the storage
|
||||
*/
|
||||
onRemoveAllSessionCookies: function () {
|
||||
// Cannot use this.currentActor() if the handler is called from the
|
||||
// tree context menu: it returns the correct value only after the
|
||||
// table data from server is successfully fetched (and that's async).
|
||||
let [, host, ...path] = this.tree.selectedItem;
|
||||
let front = this.getCurrentFront();
|
||||
let name = path.length > 0 ? JSON.stringify(path) : undefined;
|
||||
front.removeAllSessionCookies(host, name);
|
||||
},
|
||||
|
||||
/**
|
||||
* Handles removing all cookies with exactly the same domain as the
|
||||
* cookie in the selected row.
|
||||
|
@ -691,6 +691,12 @@ StorageActors.createActor({
|
||||
.originAttributes);
|
||||
}),
|
||||
|
||||
removeAllSessionCookies: Task.async(function* (host, domain) {
|
||||
let doc = this.storageActor.document;
|
||||
this.removeAllSessionCookies(host, domain, doc.nodePrincipal
|
||||
.originAttributes);
|
||||
}),
|
||||
|
||||
maybeSetupChildProcess() {
|
||||
cookieHelpers.onCookieChanged = this.onCookieChanged.bind(this);
|
||||
|
||||
@ -707,6 +713,8 @@ StorageActors.createActor({
|
||||
cookieHelpers.removeCookie.bind(cookieHelpers);
|
||||
this.removeAllCookies =
|
||||
cookieHelpers.removeAllCookies.bind(cookieHelpers);
|
||||
this.removeAllSessionCookies =
|
||||
cookieHelpers.removeAllSessionCookies.bind(cookieHelpers);
|
||||
return;
|
||||
}
|
||||
|
||||
@ -730,6 +738,8 @@ StorageActors.createActor({
|
||||
callParentProcess.bind(null, "removeCookie");
|
||||
this.removeAllCookies =
|
||||
callParentProcess.bind(null, "removeAllCookies");
|
||||
this.removeAllSessionCookies =
|
||||
callParentProcess.bind(null, "removeAllSessionCookies");
|
||||
|
||||
addMessageListener("debug:storage-cookie-request-child",
|
||||
cookieHelpers.handleParentRequest);
|
||||
@ -920,7 +930,8 @@ var cookieHelpers = {
|
||||
if (hostMatches(cookie.host, host) &&
|
||||
(!opts.name || cookie.name === opts.name) &&
|
||||
(!opts.domain || cookie.host === opts.domain) &&
|
||||
(!opts.path || cookie.path === opts.path)) {
|
||||
(!opts.path || cookie.path === opts.path) &&
|
||||
(!opts.session || (!cookie.expires && !cookie.maxAge))) {
|
||||
Services.cookies.remove(
|
||||
cookie.host,
|
||||
cookie.name,
|
||||
@ -942,6 +953,10 @@ var cookieHelpers = {
|
||||
this._removeCookies(host, { domain, originAttributes });
|
||||
},
|
||||
|
||||
removeAllSessionCookies(host, domain, originAttributes) {
|
||||
this._removeCookies(host, { domain, originAttributes, session: true });
|
||||
},
|
||||
|
||||
addCookieObservers() {
|
||||
Services.obs.addObserver(cookieHelpers, "cookie-changed");
|
||||
return null;
|
||||
@ -1024,6 +1039,12 @@ var cookieHelpers = {
|
||||
let originAttributes = msg.data.args[2];
|
||||
return cookieHelpers.removeAllCookies(host, domain, originAttributes);
|
||||
}
|
||||
case "removeAllSessionCookies": {
|
||||
let host = msg.data.args[0];
|
||||
let domain = msg.data.args[1];
|
||||
let originAttributes = msg.data.args[2];
|
||||
return cookieHelpers.removeAllSessionCookies(host, domain, originAttributes);
|
||||
}
|
||||
default:
|
||||
console.error("ERR_DIRECTOR_PARENT_UNKNOWN_METHOD", msg.json.method);
|
||||
throw new Error("ERR_DIRECTOR_PARENT_UNKNOWN_METHOD");
|
||||
|
@ -104,6 +104,14 @@ createStorageSpec({
|
||||
},
|
||||
response: {}
|
||||
}
|
||||
}, {
|
||||
removeAllSessionCookies: {
|
||||
request: {
|
||||
host: Arg(0, "string"),
|
||||
domain: Arg(1, "nullable:string")
|
||||
},
|
||||
response: {}
|
||||
}
|
||||
}
|
||||
)
|
||||
});
|
||||
|
Loading…
Reference in New Issue
Block a user