123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 |
- #include <open62541/plugin/log_stdout.h>
- #include <open62541/plugin/pubsub.h>
- #include <open62541/plugin/pubsub_udp.h>
- #include <open62541/server.h>
- #include <open62541/server_config_default.h>
- #include "ua_pubsub_networkmessage.h"
- #include <signal.h>
- #ifdef UA_ENABLE_PUBSUB_ETH_UADP
- #include <open62541/plugin/pubsub_ethernet.h>
- #endif
- UA_Boolean running = true;
- static void stopHandler(int sign) {
- UA_LOG_INFO(UA_Log_Stdout, UA_LOGCATEGORY_SERVER,
- "received ctrl-c");
- running = false;
- }
- static UA_StatusCode
- subscriberListen(UA_PubSubChannel *psc) {
- UA_ByteString buffer;
- UA_StatusCode retval = UA_ByteString_allocBuffer(&buffer, 512);
- if(retval != UA_STATUSCODE_GOOD) {
- UA_LOG_ERROR(UA_Log_Stdout, UA_LOGCATEGORY_SERVER,
- "Message buffer allocation failed!");
- return retval;
- }
-
- retval = psc->receive(psc, &buffer, NULL, 100);
- if(retval != UA_STATUSCODE_GOOD || buffer.length == 0) {
-
- buffer.length = 512;
- UA_ByteString_clear(&buffer);
- return UA_STATUSCODE_GOOD;
- }
-
- UA_LOG_INFO(UA_Log_Stdout, UA_LOGCATEGORY_USERLAND,
- "Message length: %lu", (unsigned long) buffer.length);
- UA_NetworkMessage networkMessage;
- memset(&networkMessage, 0, sizeof(UA_NetworkMessage));
- size_t currentPosition = 0;
- UA_NetworkMessage_decodeBinary(&buffer, ¤tPosition, &networkMessage);
- UA_ByteString_clear(&buffer);
-
- if(networkMessage.networkMessageType != UA_NETWORKMESSAGE_DATASET)
- goto cleanup;
-
- if(networkMessage.payloadHeaderEnabled &&
- networkMessage.payloadHeader.dataSetPayloadHeader.count < 1)
- goto cleanup;
-
- for(size_t j = 0; j < networkMessage.payloadHeader.dataSetPayloadHeader.count; j++) {
- UA_DataSetMessage *dsm = &networkMessage.payload.dataSetPayload.dataSetMessages[j];
- if(dsm->header.dataSetMessageType != UA_DATASETMESSAGE_DATAKEYFRAME)
- continue;
-
- for(int i = 0; i < dsm->data.keyFrameData.fieldCount; i++) {
- const UA_DataType *currentType = dsm->data.keyFrameData.dataSetFields[i].value.type;
- if(currentType == &UA_TYPES[UA_TYPES_BYTE]) {
- UA_Byte value = *(UA_Byte *)dsm->data.keyFrameData.dataSetFields[i].value.data;
- UA_LOG_INFO(UA_Log_Stdout, UA_LOGCATEGORY_USERLAND,
- "Message content: [Byte] \tReceived data: %i", value);
- } else if (currentType == &UA_TYPES[UA_TYPES_UINT32]) {
- UA_UInt32 value = *(UA_UInt32 *)dsm->data.keyFrameData.dataSetFields[i].value.data;
- UA_LOG_INFO(UA_Log_Stdout, UA_LOGCATEGORY_USERLAND,
- "Message content: [UInt32] \tReceived data: %u", value);
- } else if (currentType == &UA_TYPES[UA_TYPES_DATETIME]) {
- UA_DateTime value = *(UA_DateTime *)dsm->data.keyFrameData.dataSetFields[i].value.data;
- UA_DateTimeStruct receivedTime = UA_DateTime_toStruct(value);
- UA_LOG_INFO(UA_Log_Stdout, UA_LOGCATEGORY_USERLAND,
- "Message content: [DateTime] \t"
- "Received date: %02i-%02i-%02i Received time: %02i:%02i:%02i",
- receivedTime.year, receivedTime.month, receivedTime.day,
- receivedTime.hour, receivedTime.min, receivedTime.sec);
- }
- }
- }
- cleanup:
- UA_NetworkMessage_clear(&networkMessage);
- return retval;
- }
- int main(int argc, char **argv) {
- signal(SIGINT, stopHandler);
- signal(SIGTERM, stopHandler);
- UA_PubSubTransportLayer udpLayer = UA_PubSubTransportLayerUDPMP();
- UA_PubSubConnectionConfig connectionConfig;
- memset(&connectionConfig, 0, sizeof(connectionConfig));
- connectionConfig.name = UA_STRING("UADP Connection 1");
- connectionConfig.transportProfileUri =
- UA_STRING("http://opcfoundation.org/UA-Profile/Transport/pubsub-udp-uadp");
- connectionConfig.enabled = UA_TRUE;
- UA_NetworkAddressUrlDataType networkAddressUrl =
- {UA_STRING_NULL , UA_STRING("opc.udp://224.0.0.22:4840/")};
- UA_Variant_setScalar(&connectionConfig.address, &networkAddressUrl,
- &UA_TYPES[UA_TYPES_NETWORKADDRESSURLDATATYPE]);
- UA_PubSubChannel *psc =
- udpLayer.createPubSubChannel(&connectionConfig);
- psc->regist(psc, NULL, NULL);
- UA_StatusCode retval = UA_STATUSCODE_GOOD;
- while(running && retval == UA_STATUSCODE_GOOD)
- retval = subscriberListen(psc);
- psc->close(psc);
-
- return 0;
- }
|