# -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- # # The contents of this file are subject to the Netscape Public # License Version 1.1 (the "License"); you may not use this file # except in compliance with the License. You may obtain a copy of # the License at http://www.mozilla.org/NPL/ # # Software distributed under the License is distributed on an "AS # IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or # implied. See the License for the specific language governing # rights and limitations under the License. # # The Original Code is Mozilla Communicator client code, released March # 31, 1998. # # The Initial Developer of the Original Code is Netscape Communications # Corporation. Portions created by Netscape are # Copyright (C) 1998 Netscape Communications Corporation. All # Rights Reserved. # # Contributor(s): # Ben Goodger var kObserverService; // interface variables var cookiemanager = null; // cookiemanager interface var permissionmanager = null; // permissionmanager interface var popupmanager = null; // popup manager var gDateService = null; // cookies and permissions list var cookies = []; var permissions = []; var deletedCookies = []; var deletedPermissions = []; // differentiate between cookies, images, and popups const nsIPermissionManager = Components.interfaces.nsIPermissionManager; const cookieType = "cookie"; const imageType = "image"; const popupType = "popup"; var dialogType = cookieType; if (window.arguments[0] == "imageManager") dialogType = imageType; else if (window.arguments[0] == "popupManager") dialogType = popupType; var cookieBundle; function Startup() { // arguments passed to this routine: // cookieManager // cookieManagerFromIcon // imageManager // xpconnect to cookiemanager/permissionmanager/popupmanager interfaces cookiemanager = Components.classes["@mozilla.org/cookiemanager;1"].getService(); cookiemanager = cookiemanager.QueryInterface(Components.interfaces.nsICookieManager); permissionmanager = Components.classes["@mozilla.org/permissionmanager;1"].getService(); permissionmanager = permissionmanager.QueryInterface(Components.interfaces.nsIPermissionManager); popupmanager = Components.classes["@mozilla.org/PopupWindowManager;1"].getService(); popupmanager = popupmanager.QueryInterface(Components.interfaces.nsIPopupWindowManager); // intialize gDateService if (!gDateService) { const nsScriptableDateFormat_CONTRACTID = "@mozilla.org/intl/scriptabledateformat;1"; const nsIScriptableDateFormat = Components.interfaces.nsIScriptableDateFormat; gDateService = Components.classes[nsScriptableDateFormat_CONTRACTID] .getService(nsIScriptableDateFormat); } // intialize string bundle cookieBundle = document.getElementById("cookieBundle"); // label the close button document.documentElement.getButton("accept").label = cookieBundle.getString("close"); // determine if labelling is for cookies or images try { var tabBox = document.getElementById("tabbox"); var element; if (dialogType == cookieType) { element = document.getElementById("cookiesTab"); tabBox.selectedTab = element; } else if (dialogType == imageType) { element = document.getElementById("cookieviewer"); element.setAttribute("title", cookieBundle.getString("imageTitle")); element = document.getElementById("permissionsTab"); element.label = cookieBundle.getString("tabBannedImages"); tabBox.selectedTab = element; element = document.getElementById("permissionsText"); element.value = cookieBundle.getString("textBannedImages"); element = document.getElementById("cookiesTab"); element.hidden = "true"; } else { element = document.getElementById("cookieviewer"); element.setAttribute("title", cookieBundle.getString("popupTitle")); element = document.getElementById("permissionsTab"); element.label = cookieBundle.getString("tabBannedPopups"); tabBox.selectedTab = element; element = document.getElementById("permissionsText"); element.value = cookieBundle.getString("textBannedPopups"); element = document.getElementById("cookiesTab"); element.hidden = "true"; } } catch(e) { } // load in the cookies and permissions cookiesTree = document.getElementById("cookiesTree"); permissionsTree = document.getElementById("permissionsTree"); if (dialogType == cookieType) { loadCookies(); } loadPermissions(); // be prepared to reload the display if anything changes kObserverService = Components.classes["@mozilla.org/observer-service;1"].getService(Components.interfaces.nsIObserverService); kObserverService.addObserver(cookieReloadDisplay, "cookieChanged", false); kObserverService.addObserver(cookieReloadDisplay, "perm-changed", false); } function Shutdown() { kObserverService.removeObserver(cookieReloadDisplay, "cookieChanged"); kObserverService.removeObserver(cookieReloadDisplay, "perm-changed"); } var cookieReloadDisplay = { observe: function(subject, topic, state) { if (topic == "cookieChanged") { if (state == "cookies") { cookies.length = 0; if (lastCookieSortColumn == "rawHost") { lastCookieSortAscending = !lastCookieSortAscending; // prevents sort from being reversed } loadCookies(); } } else if (topic == "perm-changed") { permissions.length = 0; if (lastPermissionSortColumn == "rawHost") { lastPermissionSortAscending = !lastPermissionSortAscending; // prevents sort from being reversed } loadPermissions(); } } } /*** =================== COOKIES CODE =================== ***/ const nsICookie = Components.interfaces.nsICookie; var cookiesTreeView = { rowCount : 0, setTree : function(tree){}, getImageSrc : function(row,column) {}, getProgressMode : function(row,column) {}, getCellValue : function(row,column) {}, getCellText : function(row,column){ var rv=""; if (column=="domainCol") { rv = cookies[row].rawHost; } else if (column=="nameCol") { rv = cookies[row].name; } else if (column=="statusCol") { rv = GetStatusString(cookies[row].status); } return rv; }, isSeparator : function(index) {return false;}, isSorted: function() { return false; }, isContainer : function(index) {return false;}, cycleHeader : function(aColId, aElt) {}, getRowProperties : function(row,column,prop){}, getColumnProperties : function(column,columnElement,prop){}, getCellProperties : function(row,prop){} }; var cookiesTree; function Cookie(number,name,value,isDomain,host,rawHost,path,isSecure,expires, status,policy) { this.number = number; this.name = name; this.value = value; this.isDomain = isDomain; this.host = host; this.rawHost = rawHost; this.path = path; this.isSecure = isSecure; this.expires = expires; this.status = status; this.policy = policy; } function loadCookies() { // load cookies into a table var enumerator = cookiemanager.enumerator; var count = 0; var showPolicyField = false; while (enumerator.hasMoreElements()) { var nextCookie = enumerator.getNext(); if (!nextCookie) break; nextCookie = nextCookie.QueryInterface(Components.interfaces.nsICookie); var host = nextCookie.host; if (nextCookie.policy != nsICookie.POLICY_UNKNOWN) { showPolicyField = true; } cookies[count] = new Cookie(count++, nextCookie.name, nextCookie.value, nextCookie.isDomain, host, (host.charAt(0)==".") ? host.substring(1,host.length) : host, nextCookie.path, nextCookie.isSecure, nextCookie.expires, nextCookie.status, nextCookie.policy); } cookiesTreeView.rowCount = cookies.length; // sort and display the table cookiesTree.treeBoxObject.view = cookiesTreeView; if (window.arguments[0] == "cookieManagerFromIcon") { // came here by clicking on cookie icon // turn off the icon var observerService = Components.classes["@mozilla.org/observer-service;1"].getService(Components.interfaces.nsIObserverService); observerService.notifyObservers(null, "cookieIcon", "off"); // unhide the status column and sort by reverse order on that column // Note that the sort routine normally does an ascending sort. The only // exception is if you sort on the same column more than once in a row. // In that case, the subsequent sorts will be the reverse of the previous ones. // So we are now going to force an initial reverse sort by fooling the sort routine // into thinking that it previously sorted on the status column and in ascending // order. document.getElementById("statusCol").removeAttribute("hidden"); lastCookieSortAscending = true; // force order to have blanks last instead of vice versa lastCookieSortColumn = 'status'; CookieColumnSort('status'); } else { // sort by host column CookieColumnSort('rawHost'); } // disable "remove all cookies" button if there are no cookies if (cookies.length == 0) { document.getElementById("removeAllCookies").setAttribute("disabled","true"); } else { document.getElementById("removeAllCookies").removeAttribute("disabled"); } // show policy field if at least one cookie has a policy if (showPolicyField) { document.getElementById("policyField").removeAttribute("hidden"); } } function GetExpiresString(expires) { if (expires) { var date = new Date(1000*expires); return gDateService.FormatDateTime("", gDateService.dateFormatLong, gDateService.timeFormatSeconds, date.getFullYear(), date.getMonth()+1, date.getDate(), date.getHours(), date.getMinutes(), date.getSeconds()); } return cookieBundle.getString("AtEndOfSession"); } function GetStatusString(status) { switch (status) { case nsICookie.STATUS_ACCEPTED: return cookieBundle.getString("accepted"); case nsICookie.STATUS_FLAGGED: return cookieBundle.getString("flagged"); case nsICookie.STATUS_DOWNGRADED: return cookieBundle.getString("downgraded"); } return ""; } function GetPolicyString(policy) { switch (policy) { case nsICookie.POLICY_NONE: return cookieBundle.getString("policyUnstated"); case nsICookie.POLICY_NO_CONSENT: return cookieBundle.getString("policyNoConsent"); case nsICookie.POLICY_IMPLICIT_CONSENT: return cookieBundle.getString("policyImplicitConsent"); case nsICookie.POLICY_EXPLICIT_CONSENT: return cookieBundle.getString("policyExplicitConsent"); case nsICookie.POLICY_NO_II: return cookieBundle.getString("policyNoIICollected"); } return ""; } function CookieSelected() { var selections = GetTreeSelections(cookiesTree); if (selections.length) { document.getElementById("removeCookie").removeAttribute("disabled"); } else { ClearCookieProperties(); return true; } var idx = selections[0]; if (idx >= cookies.length) { // Something got out of synch. See bug 119812 for details dump("Tree and viewer state are out of sync! " + "Help us figure out the problem in bug 119812"); return; } var props = [ {id: "ifl_name", value: cookies[idx].name}, {id: "ifl_value", value: cookies[idx].value}, {id: "ifl_isDomain", value: cookies[idx].isDomain ? cookieBundle.getString("domainColon") : cookieBundle.getString("hostColon")}, {id: "ifl_host", value: cookies[idx].host}, {id: "ifl_path", value: cookies[idx].path}, {id: "ifl_isSecure", value: cookies[idx].isSecure ? cookieBundle.getString("yes") : cookieBundle.getString("no")}, {id: "ifl_expires", value: GetExpiresString(cookies[idx].expires)}, {id: "ifl_policy", value: GetPolicyString(cookies[idx].policy)} ]; var value; var field; for (var i = 0; i < props.length; i++) { field = document.getElementById(props[i].id); if ((selections.length > 1) && (props[i].id != "ifl_isDomain")) { value = ""; // clear field if multiple selections } else { value = props[i].value; } field.value = value; } return true; } function ClearCookieProperties() { var properties = ["ifl_name","ifl_value","ifl_host","ifl_path","ifl_isSecure","ifl_expires","ifl_policy"]; for (var prop=0; prop