forked from rigado/ble
-
Notifications
You must be signed in to change notification settings - Fork 0
/
client.go
86 lines (60 loc) · 3.75 KB
/
client.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
package ble
import "time"
// A Client is a GATT client.
type Client interface {
// Addr returns platform specific unique ID of the remote peripheral, e.g. MAC on Linux, Client UUID on OS X.
Addr() Addr
// Name returns the name of the remote peripheral.
// This can be the advertised name, if exists, or the GAP device name, which takes priority.
Name() string
// Profile returns discovered profile.
Profile() *Profile
// DiscoverProfile discovers the whole hierarchy of a server.
DiscoverProfile(force bool) (*Profile, error)
// DiscoverAndCacheProfile discovers the whole hierarchy of a server and caches it to a local file
// If a cache file is not designated via an option, this function will return an error
DiscoverAndCacheProfile(force bool) (*Profile, error)
// DiscoverServices finds all the primary services on a server. [Vol 3, Part G, 4.4.1]
// If filter is specified, only filtered services are returned.
DiscoverServices(filter []UUID) ([]*Service, error)
// DiscoverIncludedServices finds the included services of a service. [Vol 3, Part G, 4.5.1]
// If filter is specified, only filtered services are returned.
DiscoverIncludedServices(filter []UUID, s *Service) ([]*Service, error)
// DiscoverCharacteristics finds all the characteristics within a service. [Vol 3, Part G, 4.6.1]
// If filter is specified, only filtered characteristics are returned.
DiscoverCharacteristics(filter []UUID, s *Service) ([]*Characteristic, error)
// DiscoverDescriptors finds all the descriptors within a characteristic. [Vol 3, Part G, 4.7.1]
// If filter is specified, only filtered descriptors are returned.
DiscoverDescriptors(filter []UUID, c *Characteristic) ([]*Descriptor, error)
// ReadCharacteristic reads a characteristic value from a server. [Vol 3, Part G, 4.8.1]
ReadCharacteristic(c *Characteristic) ([]byte, error)
// ReadLongCharacteristic reads a characteristic value which is longer than the MTU. [Vol 3, Part G, 4.8.3]
ReadLongCharacteristic(c *Characteristic) ([]byte, error)
// WriteCharacteristic writes a characteristic value to a server. [Vol 3, Part G, 4.9.3]
WriteCharacteristic(c *Characteristic, value []byte, noRsp bool) error
// ReadDescriptor reads a characteristic descriptor from a server. [Vol 3, Part G, 4.12.1]
ReadDescriptor(d *Descriptor) ([]byte, error)
// WriteDescriptor writes a characteristic descriptor to a server. [Vol 3, Part G, 4.12.3]
WriteDescriptor(d *Descriptor, v []byte) error
// ReadRSSI retrieves the current RSSI value of remote peripheral. [Vol 2, Part E, 7.5.4]
ReadRSSI() (int8, error)
// ExchangeMTU set the ATT_MTU to the maximum possible value that can be supported by both devices [Vol 3, Part G, 4.3.1]
ExchangeMTU(rxMTU int) (txMTU int, err error)
// Subscribe subscribes to indication (if ind is set true), or notification of a characteristic value. [Vol 3, Part G, 4.10 & 4.11]
Subscribe(c *Characteristic, ind bool, h NotificationHandler) error
// Unsubscribe unsubscribes to indication (if ind is set true), or notification of a specified characteristic value. [Vol 3, Part G, 4.10 & 4.11]
Unsubscribe(c *Characteristic, ind bool) error
// ClearSubscriptions clears all subscriptions to notifications and indications.
ClearSubscriptions() error
// CancelConnection disconnects the connection.
CancelConnection() error
// Disconnected returns a receiving channel, which is closed when the client disconnects.
Disconnected() <-chan struct{}
// Conn returns the client's current connection.
Conn() Conn
Pair(AuthData, time.Duration) error
StartEncryption(c chan EncryptionChangedInfo) error
OpenLECreditBasedConnection(psm uint16) (LECreditBasedConnection, error)
ConnectionHandle() uint8
SetConnectionParameters(minInterval, maxInterval, latency, timeout, minCeLength, maxCeLength uint16) error
}