refactor
033zhek 1 year ago
parent 2efc7889a5
commit f918be204c

@ -8,8 +8,22 @@
#define ECC_LENGTH 4
#define TOTAL_LENGTH (MSG_LENGTH + ECC_LENGTH)
void TransmissionModule::decrypt(uint8_t *data, size_t data_size, uint8_t *output_data)
bool TransmissionModule::receive(uint8_t &sensor_id, MeasureData &data)
{
uint8_t buf[TOTAL_LENGTH];
if (!transmitterModule->receive(buf, TOTAL_LENGTH)) {
return false;
}
uint8_t msg[MSG_LENGTH];
if (!reedSolomonModule->decode(buf, msg)) {
return false;
}
sensor_id = msg[0];
size_t posn, len, inc = 5;
cipher->clear();
cipher->setKey(encryptionKey, key_size);
@ -23,30 +37,16 @@ void TransmissionModule::decrypt(uint8_t *data, size_t data_size, uint8_t *outpu
cipher->addAuthData(authdata + posn, len);
}
size_t data_size = 4;
for (posn = 0; posn < data_size; posn += inc) {
len = data_size - posn;
if (len > inc)
len = inc;
cipher->decrypt(buffer + posn, data + posn, len);
cipher->decrypt(buffer + posn, msg + 1 + posn, len);
}
memcpy(output_data, buffer, data_size);
}
bool TransmissionModule::receive(uint8_t &sensor_id, MeasureData &data)
{
uint8_t buf[TOTAL_LENGTH];
if (!transmitterModule->receive(buf, TOTAL_LENGTH)) {
return false;
}
uint8_t msg[MSG_LENGTH];
if (!reedSolomonModule->decode(buf, msg)) {
return false;
}
sensor_id = msg[0];
memcpy((void *) &data, msg+1, 4);
memcpy((void *) &data, buffer, 4);
return true;
}

@ -33,7 +33,6 @@ public:
reedSolomonModule(&reedSolomonModule) {
cipher = new ChaChaPoly();
}
void decrypt(uint8_t * data, size_t data_size, uint8_t* output_data);
bool receive(uint8_t &sendor_id, MeasureData &data);
};

Loading…
Cancel
Save