// // 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); } for (posn = 0; posn < data_size; posn += inc) { len = data_size - posn; if (len > inc) len = inc; cipher->encrypt(buffer + posn, (uint8_t*)&data + 1 + posn, len); } //************************* //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 msg[MSG_LENGTH]; msg[0] = data.sensor_id; memcpy(msg + 1, (void *) &data, 4); uint8_t encoded[MSG_LENGTH + ECC_LENGTH]; reedSolomonModule->encode(msg, encoded); transmitterModule->send(encoded, MSG_LENGTH + ECC_LENGTH); }