- Refactor `AppManifest`: add new fields and rename existing ones - Parse and validate the manifest from an app that is being installed. - Remove deprecated `scoped()` from `Lock` - Create `Tactility/Paths.h` - App loading at boot now properly parses the manifest files of external apps - Properly lock both source and destination locations during app install - Remove LVGL path variants from `AppPaths` and `ServicePaths` - Removed `xPath` base classes for apps and services. There's now `AppPaths` and `ServicePaths`. - Renamed app and service paths: "data" and "system" paths are now "user data" and "assets"
118 lines
3.3 KiB
C++
118 lines
3.3 KiB
C++
#include <Tactility/file/ObjectFile.h>
|
|
#include <Tactility/service/gps/GpsService.h>
|
|
#include <Tactility/service/ServicePaths.h>
|
|
|
|
#include <cstring>
|
|
#include <unistd.h>
|
|
|
|
using tt::hal::gps::GpsDevice;
|
|
|
|
namespace tt::service::gps {
|
|
|
|
constexpr const char* TAG = "GpsService";
|
|
|
|
bool GpsService::getConfigurationFilePath(std::string& output) const {
|
|
if (paths == nullptr) {
|
|
TT_LOG_E(TAG, "Can't add configuration: service not started");
|
|
return false;
|
|
}
|
|
|
|
if (!file::findOrCreateDirectory(paths->getUserDataDirectory(), 0777)) {
|
|
TT_LOG_E(TAG, "Failed to find or create path %s", paths->getUserDataDirectory().c_str());
|
|
return false;
|
|
}
|
|
|
|
output = paths->getUserDataPath("config.bin");
|
|
return true;
|
|
}
|
|
|
|
bool GpsService::getGpsConfigurations(std::vector<hal::gps::GpsConfiguration>& configurations) const {
|
|
std::string path;
|
|
if (!getConfigurationFilePath(path)) {
|
|
return false;
|
|
}
|
|
|
|
// If file does not exist, return empty list
|
|
if (access(path.c_str(), F_OK) != 0) {
|
|
TT_LOG_W(TAG, "No configurations (file not found: %s)", path.c_str());
|
|
return true;
|
|
}
|
|
|
|
TT_LOG_I(TAG, "Reading configuration file %s", path.c_str());
|
|
auto reader = file::ObjectFileReader(path, sizeof(hal::gps::GpsConfiguration));
|
|
if (!reader.open()) {
|
|
TT_LOG_E(TAG, "Failed to open configuration file");
|
|
return false;
|
|
}
|
|
|
|
hal::gps::GpsConfiguration configuration;
|
|
while (reader.hasNext()) {
|
|
if (!reader.readNext(&configuration)) {
|
|
TT_LOG_E(TAG, "Failed to read configuration");
|
|
reader.close();
|
|
return false;
|
|
} else {
|
|
configurations.push_back(configuration);
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
bool GpsService::addGpsConfiguration(hal::gps::GpsConfiguration configuration) {
|
|
std::string path;
|
|
if (!getConfigurationFilePath(path)) {
|
|
return false;
|
|
}
|
|
|
|
auto appender = file::ObjectFileWriter(path, sizeof(hal::gps::GpsConfiguration), 1, true);
|
|
if (!appender.open()) {
|
|
TT_LOG_E(TAG, "Failed to open/create configuration file");
|
|
return false;
|
|
}
|
|
|
|
if (!appender.write(&configuration)) {
|
|
TT_LOG_E(TAG, "Failed to add configuration");
|
|
appender.close();
|
|
return false;
|
|
}
|
|
|
|
appender.close();
|
|
return true;
|
|
}
|
|
|
|
bool GpsService::removeGpsConfiguration(hal::gps::GpsConfiguration configuration) {
|
|
std::string path;
|
|
if (!getConfigurationFilePath(path)) {
|
|
return false;
|
|
}
|
|
|
|
std::vector<hal::gps::GpsConfiguration> configurations;
|
|
if (!getGpsConfigurations(configurations)) {
|
|
TT_LOG_E(TAG, "Failed to get gps configurations");
|
|
return false;
|
|
}
|
|
|
|
auto count = std::erase_if(configurations, [&configuration](auto& item) {
|
|
return strcmp(item.uartName, configuration.uartName) == 0 &&
|
|
item.baudRate == configuration.baudRate &&
|
|
item.model == configuration.model;
|
|
});
|
|
|
|
auto writer = file::ObjectFileWriter(path, sizeof(hal::gps::GpsConfiguration), 1, false);
|
|
if (!writer.open()) {
|
|
TT_LOG_E(TAG, "Failed to open configuration file");
|
|
return false;
|
|
}
|
|
|
|
for (auto& configuration : configurations) {
|
|
writer.write(&configuration);
|
|
}
|
|
|
|
writer.close();
|
|
|
|
return count > 0;
|
|
}
|
|
|
|
} // namespace tt::service::gps
|