chromium/extensions/common/api/bluetooth_private.idl

// Copyright 2015 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

// Use the <code>chrome.bluetoothPrivate</code> API to control the Bluetooth
// adapter state and handle device pairing.
// NOTE: This IDL is dependent on bluetooth.idl.

[implemented_in = "extensions/browser/api/bluetooth/bluetooth_private_api.h"]
namespace bluetoothPrivate {
  // Events that can occur during pairing. The method used for pairing varies
  // depending on the capability of the two devices.
  enum PairingEventType {
    // An alphanumeric PIN code is required to be entered by the user.
    requestPincode,

    // Display a PIN code to the user.
    displayPincode,

    // A numeric passkey is required to be entered by the user.
    requestPasskey,

    // Display a zero padded 6 digit numeric passkey that the user entered on
    // the remote device. This event may occur multiple times during pairing to
    // update the entered passkey.
    displayPasskey,

    // The number of keys inputted by the user on the remote device when
    // entering a passkey. This event may be called multiple times during
    // pairing to update the number of keys inputted.
    keysEntered,

    // Requests that a 6 digit passkey be displayed and the user confirms that
    // both devies show the same passkey.
    confirmPasskey,

    // Requests authorization for a pairing under the just-works model. It is up
    // to the app to ask for user confirmation.
    requestAuthorization,

    // Pairing is completed.
    complete
  };

  // Results for connect(). See function declaration for details.
  enum ConnectResultType {
    alreadyConnected,
    authCanceled,
    authFailed,
    authRejected,
    authTimeout,
    failed,
    inProgress,
    success,
    unknownError,
    unsupportedDevice,
    notReady,
    alreadyExists,
    notConnected,
    doesNotExist,
    invalidArgs,
    nonAuthTimeout,
    noMemory,
    jniEnvironment,
    jniThreadAttach,
    wakelock,
    unexpectedState,
    socketError
  };

  // Valid pairing responses.
  enum PairingResponse {
    confirm, reject, cancel
  };

  enum TransportType {
    le, bredr, dual
  };

  // A pairing event received from a Bluetooth device.
  dictionary PairingEvent {
    PairingEventType pairing;
    bluetooth.Device device;
    DOMString? pincode;
    long? passkey;
    long? enteredKey;
  };

  dictionary NewAdapterState {
    // The human-readable name of the adapter.
    DOMString? name;

    // Whether or not the adapter has power.
    boolean? powered;

    // Whether the adapter is discoverable by other devices.
    boolean? discoverable;
  };

  dictionary SetPairingResponseOptions {
    // The remote device to send the pairing response.
    bluetooth.Device device;

    // The response type.
    PairingResponse response;

    // A 1-16 character alphanumeric set in response to
    // <code>requestPincode</code>.
    DOMString? pincode;

    // An integer between 0-999999 set in response to
    // <code>requestPasskey</code>.
    long? passkey;
  };

  dictionary DiscoveryFilter {
    // Transport type.
    TransportType? transport;

    // uuid of service or array of uuids
    (DOMString or DOMString[])? uuids;

    // RSSI ranging value. Only devices with RSSI higher than this value will be
    // reported.
    long? rssi;

    // Pathloss ranging value. Only devices with pathloss lower than this value
    // will be reported.
    long? pathloss;
  };

  callback VoidCallback = void();
  callback ConnectCallback = void(ConnectResultType result);

  // These functions all report failures via chrome.runtime.lastError.
  interface Functions {
    // Changes the state of the Bluetooth adapter.
    // |adapterState|: The new state of the adapter.
    // |callback|: Called when all the state changes have been completed.
    static void setAdapterState(
        NewAdapterState adapterState,
        optional VoidCallback callback);

    static void setPairingResponse(
        SetPairingResponseOptions options,
        optional VoidCallback callback);

    // Tears down all connections to the given device.
    static void disconnectAll(
        DOMString deviceAddress,
        optional VoidCallback callback);

    // Forgets the given device.
    static void forgetDevice(
        DOMString deviceAddress,
        optional VoidCallback callback);

    // Set or clear discovery filter.
    static void setDiscoveryFilter(
        DiscoveryFilter discoveryFilter,
        optional VoidCallback callback);

    // Connects to the given device. This will only throw an error if the
    // device address is invalid or the device is already connected. Otherwise
    // this will succeed and invoke |callback| with ConnectResultType.
    static void connect(
        DOMString deviceAddress,
        optional ConnectCallback callback);

    // Pairs the given device.
    static void pair(
        DOMString deviceAddress,
        optional VoidCallback callback);

    // Record that a pairing attempt finished. Ignores cancellations.
    static void recordPairing(bluetooth.Transport transport,
                              long pairingDurationMs,
                              optional ConnectResultType result);

    // Record that a user-initiated reconnection attempt to an already paired
    // device finished. Ignores cancellations.
    static void recordReconnection(optional ConnectResultType result);

    // Record that a user selected a device to connect to.
    static void recordDeviceSelection(long selectionDurationMs,
                                      boolean wasPaired,
                                      bluetooth.Transport transport);
  };

  interface Events {
    // Fired when a pairing event occurs.
    // |pairingEvent|: A pairing event.
    [maxListeners=1] static void onPairing(PairingEvent pairingEvent);

    // Fired when a Bluetooth device changed its address.
    static void onDeviceAddressChanged(bluetooth.Device device,
                                       DOMString oldAddress);
  };
};