/* ***** BEGIN LICENSE BLOCK ***** * Version: MPL 1.1/GPL 2.0/LGPL 2.1 * * The contents of this file are subject to the Mozilla 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/MPL/ * * 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 cookie manager code. * * The Initial Developer of the Original Code is * Michiel van Leeuwen. * Portions created by the Initial Developer are Copyright (C) 2002 * the Initial Developer. All Rights Reserved. * * Contributor(s): * * Alternatively, the contents of this file may be used under the terms of * either the GNU General Public License Version 2 or later (the "GPL"), or * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), * in which case the provisions of the GPL or the LGPL are applicable instead * of those above. If you wish to allow use of your version of this file only * under the terms of either the GPL or the LGPL, and not to allow others to * use your version of this file under the terms of the MPL, indicate your * decision by deleting the provisions above and replace them with the notice * and other provisions required by the GPL or the LGPL. If you do not delete * the provisions above, a recipient may use your version of this file under * the terms of any one of the MPL, the GPL or the LGPL. * * ***** END LICENSE BLOCK ***** */ const nsICookieAcceptDialog = Components.interfaces.nsICookieAcceptDialog; const nsIDialogParamBlock = Components.interfaces.nsIDialogParamBlock; const nsICookie = Components.interfaces.nsICookie; const nsICookiePromptService = Components.interfaces.nsICookiePromptService; var params; var cookieBundle; var gDateService = null; var showDetails = ""; var hideDetails = ""; var detailsAccessKey = ""; function onload() { doSetOKCancel(cookieAcceptNormal, cookieDeny, cookieAcceptSession); var dialog = document.documentElement; document.getElementById("Button2").collapsed = false; document.getElementById("ok").label = dialog.getAttribute("acceptLabel"); document.getElementById("ok").accessKey = dialog.getAttribute("acceptKey"); document.getElementById("Button2").label = dialog.getAttribute("extra1Label"); document.getElementById("Button2").accessKey = dialog.getAttribute("extra1Key"); document.getElementById("cancel").label = dialog.getAttribute("cancelLabel"); document.getElementById("cancel").accessKey = dialog.getAttribute("cancelKey"); // hook up button icons where implemented document.getElementById("ok").setAttribute("icon","accept"); document.getElementById("cancel").setAttribute("icon","cancel"); document.getElementById("disclosureButton").setAttribute("icon","properties"); if (!gDateService) { const nsScriptableDateFormat_CONTRACTID = "@mozilla.org/intl/scriptabledateformat;1"; const nsIScriptableDateFormat = Components.interfaces.nsIScriptableDateFormat; gDateService = Components.classes[nsScriptableDateFormat_CONTRACTID] .getService(nsIScriptableDateFormat); } cookieBundle = document.getElementById("cookieBundle"); //cache strings if (!showDetails) { showDetails = cookieBundle.getString('showDetails'); } if (!hideDetails) { hideDetails = cookieBundle.getString('hideDetails'); } detailsAccessKey = cookieBundle.getString('detailsAccessKey'); if (document.getElementById('infobox').hidden) { document.getElementById('disclosureButton').setAttribute("label",showDetails); } else { document.getElementById('disclosureButton').setAttribute("label",hideDetails); } document.getElementById('disclosureButton').setAttribute("accesskey",detailsAccessKey); if ("arguments" in window && window.arguments.length >= 1 && window.arguments[0]) { try { params = window.arguments[0].QueryInterface(nsIDialogParamBlock); var objects = params.objects; var cookie = params.objects.queryElementAt(0,nsICookie); var cookiesFromHost = params.GetInt(nsICookieAcceptDialog.COOKIESFROMHOST); var messageFormat; if (params.GetInt(nsICookieAcceptDialog.CHANGINGCOOKIE)) messageFormat = 'permissionToModifyCookie'; else if (cookiesFromHost > 1) messageFormat = 'permissionToSetAnotherCookie'; else if (cookiesFromHost == 1) messageFormat = 'permissionToSetSecondCookie'; else messageFormat = 'permissionToSetACookie'; var hostname = params.GetString(nsICookieAcceptDialog.HOSTNAME); var messageText; if (cookie) messageText = cookieBundle.getFormattedString(messageFormat,[hostname, cookiesFromHost]); else // No cookies means something went wrong. Bring up the dialog anyway // to not make the mess worse. messageText = cookieBundle.getFormattedString(messageFormat,["",cookiesFromHost]); var messageParent = document.getElementById("dialogtextbox"); var messageParagraphs = messageText.split("\n"); // use value for the header, so it doesn't wrap. var headerNode = document.getElementById("dialog-header"); headerNode.setAttribute("value",messageParagraphs[0]); // use childnodes here, the text can wrap for (var i = 1; i < messageParagraphs.length; i++) { var descriptionNode = document.createElement("description"); text = document.createTextNode(messageParagraphs[i]); descriptionNode.appendChild(text); messageParent.appendChild(descriptionNode); } if (cookie) { document.getElementById('ifl_name').setAttribute("value",cookie.name); document.getElementById('ifl_value').setAttribute("value",cookie.value); document.getElementById('ifl_host').setAttribute("value",cookie.host); document.getElementById('ifl_path').setAttribute("value",cookie.path); document.getElementById('ifl_isSecure').setAttribute("value", cookie.isSecure ? cookieBundle.getString("forSecureOnly") : cookieBundle.getString("forAnyConnection") ); document.getElementById('ifl_expires').setAttribute("value",GetExpiresString(cookie.expires)); document.getElementById('ifl_isDomain').setAttribute("value", cookie.isDomain ? cookieBundle.getString("domainColon") : cookieBundle.getString("hostColon") ); } // set default result to not accept the cookie params.SetInt(nsICookieAcceptDialog.ACCEPT_COOKIE, 0); // and to not persist params.SetInt(nsICookieAcceptDialog.REMEMBER_DECISION, 0); } catch (e) { } } } function showhideinfo() { var infobox=document.getElementById('infobox'); if (infobox.hidden) { infobox.setAttribute("hidden","false"); document.getElementById('disclosureButton').setAttribute("label",hideDetails); } else { infobox.setAttribute("hidden","true"); document.getElementById('disclosureButton').setAttribute("label",showDetails); } sizeToContent(); } function cookieAcceptNormal() { // accept the cookie normally params.SetInt(nsICookieAcceptDialog.ACCEPT_COOKIE, nsICookiePromptService.ACCEPT_COOKIE); // And remember that when needed params.SetInt(nsICookieAcceptDialog.REMEMBER_DECISION, document.getElementById('persistDomainAcceptance').checked); window.close(); } function cookieAcceptSession() { // accept for the session only params.SetInt(nsICookieAcceptDialog.ACCEPT_COOKIE, nsICookiePromptService.ACCEPT_SESSION_COOKIE); // And remember that when needed params.SetInt(nsICookieAcceptDialog.REMEMBER_DECISION, document.getElementById('persistDomainAcceptance').checked); window.close(); } function cookieDeny() { // say that the cookie was rejected params.SetInt(nsICookieAcceptDialog.ACCEPT_COOKIE, nsICookiePromptService.DENY_COOKIE); // And remember that when needed params.SetInt(nsICookieAcceptDialog.REMEMBER_DECISION, document.getElementById('persistDomainAcceptance').checked); window.close(); } function GetExpiresString(secondsUntilExpires) { if (secondsUntilExpires) { var date = new Date(1000*secondsUntilExpires); // if a server manages to set a really long-lived cookie, the dateservice // can't cope with it properly, so we'll just return a blank string // see bug 238045 for details var expiry = ""; try { expiry = gDateService.FormatDateTime("", gDateService.dateFormatLong, gDateService.timeFormatSeconds, date.getFullYear(), date.getMonth()+1, date.getDate(), date.getHours(), date.getMinutes(), date.getSeconds()); } catch(ex) { // do nothing } return expiry; } return cookieBundle.getString("atEndOfSession"); }