Source code

Revision control

Copy as Markdown

Other Tools

/* 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();
};