summaryrefslogtreecommitdiffstats
path: root/netwerk/base/nsIParentChannel.idl
blob: a351019d7dca0584e29d1a8ef07a1f4dae02f2bb (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
/* 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 "nsIStreamListener.idl"
#include "nsIHttpChannel.idl"

interface nsIRemoteTab;

%{C++
namespace mozilla {
namespace net {
class ParentChannelListener;
}
}
%}

[ptr] native ParentChannelListener(mozilla::net::ParentChannelListener);

/**
 * Implemented by chrome side of IPC protocols.
 */

[scriptable, uuid(e0fc4801-6030-4653-a59f-1fb282bd1a04)]
interface nsIParentChannel : nsIStreamListener
{
  /**
   * Called to set the ParentChannelListener object (optional).
   */
  [noscript] void setParentListener(in ParentChannelListener listener);

   /**
   * Called to set matched information when URL matches SafeBrowsing list.
   * @param aList
   *        Name of the list that matched
   * @param aProvider
   *        Name of provider that matched
   * @param aFullHash
   *        String represents full hash that matched
   */
  [noscript] void setClassifierMatchedInfo(in ACString aList,
                                           in ACString aProvider,
                                           in ACString aFullHash);

   /**
   * Called to set matched tracking information when URL matches tracking annotation list.
   * @param aList
   *        Comma-separated list of tables that matched
   * @param aFullHashes
   *        Comma-separated list of base64 encoded full hashes that matched
   */
  [noscript] void setClassifierMatchedTrackingInfo(in ACString aLists,
                                                   in ACString aFullHashes);

  /**
   * Called to notify the HttpChannelChild that the resource being loaded
   * has been classified.
   * @param aClassificationFlags
   *        What classifier identifies this channel.
   * @param aIsThirdParty
   *        Whether or not the resourced is considered first-party
   *        with the URI of the window.
   */
  [noscript] void notifyClassificationFlags(in uint32_t aClassificationFlags,
                                            in bool aIsThirdParty);

  /**
   * Called to invoke deletion of the IPC protocol.
   */
  void delete();

  /**
   * The remote type of the target process for this load.
   */
  readonly attribute AUTF8String remoteType;
};