aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/ble
diff options
context:
space:
mode:
Diffstat (limited to 'src/components/ble')
-rw-r--r--src/components/ble/DfuService.cpp14
-rw-r--r--src/components/ble/DfuService.h5
-rw-r--r--src/components/ble/FSService.cpp14
-rw-r--r--src/components/ble/FSService.h6
4 files changed, 39 insertions, 0 deletions
diff --git a/src/components/ble/DfuService.cpp b/src/components/ble/DfuService.cpp
index 2427513d..ad9c99e9 100644
--- a/src/components/ble/DfuService.cpp
+++ b/src/components/ble/DfuService.cpp
@@ -1,6 +1,8 @@
#include "components/ble/DfuService.h"
#include <cstring>
#include "components/ble/BleController.h"
+#include "components/ble/NotificationManager.h"
+#include "components/settings/Settings.h"
#include "drivers/SpiNorFlash.h"
#include "systemtask/SystemTask.h"
#include <nrf_log.h>
@@ -78,6 +80,18 @@ void DfuService::Init() {
}
int DfuService::OnServiceData(uint16_t connectionHandle, uint16_t attributeHandle, ble_gatt_access_ctxt* context) {
+#ifndef PINETIME_IS_RECOVERY
+ if (systemTask.GetSettings().GetDfuAndFsMode() == Pinetime::Controllers::Settings::DfuAndFsMode::Disabled) {
+ Pinetime::Controllers::NotificationManager::Notification notif;
+ memcpy(notif.message.data(), denyAlert, denyAlertLength);
+ notif.size = denyAlertLength;
+ notif.category = Pinetime::Controllers::NotificationManager::Categories::SimpleAlert;
+ systemTask.GetNotificationManager().Push(std::move(notif));
+ systemTask.PushMessage(Pinetime::System::Messages::OnNewNotification);
+ return BLE_ATT_ERR_INSUFFICIENT_AUTHOR;
+ }
+#endif
+
if (bleController.IsFirmwareUpdating()) {
xTimerStart(timeoutTimer, 0);
}
diff --git a/src/components/ble/DfuService.h b/src/components/ble/DfuService.h
index 6652cdc1..99be27b9 100644
--- a/src/components/ble/DfuService.h
+++ b/src/components/ble/DfuService.h
@@ -20,6 +20,8 @@ namespace Pinetime {
namespace Controllers {
class Ble;
+ class Settings;
+ class NotificationManager;
class DfuService {
public:
@@ -87,6 +89,9 @@ namespace Pinetime {
DfuImage dfuImage;
NotificationManager notificationManager;
+ static constexpr const char denyAlert[] = "InfiniTime\0Firmware update attempted, but disabled in settings.";
+ static constexpr const uint8_t denyAlertLength = sizeof(denyAlert); // for this to work denyAlert MUST be array
+
static constexpr uint16_t dfuServiceId {0x1530};
static constexpr uint16_t packetCharacteristicId {0x1532};
static constexpr uint16_t controlPointCharacteristicId {0x1531};
diff --git a/src/components/ble/FSService.cpp b/src/components/ble/FSService.cpp
index fda6b392..721ed297 100644
--- a/src/components/ble/FSService.cpp
+++ b/src/components/ble/FSService.cpp
@@ -1,6 +1,8 @@
#include <nrf_log.h>
#include "FSService.h"
#include "components/ble/BleController.h"
+#include "components/ble/NotificationManager.h"
+#include "components/settings/Settings.h"
#include "systemtask/SystemTask.h"
using namespace Pinetime::Controllers;
@@ -49,6 +51,18 @@ void FSService::Init() {
}
int FSService::OnFSServiceRequested(uint16_t connectionHandle, uint16_t attributeHandle, ble_gatt_access_ctxt* context) {
+#ifndef PINETIME_IS_RECOVERY
+ if (systemTask.GetSettings().GetDfuAndFsMode() == Pinetime::Controllers::Settings::DfuAndFsMode::Disabled) {
+ Pinetime::Controllers::NotificationManager::Notification notif;
+ memcpy(notif.message.data(), denyAlert, denyAlertLength);
+ notif.size = denyAlertLength;
+ notif.category = Pinetime::Controllers::NotificationManager::Categories::SimpleAlert;
+ systemTask.GetNotificationManager().Push(std::move(notif));
+ systemTask.PushMessage(Pinetime::System::Messages::OnNewNotification);
+ return BLE_ATT_ERR_INSUFFICIENT_AUTHOR;
+ }
+#endif
+
if (attributeHandle == versionCharacteristicHandle) {
NRF_LOG_INFO("FS_S : handle = %d", versionCharacteristicHandle);
int res = os_mbuf_append(context->om, &fsVersion, sizeof(fsVersion));
diff --git a/src/components/ble/FSService.h b/src/components/ble/FSService.h
index b2299623..b43bc9e4 100644
--- a/src/components/ble/FSService.h
+++ b/src/components/ble/FSService.h
@@ -14,6 +14,8 @@ namespace Pinetime {
namespace Controllers {
class Ble;
+ class Settings;
+ class NotificationManager;
class FSService {
public:
@@ -26,6 +28,10 @@ namespace Pinetime {
private:
Pinetime::System::SystemTask& systemTask;
Pinetime::Controllers::FS& fs;
+
+ static constexpr const char denyAlert[] = "InfiniTime\0File access attempted, but disabled in settings.";
+ static constexpr const uint8_t denyAlertLength = sizeof(denyAlert); // for this to work denyAlert MUST be array
+
static constexpr uint16_t FSServiceId {0xFEBB};
static constexpr uint16_t fsVersionId {0x0100};
static constexpr uint16_t fsTransferId {0x0200};