summaryrefslogtreecommitdiffstats
path: root/netwerk/url-classifier/nsIURIClassifier.idl
blob: d99152330e7a89d70c0be5398219cacccd382037 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
/* 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"
#include "nsIUrlClassifierFeature.idl"

%{C++
#include "nsStringFwd.h"
#include "nsTArrayForwardDeclare.h"
%}
[ref] native StringArrayRef(nsTArray<nsCString>);

interface nsIChannel;
interface nsISerialEventTarget;
interface nsIPrincipal;
interface nsIURI;
interface nsIUrlClassifierFeatureCallback;

/**
 * Callback function for nsIURIClassifier lookups.
 */
[scriptable, function, uuid(8face46e-0c96-470f-af40-0037dcd797bd)]
interface nsIURIClassifierCallback : nsISupports
{
  /**
   * Called by the URI classifier service when it is done checking a URI.
   *
   * Clients are responsible for associating callback objects with classify()
   * calls.
   *
   * @param aErrorCode
   *        The error code with which the channel should be cancelled, or
   *        NS_OK if the load should continue normally.
   * @param aList
   *        Name of the list that matched
   * @param aProvider
   *        Name of provider that matched
   * @param aFullHash
   *        Full hash of URL that matched
   */
  void onClassifyComplete(in nsresult aErrorCode,
                          in ACString aList,
                          in ACString aProvider,
                          in ACString aFullHash);
};

/**
 * The URI classifier service checks a URI against lists of phishing
 * and malware sites.
 */
[scriptable, uuid(596620cc-76e3-4133-9d90-360e59a794cf)]
interface nsIURIClassifier : nsISupports
{
  /**
   * Classify a Principal using its URI.
   *
   * @param aPrincipal
   *        The principal that should be checked by the URI classifier.
   *
   * @param nsISerialEventTarget
   *        Event target for constructing actor in content process.
   *        The event target should be tied to Docgroup/Tabgroup by
   *        using EventTargetFor
   *
   * @param aCallback
   *        The URI classifier will call this callback when the URI has been
   *        classified.
   *
   * @return <code>false</code> if classification is not necessary.  The
   *         callback will not be called.
   *         <code>true</code> if classification will be performed.  The
   *         callback will be called.
   */
  boolean classify(in nsIPrincipal aPrincipal,
                   in nsISerialEventTarget aEventTarget,
                   in nsIURIClassifierCallback aCallback);

  /**
   * Asynchronously classify a URI with list of features. This does not make
   * network requests.
   */
  void asyncClassifyLocalWithFeatures(in nsIURI aURI,
                                      in Array<nsIUrlClassifierFeature> aFeatures,
                                      in nsIUrlClassifierFeature_listType aListType,
                                      in nsIUrlClassifierFeatureCallback aCallback);

  /**
   * Returns a feature named aFeatureName.
   */
  nsIUrlClassifierFeature getFeatureByName(in ACString aFeatureName);

  /**
   * Returns all the feature names.
   */
  Array<ACString> getFeatureNames();

  /**
   * Create a new feature with a list of tables. This method is just for
   * testing! Don't use it elsewhere.
   */
  nsIUrlClassifierFeature createFeatureWithTables(in ACString aName,
                                                  in Array<ACString> aBlocklistTables,
                                                  in Array<ACString> aEntitylistTables);

  /**
   * Report to the provider that a Safe Browsing warning was shown.
   *
   * @param aChannel
   *        Channel for which the URL matched something on the threat list.
   * @param aProvider
   *        Provider to notify.
   * @param aList
   *        List where the full hash was found.
   * @param aFullHash
   *        Full URL hash that triggered the warning.
   */

  void sendThreatHitReport(in nsIChannel aChannel, in ACString aProvider,
                           in ACString aList, in ACString aFullHash);
};