4#include <boost/asio.hpp>
6#include <nlohmann/json.hpp>
265 std::chrono::milliseconds interval);
285 void refresh(
const std::vector<mm::comm::base::Parameter::Address>& addresses)
313 Device(
const std::string& ip, uint16_t port, uint16_t position = 0,
314 std::chrono::milliseconds refresherInterval =
315 std::chrono::milliseconds(3000));
358 bool connect(std::chrono::seconds expiryTime = std::chrono::seconds(3));
404 const std::chrono::steady_clock::duration expiryTime);
435 uint8_t
getState(
bool refresh =
false,
436 const std::chrono::steady_clock::duration expiryTime =
437 std::chrono::milliseconds(5000))
override;
457 const std::chrono::steady_clock::duration expiryTime =
458 std::chrono::milliseconds(5000))
override;
511 const std::string& filename,
512 const std::chrono::steady_clock::duration expiryTime =
513 std::chrono::milliseconds(5000))
override;
516 const bool stripSizeSuffix =
true,
517 const std::chrono::steady_clock::duration expiryTime =
518 std::chrono::milliseconds(5000))
override;
538 const std::chrono::steady_clock::duration expiryTime =
539 std::chrono::milliseconds(5000))
override;
563 const std::vector<std::uint8_t>& data,
564 const std::vector<std::string>& skipFiles = {
"SOMANET_CiA_402.xml.zip",
565 "stack_image.svg.zip"},
566 std::function<void(uint8_t, std::string)> progressCallback =
nullptr,
567 const std::chrono::steady_clock::duration expiryTime =
568 std::chrono::milliseconds(60000))
override;
591 void writeFile(
const std::string& filename,
const std::vector<uint8_t>& data,
592 const std::chrono::steady_clock::duration expiryTime =
593 std::chrono::milliseconds(5000))
override;
612 expiryTime = std::chrono::milliseconds(2000));
641 bool readValues =
false,
642 const std::chrono::steady_clock::duration expiryTime =
643 std::chrono::milliseconds(1000));
665 uint16_t
index, uint8_t subindex,
666 const std::chrono::steady_clock::duration expiryTime =
667 std::chrono::milliseconds(1000));
698 const std::vector<mm::comm::base::Parameter::Address>& addresses,
699 const std::chrono::steady_clock::duration expiryTime =
700 std::chrono::milliseconds(1000));
715 const std::vector<mm::comm::base::Parameter>&
parameters,
716 const std::chrono::steady_clock::duration expiryTime =
717 std::chrono::milliseconds(1000));
731 std::vector<mm::comm::base::Parameter>&
parameters,
732 std::size_t batchSize = 50,
733 std::chrono::steady_clock::duration expiryTime =
734 std::chrono::milliseconds(1000));
756 const std::vector<uint8_t>& data,
757 const std::chrono::steady_clock::duration expiryTime =
758 std::chrono::milliseconds(1000));
774 const std::chrono::steady_clock::duration expiryTime =
775 std::chrono::milliseconds(9000))
override;
790 std::vector<std::reference_wrapper<mm::comm::base::Parameter>>
parameters()
794 uint8_t subindex)
override;
797 const uint16_t
index,
const uint8_t subindex,
798 const std::chrono::steady_clock::duration expiryTime =
799 std::chrono::milliseconds(3000))
override;
821 template <
typename T>
823 const std::chrono::steady_clock::duration expiryTime =
824 std::chrono::milliseconds(5000)) {
830 const std::chrono::steady_clock::duration expiryTime =
831 std::chrono::milliseconds(5000))
override;
835 const std::chrono::steady_clock::duration expiryTime =
836 std::chrono::milliseconds(5000))
override;
856 template <
typename T>
858 const std::chrono::steady_clock::duration expiryTime =
859 std::chrono::milliseconds(5000)) {
879 expiryTime = std::chrono::milliseconds(3000));
882 const std::chrono::steady_clock::duration expiryTime =
883 std::chrono::milliseconds(3000));
903 const std::vector<uint8_t>& data,
904 const std::chrono::steady_clock::duration expiryTime =
905 std::chrono::milliseconds(1000));
944 uint64_t missedCycles = 0)
override;
947 uint16_t
index, uint8_t subindex)
const override;
983 boost::asio::io_context ioContext_;
985 boost::asio::ip::tcp::endpoint
988 boost::asio::ip::tcp::socket
1000 std::mutex disconnectMutex_;
1009 std::atomic<uint16_t> seqId_{0};
1024 std::atomic_flag isSendingAndReceivingProcessData_ =
1032 sendAndReceiveProcessDataExceptionPtrMutex_;
1036 std::exception_ptr sendAndReceiveProcessDataExceptionPtr_ =
1040 DeviceParameterRefresher refresher_;
Base class for periodically refreshing a set of device parameters in a background thread.
Definition: base.h:1605
Abstract interface representing a generic device.
Definition: base.h:1032
Represents a device parameter identified by index and subindex.
Definition: base.h:463
ParameterValue getValue() const
Retrieves the value of the parameter based on its data type.
Definition: base.cc:36
std::pair< uint16_t, uint8_t > Address
Alias for a pair of uint16_t and uint8_t representing a parameter address.
Definition: base.h:473
Concrete refresher that uploads parameters from a device.
Definition: spoe.h:261
void refresh(const std::vector< mm::comm::base::Parameter::Address > &addresses) override
Rereads the specified device parameters in a single message exchange.
Definition: spoe.cc:65
Handles TCP communication with SOMANET devices over SPoE.
Definition: spoe.h:298
mm::comm::base::Parameter & findParameter(uint16_t index, uint8_t subindex) override
Finds and returns a reference to a parameter by its index and subindex.
Definition: spoe.cc:1012
size_t loadParameters(bool readValues=false, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(9000)) override
Loads parameters from the device and stores them locally.
Definition: spoe.cc:988
void clearParameters() override
Clears all loaded object dictionary parameters.
Definition: spoe.cc:998
void removeFile(const std::string &filename, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(5000)) override
Remove a file from the SPoE device.
Definition: spoe.cc:477
Message exchangeWithTimeout(const Message &request, const std::chrono::steady_clock::duration expiryTime)
Exchanges a message with a remote server and waits for a response with a timeout.
Definition: spoe.cc:236
DeviceParameterRefresher & refresher()
Get a reference to the device parameter refresher.
Definition: spoe.h:980
bool setState(uint8_t state, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(5000)) override
Sends a state control command to the SPoE device and checks the response.
Definition: spoe.cc:332
void readSdoBatchAndUpdateParameters(std::vector< mm::comm::base::Parameter > ¶meters, std::size_t batchSize=50, std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(1000))
Reads the specified parameters in batches and updates their values.
Definition: spoe.cc:916
uint16_t getPosition() const override
Gets the device's position in the network chain.
Definition: spoe.cc:305
bool isConnected()
Checks if the SPoE socket is currently open.
Definition: spoe.cc:198
std::vector< std::reference_wrapper< mm::comm::base::Parameter > > parameters() override
Get a vector of references to parameters.
Definition: spoe.cc:1001
bool writeSdo(uint16_t index, uint8_t subindex, const std::vector< uint8_t > &data, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(1000))
Writes a Service Data Object (SDO) to the device.
Definition: spoe.cc:941
std::vector< uint8_t > readFile(const std::string &filename, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(5000)) override
Reads a file from the device using segmented SPoE messages.
Definition: spoe.cc:358
void writeFile(const std::string &filename, const std::vector< uint8_t > &data, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(5000)) override
Write a file to the SPoE device in segments.
Definition: spoe.cc:544
void performProcessDataExchangeAsync()
Perform asynchronous process data exchange with the SPoE device.
Definition: spoe.cc:1157
std::vector< uint8_t > exchangeProcessData(const std::vector< uint8_t > &data, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(1000))
Exchanges process data (PDO) with the device.
Definition: spoe.cc:1127
std::string getSocketAddress() const
Returns the socket address as a string in the format "IP:port".
Definition: spoe.cc:150
bool connect(std::chrono::seconds expiryTime=std::chrono::seconds(3))
Attempts to connect the SPoE device to the specified endpoint.
Definition: spoe.cc:160
void download(uint16_t index, uint8_t subindex, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(5000)) override
Downloads a parameter to the device using SDO communication.
Definition: spoe.cc:1045
std::vector< uint8_t > readSdo(uint16_t index, uint8_t subindex, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(1000))
Reads an SDO (Service Data Object) from the device.
Definition: spoe.cc:787
void download(uint16_t index, uint8_t subindex, const T &value, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(5000))
Sets and downloads a parameter value to the device using the specified type.
Definition: spoe.h:857
T upload(uint16_t index, uint8_t subindex, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(5000))
Uploads a parameter from the device and returns its value as the specified type.
Definition: spoe.h:822
~Device()
Destructor for the Device class.
Definition: spoe.cc:145
bool triggerFirmwareUpdate(const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(2000))
Sends a firmware update request to the connected Integro device.
Definition: spoe.cc:606
uint8_t getState(bool refresh=false, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(5000)) override
Sends a request to read the state of the device and returns the state value.
Definition: spoe.cc:307
mm::comm::base::MappedParameterValues getMappedParameterValues()
Retrieves the mapped parameter values for the SPoE device.
Definition: spoe.cc:1306
std::vector< std::vector< uint8_t > > readSdoBatch(const std::vector< mm::comm::base::Parameter::Address > &addresses, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(1000))
Reads a batch of SDOs from the device in a single request.
Definition: spoe.cc:823
bool isOnline() override
Checks if the SPoE device is online.
Definition: spoe.cc:1324
mm::comm::base::PdoMappingStatus getPdoMappingStatus(uint16_t index, uint8_t subindex) const override
Determines the PDO mapping status of a parameter by its index and subindex.
Definition: spoe.cc:1278
uint16_t incrementSeqId()
Increments the sequence ID atomically and wraps it around at the maximum value.
Definition: spoe.cc:155
mm::comm::base::Parameter & upload(const uint16_t index, const uint8_t subindex, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(3000)) override
Uploads a parameter from the device via SDO and updates the local parameter store.
Definition: spoe.cc:1025
bool disconnect()
Gracefully disconnects the SPoE device.
Definition: spoe.cc:200
void updateFirmware(const std::vector< std::uint8_t > &data, const std::vector< std::string > &skipFiles={"SOMANET_CiA_402.xml.zip", "stack_image.svg.zip"}, std::function< void(uint8_t, std::string)> progressCallback=nullptr, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(60000)) override
Updates the firmware on this SPoE device.
bool setPdoMode(PdoMode mode, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(3000))
Definition: spoe.cc:1107
void exchangeProcessDataAndUpdateParameters(uint64_t missedCycles=0) override
Exchanges process data and updates device parameters.
Definition: spoe.cc:1217
std::vector< std::string > readFileList(const bool stripSizeSuffix=true, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(5000)) override
Reads a list of file names from the device.
Definition: spoe.cc:439
ServerInfo getServerInfo(const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(3000))
Retrieves the server information from the connected SPoE device.
Definition: spoe.cc:1071
std::vector< mm::comm::base::Parameter > getParametersFromDevice(bool readValues=false, const std::chrono::steady_clock::duration expiryTime=std::chrono::milliseconds(1000))
Retrieves the parameter list from the device.
Definition: spoe.cc:625
A simple thread-safe FIFO queue.
Definition: util.h:484
uint8_t type
Definition: co_dictionary.h:1
uint8_t * value
Definition: co_dictionary.h:9
uint16_t index
Definition: co_dictionary.h:0
std::variant< bool, std::int8_t, std::int16_t, std::int32_t, std::int64_t, std::uint8_t, std::uint16_t, std::uint32_t, std::uint64_t, float, double, std::string, std::vector< std::uint8_t > > ParameterValue
Definition: base.h:405
PdoMappingStatus
Represents the PDO mapping status of a parameter.
Definition: base.h:436
SpoeMessagePacketStatus
Packet status codes for SPoE messages.
Definition: spoe.h:123
SpoeMessageFileErrorStatus
Error status codes returned when reading or writing a file via SPoE message.
Definition: spoe.h:95
@ COMMUNICATION_BRIDGE_ERROR
SpoeMessageParamListErrorStatus
Error status codes returned when reading the parameter list via SPoE.
Definition: spoe.h:57
@ SUCCESS_ACK
Success Acknowledgement.
PdoMode
Defines the modes for Process Data Object (PDO) communication over SPoE.
Definition: spoe.h:141
@ NONE
No process or cyclic data exchange available.
@ CONTROL
Both RxPDO and TxPDO data exchange enabled.
@ MONITOR
Device sends RxPDO values only; incoming requests are ignored.
std::vector< uint8_t > serializeSpoeMessage(const Message &message)
Serializes an SpoeMessage object into a byte buffer.
Definition: spoe.cc:39
SpoeMessageType
Enumeration of SPoE message types used in the protocol.
Definition: spoe.h:22
@ SDO_BATCH_READ
Read multiple SDOs in a single request.
@ SERVER_INFO
Request information about the server or device.
@ STATE_CONTROL
Control the state of the device (e.g., INIT, PREOP).
@ FILE_READ
Read a file from the device.
@ STATE_READ
Read the current state of the device.
@ SDO_WRITE
Write a value to a Service Data Object (SDO).
@ SDO_READ
Read a Service Data Object (SDO) value.
@ FIRMWARE_UPDATE
Perform firmware update operation.
@ FILE_WRITE
Write a file to the device.
@ PDO_CONTROL
Control or configure PDO behavior.
@ PARAM_LIST
Request a full list of parameters.
@ PDO_RXTX_FRAME
Transmit or receive a Process Data Object (PDO) frame.
SpoeMessageRequestStatus
Status codes representing the state of an SPoE request message.
Definition: spoe.h:46
@ FIRST
First segment of a multi-part message.
@ MIDDLE
Middle segment of a multi-part message.
@ OK
Message is complete and valid.
@ LAST
Last segment of a multi-part message.
SpoeMessageSdoStatus
Status codes returned during SDO (Service Data Object) read and write operations.
Definition: spoe.h:70
@ NO_ERR
Success Acknowledgement.
Message parseMessage(const std::vector< uint8_t > &buffer)
Parses a raw SPoE message buffer into a structured SpoeMessage.
Definition: spoe.cc:12
NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE(Message, type, id, status, size, data)
Holds collections of mapped parameter values for RX and TX directions.
Definition: base.h:425
Represents the mapped PDO entries for a slave device.
Definition: base.h:145
uint16_t status
The status of the response message.
Definition: spoe.h:180
uint16_t size
The size of the buffer in the response message.
Definition: spoe.h:187
static constexpr size_t kBufferSize
Definition: spoe.h:160
SpoeMessageType type
The type of the response message.
Definition: spoe.h:166
std::vector< uint8_t > data
The payload data of the response message.
Definition: spoe.h:194
static constexpr size_t kHeaderSize
Definition: spoe.h:157
uint16_t id
The sequence ID of the response message.
Definition: spoe.h:173
Contains information about the server's protocol version and monitoring mode.
Definition: spoe.h:237
uint16_t protocolVersion
Version of the communication protocol used by the server.
Definition: spoe.h:241
uint8_t monitoringMode
Indicates the monitoring mode configuration.
Definition: spoe.h:246