forked from mirrors/gecko-dev
		
	 a2384c2234
			
		
	
	
		a2384c2234
		
	
	
	
	
		
			
			MozReview-Commit-ID: KbYBy2RjK1i --HG-- extra : rebase_source : 285700446cd9c183fbf6589d461c88b755d4af8c
		
			
				
	
	
		
			73 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
	
		
			2.7 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/. */
 | |
| 
 | |
| // This file is loaded into the browser window scope.
 | |
| /* eslint-env mozilla/browser-window */
 | |
| 
 | |
| var gSafeBrowsing = {
 | |
| 
 | |
|   setReportPhishingMenu() {
 | |
|     // In order to detect whether or not we're at the phishing warning
 | |
|     // page, we have to check the documentURI instead of the currentURI.
 | |
|     // This is because when the DocShell loads an error page, the
 | |
|     // currentURI stays at the original target, while the documentURI
 | |
|     // will point to the internal error page we loaded instead.
 | |
|     var docURI = gBrowser.selectedBrowser.documentURI;
 | |
|     var isPhishingPage =
 | |
|       docURI && docURI.spec.startsWith("about:blocked?e=deceptiveBlocked");
 | |
| 
 | |
|     // Show/hide the appropriate menu item.
 | |
|     const reportMenu = document.getElementById("menu_HelpPopup_reportPhishingtoolmenu");
 | |
|     reportMenu.hidden = isPhishingPage;
 | |
|     const reportErrorMenu = document.getElementById("menu_HelpPopup_reportPhishingErrortoolmenu");
 | |
|     reportErrorMenu.hidden = !isPhishingPage;
 | |
| 
 | |
|     // Now look at the currentURI to learn which page we were trying
 | |
|     // to browse to.
 | |
|     const uri = gBrowser.currentURI;
 | |
|     const isReportablePage = uri && (uri.schemeIs("http") || uri.schemeIs("https"));
 | |
| 
 | |
|     const disabledByPolicy = !Services.policies.isAllowed("feedbackCommands");
 | |
| 
 | |
|     if (disabledByPolicy || isPhishingPage || !isReportablePage) {
 | |
|       reportMenu.setAttribute("disabled", "true");
 | |
|     } else {
 | |
|       reportMenu.removeAttribute("disabled");
 | |
|     }
 | |
| 
 | |
|     if (disabledByPolicy || !isPhishingPage || !isReportablePage) {
 | |
|       reportErrorMenu.setAttribute("disabled", "true");
 | |
|     } else {
 | |
|       reportErrorMenu.removeAttribute("disabled");
 | |
|     }
 | |
|   },
 | |
| 
 | |
|   /**
 | |
|    * Used to report a phishing page or a false positive
 | |
|    *
 | |
|    * @param name
 | |
|    *        String One of "PhishMistake", "MalwareMistake", or "Phish"
 | |
|    * @param info
 | |
|    *        Information about the reasons for blocking the resource.
 | |
|    *        In the case false positive, it may contain SafeBrowsing
 | |
|    *        matching list and provider of the list
 | |
|    * @return String the report phishing URL.
 | |
|    */
 | |
|   getReportURL(name, info) {
 | |
|     let reportInfo = info;
 | |
|     if (!reportInfo) {
 | |
|       let pageUri = gBrowser.currentURI;
 | |
| 
 | |
|       // Remove the query to avoid including potentially sensitive data
 | |
|       if (pageUri instanceof Ci.nsIURL) {
 | |
|         pageUri = pageUri.mutate()
 | |
|                          .setQuery("")
 | |
|                          .finalize();
 | |
|       }
 | |
| 
 | |
|       reportInfo = { uri: pageUri.asciiSpec };
 | |
|     }
 | |
|     return SafeBrowsing.getReportURL(name, reportInfo);
 | |
|   }
 | |
| };
 |