25#ifndef _DRIVER_NAVMSG_H
26#define _DRIVER_NAVMSG_H
36#include <netinet/in.h>
39#include "observable.h"
44 N2kPGN(uint64_t _pgn) { pgn = _pgn; }
46 friend bool operator<(
const N2kPGN& lhs,
const N2kPGN& rhs) {
47 return lhs.pgn < rhs.pgn;
50 std::string to_string()
const {
68 N2kName(uint64_t name) { value.Name = name; }
71 return lhs.value.Name < rhs.value.Name;
74 std::string to_string()
const {
80 static uint64_t Parse(
const std::string& s) {
100 uint32_t UnicNumberAndManCode;
102 unsigned char DeviceInstance;
103 unsigned char DeviceFunction;
104 unsigned char DeviceClass;
105 unsigned char IndustryGroupAndSystemInstance;
111 void SetUniqueNumber(uint32_t _UniqueNumber) {
112 value.UnicNumberAndManCode =
113 (value.UnicNumberAndManCode & 0xffe00000) | (_UniqueNumber & 0x1fffff);
115 void SetManufacturerCode(uint16_t _ManufacturerCode) {
116 value.UnicNumberAndManCode =
117 (value.UnicNumberAndManCode & 0x1fffff) |
118 (((
unsigned long)(_ManufacturerCode & 0x7ff)) << 21);
120 void SetDeviceInstance(
unsigned char _DeviceInstance) {
121 value.DeviceInstance = _DeviceInstance;
123 void SetDeviceFunction(
unsigned char _DeviceFunction) {
124 value.DeviceFunction = _DeviceFunction;
126 void SetDeviceClass(
unsigned char _DeviceClass) {
127 value.DeviceClass = ((_DeviceClass & 0x7f) << 1);
129 void SetIndustryGroup(
unsigned char _IndustryGroup) {
130 value.IndustryGroupAndSystemInstance =
131 (value.IndustryGroupAndSystemInstance & 0x0f) | (_IndustryGroup << 4) |
134 void SetSystemInstance(
unsigned char _SystemInstance) {
135 value.IndustryGroupAndSystemInstance =
136 (value.IndustryGroupAndSystemInstance & 0xf0) |
137 (_SystemInstance & 0x0f);
140 uint64_t GetName()
const {
return value.Name; }
146 enum class Bus { N0183, Signalk, N2000, Onenet,
Plugin, TestBus, Undef };
148 NavAddr(Bus b,
const std::string& i) : bus(b),
iface(i) {};
151 std::string to_string()
const {
152 return NavAddr::BusToString(bus) +
" " +
iface;
154 static std::string BusToString(Bus b);
155 static Bus StringToBus(
const std::string& s);
169 std::string to_string()
const {
return iface; }
178 :
NavAddr(NavAddr::Bus::N2000,
iface), name(0), address(_address) {};
183 std::string to_string()
const {
return name.to_string(); }
186 unsigned char address;
191 const std::string id;
193 :
NavAddr(NavAddr::Bus::Plugin,
"Plugin"), id(_id) {}
200 std::string to_string()
const {
return NavAddr::to_string(); }
206 :
NavAddr(NavAddr::Bus::TestBus,
"Test"), name(output_path) {};
208 const std::string name;
217 virtual std::string
key()
const = 0;
221 return NavAddr::BusToString(bus) +
" " +
key();
227 const NavAddr::Bus bus;
236 NavMsg(
const NavAddr::Bus& _bus, std::shared_ptr<const NavAddr> src)
237 : bus(_bus),
source(src) {};
246 :
NavMsg(NavAddr::Bus::N2000, std::make_shared<NavAddr>()), PGN(_pgn) {}
248 Nmea2000Msg(
const uint64_t _pgn, std::shared_ptr<const NavAddr2000> src)
249 :
NavMsg(NavAddr::Bus::N2000, src), PGN(_pgn) {}
251 Nmea2000Msg(
const uint64_t _pgn,
const std::vector<unsigned char>& _payload,
252 std::shared_ptr<const NavAddr2000> src)
253 :
NavMsg(NavAddr::Bus::N2000, src), PGN(_pgn), payload(_payload) {}
255 Nmea2000Msg(
const uint64_t _pgn,
const std::vector<unsigned char>& _payload,
256 std::shared_ptr<const NavAddr2000> src,
int _priority)
257 :
NavMsg(NavAddr::Bus::N2000, src),
260 priority(_priority) {}
264 std::string
key()
const {
return std::string(
"n2000-") + PGN.to_string(); };
270 std::vector<unsigned char> payload;
277 Nmea0183Msg(
const std::string&
id,
const std::string& _payload,
278 std::shared_ptr<const NavAddr> src)
279 :
NavMsg(NavAddr::Bus::N0183, src),
285 :
NavMsg(NavAddr::Bus::Undef, std::make_shared<const NavAddr>()) {}
288 :
Nmea0183Msg(
id.size() <= 3 ? std::string(
"??") +
id : id,
"",
289 std::make_shared<const NavAddr>()) {}
305 static const char*
const prefix =
"n0183-";
306 return std::string(prefix) +
type;
318 :
NavMsg(NavAddr::Bus::Undef, std::make_shared<const NavAddr>()) {}
320 PluginMsg(
const std::string& _name,
const std::string& _dest_host,
321 const std::string& msg)
322 :
NavMsg(NavAddr::Bus::Plugin,
323 std::make_shared<const NavAddr>(NavAddr::Bus::Plugin,
"")),
328 PluginMsg(
const std::string& _name,
const std::string& msg)
333 const std::string name;
334 const std::string message;
337 std::string
key()
const {
return std::string(
"plug.json-") + name; };
339 std::string
to_string()
const {
return name +
": " + message; }
346 :
NavMsg(NavAddr::Bus::Undef, std::make_shared<const NavAddr>()) {}
348 SignalkMsg(std::string _context_self, std::string _context,
349 std::string _raw_message, std::string _iface)
350 :
NavMsg(NavAddr::Bus::Signalk,
351 std::make_shared<const NavAddr>(NavAddr::Bus::Signalk, _iface)),
352 context_self(_context_self),
354 raw_message(_raw_message) {};
360 std::string context_self;
362 std::string raw_message;
364 std::string
key()
const {
return std::string(
"signalK"); };
371 :
NavMsg(NavAddr::Bus::Undef, std::make_shared<const NavAddr>()) {}
375 std::string
key()
const {
return "navmsg-undef"; }
Interface implemented by classes which listens.
Where messages are sent to or received from.
const std::string iface
Physical device for 0183, else a unique string.
Actual data sent between application and transport layer.
std::string GetKey() const
Alias for key().
virtual std::string key() const =0
Return unique key used by observable to notify/listen.
std::shared_ptr< const NavAddr > source
Source address is set by drivers when receiving, unused and should be empty when sending.
virtual std::string to_string() const
Return printable string for logging etc without trailing nl.
A regular Nmea0183 message.
std::string key() const
Return unique key used by observable to notify/listen.
const std::string type
For example 'GGA'.
const std::string talker
For example 'GP'.
const std::string payload
Complete NMEA0183 sentence, also prefix.
static std::string MessageKey(const char *type="ALL")
Return key which should be used to listen to given message type.
std::string to_string() const
Return printable string for logging etc without trailing nl.
See: https://github.com/OpenCPN/OpenCPN/issues/2729#issuecomment-1179506343.
std::string to_string() const
Print "bus key id payload".
std::string key() const
Return unique key used by observable to notify/listen.
An invalid message, error return value.
std::string key() const
Return unique key used by observable to notify/listen.
A plugin to plugin json message over the REST interface.
std::string to_string() const
Return printable string for logging etc without trailing nl.
std::string key() const
Return unique key used by observable to notify/listen.
const std::string dest_host
hostname, ip address or 'localhost'
Plugin ABI encapsulation.
A parsed SignalK message over ipv4.
std::string key() const
Return unique key used by observable to notify/listen.
N2k uses CAN which defines the basic properties of messages.
uint32_t GetNumber() const
21 bits
uint16_t GetManufacturer() const
9 bits
uint8_t GetDevClass() const
7 bits
uint8_t GetDevFunc() const
8 bits
uint8_t GetIndustryGroup() const
4 bits
uint8_t GetDevInstanceHigh() const
5 bits
uint8_t GetDevInstanceLow() const
3 bits
uint8_t GetSysInstance() const
4 bits