2020-04-23 14:57:53 -04:00
|
|
|
#include <hal/nrf_rtc.h>
|
|
|
|
#include "CurrentTimeClient.h"
|
|
|
|
|
|
|
|
using namespace Pinetime::Controllers;
|
|
|
|
|
|
|
|
constexpr ble_uuid16_t CurrentTimeClient::ctsServiceUuid;
|
|
|
|
constexpr ble_uuid16_t CurrentTimeClient::currentTimeCharacteristicUuid;
|
|
|
|
|
|
|
|
CurrentTimeClient::CurrentTimeClient(DateTime& dateTimeController) : dateTimeController{dateTimeController} {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void CurrentTimeClient::Init() {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2020-04-25 07:09:47 -04:00
|
|
|
bool CurrentTimeClient::OnDiscoveryEvent(uint16_t connectionHandle, const ble_gatt_error *error, const ble_gatt_svc *service) {
|
2020-05-24 10:51:50 -04:00
|
|
|
if(service == nullptr && error->status == BLE_HS_EDONE) {
|
|
|
|
NRF_LOG_INFO("CTS Discovery complete");
|
|
|
|
return true;
|
|
|
|
}
|
2020-04-23 14:57:53 -04:00
|
|
|
|
2020-05-24 10:51:50 -04:00
|
|
|
if(service != nullptr && ble_uuid_cmp(((ble_uuid_t*)&ctsServiceUuid), &service->uuid.u) == 0) {
|
|
|
|
NRF_LOG_INFO("CTS discovered : 0x%x", service->start_handle);
|
|
|
|
isDiscovered = true;
|
|
|
|
ctsStartHandle = service->start_handle;
|
|
|
|
ctsEndHandle = service->end_handle;
|
|
|
|
return false;
|
|
|
|
}
|
2020-04-25 09:52:00 -04:00
|
|
|
return false;
|
2020-04-23 14:57:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
int CurrentTimeClient::OnCharacteristicDiscoveryEvent(uint16_t conn_handle, const ble_gatt_error *error,
|
2020-05-24 10:51:50 -04:00
|
|
|
const ble_gatt_chr *characteristic) {
|
2020-10-28 13:23:09 -04:00
|
|
|
if (characteristic == nullptr && error->status == BLE_HS_EDONE) {
|
|
|
|
NRF_LOG_INFO("CTS Characteristic discovery complete");
|
2020-05-24 10:51:50 -04:00
|
|
|
return 0;
|
2020-10-28 13:23:09 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
if (characteristic != nullptr && ble_uuid_cmp(((ble_uuid_t *) ¤tTimeCharacteristicUuid), &characteristic->uuid.u) == 0) {
|
|
|
|
NRF_LOG_INFO("CTS Characteristic discovered : 0x%x", characteristic->val_handle);
|
|
|
|
isCharacteristicDiscovered = true;
|
|
|
|
currentTimeHandle = characteristic->val_handle;
|
|
|
|
}
|
|
|
|
return 0;
|
2020-04-23 14:57:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
int CurrentTimeClient::OnCurrentTimeReadResult(uint16_t conn_handle, const ble_gatt_error *error, const ble_gatt_attr *attribute) {
|
2020-05-24 10:51:50 -04:00
|
|
|
if(error->status == 0) {
|
|
|
|
// TODO check that attribute->handle equals the handle discovered in OnCharacteristicDiscoveryEvent
|
|
|
|
CtsData result;
|
|
|
|
os_mbuf_copydata(attribute->om, 0, sizeof(CtsData), &result);
|
|
|
|
NRF_LOG_INFO("Received data: %d-%d-%d %d:%d:%d", result.year,
|
|
|
|
result.month, result.dayofmonth,
|
|
|
|
result.hour, result.minute, result.second);
|
|
|
|
dateTimeController.SetTime(result.year, result.month, result.dayofmonth,
|
|
|
|
0, result.hour, result.minute, result.second, nrf_rtc_counter_get(portNRF_RTC_REG));
|
|
|
|
} else {
|
|
|
|
NRF_LOG_INFO("Error retrieving current time: %d", error->status);
|
|
|
|
}
|
|
|
|
return 0;
|
2020-04-23 14:57:53 -04:00
|
|
|
}
|
2020-04-25 09:52:00 -04:00
|
|
|
|
|
|
|
bool CurrentTimeClient::IsDiscovered() const {
|
2020-05-24 10:51:50 -04:00
|
|
|
return isDiscovered;
|
2020-04-25 09:52:00 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
uint16_t CurrentTimeClient::StartHandle() const {
|
2020-05-24 10:51:50 -04:00
|
|
|
return ctsStartHandle;
|
2020-04-25 09:52:00 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
uint16_t CurrentTimeClient::EndHandle() const {
|
2020-05-24 10:51:50 -04:00
|
|
|
return ctsEndHandle;
|
2020-04-25 09:52:00 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
uint16_t CurrentTimeClient::CurrentTimeHandle() const {
|
2020-05-24 10:51:50 -04:00
|
|
|
return currentTimeHandle;
|
2020-10-28 13:23:09 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void CurrentTimeClient::Reset() {
|
|
|
|
isDiscovered = false;
|
|
|
|
isCharacteristicDiscovered = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool CurrentTimeClient::IsCharacteristicDiscovered() const {
|
|
|
|
return isCharacteristicDiscovered;
|
|
|
|
}
|