mirror of
https://github.com/CovidBraceletPrj/CovidBracelet.git
synced 2025-01-06 19:34:24 +01:00
Use record_t for storing contacts
This commit is contained in:
parent
9ae226d50b
commit
c8607507b7
21
src/covid.c
21
src/covid.c
@ -17,6 +17,7 @@
|
||||
#include "covid_types.h"
|
||||
#include "contacts.h"
|
||||
#include "covid.h"
|
||||
#include "ens/storage.h"
|
||||
|
||||
#ifndef COVID_MEASURE_PERFORMANCE
|
||||
#define COVID_MEASURE_PERFORMANCE 0
|
||||
@ -74,7 +75,16 @@ static void scan_cb(const bt_addr_le_t *addr, int8_t rssi, uint8_t adv_type, str
|
||||
covid_adv_svd_t *rx_adv = (covid_adv_svd_t *)buf->data;
|
||||
if (rx_adv->ens == COVID_ENS)
|
||||
{
|
||||
check_add_contact(k_uptime_get() / 1000, &rx_adv->rolling_proximity_identifier, &rx_adv->associated_encrypted_metadata, rssi);
|
||||
printk("Attempting to store contact...\n");
|
||||
record_t contact;
|
||||
uint32_t timestamp = k_uptime_get() / 1000;
|
||||
memcpy(&contact.rssi, &rssi, sizeof(contact.rssi));
|
||||
memcpy(&contact.associated_encrypted_metadata, &rx_adv->associated_encrypted_metadata, sizeof(contact.associated_encrypted_metadata));
|
||||
memcpy(&contact.rolling_proximity_identifier, &rx_adv->rolling_proximity_identifier, sizeof(contact.rolling_proximity_identifier));
|
||||
memcpy(&contact.timestamp, ×tamp, sizeof(contact.timestamp));
|
||||
int rc = add_contact(&contact);
|
||||
printk("Contact stored (err %d)\n", rc);
|
||||
// check_add_contact(k_uptime_get() / 1000, &rx_adv->rolling_proximity_identifier, &rx_adv->associated_encrypted_metadata, rssi);
|
||||
}
|
||||
}
|
||||
net_buf_simple_pull(buf, len - 1); //consume the rest, note we already consumed one byte via net_buf_simple_pull_u8(buf)
|
||||
@ -312,10 +322,11 @@ static void check_keys(struct k_work *work)
|
||||
memcpy(&covid_adv_svd.rolling_proximity_identifier, &intervalIdentifier, sizeof(rolling_proximity_identifier_t));
|
||||
memcpy(&covid_adv_svd.associated_encrypted_metadata, &encryptedMetadata, sizeof(associated_encrypted_metadata_t));
|
||||
|
||||
if (!init)
|
||||
{
|
||||
key_change(current_period_index);
|
||||
}
|
||||
// // TODO lome: remove this?
|
||||
// if (!init)
|
||||
// {
|
||||
// key_change(current_period_index);
|
||||
// }
|
||||
init = 0;
|
||||
}
|
||||
}
|
||||
|
@ -24,7 +24,7 @@ record_t* ens_records_iterator_next(record_iterator_t* iter) {
|
||||
|
||||
// What is this?
|
||||
while (next == NULL) {
|
||||
contact_t contact;
|
||||
record_t contact;
|
||||
// try to load the next contact
|
||||
int res = load_contact(&contact, iter->sn_next);
|
||||
|
||||
@ -32,7 +32,7 @@ record_t* ens_records_iterator_next(record_iterator_t* iter) {
|
||||
next = &iter->current;
|
||||
memcpy(&next->associated_encrypted_metadata, &contact.associated_encrypted_metadata, sizeof(associated_encrypted_metadata_t));
|
||||
memcpy(&next->rolling_proximity_identifier, &contact.rolling_proximity_identifier, sizeof(rolling_proximity_identifier_t));
|
||||
memcpy(&next->rssi, &contact.max_rssi, sizeof(rssi_t));
|
||||
memcpy(&next->rssi, &contact.rssi, sizeof(rssi_t));
|
||||
memcpy(&next->sn, &iter->sn_next, sizeof(record_sequence_number_t));
|
||||
|
||||
// TODO lome: timestamp?
|
||||
|
@ -10,14 +10,6 @@
|
||||
#include "sequencenumber.h"
|
||||
#include "storage.h"
|
||||
|
||||
typedef struct record {
|
||||
record_sequence_number_t sn; // TODO: Convert Sequence Number
|
||||
uint32_t timestamp; // TODO: Seconds from january first 2000 (UTC+0)
|
||||
rssi_t rssi; // TODO: Check correct
|
||||
rolling_proximity_identifier_t rolling_proximity_identifier;
|
||||
associated_encrypted_metadata_t associated_encrypted_metadata;
|
||||
} record_t;
|
||||
|
||||
typedef struct record_iterator {
|
||||
record_t current;
|
||||
record_sequence_number_t sn_next;
|
||||
|
@ -107,7 +107,7 @@ int init_contact_storage(void) {
|
||||
return rc;
|
||||
}
|
||||
|
||||
int load_contact(contact_t* dest, record_sequence_number_t sn) {
|
||||
int load_contact(record_t* dest, record_sequence_number_t sn) {
|
||||
storage_id_t id = convert_sn_to_storage_id(sn);
|
||||
// int rc = nvs_read(&info_fs, id, dest, sizeof(*dest));
|
||||
int rc = ens_fs_read(&ens_fs, id, dest);
|
||||
@ -117,7 +117,7 @@ int load_contact(contact_t* dest, record_sequence_number_t sn) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
int add_contact(contact_t* src) {
|
||||
int add_contact(record_t* src) {
|
||||
|
||||
// Check, if next sn would be at start of page
|
||||
record_sequence_number_t potential_next_sn = sn_increment(get_latest_sequence_number());
|
||||
@ -129,6 +129,7 @@ int add_contact(contact_t* src) {
|
||||
|
||||
// Actually increment sn
|
||||
record_sequence_number_t curr_sn = get_next_sequence_number();
|
||||
src->sn = curr_sn;
|
||||
storage_id_t id = convert_sn_to_storage_id(curr_sn);
|
||||
|
||||
int rc = ens_fs_write(&ens_fs, id, src);
|
||||
@ -138,21 +139,20 @@ int add_contact(contact_t* src) {
|
||||
return rc;
|
||||
}
|
||||
|
||||
// TODO lome: Implement delete flag in ens_fs.c
|
||||
int delete_contact(record_sequence_number_t sn) {
|
||||
// storage_id_t id = convert_sn_to_storage_id(sn);
|
||||
// int rc = nvs_delete(&info_fs, id);
|
||||
// if (!rc) {
|
||||
// if (sn_equal(sn, get_latest_sequence_number())) {
|
||||
// contact_information.count--;
|
||||
// } else if (sn_equal(sn, get_oldest_sequence_number())) {
|
||||
// contact_information.oldest_contact = sn_increment(contact_information.oldest_contact);
|
||||
// contact_information.count--;
|
||||
// }
|
||||
// save_storage_information();
|
||||
// }
|
||||
// return rc;
|
||||
return 0;
|
||||
// TODO lome: Use lock
|
||||
storage_id_t id = convert_sn_to_storage_id(sn);
|
||||
int rc = ens_fs_delete(&ens_fs, id);
|
||||
if (!rc) {
|
||||
if (sn_equal(sn, get_latest_sequence_number())) {
|
||||
contact_information.count--;
|
||||
} else if (sn_equal(sn, get_oldest_sequence_number())) {
|
||||
contact_information.oldest_contact = sn_increment(contact_information.oldest_contact);
|
||||
contact_information.count--;
|
||||
}
|
||||
save_storage_information();
|
||||
}
|
||||
return rc;
|
||||
}
|
||||
|
||||
record_sequence_number_t get_latest_sequence_number() {
|
||||
|
@ -6,6 +6,15 @@
|
||||
|
||||
typedef uint16_t storage_id_t;
|
||||
|
||||
// TODO lome: own datatype for storage
|
||||
typedef struct record {
|
||||
record_sequence_number_t sn; // TODO: Convert Sequence Number
|
||||
uint32_t timestamp; // TODO: Seconds from january first 2000 (UTC+0)
|
||||
rssi_t rssi; // TODO: Check correct
|
||||
rolling_proximity_identifier_t rolling_proximity_identifier;
|
||||
associated_encrypted_metadata_t associated_encrypted_metadata;
|
||||
} record_t;
|
||||
|
||||
typedef struct stored_contacts_information {
|
||||
record_sequence_number_t oldest_contact;
|
||||
record_sequence_number_t count;
|
||||
@ -23,7 +32,7 @@ int init_contact_storage();
|
||||
* @param sn
|
||||
* @return 0 in case of success
|
||||
*/
|
||||
int load_contact(contact_t* dest, record_sequence_number_t sn);
|
||||
int load_contact(record_t* dest, record_sequence_number_t sn);
|
||||
|
||||
/**
|
||||
* Stores the contact from src with number sn, increases latest sequence number
|
||||
@ -31,7 +40,7 @@ int load_contact(contact_t* dest, record_sequence_number_t sn);
|
||||
* @param src
|
||||
* @return 0 in case of success
|
||||
*/
|
||||
int add_contact(contact_t* src);
|
||||
int add_contact(record_t* src);
|
||||
|
||||
/**
|
||||
* Deletes the contact from storage with number sn
|
||||
|
Loading…
x
Reference in New Issue
Block a user