aboutsummaryrefslogtreecommitdiffstats

Bluetooth Service

Overview

Bluetooth service uses the respective BlueZ package to connect to bluetooth devices

Verbs

Name Description JSON Response
subscribe subscribe to bluetooth events Request: {"value": "device_changes"}
unsubscribe unsubscribe to bluetooth events Request: {"value": "device_changes"}
managed_objects retrieve managed bluetooth devices see managed_objects verb section
adapter_state retrieve or change adapter scan settings see adapter_state verb section
default_adapter retrieve or change default adapter setting Request: {"adapter": "hci1"}
avrcp_controls avrcp controls for MediaPlayer1 playback see avrcp_controls verb section
connect connect to already paired device see connect/disconnect verb section
disconnect disconnect to already connected device see connect/disconnect verb section
pair initialize a pairing request Request: {"device":"dev_88_0F_10_96_D3_20"}
cancel_pairing cancel an outgoing pair request
confirm_pairing confirm incoming/outgoing bluetooth pairing pincode Request: {"pincode": 31415}
remove_device remove already paired device Request: {"device": "dev_88_0F_10_96_D3_20"}
set_pincode set pincode as string into database for outgoing pairing request Request: {"pincode": "4321"}

managed_objects verb

This verb allows an client to get initial paired devices, and discovered unpaired devices before subscriptio to devices_changed event.

{
  "response": {
    "adapters": [
      {
        "name": "hci0",
        "properties": {
          "address": "00:1A:7D:DA:71:0F",
          "powered": true,
          "discoverable": true,
          "discoverabletimeout": 180,
          "pairable": true,
          "pairabletimeout": 0,
          "discovering": true,
          "uuids": [
            "00001112-0000-1000-8000-00805f9b34fb",
            "00001801-0000-1000-8000-00805f9b34fb",
            "0000110e-0000-1000-8000-00805f9b34fb",
            "00001800-0000-1000-8000-00805f9b34fb",
            "00001200-0000-1000-8000-00805f9b34fb",
            "0000110c-0000-1000-8000-00805f9b34fb",
            "0000110b-0000-1000-8000-00805f9b34fb",
            "0000110a-0000-1000-8000-00805f9b34fb",
            "0000111e-0000-1000-8000-00805f9b34fb",
            "0000111f-0000-1000-8000-00805f9b34fb",
            "00001108-0000-1000-8000-00805f9b34fb"
          ]
        }
      }
    ],
    "devices": [
      {
        "adapter": "hci0",
        "device": "dev_F8_34_41_DA_BA_46",
        "properties": {
          "address": "F8:34:41:DA:BA:46",
          "name": "roguebox",
          "alias": "roguebox",
          "class": 1835276,
          "icon": "computer",
          "paired": false,
          "trusted": false,
          "blocked": false,
          "legacypairing": false,
          "rssi": -63,
          "connected": false,
          "uuids": [
            "0000110e-0000-1000-8000-00805f9b34fb",
            "0000110c-0000-1000-8000-00805f9b34fb",
            "00001112-0000-1000-8000-00805f9b34fb",
            "00001108-0000-1000-8000-00805f9b34fb",
            "00001133-0000-1000-8000-00805f9b34fb",
            "00001132-0000-1000-8000-00805f9b34fb",
            "0000112f-0000-1000-8000-00805f9b34fb",
            "00001104-0000-1000-8000-00805f9b34fb",
            "00001106-0000-1000-8000-00805f9b34fb",
            "00001105-0000-1000-8000-00805f9b34fb",
            "0000110a-0000-1000-8000-00805f9b34fb",
            "0000110b-0000-1000-8000-00805f9b34fb",
            "00005005-0000-1000-8000-0002ee000001"
          ],
          "modalias": "usb:v1D6Bp0246d0530",
          "adapter": "/org/bluez/hci0",
          "txpower": 12,
          "servicesresolved": false
        }
      },
      {
        "adapter": "hci0",
        "device": "dev_67_13_E2_57_29_0F",
        "properties": {
          "address": "68:13:E2:57:29:0F",
          "alias": "67-13-E2-57-29-0F",
          "paired": false,
          "trusted": false,
          "blocked": false,
          "legacypairing": false,
          "rssi": -69,
          "connected": false,
          "uuids": [],
          "adapter": "/org/bluez/hci0",
          "servicesresolved": false
        }
      },
    ],
    "transports": [
      {
          "endpoint": "fd1",
          "adapter": "hci0",
          "device": "dev_D0_81_7A_5A_BC_5E",
          "properties": {
            "uuid": "0000110B-0000-1000-8000-00805F9B34FB",
            "state": "idle",
            "volume": 127
          }
      }
   ],
}

adapter_state verb

adapter_state verb allows setting and retrieving of requested adapter settings

Name Description
adapter Must be the name of the adapter (i.e. hci0)
discovery Discover nearby broadcasting devices
discoverable Allow other devices to detect this device
powered Adapter power state (optional, rfkill should be disabled already)

adapter_state verb write-only parameters

Name Description
filter Scan for devices only with respective UUIDS listed
transport Scan for devices with only defined transport type (e.g. auto, bredr, le)

avrcp_controls verb

avrcp_controls verb allow controlling the playback of the defined device

Name Description
adapter Name of the adapter (optional, i.e. hci0)
device Must be the name of the device (optional, i.e. dev_88_0F_10_96_D3_20)
action Playback control action to take (e.g Play, Pause, Stop, Next, Previous, FastForward, Rewind)

connect/disconnect verbs

NOTE: uuid in this respect is not related to the afb framework but the Bluetooth profile UUID

To connect/disconnect using the respective verb with all known and authenticated profiles:

  {"device": "dev_88_0F_10_96_D3_20"}

To do the same for the respective device, verb, and for singular profile

  {"device": "dev_88_0F_10_96_D3_20", "uuid": "0000110e-0000-1000-8000-00805f9b34fb"}

Events

Name Description JSON Event Data
adapter_changes report on Bluetooth adapter states see adapter_changes event section
device_changes report on Bluetooth devices see device_changes event section
media report on MediaPlayer1 events see media event section
agent PIN from BlueZ agent for confirmation see agent event section

adapter_changes event

Sample of adding new adapter event:

{
  "adapter": "hci0",
  "action": "added",
  "properties": {
    "address": "60:30:D4:66:55:A7",
    "powered": false,
    "discoverable": false,
    "discoverabletimeout": 180,
    "pairable": true,
    "pairabletimeout": 0,
    "discovering": false,
    "uuids": [
      "00001801-0000-1000-8000-00805f9b34fb",
      "0000110e-0000-1000-8000-00805f9b34fb",
      "00001200-0000-1000-8000-00805f9b34fb",
      "00001800-0000-1000-8000-00805f9b34fb",
      "0000111e-0000-1000-8000-00805f9b34fb",
      "0000110c-0000-1000-8000-00805f9b34fb"
    ]
  }
}

Sample of adapter property changes:

{
  "adapter": "hci0",
  "action": "changed",
  "properties": {
    "powered": false,
    "discovering": false,
    "discoverable": false
  }
}

Sample of adapter being removed:

{
  "adapter": "hci0",
  "action": "removed",
}

device_changes event

Sample of discovering a new device event:

{
  "adapter": "hci0",
  "device": "dev_88_0F_10_96_D3_20",
  "action": "added",
  "properties": {
    "address": "88:0F:10:96:D3:20",
    "name": "MI_SCALE",
    "alias": "MI_SCALE",
    "class": 7995916,
    "icon": "phone",
    "paired": false,
    "trusted": false,
    "blocked": false,
    "legacypairing": false,
    "rssi": -55,
    "connected": false,
    "uuids": [
      "00001200-0000-1000-8000-00805f9b34fb",
      "0000111f-0000-1000-8000-00805f9b34fb",
      "0000112f-0000-1000-8000-00805f9b34fb",
      "0000110a-0000-1000-8000-00805f9b34fb",
      "0000110c-0000-1000-8000-00805f9b34fb",
      "00001116-0000-1000-8000-00805f9b34fb",
      "00001132-0000-1000-8000-00805f9b34fb",
      "00000000-deca-fade-deca-deafdecacafe",
      "02030302-1d19-415f-86f2-22a2106a0a77",
      "2d8d2466-e14d-451c-88bc-7301abea291a"
    ],
    "adapter": "/org/bluez/hci0",
    "servicesresolved": false
  }
}

Changed status events for a device:

{
  "adapter": "hci0",
  "device": "dev_88_0F_10_96_D3_20",
  "action": "changed",
  "properties": {
    "connected": true
  }
}

media event

Playing audio reporting event (not all fields will be passed in every event):

{
        "adapter": "hci0",
        "device": "dev_D0_81_7A_5A_BC_5E",
        "type": "playback",
        "track": {
                "title": "True Colors",
                "duration": 228000,
                "album": "True Colors",
                "tracknumber": 6,
                "artist": "Zedd",
                "numberoftracks": 11,
                "genre": "Dance & DJ/General"
        },
        "position": 5600,
        "status": "playing",
        "connected": true,
        "player": "player0"
}

A2DP transport addition/removal (some fields are optional):

{
        "adapter": "hci0",
        "device": "dev_D0_81_7A_5A_BC_5E",
        "action": "added",
        "type": "transport",
        "endpoint": "fd0"
        "properties": {
                "uuid": "0000110B-0000-1000-8000-00805F9B34FB",
                "state": "idle",
                "volume": 127
         },
}
...
{
        "adapter": "hci0",
        "device": "dev_D0_81_7A_5A_BC_5E",
        "action": "removed",
        "type": "transport",
        "endpoint": "fd0"
}

agent event

After pairing request agent will send event for a pincode that must be confirmed on both sides:

{
  "adapter": "hci0",
  "device": "dev_88_OF_10_96_D3_20",
  "action": "request_confirmation",
  "pincode": 327142
}

If pairing is canceled or fails:

{
  "action": "canceled_pairing"
}