2025-09-21 17:40:26 -04:00
|
|
|
|
#pragma once
|
2025-09-26 00:28:25 -04:00
|
|
|
|
#include "mesh/generated/meshtastic/mesh.pb.h"
|
2025-09-21 17:40:26 -04:00
|
|
|
|
#include <cstdint>
|
|
|
|
|
|
#include <deque>
|
|
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
|
|
|
|
// Max number of messages we’ll keep in history
|
|
|
|
|
|
constexpr size_t MAX_MESSAGES_SAVED = 20;
|
|
|
|
|
|
constexpr size_t MAX_MESSAGE_SIZE = 220; // safe bound for text payload
|
|
|
|
|
|
|
|
|
|
|
|
// Explicit message classification
|
|
|
|
|
|
enum class MessageType : uint8_t { BROADCAST = 0, DM_TO_US = 1 };
|
|
|
|
|
|
|
|
|
|
|
|
struct StoredMessage {
|
|
|
|
|
|
uint32_t timestamp; // When message was created (secs since boot/RTC)
|
|
|
|
|
|
uint32_t sender; // NodeNum of sender
|
|
|
|
|
|
uint8_t channelIndex; // Channel index used
|
|
|
|
|
|
std::string text; // UTF-8 text payload
|
|
|
|
|
|
|
|
|
|
|
|
// Destination node.
|
|
|
|
|
|
// 0xffffffff (NODENUM_BROADCAST) means broadcast,
|
|
|
|
|
|
// otherwise this is the NodeNum of the DM recipient.
|
|
|
|
|
|
uint32_t dest;
|
|
|
|
|
|
|
|
|
|
|
|
// Explicit classification (derived from dest when loading old messages)
|
|
|
|
|
|
MessageType type;
|
2025-09-23 01:05:22 -04:00
|
|
|
|
|
|
|
|
|
|
// Marks whether the timestamp was stored relative to boot time
|
|
|
|
|
|
// (true = millis()/1000 fallback, false = epoch/RTC absolute)
|
|
|
|
|
|
bool isBootRelative;
|
|
|
|
|
|
|
|
|
|
|
|
// Default constructor to initialize all fields safely
|
|
|
|
|
|
StoredMessage()
|
|
|
|
|
|
: timestamp(0), sender(0), channelIndex(0), text(""), dest(0xffffffff), type(MessageType::BROADCAST),
|
|
|
|
|
|
isBootRelative(false)
|
|
|
|
|
|
{
|
|
|
|
|
|
}
|
2025-09-21 17:40:26 -04:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class MessageStore
|
|
|
|
|
|
{
|
|
|
|
|
|
public:
|
|
|
|
|
|
explicit MessageStore(const std::string &label);
|
|
|
|
|
|
|
2025-09-26 00:28:25 -04:00
|
|
|
|
// Live RAM methods (always current, used by UI and runtime)
|
2025-09-21 17:40:26 -04:00
|
|
|
|
void addLiveMessage(const StoredMessage &msg);
|
|
|
|
|
|
const std::deque<StoredMessage> &getLiveMessages() const { return liveMessages; }
|
|
|
|
|
|
|
2025-09-26 00:28:25 -04:00
|
|
|
|
// Persistence methods (used only on boot/shutdown)
|
|
|
|
|
|
void addMessage(const StoredMessage &msg);
|
|
|
|
|
|
const StoredMessage &addFromPacket(const meshtastic_MeshPacket &mp); // Incoming/outgoing → RAM only
|
|
|
|
|
|
void addFromString(uint32_t sender, uint8_t channelIndex, const std::string &text);
|
|
|
|
|
|
void saveToFlash();
|
|
|
|
|
|
void loadFromFlash();
|
2025-09-21 17:40:26 -04:00
|
|
|
|
|
2025-09-26 00:28:25 -04:00
|
|
|
|
// Clear all messages (RAM + persisted queue)
|
2025-09-21 17:40:26 -04:00
|
|
|
|
void clearAllMessages();
|
|
|
|
|
|
|
2025-09-26 00:28:25 -04:00
|
|
|
|
// Dismiss helpers
|
|
|
|
|
|
void dismissOldestMessage();
|
|
|
|
|
|
void dismissNewestMessage();
|
2025-09-21 17:40:26 -04:00
|
|
|
|
|
2025-09-26 00:28:25 -04:00
|
|
|
|
// Unified accessor (for UI code, defaults to RAM buffer)
|
2025-09-21 17:40:26 -04:00
|
|
|
|
const std::deque<StoredMessage> &getMessages() const { return liveMessages; }
|
|
|
|
|
|
|
|
|
|
|
|
// Optional: direct access to persisted copy (mainly for debugging/inspection)
|
|
|
|
|
|
const std::deque<StoredMessage> &getPersistedMessages() const { return messages; }
|
|
|
|
|
|
|
2025-09-26 00:28:25 -04:00
|
|
|
|
// Helper filters for future use
|
2025-09-21 17:40:26 -04:00
|
|
|
|
std::deque<StoredMessage> getChannelMessages(uint8_t channel) const;
|
|
|
|
|
|
std::deque<StoredMessage> getDirectMessages() const;
|
|
|
|
|
|
std::deque<StoredMessage> getConversationWith(uint32_t peer) const;
|
|
|
|
|
|
|
2025-09-23 01:05:22 -04:00
|
|
|
|
// Upgrade boot-relative timestamps once RTC is valid
|
|
|
|
|
|
void upgradeBootRelativeTimestamps();
|
|
|
|
|
|
|
2025-09-21 17:40:26 -04:00
|
|
|
|
private:
|
|
|
|
|
|
std::deque<StoredMessage> liveMessages;
|
2025-09-26 00:28:25 -04:00
|
|
|
|
std::deque<StoredMessage> messages; // persisted copy
|
2025-09-21 17:40:26 -04:00
|
|
|
|
std::string filename;
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2025-09-26 00:28:25 -04:00
|
|
|
|
// Global instance (defined in MessageStore.cpp)
|
|
|
|
|
|
extern MessageStore messageStore;
|