forked from mirrors/gecko-dev
		
	
		
			
				
	
	
		
			71 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
/* 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/. */
 | 
						|
 | 
						|
#include "nsISupports.idl"
 | 
						|
 | 
						|
/**
 | 
						|
 * Observer for exception list updates.
 | 
						|
 */
 | 
						|
[scriptable, function, uuid(f7c918e5-94bf-4b6e-9758-ef7bdab6af7e)]
 | 
						|
interface nsIUrlClassifierExceptionListObserver : nsISupports
 | 
						|
{
 | 
						|
  /**
 | 
						|
   * Called by nsIUrlClassifierExceptionListService when the exception list
 | 
						|
   * for a designated feature changes and when the observer is first registered.
 | 
						|
   *
 | 
						|
   * @param aList
 | 
						|
   *        A comma-separated list of url patterns, intended to be parsed
 | 
						|
   *        by nsContentUtils::IsURIInList.
 | 
						|
   */
 | 
						|
  void onExceptionListUpdate(in ACString aList);
 | 
						|
};
 | 
						|
 | 
						|
/**
 | 
						|
 * A service that monitors updates to the exception list of url-classifier
 | 
						|
 * feature from sources such as a local pref and remote settings updates.
 | 
						|
 */
 | 
						|
[scriptable, uuid(75c3d1a3-e977-4079-9e27-b3b56bdb76ea)]
 | 
						|
interface nsIUrlClassifierExceptionListService : nsISupports
 | 
						|
{
 | 
						|
  /**
 | 
						|
   * Register a new observer to exception list updates. When the observer is
 | 
						|
   * registered it is called immediately once. Afterwards it will be called
 | 
						|
   * whenever the specified pref changes or when remote settings for
 | 
						|
   * url-classifier features updates.
 | 
						|
   *
 | 
						|
   * @param aFeature
 | 
						|
   *        The feature for which to observe the exception list.
 | 
						|
   *
 | 
						|
   * @param aPrefName
 | 
						|
   *        (Optional) A pref name to monitor. The pref must be of string
 | 
						|
   *        type and contain a comma-separated list of URL patterns.
 | 
						|
   *
 | 
						|
   * @param aObserver
 | 
						|
   *        An nsIUrlClassifierExceptionListObserver object or function that
 | 
						|
   *        will receive updates to the exception list as a comma-separated
 | 
						|
   *        string. Will be called immediately with the current exception
 | 
						|
   *        list value.
 | 
						|
   */
 | 
						|
  void registerAndRunExceptionListObserver(in ACString aFeature,
 | 
						|
                                      in ACString aPrefName,
 | 
						|
                                      in nsIUrlClassifierExceptionListObserver aObserver);
 | 
						|
 | 
						|
  /**
 | 
						|
   * Unregister an observer.
 | 
						|
   *
 | 
						|
   * @param aFeature
 | 
						|
   *        The feature for which to stop observing.
 | 
						|
   *
 | 
						|
   * @param aObserver
 | 
						|
   *        The nsIUrlClassifierExceptionListObserver object to unregister.
 | 
						|
   */
 | 
						|
  void unregisterExceptionListObserver(in ACString aFeature,
 | 
						|
                                  in nsIUrlClassifierExceptionListObserver aObserver);
 | 
						|
 | 
						|
  /**
 | 
						|
   *  Clear all data in the service.
 | 
						|
   *  This API is for testing only.
 | 
						|
   */
 | 
						|
  void clear();
 | 
						|
};
 |