xpfe/appshell/nsIPopupWindowManager.idl
author Ryan VanderMeulen <ryanvm@gmail.com>
Tue, 17 Mar 2015 15:46:50 -0400
changeset 234126 2fb7a59b725ef854befc3f3c9da1a3fa032d1b16
parent 197473 963723a2077d585c2cb00025622ed30bdd3d1148
permissions -rw-r--r--
Backed out changeset e86c7b372d7a (bug 1120780) for causing bug 1144224. CLOSED TREE

/* -*- 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 is the interface to the Popup Window Manager: an object which
 * maintains popup window permissions by website.
 */

#include "nsISupports.idl"

interface nsIPrincipal;

[scriptable, uuid(66386aa9-2088-4bae-82c7-9f58bc02be64)]
interface nsIPopupWindowManager : nsISupports {

  /**
   * These values are returned by the testPermission method
   */
  const uint32_t ALLOW_POPUP = 1;
  const uint32_t DENY_POPUP = 2;
  const uint32_t ALLOW_POPUP_WITH_PREJUDICE = 3;

  /**
   * Test whether a website has permission to show a popup window.
   * @param   principal is the principal to be tested
   * @return  one of the enumerated permission actions defined above
   */
  uint32_t testPermission(in nsIPrincipal principal);
};

%{ C++
#define NS_POPUPWINDOWMANAGER_CONTRACTID "@mozilla.org/PopupWindowManager;1"
%}