mirror of
https://github.com/meshcore-dev/MeshCore.git
synced 2026-04-20 22:13:47 +00:00
* new nRF52 impl for advert blobs
This commit is contained in:
parent
6e0b505a2a
commit
dd808ee6c7
3 changed files with 102 additions and 37 deletions
|
|
@ -12,13 +12,28 @@ DataStore::DataStore(FILESYSTEM& fs) : _fs(&fs),
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static File openWrite(FILESYSTEM* _fs, const char* filename) {
|
||||||
|
#if defined(NRF52_PLATFORM) || defined(STM32_PLATFORM)
|
||||||
|
_fs->remove(filename);
|
||||||
|
return _fs->open(filename, FILE_O_WRITE);
|
||||||
|
#elif defined(RP2040_PLATFORM)
|
||||||
|
return _fs->open(filename, "w");
|
||||||
|
#else
|
||||||
|
return _fs->open(filename, "w", true);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
void DataStore::begin() {
|
void DataStore::begin() {
|
||||||
#if defined(RP2040_PLATFORM)
|
#if defined(RP2040_PLATFORM)
|
||||||
identity_store.begin();
|
identity_store.begin();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(NRF52_PLATFORM) || defined(STM32_PLATFORM)
|
||||||
|
checkAdvBlobFile();
|
||||||
|
#else
|
||||||
// init 'blob store' support
|
// init 'blob store' support
|
||||||
_fs->mkdir("/bl");
|
_fs->mkdir("/bl");
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(ESP32)
|
#if defined(ESP32)
|
||||||
|
|
@ -90,14 +105,7 @@ void DataStore::loadPrefsInt(const char *filename, NodePrefs& _prefs, double& no
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataStore::savePrefs(const NodePrefs& _prefs, double node_lat, double node_lon) {
|
void DataStore::savePrefs(const NodePrefs& _prefs, double node_lat, double node_lon) {
|
||||||
#if defined(NRF52_PLATFORM) || defined(STM32_PLATFORM)
|
File file = openWrite(_fs, "/new_prefs");
|
||||||
_fs->remove("/new_prefs");
|
|
||||||
File file = _fs->open("/new_prefs", FILE_O_WRITE);
|
|
||||||
#elif defined(RP2040_PLATFORM)
|
|
||||||
File file = _fs->open("/new_prefs", "w");
|
|
||||||
#else
|
|
||||||
File file = _fs->open("/new_prefs", "w", true);
|
|
||||||
#endif
|
|
||||||
if (file) {
|
if (file) {
|
||||||
uint8_t pad[8];
|
uint8_t pad[8];
|
||||||
memset(pad, 0, sizeof(pad));
|
memset(pad, 0, sizeof(pad));
|
||||||
|
|
@ -163,14 +171,7 @@ void DataStore::loadContacts(DataStoreHost* host) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataStore::saveContacts(DataStoreHost* host) {
|
void DataStore::saveContacts(DataStoreHost* host) {
|
||||||
#if defined(NRF52_PLATFORM) || defined(STM32_PLATFORM)
|
File file = openWrite(_fs, "/contacts3");
|
||||||
_fs->remove("/contacts3");
|
|
||||||
File file = _fs->open("/contacts3", FILE_O_WRITE);
|
|
||||||
#elif defined(RP2040_PLATFORM)
|
|
||||||
File file = _fs->open("/contacts3", "w");
|
|
||||||
#else
|
|
||||||
File file = _fs->open("/contacts3", "w", true);
|
|
||||||
#endif
|
|
||||||
if (file) {
|
if (file) {
|
||||||
uint32_t idx = 0;
|
uint32_t idx = 0;
|
||||||
ContactInfo c;
|
ContactInfo c;
|
||||||
|
|
@ -230,14 +231,7 @@ void DataStore::loadChannels(DataStoreHost* host) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataStore::saveChannels(DataStoreHost* host) {
|
void DataStore::saveChannels(DataStoreHost* host) {
|
||||||
#if defined(NRF52_PLATFORM) || defined(STM32_PLATFORM)
|
File file = openWrite(_fs, "/channels2");
|
||||||
_fs->remove("/channels2");
|
|
||||||
File file = _fs->open("/channels2", FILE_O_WRITE);
|
|
||||||
#elif defined(RP2040_PLATFORM)
|
|
||||||
File file = _fs->open("/channels2", "w");
|
|
||||||
#else
|
|
||||||
File file = _fs->open("/channels2", "w", true);
|
|
||||||
#endif
|
|
||||||
if (file) {
|
if (file) {
|
||||||
uint8_t channel_idx = 0;
|
uint8_t channel_idx = 0;
|
||||||
ChannelDetails ch;
|
ChannelDetails ch;
|
||||||
|
|
@ -256,7 +250,79 @@ void DataStore::saveChannels(DataStoreHost* host) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int DataStore::getBlobByKey(const uint8_t key[], int key_len, uint8_t dest_buf[]) {
|
#if defined(NRF52_PLATFORM) || defined(STM32_PLATFORM)
|
||||||
|
|
||||||
|
#define MAX_ADVERT_PKT_LEN (PUB_KEY_SIZE + 4 + SIGNATURE_SIZE + MAX_ADVERT_DATA_SIZE)
|
||||||
|
|
||||||
|
void DataStore::checkAdvBlobFile() {
|
||||||
|
if (!_fs->exists("/adv_blobs")) {
|
||||||
|
File file = openWrite(_fs, "/adv_blobs");
|
||||||
|
if (file) {
|
||||||
|
uint8_t zeroes[1 + MAX_ADVERT_PKT_LEN];
|
||||||
|
memset(zeroes, 0, sizeof(zeroes));
|
||||||
|
for (int i = 0; i < 24; i++) { // pre-allocate to fixed size
|
||||||
|
file.write(zeroes, sizeof(zeroes));
|
||||||
|
}
|
||||||
|
file.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t DataStore::getBlobByKey(const uint8_t key[], int key_len, uint8_t dest_buf[]) {
|
||||||
|
File file = _fs->open("/adv_blobs");
|
||||||
|
uint8_t len = 0; // 0 = not found
|
||||||
|
if (file) {
|
||||||
|
uint8_t tmp[1 + MAX_ADVERT_PKT_LEN];
|
||||||
|
while (file.read(tmp, sizeof(tmp)) == sizeof(tmp)) {
|
||||||
|
if (memcmp(key, &tmp[1], PUB_KEY_SIZE) == 0) { // public key is first 32 bytes of advert blob
|
||||||
|
len = tmp[0];
|
||||||
|
memcpy(dest_buf, &tmp[1], len);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
file.close();
|
||||||
|
}
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool DataStore::putBlobByKey(const uint8_t key[], int key_len, const uint8_t src_buf[], uint8_t len) {
|
||||||
|
if (len < PUB_KEY_SIZE+4+SIGNATURE_SIZE || len > MAX_ADVERT_PKT_LEN) return false;
|
||||||
|
|
||||||
|
checkAdvBlobFile();
|
||||||
|
|
||||||
|
File file = _fs->open("/adv_blobs", FILE_O_WRITE);
|
||||||
|
if (file) {
|
||||||
|
uint32_t pos = 0, found_pos = 0;
|
||||||
|
uint32_t min_timestamp = 0xFFFFFFFF;
|
||||||
|
|
||||||
|
// search for matching key OR evict by oldest timestmap
|
||||||
|
uint8_t tmp[1 + MAX_ADVERT_PKT_LEN];
|
||||||
|
while (file.read(tmp, sizeof(tmp)) == sizeof(tmp)) {
|
||||||
|
if (memcmp(src_buf, &tmp[1], PUB_KEY_SIZE) == 0) { // public key is first 32 bytes of advert blob
|
||||||
|
found_pos = pos;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
uint32_t timestamp;
|
||||||
|
memcpy(×tamp, &tmp[1 + PUB_KEY_SIZE], 4);
|
||||||
|
if (timestamp < min_timestamp) {
|
||||||
|
min_timestamp = timestamp;
|
||||||
|
found_pos = pos;
|
||||||
|
}
|
||||||
|
|
||||||
|
pos += sizeof(tmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
file.seek(found_pos);
|
||||||
|
file.write(&len, 1);
|
||||||
|
file.write(src_buf, len);
|
||||||
|
|
||||||
|
file.close();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false; // error
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
uint8_t DataStore::getBlobByKey(const uint8_t key[], int key_len, uint8_t dest_buf[]) {
|
||||||
char path[64];
|
char path[64];
|
||||||
char fname[18];
|
char fname[18];
|
||||||
|
|
||||||
|
|
@ -279,7 +345,7 @@ int DataStore::getBlobByKey(const uint8_t key[], int key_len, uint8_t dest_buf[]
|
||||||
return 0; // not found
|
return 0; // not found
|
||||||
}
|
}
|
||||||
|
|
||||||
bool DataStore::putBlobByKey(const uint8_t key[], int key_len, const uint8_t src_buf[], int len) {
|
bool DataStore::putBlobByKey(const uint8_t key[], int key_len, const uint8_t src_buf[], uint8_t len) {
|
||||||
char path[64];
|
char path[64];
|
||||||
char fname[18];
|
char fname[18];
|
||||||
|
|
||||||
|
|
@ -287,14 +353,7 @@ bool DataStore::putBlobByKey(const uint8_t key[], int key_len, const uint8_t src
|
||||||
mesh::Utils::toHex(fname, key, key_len);
|
mesh::Utils::toHex(fname, key, key_len);
|
||||||
sprintf(path, "/bl/%s", fname);
|
sprintf(path, "/bl/%s", fname);
|
||||||
|
|
||||||
#if defined(NRF52_PLATFORM) || defined(STM32_PLATFORM)
|
File f = openWrite(_fs, path);
|
||||||
_fs->remove(path);
|
|
||||||
File f = _fs->open(path, FILE_O_WRITE);
|
|
||||||
#elif defined(RP2040_PLATFORM)
|
|
||||||
File f = _fs->open(path, "w");
|
|
||||||
#else
|
|
||||||
File f = _fs->open(path, "w", true);
|
|
||||||
#endif
|
|
||||||
if (f) {
|
if (f) {
|
||||||
int n = f.write(src_buf, len);
|
int n = f.write(src_buf, len);
|
||||||
f.close();
|
f.close();
|
||||||
|
|
@ -304,3 +363,4 @@ bool DataStore::putBlobByKey(const uint8_t key[], int key_len, const uint8_t src
|
||||||
}
|
}
|
||||||
return false; // error
|
return false; // error
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -18,8 +18,11 @@ class DataStore {
|
||||||
IdentityStore identity_store;
|
IdentityStore identity_store;
|
||||||
|
|
||||||
void loadPrefsInt(const char *filename, NodePrefs& prefs, double& node_lat, double& node_lon);
|
void loadPrefsInt(const char *filename, NodePrefs& prefs, double& node_lat, double& node_lon);
|
||||||
|
#if defined(NRF52_PLATFORM) || defined(STM32_PLATFORM)
|
||||||
|
void checkAdvBlobFile();
|
||||||
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
DataStore(FILESYSTEM& fs);
|
DataStore(FILESYSTEM& fs);
|
||||||
void begin();
|
void begin();
|
||||||
bool formatFileSystem();
|
bool formatFileSystem();
|
||||||
|
|
@ -31,6 +34,6 @@ class DataStore {
|
||||||
void saveContacts(DataStoreHost* host);
|
void saveContacts(DataStoreHost* host);
|
||||||
void loadChannels(DataStoreHost* host);
|
void loadChannels(DataStoreHost* host);
|
||||||
void saveChannels(DataStoreHost* host);
|
void saveChannels(DataStoreHost* host);
|
||||||
int getBlobByKey(const uint8_t key[], int key_len, uint8_t dest_buf[]);
|
uint8_t getBlobByKey(const uint8_t key[], int key_len, uint8_t dest_buf[]);
|
||||||
bool putBlobByKey(const uint8_t key[], int key_len, const uint8_t src_buf[], int len);
|
bool putBlobByKey(const uint8_t key[], int key_len, const uint8_t src_buf[], uint8_t len);
|
||||||
};
|
};
|
||||||
|
|
|
||||||
|
|
@ -1291,7 +1291,9 @@ void MyMesh::checkCLIRescueCmd() {
|
||||||
bool success = _store->formatFileSystem();
|
bool success = _store->formatFileSystem();
|
||||||
if (success) {
|
if (success) {
|
||||||
_store->saveMainIdentity(self_id);
|
_store->saveMainIdentity(self_id);
|
||||||
|
savePrefs();
|
||||||
saveContacts();
|
saveContacts();
|
||||||
|
saveChannels();
|
||||||
Serial.println(" > erase and rebuild done");
|
Serial.println(" > erase and rebuild done");
|
||||||
} else {
|
} else {
|
||||||
Serial.println(" Error: erase failed");
|
Serial.println(" Error: erase failed");
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue