mirror of
https://github.com/meshtastic/firmware.git
synced 2025-06-18 11:02:16 +00:00
Fix #69 - new BLE API is in and tested from android
This commit is contained in:
parent
3673f95fe5
commit
a0b6d57591
@ -1,3 +1,3 @@
|
|||||||
|
|
||||||
|
|
||||||
export VERSION=0.4.3
|
export VERSION=0.5.5
|
@ -13,16 +13,16 @@ This is the main bluetooth service for the device and provides the API your app
|
|||||||
For a reference implementation of a client that uses this service see [RadioInterfaceService](https://github.com/meshtastic/Meshtastic-Android/blob/master/app/src/main/java/com/geeksville/mesh/service/RadioInterfaceService.kt). Typical flow when
|
For a reference implementation of a client that uses this service see [RadioInterfaceService](https://github.com/meshtastic/Meshtastic-Android/blob/master/app/src/main/java/com/geeksville/mesh/service/RadioInterfaceService.kt). Typical flow when
|
||||||
a phone connects to the device should be the following:
|
a phone connects to the device should be the following:
|
||||||
|
|
||||||
* SetMTU size to 512
|
- SetMTU size to 512
|
||||||
* Read a RadioConfig from "radio" - used to get the channel and radio settings
|
- Read a RadioConfig from "radio" - used to get the channel and radio settings
|
||||||
* Read (and write if incorrect) a User from "user" - to get the username for this node
|
- Read (and write if incorrect) a User from "user" - to get the username for this node
|
||||||
* Read a MyNodeInfo from "mynode" to get information about this local device
|
- Read a MyNodeInfo from "mynode" to get information about this local device
|
||||||
* Write an empty record to "nodeinfo" to restart the nodeinfo reading state machine
|
- Write an empty record to "nodeinfo" to restart the nodeinfo reading state machine
|
||||||
* Read from "nodeinfo" until it returns empty to build the phone's copy of the current NodeDB for the mesh
|
- Read from "nodeinfo" until it returns empty to build the phone's copy of the current NodeDB for the mesh
|
||||||
* Read from "fromradio" until it returns empty to get any messages that arrived for this node while the phone was away
|
- Read from "fromradio" until it returns empty to get any messages that arrived for this node while the phone was away
|
||||||
* Subscribe to notify on "fromnum" to get notified whenever the device has a new received packet
|
- Subscribe to notify on "fromnum" to get notified whenever the device has a new received packet
|
||||||
* Read that new packet from "fromradio"
|
- Read that new packet from "fromradio"
|
||||||
* Whenever the phone has a packet to send write to "toradio"
|
- Whenever the phone has a packet to send write to "toradio"
|
||||||
|
|
||||||
For definitions (and documentation) on FromRadio, ToRadio, MyNodeInfo, NodeInfo and User protocol buffers see [mesh.proto](https://github.com/meshtastic/Meshtastic-protobufs/blob/master/mesh.proto)
|
For definitions (and documentation) on FromRadio, ToRadio, MyNodeInfo, NodeInfo and User protocol buffers see [mesh.proto](https://github.com/meshtastic/Meshtastic-protobufs/blob/master/mesh.proto)
|
||||||
|
|
||||||
@ -54,29 +54,17 @@ When the esp32 advances fromnum, it will delay doing the notify by 100ms, in the
|
|||||||
|
|
||||||
Note: that if the phone ever sees this number decrease, it means the esp32 has rebooted.
|
Note: that if the phone ever sees this number decrease, it means the esp32 has rebooted.
|
||||||
|
|
||||||
ea9f3f82-8dc4-4733-9452-1f6da28892a2
|
|
||||||
read
|
|
||||||
mynode - read this to access a MyNodeInfo protobuf
|
|
||||||
|
|
||||||
d31e02e0-c8ab-4d3f-9cc9-0b8466bdabe8
|
|
||||||
read, write
|
|
||||||
nodeinfo - read this to get a series of NodeInfos (ending with a null empty record), write to this to restart the read statemachine that returns all the node infos
|
|
||||||
|
|
||||||
b56786c8-839a-44a1-b98e-a1724c4a0262
|
|
||||||
read,write
|
|
||||||
radio - read/write this to access a RadioConfig protobuf
|
|
||||||
|
|
||||||
6ff1d8b6-e2de-41e3-8c0b-8fa384f64eb6
|
|
||||||
read,write
|
|
||||||
owner - read/write this to access a User protobuf
|
|
||||||
|
|
||||||
Re: queue management
|
Re: queue management
|
||||||
Not all messages are kept in the fromradio queue (filtered based on SubPacket):
|
Not all messages are kept in the fromradio queue (filtered based on SubPacket):
|
||||||
* only the most recent Position and User messages for a particular node are kept
|
|
||||||
* all Data SubPackets are kept
|
|
||||||
* No WantNodeNum / DenyNodeNum messages are kept
|
|
||||||
A variable keepAllPackets, if set to true will suppress this behavior and instead keep everything for forwarding to the phone (for debugging)
|
|
||||||
|
|
||||||
|
- only the most recent Position and User messages for a particular node are kept
|
||||||
|
- all Data SubPackets are kept
|
||||||
|
- No WantNodeNum / DenyNodeNum messages are kept
|
||||||
|
A variable keepAllPackets, if set to true will suppress this behavior and instead keep everything for forwarding to the phone (for debugging)
|
||||||
|
|
||||||
|
## Protobuf API
|
||||||
|
|
||||||
|
On connect, you should send a want_config_id protobuf to the device. This will cause the device to send its node DB and radio config via the fromradio endpoint. After sending the full DB, the radio will send a want_config_id to indicate it is done sending the configuration.
|
||||||
|
|
||||||
## Other bluetooth services
|
## Other bluetooth services
|
||||||
|
|
||||||
@ -91,8 +79,8 @@ SoftwareUpdateService UUID cb0b9a0b-a84c-4c0d-bdbb-442e3144ee30
|
|||||||
|
|
||||||
Characteristics
|
Characteristics
|
||||||
|
|
||||||
| UUID | properties | description|
|
| UUID | properties | description |
|
||||||
|--------------------------------------|------------------|------------|
|
| ------------------------------------ | ----------- | ----------------------------------------------------------------------------------------------------------------- |
|
||||||
| e74dd9c0-a301-4a6f-95a1-f0e1dbea8e1e | write,read | total image size, 32 bit, write this first, then read read back to see if it was acceptable (0 mean not accepted) |
|
| e74dd9c0-a301-4a6f-95a1-f0e1dbea8e1e | write,read | total image size, 32 bit, write this first, then read read back to see if it was acceptable (0 mean not accepted) |
|
||||||
| e272ebac-d463-4b98-bc84-5cc1a39ee517 | write | data, variable sized, recommended 512 bytes, write one for each block of file |
|
| e272ebac-d463-4b98-bc84-5cc1a39ee517 | write | data, variable sized, recommended 512 bytes, write one for each block of file |
|
||||||
| 4826129c-c22a-43a3-b066-ce8f0d5bacc6 | write | crc32, write last - writing this will complete the OTA operation, now you can read result |
|
| 4826129c-c22a-43a3-b066-ce8f0d5bacc6 | write | crc32, write last - writing this will complete the OTA operation, now you can read result |
|
||||||
|
@ -23,6 +23,9 @@ static CallbackCharacteristic *meshFromNumCharacteristic;
|
|||||||
|
|
||||||
BLEService *meshService;
|
BLEService *meshService;
|
||||||
|
|
||||||
|
// If defined we will also support the old API
|
||||||
|
#define SUPPORT_OLD_BLE_API
|
||||||
|
|
||||||
class BluetoothPhoneAPI : public PhoneAPI
|
class BluetoothPhoneAPI : public PhoneAPI
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
@ -80,6 +83,7 @@ class ProtobufCharacteristic : public CallbackCharacteristic
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#ifdef SUPPORT_OLD_BLE_API
|
||||||
class NodeInfoCharacteristic : public BLECharacteristic, public BLEKeepAliveCallbacks
|
class NodeInfoCharacteristic : public BLECharacteristic, public BLEKeepAliveCallbacks
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -162,6 +166,29 @@ class OwnerCharacteristic : public ProtobufCharacteristic
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class MyNodeInfoCharacteristic : public ProtobufCharacteristic
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
MyNodeInfoCharacteristic()
|
||||||
|
: ProtobufCharacteristic("ea9f3f82-8dc4-4733-9452-1f6da28892a2", BLECharacteristic::PROPERTY_READ, MyNodeInfo_fields,
|
||||||
|
&myNodeInfo)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void onRead(BLECharacteristic *c)
|
||||||
|
{
|
||||||
|
// update gps connection state
|
||||||
|
myNodeInfo.has_gps = gps.isConnected;
|
||||||
|
|
||||||
|
ProtobufCharacteristic::onRead(c);
|
||||||
|
|
||||||
|
myNodeInfo.error_code = 0; // The phone just read us, so throw it away
|
||||||
|
myNodeInfo.error_address = 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
class ToRadioCharacteristic : public CallbackCharacteristic
|
class ToRadioCharacteristic : public CallbackCharacteristic
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -216,27 +243,6 @@ class FromNumCharacteristic : public CallbackCharacteristic
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class MyNodeInfoCharacteristic : public ProtobufCharacteristic
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
MyNodeInfoCharacteristic()
|
|
||||||
: ProtobufCharacteristic("ea9f3f82-8dc4-4733-9452-1f6da28892a2", BLECharacteristic::PROPERTY_READ, MyNodeInfo_fields,
|
|
||||||
&myNodeInfo)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
void onRead(BLECharacteristic *c)
|
|
||||||
{
|
|
||||||
// update gps connection state
|
|
||||||
myNodeInfo.has_gps = gps.isConnected;
|
|
||||||
|
|
||||||
ProtobufCharacteristic::onRead(c);
|
|
||||||
|
|
||||||
myNodeInfo.error_code = 0; // The phone just read us, so throw it away
|
|
||||||
myNodeInfo.error_address = 0;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
See bluetooth-api.md for documentation.
|
See bluetooth-api.md for documentation.
|
||||||
*/
|
*/
|
||||||
@ -257,10 +263,12 @@ BLEService *createMeshBluetoothService(BLEServer *server)
|
|||||||
addWithDesc(service, meshFromNumCharacteristic, "fromRadio");
|
addWithDesc(service, meshFromNumCharacteristic, "fromRadio");
|
||||||
addWithDesc(service, new ToRadioCharacteristic, "toRadio");
|
addWithDesc(service, new ToRadioCharacteristic, "toRadio");
|
||||||
addWithDesc(service, new FromRadioCharacteristic, "fromNum");
|
addWithDesc(service, new FromRadioCharacteristic, "fromNum");
|
||||||
|
#ifdef SUPPORT_OLD_BLE_API
|
||||||
addWithDesc(service, new MyNodeInfoCharacteristic, "myNode");
|
addWithDesc(service, new MyNodeInfoCharacteristic, "myNode");
|
||||||
addWithDesc(service, new RadioCharacteristic, "radio");
|
addWithDesc(service, new RadioCharacteristic, "radio");
|
||||||
addWithDesc(service, new OwnerCharacteristic, "owner");
|
addWithDesc(service, new OwnerCharacteristic, "owner");
|
||||||
addWithDesc(service, new NodeInfoCharacteristic, "nodeinfo");
|
addWithDesc(service, new NodeInfoCharacteristic, "nodeinfo");
|
||||||
|
#endif
|
||||||
|
|
||||||
meshFromNumCharacteristic->addDescriptor(addBLEDescriptor(new BLE2902())); // Needed so clients can request notification
|
meshFromNumCharacteristic->addDescriptor(addBLEDescriptor(new BLE2902())); // Needed so clients can request notification
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user