mirror of
https://github.com/meshtastic/firmware.git
synced 2025-12-17 16:22:48 +00:00
* More spoof remediation * Fix signed comparison error * Only fire self-bound messages into the routing module * Update src/mesh/MeshModule.cpp Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * String const --------- Co-authored-by: Ben Meadors <benmmeadors@gmail.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
41 lines
1.4 KiB
C++
41 lines
1.4 KiB
C++
#pragma once
|
|
#include "Channels.h"
|
|
#include "ProtobufModule.h"
|
|
|
|
static const char *ROUTING_MODULE = "routing";
|
|
|
|
/**
|
|
* Routing module for router control messages
|
|
*/
|
|
class RoutingModule : public ProtobufModule<meshtastic_Routing>
|
|
{
|
|
public:
|
|
/** Constructor
|
|
* name is for debugging output
|
|
*/
|
|
RoutingModule();
|
|
|
|
virtual void sendAckNak(meshtastic_Routing_Error err, NodeNum to, PacketId idFrom, ChannelIndex chIndex,
|
|
uint8_t hopLimit = 0);
|
|
|
|
// Given the hopStart and hopLimit upon reception of a request, return the hop limit to use for the response
|
|
uint8_t getHopLimitForResponse(uint8_t hopStart, uint8_t hopLimit);
|
|
|
|
protected:
|
|
friend class Router;
|
|
|
|
/** Called to handle a particular incoming message
|
|
|
|
@return true if you've guaranteed you've handled this message and no other handlers should be considered for it
|
|
*/
|
|
virtual bool handleReceivedProtobuf(const meshtastic_MeshPacket &mp, meshtastic_Routing *p) override;
|
|
|
|
/** Messages can be received that have the want_response bit set. If set, this callback will be invoked
|
|
* so that subclasses can (optionally) send a response back to the original sender. */
|
|
virtual meshtastic_MeshPacket *allocReply() override;
|
|
|
|
/// Override wantPacket to say we want to see all packets, not just those for our port number
|
|
virtual bool wantPacket(const meshtastic_MeshPacket *p) override { return true; }
|
|
};
|
|
|
|
extern RoutingModule *routingModule; |