|
|
|
//
|
|
|
|
// Created by o.likhogub on 10/7/2023.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "TransmissionModule.h"
|
|
|
|
|
|
|
|
#define MSG_LENGTH 5
|
|
|
|
#define ECC_LENGTH 4
|
|
|
|
#define TOTAL_LENGTH (MSG_LENGTH + ECC_LENGTH)
|
|
|
|
|
|
|
|
void TransmissionModule::transmit(MeasureData &data)
|
|
|
|
{
|
|
|
|
|
|
|
|
size_t posn, len, inc = 5;
|
|
|
|
size_t data_size = 4;
|
|
|
|
cipher->clear();
|
|
|
|
cipher->setKey(encryptionKey, key_size);
|
|
|
|
cipher->setIV(iv, iv_size);
|
|
|
|
memset(buffer, 0xBA, sizeof(buffer));
|
|
|
|
|
|
|
|
for (posn = 0; posn < auth_size; posn += inc) {
|
|
|
|
len = auth_size - posn;
|
|
|
|
if (len > inc)
|
|
|
|
len = inc;
|
|
|
|
cipher->addAuthData(authdata + posn, len);
|
|
|
|
}
|
|
|
|
|
|
|
|
cipher->encrypt(buffer + 1, (uint8_t*)&data, data_size);
|
|
|
|
buffer[0] = data.sensor_id;
|
|
|
|
|
|
|
|
//*************************
|
|
|
|
//Encryption Testing
|
|
|
|
//*************************
|
|
|
|
|
|
|
|
// byte buffer2[MAX_PLAINTEXT_LEN];
|
|
|
|
// memset(buffer2, 0xBA, sizeof(buffer));
|
|
|
|
|
|
|
|
// cipher->setKey(encryptionKey, 16);
|
|
|
|
// cipher->setIV(iv, iv_size);
|
|
|
|
|
|
|
|
// for (posn = 0; posn < data_size; posn += inc) {
|
|
|
|
// len = data_size - posn;
|
|
|
|
// if (len > inc)
|
|
|
|
// len = inc;
|
|
|
|
// cipher->decrypt(buffer2 + posn, buffer + posn, len);
|
|
|
|
// }
|
|
|
|
|
|
|
|
// if (memcmp(buffer2, (uint8_t*)&data + 1, data_size) != 0) {
|
|
|
|
// Serial.println("doesn't work");
|
|
|
|
// } else{
|
|
|
|
// Serial.println("works");
|
|
|
|
// }
|
|
|
|
|
|
|
|
uint8_t encoded[MSG_LENGTH + ECC_LENGTH];
|
|
|
|
reedSolomonModule->encode(buffer, encoded);
|
|
|
|
transmitterModule->send(encoded, MSG_LENGTH + ECC_LENGTH);
|
|
|
|
}
|