summaryrefslogtreecommitdiffstats
path: root/dom/interfaces/base/nsIPermissionDelegateHandler.idl
blob: 4207077532eba6a190259ab625c8e8007c162a1d (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
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* 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/. */

/**
 * This file contains an interface to the Permission Delegate Handler,
 */

#include "nsISupports.idl"

interface nsIPrincipal;

[scriptable, builtinclass, uuid(07611dc6-bf4d-4d8a-a64b-f3a5904dddc7)]
interface nsIPermissionDelegateHandler : nsISupports
{
  /*
   * Return true if we are delegating permission to a third party which is not
   * explicitly trusted. An orgin is not explicitly trusted means it is not
   * presented in the Feature Policy ancestor chain, via src, explicitly listed
   * in allow, and it is not the top-level origin.
   *
   * @param aTypes the permission types to check
   */
  boolean maybeUnsafePermissionDelegate(in Array<ACString> aTypes);

  /*
   * Return true if permissions.delegation.enabled is true.
   */
  readonly attribute boolean permissionDelegateFPEnabled;
};