Skip to content

Commit

Permalink
Add setting to disable DFU and FS access
Browse files Browse the repository at this point in the history
  • Loading branch information
DavisNT committed Oct 20, 2023
1 parent eac460f commit 7615745
Show file tree
Hide file tree
Showing 17 changed files with 183 additions and 12 deletions.
1 change: 1 addition & 0 deletions src/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -425,6 +425,7 @@ list(APPEND SOURCE_FILES
displayapp/screens/settings/SettingChimes.cpp
displayapp/screens/settings/SettingShakeThreshold.cpp
displayapp/screens/settings/SettingBluetooth.cpp
displayapp/screens/settings/SettingOTA.cpp

## Watch faces
displayapp/screens/WatchFaceAnalog.cpp
Expand Down
20 changes: 19 additions & 1 deletion src/components/ble/DfuService.cpp
Original file line number Diff line number Diff line change
@@ -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>
Expand Down Expand Up @@ -29,9 +31,13 @@ void TimeoutTimerCallback(TimerHandle_t xTimer) {

DfuService::DfuService(Pinetime::System::SystemTask& systemTask,
Pinetime::Controllers::Ble& bleController,
Pinetime::Drivers::SpiNorFlash& spiNorFlash)
Pinetime::Drivers::SpiNorFlash& spiNorFlash,
Pinetime::Controllers::Settings& settingsController,
Pinetime::Controllers::NotificationManager& controllerNotificationManager)
: systemTask {systemTask},
bleController {bleController},
settingsController {settingsController},
controllerNotificationManager {controllerNotificationManager},
dfuImage {spiNorFlash},
characteristicDefinition {{
.uuid = &packetCharacteristicUuid.u,
Expand Down Expand Up @@ -78,6 +84,18 @@ void DfuService::Init() {
}

int DfuService::OnServiceData(uint16_t connectionHandle, uint16_t attributeHandle, ble_gatt_access_ctxt* context) {
#ifndef PINETIME_IS_RECOVERY
if (settingsController.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;
controllerNotificationManager.Push(std::move(notif));
systemTask.PushMessage(Pinetime::System::Messages::OnNewNotification);
return 0;
}
#endif

if (bleController.IsFirmwareUpdating()) {
xTimerStart(timeoutTimer, 0);
}
Expand Down
11 changes: 10 additions & 1 deletion src/components/ble/DfuService.h
Original file line number Diff line number Diff line change
Expand Up @@ -20,12 +20,16 @@ namespace Pinetime {

namespace Controllers {
class Ble;
class Settings;
class NotificationManager;

class DfuService {
public:
DfuService(Pinetime::System::SystemTask& systemTask,
Pinetime::Controllers::Ble& bleController,
Pinetime::Drivers::SpiNorFlash& spiNorFlash);
Pinetime::Drivers::SpiNorFlash& spiNorFlash,
Pinetime::Controllers::Settings& settingsController,
Pinetime::Controllers::NotificationManager& controllerNotificationManager);
void Init();
int OnServiceData(uint16_t connectionHandle, uint16_t attributeHandle, ble_gatt_access_ctxt* context);
void OnTimeout();
Expand Down Expand Up @@ -80,9 +84,14 @@ namespace Pinetime {
private:
Pinetime::System::SystemTask& systemTask;
Pinetime::Controllers::Ble& bleController;
Pinetime::Controllers::Settings& settingsController;
Pinetime::Controllers::NotificationManager& controllerNotificationManager;
DfuImage dfuImage;
NotificationManager notificationManager;

static constexpr const char* denyAlert = "InfiniTime\0Firmware update attempted, but disabled.";
static constexpr const uint8_t denyAlertLength = 52;

static constexpr uint16_t dfuServiceId {0x1530};
static constexpr uint16_t packetCharacteristicId {0x1532};
static constexpr uint16_t controlPointCharacteristicId {0x1531};
Expand Down
21 changes: 20 additions & 1 deletion src/components/ble/FSService.cpp
Original file line number Diff line number Diff line change
@@ -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;
Expand All @@ -14,9 +16,14 @@ int FSServiceCallback(uint16_t conn_handle, uint16_t attr_handle, struct ble_gat
return fsService->OnFSServiceRequested(conn_handle, attr_handle, ctxt);
}

FSService::FSService(Pinetime::System::SystemTask& systemTask, Pinetime::Controllers::FS& fs)
FSService::FSService(Pinetime::System::SystemTask& systemTask,
Pinetime::Controllers::FS& fs,
Pinetime::Controllers::Settings& settingsController,
Pinetime::Controllers::NotificationManager& notificationManager)
: systemTask {systemTask},
fs {fs},
settingsController {settingsController},
notificationManager {notificationManager},
characteristicDefinition {{.uuid = &fsVersionUuid.u,
.access_cb = FSServiceCallback,
.arg = this,
Expand Down Expand Up @@ -49,6 +56,18 @@ void FSService::Init() {
}

int FSService::OnFSServiceRequested(uint16_t connectionHandle, uint16_t attributeHandle, ble_gatt_access_ctxt* context) {
#ifndef PINETIME_IS_RECOVERY
if (settingsController.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;
notificationManager.Push(std::move(notif));
systemTask.PushMessage(Pinetime::System::Messages::OnNewNotification);
return 0;
}
#endif

if (attributeHandle == versionCharacteristicHandle) {
NRF_LOG_INFO("FS_S : handle = %d", versionCharacteristicHandle);
int res = os_mbuf_append(context->om, &fsVersion, sizeof(fsVersion));
Expand Down
13 changes: 12 additions & 1 deletion src/components/ble/FSService.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,15 @@ namespace Pinetime {

namespace Controllers {
class Ble;
class Settings;
class NotificationManager;

class FSService {
public:
FSService(Pinetime::System::SystemTask& systemTask, Pinetime::Controllers::FS& fs);
FSService(Pinetime::System::SystemTask& systemTask,
Pinetime::Controllers::FS& fs,
Pinetime::Controllers::Settings& settingsController,
Pinetime::Controllers::NotificationManager& notificationManager);
void Init();

int OnFSServiceRequested(uint16_t connectionHandle, uint16_t attributeHandle, ble_gatt_access_ctxt* context);
Expand All @@ -26,6 +31,12 @@ namespace Pinetime {
private:
Pinetime::System::SystemTask& systemTask;
Pinetime::Controllers::FS& fs;
Pinetime::Controllers::Settings& settingsController;
Pinetime::Controllers::NotificationManager& notificationManager;

static constexpr const char* denyAlert = "InfiniTime\0File access attempted, but disabled.";
static constexpr const uint8_t denyAlertLength = 48;

static constexpr uint16_t FSServiceId {0xFEBB};
static constexpr uint16_t fsVersionId {0x0100};
static constexpr uint16_t fsTransferId {0x0200};
Expand Down
7 changes: 4 additions & 3 deletions src/components/ble/NimbleController.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,14 @@ NimbleController::NimbleController(Pinetime::System::SystemTask& systemTask,
Pinetime::Drivers::SpiNorFlash& spiNorFlash,
HeartRateController& heartRateController,
MotionController& motionController,
FS& fs)
FS& fs,
Settings& settingsController)
: systemTask {systemTask},
bleController {bleController},
dateTimeController {dateTimeController},
spiNorFlash {spiNorFlash},
fs {fs},
dfuService {systemTask, bleController, spiNorFlash},
dfuService {systemTask, bleController, spiNorFlash, settingsController, notificationManager},

currentTimeClient {dateTimeController},
anService {systemTask, notificationManager},
Expand All @@ -48,7 +49,7 @@ NimbleController::NimbleController(Pinetime::System::SystemTask& systemTask,
immediateAlertService {systemTask, notificationManager},
heartRateService {*this, heartRateController},
motionService {*this, motionController},
fsService {systemTask, fs},
fsService {systemTask, fs, settingsController, notificationManager},
serviceDiscovery({&currentTimeClient, &alertNotificationClient}) {
}

Expand Down
3 changes: 2 additions & 1 deletion src/components/ble/NimbleController.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,8 @@ namespace Pinetime {
Pinetime::Drivers::SpiNorFlash& spiNorFlash,
HeartRateController& heartRateController,
MotionController& motionController,
FS& fs);
FS& fs,
Settings& settingsController);
void Init();
void StartAdvertising();
int OnGAPEvent(ble_gap_event* event);
Expand Down
3 changes: 3 additions & 0 deletions src/components/settings/Settings.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,9 @@ void Settings::LoadSettingsFromFile() {
if (bufferSettings.version == settingsVersion) {
settings = bufferSettings;
}
if (settings.dfuAndFsMode == DfuAndFsMode::EnabledTillReboot) {
settings.dfuAndFsMode = DfuAndFsMode::Disabled;
}
}

void Settings::SaveSettingsToFile() {
Expand Down
16 changes: 15 additions & 1 deletion src/components/settings/Settings.h
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ namespace Pinetime {
};
enum class PTSGaugeStyle : uint8_t { Full, Half, Numeric };
enum class PTSWeather : uint8_t { On, Off };
enum class DfuAndFsMode : uint8_t { Disabled = 0, Enabled = 1, EnabledTillReboot = 2 };

struct PineTimeStyle {
Colors ColorTime = Colors::Teal;
Expand Down Expand Up @@ -271,10 +272,21 @@ namespace Pinetime {
return bleRadioEnabled;
};

void SetDfuAndFsMode(DfuAndFsMode mode) {
if (mode != settings.dfuAndFsMode) {
settingsChanged = true;
}
settings.dfuAndFsMode = mode;
};

DfuAndFsMode GetDfuAndFsMode() const {
return settings.dfuAndFsMode;
};

private:
Pinetime::Controllers::FS& fs;

static constexpr uint32_t settingsVersion = 0x0006;
static constexpr uint32_t settingsVersion = 0x0007;

struct SettingsData {
uint32_t version = settingsVersion;
Expand All @@ -295,6 +307,8 @@ namespace Pinetime {
uint16_t shakeWakeThreshold = 150;

Controllers::BrightnessController::Levels brightLevel = Controllers::BrightnessController::Levels::Medium;

DfuAndFsMode dfuAndFsMode = DfuAndFsMode::Disabled;
};

SettingsData settings;
Expand Down
1 change: 1 addition & 0 deletions src/displayapp/Apps.h
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ namespace Pinetime {
SettingChimes,
SettingShakeThreshold,
SettingBluetooth,
SettingOTA,
Error
};
}
Expand Down
4 changes: 4 additions & 0 deletions src/displayapp/DisplayApp.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@
#include "displayapp/screens/settings/SettingChimes.h"
#include "displayapp/screens/settings/SettingShakeThreshold.h"
#include "displayapp/screens/settings/SettingBluetooth.h"
#include "displayapp/screens/settings/SettingOTA.h"

#include "libs/lv_conf.h"

Expand Down Expand Up @@ -500,6 +501,9 @@ void DisplayApp::LoadScreen(Apps app, DisplayApp::FullRefreshDirections directio
case Apps::SettingBluetooth:
currentScreen = std::make_unique<Screens::SettingBluetooth>(this, settingsController);
break;
case Apps::SettingOTA:
currentScreen = std::make_unique<Screens::SettingOTA>(this, settingsController);
break;
case Apps::BatteryInfo:
currentScreen = std::make_unique<Screens::BatteryInfo>(batteryController);
break;
Expand Down
2 changes: 1 addition & 1 deletion src/displayapp/fonts/fonts.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
},
{
"file": "FontAwesome5-Solid+Brands+Regular.woff",
"range": "0xf294, 0xf242, 0xf54b, 0xf21e, 0xf1e6, 0xf017, 0xf129, 0xf03a, 0xf185, 0xf560, 0xf001, 0xf3fd, 0xf1fc, 0xf45d, 0xf59f, 0xf5a0, 0xf027, 0xf028, 0xf6a9, 0xf04b, 0xf04c, 0xf048, 0xf051, 0xf095, 0xf3dd, 0xf04d, 0xf2f2, 0xf024, 0xf252, 0xf569, 0xf06e, 0xf015, 0xf00c"
"range": "0xf294, 0xf242, 0xf54b, 0xf21e, 0xf1e6, 0xf017, 0xf129, 0xf03a, 0xf185, 0xf560, 0xf001, 0xf3fd, 0xf1fc, 0xf45d, 0xf59f, 0xf5a0, 0xf027, 0xf028, 0xf6a9, 0xf04b, 0xf04c, 0xf048, 0xf051, 0xf095, 0xf3dd, 0xf04d, 0xf2f2, 0xf024, 0xf252, 0xf569, 0xf06e, 0xf015, 0xf00c, 0xf3ed"
}
],
"bpp": 1,
Expand Down
1 change: 1 addition & 0 deletions src/displayapp/screens/Symbols.h
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ namespace Pinetime {
static constexpr const char* batteryHalf = "\xEF\x89\x82";
static constexpr const char* heartBeat = "\xEF\x88\x9E";
static constexpr const char* bluetooth = "\xEF\x8A\x94";
static constexpr const char* shieldAlt = "\xEF\x8F\xAD";
static constexpr const char* plug = "\xEF\x87\xA6";
static constexpr const char* shoe = "\xEF\x95\x8B";
static constexpr const char* clock = "\xEF\x80\x97";
Expand Down
57 changes: 57 additions & 0 deletions src/displayapp/screens/settings/SettingOTA.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
#include "displayapp/screens/settings/SettingOTA.h"
#include <lvgl/lvgl.h>
#include "displayapp/DisplayApp.h"
#include "displayapp/Messages.h"
#include "displayapp/screens/Styles.h"
#include "displayapp/screens/Screen.h"
#include "displayapp/screens/Symbols.h"

using namespace Pinetime::Applications::Screens;

namespace {
struct Option {
const char* name;
Pinetime::Controllers::Settings::DfuAndFsMode mode;
};

constexpr std::array<Option, 3> options = {{
{"Enabled", Pinetime::Controllers::Settings::DfuAndFsMode::Enabled},
{"Disabled", Pinetime::Controllers::Settings::DfuAndFsMode::Disabled},
{"Till reboot", Pinetime::Controllers::Settings::DfuAndFsMode::EnabledTillReboot},
}};

std::array<CheckboxList::Item, CheckboxList::MaxItems> CreateOptionArray() {
std::array<Pinetime::Applications::Screens::CheckboxList::Item, CheckboxList::MaxItems> optionArray;
for (size_t i = 0; i < CheckboxList::MaxItems; i++) {
if (i >= options.size()) {
optionArray[i].name = "";
optionArray[i].enabled = false;
} else {
optionArray[i].name = options[i].name;
optionArray[i].enabled = true;
}
}
return optionArray;
};
}

SettingOTA::SettingOTA(Pinetime::Applications::DisplayApp* app, Pinetime::Controllers::Settings& settingsController)
: app {app},
settingsController {settingsController},
checkboxList(
0,
1,
"Firmware & files",
Symbols::shieldAlt,
settingsController.GetDfuAndFsMode() == Pinetime::Controllers::Settings::DfuAndFsMode::Enabled ? 0 :
settingsController.GetDfuAndFsMode() == Pinetime::Controllers::Settings::DfuAndFsMode::EnabledTillReboot ? 2 : 1,
[&settings = settingsController](uint32_t index) {
settings.SetDfuAndFsMode(options[index].mode);
},
CreateOptionArray()) {
}

SettingOTA::~SettingOTA() {
lv_obj_clean(lv_scr_act());
settingsController.SaveSettings();
}
28 changes: 28 additions & 0 deletions src/displayapp/screens/settings/SettingOTA.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
#pragma once

#include <array>
#include <cstdint>
#include <lvgl/lvgl.h>

#include "components/settings/Settings.h"
#include "displayapp/screens/Screen.h"
#include "displayapp/screens/CheckboxList.h"

namespace Pinetime {

namespace Applications {
namespace Screens {

class SettingOTA : public Screen {
public:
SettingOTA(DisplayApp* app, Pinetime::Controllers::Settings& settingsController);
~SettingOTA() override;

private:
DisplayApp* app;
Pinetime::Controllers::Settings& settingsController;
CheckboxList checkboxList;
};
}
}
}
4 changes: 3 additions & 1 deletion src/displayapp/screens/settings/Settings.h
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ namespace Pinetime {
static constexpr int entriesPerScreen = 4;

// Increment this when more space is needed
static constexpr int nScreens = 3;
static constexpr int nScreens = 4;

static constexpr std::array<List::Applications, entriesPerScreen * nScreens> entries {{
{Symbols::sun, "Display", Apps::SettingDisplay},
Expand All @@ -44,7 +44,9 @@ namespace Pinetime {

{Symbols::tachometer, "Shake Calib.", Apps::SettingShakeThreshold},
{Symbols::check, "Firmware", Apps::FirmwareValidation},
{Symbols::shieldAlt, "Over-the-air", Apps::SettingOTA},
{Symbols::bluetooth, "Bluetooth", Apps::SettingBluetooth},

{Symbols::list, "About", Apps::SysInfo},

// {Symbols::none, "None", Apps::None},
Expand Down
Loading

0 comments on commit 7615745

Please sign in to comment.