Run the alert notification service and simplify trhe pinetime service
initialization
This commit is contained in:
parent
49a9a93cef
commit
d33be52bc9
|
@ -320,6 +320,7 @@ list(APPEND SOURCE_FILES
|
|||
Components/Ble/CurrentTimeClient.cpp
|
||||
Components/Ble/AlertNotificationClient.cpp
|
||||
Components/Ble/PinetimeService.cpp
|
||||
Components/Ble/AlertNotificationService.cpp
|
||||
drivers/Cst816s.cpp
|
||||
FreeRTOS/port.c
|
||||
FreeRTOS/port_cmsis_systick.c
|
||||
|
|
|
@ -30,7 +30,9 @@ NimbleController::NimbleController(Pinetime::System::SystemTask& systemTask,
|
|||
dateTimeController{dateTimeController},
|
||||
notificationManager{notificationManager},
|
||||
currentTimeClient{dateTimeController},
|
||||
alertNotificationClient{systemTask, notificationManager} {
|
||||
alertNotificationClient{systemTask, notificationManager},
|
||||
anService{systemTask, notificationManager},
|
||||
pinetimeService{dateTimeController} {
|
||||
|
||||
}
|
||||
|
||||
|
@ -75,7 +77,8 @@ void NimbleController::Init() {
|
|||
deviceInformationService.Init();
|
||||
currentTimeClient.Init();
|
||||
pinetimeService.Init();
|
||||
pinetimeService.setDateTimeController(&dateTimeController);
|
||||
|
||||
anService.Init();
|
||||
|
||||
int res;
|
||||
res = ble_hs_util_ensure_addr(0);
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
#pragma once
|
||||
|
||||
#include <cstdint>
|
||||
#include "AlertNotificationService.h"
|
||||
#include "AlertNotificationClient.h"
|
||||
#include "DeviceInformationService.h"
|
||||
#include "CurrentTimeClient.h"
|
||||
|
@ -35,8 +36,10 @@ namespace Pinetime {
|
|||
|
||||
DeviceInformationService deviceInformationService;
|
||||
CurrentTimeClient currentTimeClient;
|
||||
AlertNotificationService anService;
|
||||
AlertNotificationClient alertNotificationClient;
|
||||
PinetimeService pinetimeService;
|
||||
|
||||
uint8_t addrType;
|
||||
uint16_t connectionHandle;
|
||||
};
|
||||
|
|
|
@ -24,22 +24,21 @@ int PinetimeService::OnTimeAccessed(uint16_t conn_handle, uint16_t attr_handle,
|
|||
NRF_LOG_INFO("Setting time...");
|
||||
|
||||
if (ctxt->op == BLE_GATT_ACCESS_OP_WRITE_CHR) {
|
||||
if (m_dateTimeController) {
|
||||
CtsData result;
|
||||
os_mbuf_copydata(ctxt->om, 0, sizeof(CtsData), &result);
|
||||
CtsData result;
|
||||
os_mbuf_copydata(ctxt->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);
|
||||
NRF_LOG_INFO("Received data: %d-%d-%d %d:%d:%d", result.year,
|
||||
result.month, result.dayofmonth,
|
||||
result.hour, result.minute, result.second);
|
||||
|
||||
m_dateTimeController.SetTime(result.year, result.month, result.dayofmonth,
|
||||
0, result.hour, result.minute, result.second, nrf_rtc_counter_get(portNRF_RTC_REG));
|
||||
|
||||
m_dateTimeController->SetTime(result.year, result.month, result.dayofmonth,
|
||||
0, result.hour, result.minute, result.second, nrf_rtc_counter_get(portNRF_RTC_REG));
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
PinetimeService::PinetimeService() :
|
||||
PinetimeService::PinetimeService(DateTime &dateTimeController) : m_dateTimeController{dateTimeController},
|
||||
characteristicDefinition{
|
||||
{
|
||||
.uuid = (ble_uuid_t *) &timeUuid,
|
||||
|
@ -67,7 +66,3 @@ PinetimeService::PinetimeService() :
|
|||
|
||||
}
|
||||
|
||||
void PinetimeService::setDateTimeController(DateTime *dateTimeController)
|
||||
{
|
||||
m_dateTimeController = dateTimeController;
|
||||
}
|
||||
|
|
|
@ -8,7 +8,7 @@ namespace Pinetime {
|
|||
namespace Controllers {
|
||||
class PinetimeService {
|
||||
public:
|
||||
PinetimeService();
|
||||
PinetimeService(DateTime &dateTimeController);
|
||||
void Init();
|
||||
|
||||
int OnTimeAccessed(uint16_t conn_handle, uint16_t attr_handle,
|
||||
|
@ -44,7 +44,7 @@ namespace Pinetime {
|
|||
uint8_t reason;
|
||||
} CtsData;
|
||||
|
||||
DateTime *m_dateTimeController = nullptr;
|
||||
DateTime &m_dateTimeController;
|
||||
};
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user