Documentation ¶
Overview ¶
Package ble provides the Gobot adaptor for Bluetooth LE.
It also includes drivers for several well-known BLE Services:
- Battery Service - Device Information Service - Generic Access Service
For more information refer to the README: https://github.com/hybridgroup/gobot/blob/master/platforms/ble/README.md
Index ¶
- type BLEConnector
- type BatteryDriver
- type ClientAdaptor
- func (b *ClientAdaptor) Address() string
- func (b *ClientAdaptor) Connect() error
- func (b *ClientAdaptor) Disconnect() error
- func (b *ClientAdaptor) Finalize() error
- func (b *ClientAdaptor) Name() string
- func (b *ClientAdaptor) ReadCharacteristic(cUUID string) ([]byte, error)
- func (b *ClientAdaptor) Reconnect() error
- func (b *ClientAdaptor) SetName(n string)
- func (b *ClientAdaptor) Subscribe(cUUID string, f func([]byte, error)) error
- func (b *ClientAdaptor) WithoutResponses(use bool)
- func (b *ClientAdaptor) WriteCharacteristic(cUUID string, data []byte) error
- type DeviceInformationDriver
- func (b *DeviceInformationDriver) Connection() gobot.Connection
- func (b *DeviceInformationDriver) GetFirmwareRevision() string
- func (b *DeviceInformationDriver) GetHardwareRevision() string
- func (b *DeviceInformationDriver) GetManufacturerName() string
- func (b *DeviceInformationDriver) GetModelNumber() string
- func (b *DeviceInformationDriver) GetPnPId() string
- func (b *DeviceInformationDriver) Halt() error
- func (b *DeviceInformationDriver) Name() string
- func (b *DeviceInformationDriver) SetName(n string)
- func (b *DeviceInformationDriver) Start() error
- type GenericAccessDriver
- func (b *GenericAccessDriver) Connection() gobot.Connection
- func (b *GenericAccessDriver) GetAppearance() string
- func (b *GenericAccessDriver) GetDeviceName() string
- func (b *GenericAccessDriver) Halt() error
- func (b *GenericAccessDriver) Name() string
- func (b *GenericAccessDriver) SetName(n string)
- func (b *GenericAccessDriver) Start() error
- type SerialPort
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type BLEConnector ¶
type BLEConnector interface { gobot.Adaptor Reconnect() error Disconnect() error Address() string ReadCharacteristic(cUUID string) ([]byte, error) WriteCharacteristic(cUUID string, data []byte) error Subscribe(cUUID string, f func([]byte, error)) error WithoutResponses(use bool) }
BLEConnector is the interface that a BLE ClientAdaptor must implement
type BatteryDriver ¶
type BatteryDriver struct { gobot.Eventer // contains filtered or unexported fields }
BatteryDriver represents the Battery Service for a BLE Peripheral
func NewBatteryDriver ¶
func NewBatteryDriver(a BLEConnector) *BatteryDriver
NewBatteryDriver creates a BatteryDriver
func (*BatteryDriver) Connection ¶
func (b *BatteryDriver) Connection() gobot.Connection
Connection returns the Driver's Connection to the associated Adaptor
func (*BatteryDriver) GetBatteryLevel ¶
func (b *BatteryDriver) GetBatteryLevel() uint8
GetBatteryLevel reads and returns the current battery level
func (*BatteryDriver) SetName ¶
func (b *BatteryDriver) SetName(n string)
SetName sets the Driver name
func (*BatteryDriver) Start ¶
func (b *BatteryDriver) Start() error
Start tells driver to get ready to do work
type ClientAdaptor ¶
type ClientAdaptor struct { AdapterName string // contains filtered or unexported fields }
ClientAdaptor represents a Client Connection to a BLE Peripheral
func NewClientAdaptor ¶
func NewClientAdaptor(address string) *ClientAdaptor
NewClientAdaptor returns a new ClientAdaptor given an address
func (*ClientAdaptor) Address ¶
func (b *ClientAdaptor) Address() string
Address returns the Bluetooth LE address for the adaptor
func (*ClientAdaptor) Connect ¶
func (b *ClientAdaptor) Connect() error
Connect initiates a connection to the BLE peripheral. Returns true on successful connection.
func (*ClientAdaptor) Disconnect ¶
func (b *ClientAdaptor) Disconnect() error
Disconnect terminates the connection to the BLE peripheral. Returns true on successful disconnect.
func (*ClientAdaptor) Finalize ¶
func (b *ClientAdaptor) Finalize() error
Finalize finalizes the BLEAdaptor
func (*ClientAdaptor) Name ¶
func (b *ClientAdaptor) Name() string
Name returns the name for the adaptor
func (*ClientAdaptor) ReadCharacteristic ¶
func (b *ClientAdaptor) ReadCharacteristic(cUUID string) ([]byte, error)
ReadCharacteristic returns bytes from the BLE device for the requested characteristic uuid
func (*ClientAdaptor) Reconnect ¶
func (b *ClientAdaptor) Reconnect() error
Reconnect attempts to reconnect to the BLE peripheral. If it has an active connection it will first close that connection and then establish a new connection. Returns true on Successful reconnection
func (*ClientAdaptor) SetName ¶
func (b *ClientAdaptor) SetName(n string)
SetName sets the name for the adaptor
func (*ClientAdaptor) Subscribe ¶
func (b *ClientAdaptor) Subscribe(cUUID string, f func([]byte, error)) error
Subscribe subscribes to notifications from the BLE device for the requested service and characteristic
func (*ClientAdaptor) WithoutResponses ¶
func (b *ClientAdaptor) WithoutResponses(use bool)
WithoutResponses sets if the adaptor should expect responses after writing characteristics for this device
func (*ClientAdaptor) WriteCharacteristic ¶
func (b *ClientAdaptor) WriteCharacteristic(cUUID string, data []byte) error
WriteCharacteristic writes bytes to the BLE device for the requested service and characteristic
type DeviceInformationDriver ¶
type DeviceInformationDriver struct { gobot.Eventer // contains filtered or unexported fields }
DeviceInformationDriver represents the Device Information Service for a BLE Peripheral
func NewDeviceInformationDriver ¶
func NewDeviceInformationDriver(a BLEConnector) *DeviceInformationDriver
NewDeviceInformationDriver creates a DeviceInformationDriver
func (*DeviceInformationDriver) Connection ¶
func (b *DeviceInformationDriver) Connection() gobot.Connection
Connection returns the Driver's Connection to the associated Adaptor
func (*DeviceInformationDriver) GetFirmwareRevision ¶
func (b *DeviceInformationDriver) GetFirmwareRevision() string
GetFirmwareRevision returns the firmware revision for the BLE Peripheral
func (*DeviceInformationDriver) GetHardwareRevision ¶
func (b *DeviceInformationDriver) GetHardwareRevision() string
GetHardwareRevision returns the hardware revision for the BLE Peripheral
func (*DeviceInformationDriver) GetManufacturerName ¶
func (b *DeviceInformationDriver) GetManufacturerName() string
GetManufacturerName returns the manufacturer name for the BLE Peripheral
func (*DeviceInformationDriver) GetModelNumber ¶
func (b *DeviceInformationDriver) GetModelNumber() string
GetModelNumber returns the model number for the BLE Peripheral
func (*DeviceInformationDriver) GetPnPId ¶
func (b *DeviceInformationDriver) GetPnPId() string
GetPnPId returns the PnP ID for the BLE Peripheral
func (*DeviceInformationDriver) Halt ¶
func (b *DeviceInformationDriver) Halt() error
Halt stops driver (void)
func (*DeviceInformationDriver) Name ¶
func (b *DeviceInformationDriver) Name() string
Name returns the Driver name
func (*DeviceInformationDriver) SetName ¶
func (b *DeviceInformationDriver) SetName(n string)
SetName sets the Driver name
func (*DeviceInformationDriver) Start ¶
func (b *DeviceInformationDriver) Start() error
Start tells driver to get ready to do work
type GenericAccessDriver ¶
type GenericAccessDriver struct { gobot.Eventer // contains filtered or unexported fields }
GenericAccessDriver represents the Generic Access Service for a BLE Peripheral
func NewGenericAccessDriver ¶
func NewGenericAccessDriver(a BLEConnector) *GenericAccessDriver
NewGenericAccessDriver creates a GenericAccessDriver
func (*GenericAccessDriver) Connection ¶
func (b *GenericAccessDriver) Connection() gobot.Connection
Connection returns the Driver's Connection to the associated Adaptor
func (*GenericAccessDriver) GetAppearance ¶
func (b *GenericAccessDriver) GetAppearance() string
GetAppearance returns the appearance string for the BLE Peripheral
func (*GenericAccessDriver) GetDeviceName ¶
func (b *GenericAccessDriver) GetDeviceName() string
GetDeviceName returns the device name for the BLE Peripheral
func (*GenericAccessDriver) Halt ¶
func (b *GenericAccessDriver) Halt() error
Halt stops driver (void)
func (*GenericAccessDriver) Name ¶
func (b *GenericAccessDriver) Name() string
Name returns the Driver name
func (*GenericAccessDriver) SetName ¶
func (b *GenericAccessDriver) SetName(n string)
SetName sets the Driver name
func (*GenericAccessDriver) Start ¶
func (b *GenericAccessDriver) Start() error
Start tells driver to get ready to do work
type SerialPort ¶
type SerialPort struct {
// contains filtered or unexported fields
}
SerialPort is a implementation of serial over Bluetooth LE Inspired by https://github.com/monteslu/ble-serial by @monteslu
func NewSerialPort ¶
func NewSerialPort(address string, rid string, tid string) *SerialPort
NewSerialPort returns a new serial over Bluetooth LE connection
func (*SerialPort) Close ¶
func (p *SerialPort) Close() error
Close closes the BLE serial port connection
func (*SerialPort) Open ¶
func (p *SerialPort) Open() error
Open opens a connection to a BLE serial device