forked from mirrors/gecko-dev
		
	 758d80f10b
			
		
	
	
		758d80f10b
		
	
	
	
	
		
			
			MozReview-Commit-ID: 6fIbN6a6gHI --HG-- extra : rebase_source : d64a2b4f85b24aac0a847a46748b3b3fdf0db749 extra : intermediate-source : c486204319c1afc158b871bad7edd2f7a565022a extra : source : adf76dccec9d51df0d3a659ffa3dd201d8115bc4
		
			
				
	
	
		
			68 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
	
		
			2.4 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"
 | |
| 
 | |
| /**
 | |
|  * This interface is implemented by nsIUrlClassifierHashCompleter clients.
 | |
|  */
 | |
| [scriptable, uuid(da16de40-df26-414d-bde7-c4faf4504868)]
 | |
| interface nsIUrlClassifierHashCompleterCallback : nsISupports
 | |
| {
 | |
|   /**
 | |
|    * A complete hash has been found that matches the partial hash.
 | |
|    * This method may be called 0-n times for a given
 | |
|    * nsIUrlClassifierCompleter::complete() call.
 | |
|    *
 | |
|    * @param hash
 | |
|    *        The 128-bit hash that was discovered.
 | |
|    * @param table
 | |
|    *        The name of the table that this hash belongs to.
 | |
|    * @param chunkId
 | |
|    *        The database chunk that this hash belongs to.
 | |
|    */
 | |
|   void completion(in ACString hash,
 | |
|                   in ACString table,
 | |
|                   in uint32_t chunkId);
 | |
| 
 | |
|   /**
 | |
|    * The completion is complete.  This method is called once per
 | |
|    * nsIUrlClassifierCompleter::complete() call, after all completion()
 | |
|    * calls are finished.
 | |
|    *
 | |
|    * @param status
 | |
|    *        NS_OK if the request completed successfully, or an error code.
 | |
|    */
 | |
|   void completionFinished(in nsresult status);
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Clients updating the url-classifier database have the option of sending
 | |
|  * partial (32-bit) hashes of URL fragments to be blacklisted.  If the
 | |
|  * url-classifier encounters one of these truncated hashes, it will ask an
 | |
|  * nsIUrlClassifierCompleter instance to asynchronously provide the complete
 | |
|  * hash, along with some associated metadata.
 | |
|  * This is only ever used for testing and should absolutely be deleted (I
 | |
|  * think).
 | |
|  */
 | |
| [scriptable, uuid(231fb2ad-ea8a-4e63-a331-eafc3b434811)]
 | |
| interface nsIUrlClassifierHashCompleter : nsISupports
 | |
| {
 | |
|   /**
 | |
|    * Request a completed hash from the given gethash url.
 | |
|    *
 | |
|    * @param partialHash
 | |
|    *        The 32-bit hash encountered by the url-classifier.
 | |
|    * @param gethashUrl
 | |
|    *        The gethash url to use.
 | |
|    * @param tableName
 | |
|    *        The table where we matched the partial hash.
 | |
|    * @param callback
 | |
|    *        An nsIUrlClassifierCompleterCallback instance.
 | |
|    */
 | |
|   void complete(in ACString partialHash,
 | |
|                 in ACString gethashUrl,
 | |
|                 in ACString tableName,
 | |
|                 in nsIUrlClassifierHashCompleterCallback callback);
 | |
| };
 |