dom/wifi/nsIWifiCertService.idl
author Masayuki Nakano <masayuki@d-toybox.com>
Tue, 19 Apr 2016 20:09:37 +0900
changeset 294638 1952b7fec843cbb6e1b402c7a0e2a42ba9ba335f
parent 232815 9c391997393087912f2cd7f272de0040115bfee6
permissions -rw-r--r--
Bug 1257759 part.5 PluginInstanceChild should post received native key event to chrome process if the key combination may be a shortcut key r=jimm When PluginInstanceChild receives native key events, it should post the events to the chrome process first for checking if the key combination is reserved. However, posting all key events to the chrome process may make damage to the performance of text input. Therefore, this patch starts to post a key event whose key combination may be a shortcut key. However, for avoiding to shuffle the event order, it posts following key events until all posted key events are handled by the chrome process. For receiving response from widget, this patch defines nsIKeyEventInPluginCallback. It's specified by nsIWidget::OnWindowedPluginKeyEvent() for ensuring the caller will receive the reply. Basically, the caller of nsIWidget::OnWindowedPluginKeyEvent() should reply to the child process. However, if the widget is a PuppetWidget, it cannot return the result synchronously. Therefore, PuppetWidget::OnWindowedPluginKeyEvent() returns NS_SUCCESS_EVENT_HANDLED_ASYNCHRONOUSLY and stores the callback to mKeyEventInPluginCallbacks. Then, TabParent::HandledWindowedPluginKeyEvent() will call PuppetWidget::HandledWindowedPluginKeyEvent(). MozReview-Commit-ID: G6brOU26NwQ

/* 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"

interface nsIDOMBlob;
interface nsIWifiEventListener;

[scriptable, uuid(5d0edcd3-c2f1-4946-aae5-06adcbdf0992)]
interface nsIWifiCertService : nsISupports
{
  const unsigned short WIFI_CERT_USAGE_FLAG_SERVER = 0x01;
  const unsigned short WIFI_CERT_USAGE_FLAG_USER   = 0x02;

  void start(in nsIWifiEventListener listener);
  void shutdown();

  /**
   * Import a certificate file.
   *
   * @param id
   *        Request ID.
   * @param certBlob
   *        A Blob object containing raw data of certificate to be imported.
   * @param certPassword
   *        Password of certificate.
   * @param certNickname
   *        User assigned nickname for imported certificate.
   */
  void importCert(in long id,
                  in nsIDOMBlob certBlob,
                  in DOMString certPassword,
                  in DOMString certNickname);

  /**
   * Delete an imported certificate file
   *
   * @param id
   *        Request ID.
   * @param certNickname
   *        Certificate nickname to delete.
   */
  void deleteCert(in long id,
                  in DOMString certNickname);

  /**
   * Check if certificate has private key.
   *
   * @param certNickname
   *        Certificate nickname to check for private key.
   */
   boolean hasPrivateKey(in DOMString certNickname);
};