ua_subscription.h 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. /* This Source Code Form is subject to the terms of the Mozilla Public
  2. * License, v. 2.0. If a copy of the MPL was not distributed with this
  3. * file, You can obtain one at http://mozilla.org/MPL/2.0/.
  4. *
  5. * Copyright 2015-2017 (c) Julius Pfrommer, Fraunhofer IOSB
  6. * Copyright 2015 (c) Chris Iatrou
  7. * Copyright 2015-2016 (c) Sten Grüner
  8. * Copyright 2015 (c) Oleksiy Vasylyev
  9. * Copyright 2017 (c) Florian Palm
  10. * Copyright 2017 (c) Stefan Profanter, fortiss GmbH
  11. * Copyright 2017 (c) Mattias Bornhager
  12. */
  13. #ifndef UA_SUBSCRIPTION_H_
  14. #define UA_SUBSCRIPTION_H_
  15. #include "ua_util.h"
  16. #include "ua_types.h"
  17. #include "ua_types_generated.h"
  18. #include "ua_session.h"
  19. /*****************/
  20. /* MonitoredItem */
  21. /*****************/
  22. typedef enum {
  23. UA_MONITOREDITEMTYPE_CHANGENOTIFY = 1,
  24. UA_MONITOREDITEMTYPE_STATUSNOTIFY = 2,
  25. UA_MONITOREDITEMTYPE_EVENTNOTIFY = 4
  26. } UA_MonitoredItemType;
  27. typedef struct MonitoredItem_queuedValue {
  28. TAILQ_ENTRY(MonitoredItem_queuedValue) listEntry;
  29. UA_UInt32 clientHandle;
  30. UA_DataValue value;
  31. } MonitoredItem_queuedValue;
  32. typedef TAILQ_HEAD(QueuedValueQueue, MonitoredItem_queuedValue) QueuedValueQueue;
  33. typedef struct UA_MonitoredItem {
  34. LIST_ENTRY(UA_MonitoredItem) listEntry;
  35. /* Settings */
  36. UA_Subscription *subscription;
  37. UA_UInt32 itemId;
  38. UA_MonitoredItemType monitoredItemType;
  39. UA_TimestampsToReturn timestampsToReturn;
  40. UA_MonitoringMode monitoringMode;
  41. UA_NodeId monitoredNodeId;
  42. UA_UInt32 attributeId;
  43. UA_UInt32 clientHandle;
  44. UA_Double samplingInterval; // [ms]
  45. UA_UInt32 currentQueueSize;
  46. UA_UInt32 maxQueueSize;
  47. UA_Boolean discardOldest;
  48. UA_String indexRange;
  49. // TODO: dataEncoding is hardcoded to UA binary
  50. UA_DataChangeTrigger trigger;
  51. /* Sample Callback */
  52. UA_UInt64 sampleCallbackId;
  53. UA_Boolean sampleCallbackIsRegistered;
  54. /* Sample Queue */
  55. UA_ByteString lastSampledValue;
  56. QueuedValueQueue queue;
  57. } UA_MonitoredItem;
  58. UA_MonitoredItem * UA_MonitoredItem_new(void);
  59. void MonitoredItem_delete(UA_Server *server, UA_MonitoredItem *monitoredItem);
  60. void UA_MoniteredItem_SampleCallback(UA_Server *server, UA_MonitoredItem *monitoredItem);
  61. UA_StatusCode MonitoredItem_registerSampleCallback(UA_Server *server, UA_MonitoredItem *mon);
  62. UA_StatusCode MonitoredItem_unregisterSampleCallback(UA_Server *server, UA_MonitoredItem *mon);
  63. /* Remove entries until mon->maxQueueSize is reached. Sets infobits for lost
  64. * data if required. */
  65. void MonitoredItem_ensureQueueSpace(UA_MonitoredItem *mon);
  66. /****************/
  67. /* Subscription */
  68. /****************/
  69. typedef struct UA_NotificationMessageEntry {
  70. TAILQ_ENTRY(UA_NotificationMessageEntry) listEntry;
  71. UA_NotificationMessage message;
  72. } UA_NotificationMessageEntry;
  73. /* We use only a subset of the states defined in the standard */
  74. typedef enum {
  75. /* UA_SUBSCRIPTIONSTATE_CLOSED */
  76. /* UA_SUBSCRIPTIONSTATE_CREATING */
  77. UA_SUBSCRIPTIONSTATE_NORMAL,
  78. UA_SUBSCRIPTIONSTATE_LATE,
  79. UA_SUBSCRIPTIONSTATE_KEEPALIVE
  80. } UA_SubscriptionState;
  81. typedef TAILQ_HEAD(ListOfNotificationMessages, UA_NotificationMessageEntry) ListOfNotificationMessages;
  82. struct UA_Subscription {
  83. LIST_ENTRY(UA_Subscription) listEntry;
  84. /* Settings */
  85. UA_Session *session;
  86. UA_UInt32 lifeTimeCount;
  87. UA_UInt32 maxKeepAliveCount;
  88. UA_Double publishingInterval; /* in ms */
  89. UA_UInt32 subscriptionId;
  90. UA_UInt32 notificationsPerPublish;
  91. UA_Boolean publishingEnabled;
  92. UA_UInt32 priority;
  93. /* Runtime information */
  94. UA_SubscriptionState state;
  95. UA_UInt32 sequenceNumber;
  96. UA_UInt32 currentKeepAliveCount;
  97. UA_UInt32 currentLifetimeCount;
  98. UA_UInt32 lastMonitoredItemId;
  99. UA_UInt32 numMonitoredItems;
  100. /* Publish Callback */
  101. UA_UInt64 publishCallbackId;
  102. UA_Boolean publishCallbackIsRegistered;
  103. /* MonitoredItems */
  104. LIST_HEAD(UA_ListOfUAMonitoredItems, UA_MonitoredItem) monitoredItems;
  105. /* When the last publish response could not hold all available
  106. * notifications, in the next iteration, start at the monitoreditem with
  107. * this id. If zero, start at the first monitoreditem. */
  108. UA_UInt32 lastSendMonitoredItemId;
  109. /* Retransmission Queue */
  110. ListOfNotificationMessages retransmissionQueue;
  111. UA_UInt32 retransmissionQueueSize;
  112. };
  113. UA_Subscription * UA_Subscription_new(UA_Session *session, UA_UInt32 subscriptionId);
  114. void UA_Subscription_deleteMembers(UA_Subscription *subscription, UA_Server *server);
  115. UA_StatusCode Subscription_registerPublishCallback(UA_Server *server, UA_Subscription *sub);
  116. UA_StatusCode Subscription_unregisterPublishCallback(UA_Server *server, UA_Subscription *sub);
  117. UA_StatusCode
  118. UA_Subscription_deleteMonitoredItem(UA_Server *server, UA_Subscription *sub,
  119. UA_UInt32 monitoredItemId);
  120. void
  121. UA_Subscription_addMonitoredItem(UA_Subscription *sub,
  122. UA_MonitoredItem *newMon);
  123. UA_UInt32
  124. UA_Subscription_getNumMonitoredItems(UA_Subscription *sub);
  125. UA_MonitoredItem *
  126. UA_Subscription_getMonitoredItem(UA_Subscription *sub, UA_UInt32 monitoredItemId);
  127. void UA_Subscription_publishCallback(UA_Server *server, UA_Subscription *sub);
  128. UA_StatusCode
  129. UA_Subscription_removeRetransmissionMessage(UA_Subscription *sub, UA_UInt32 sequenceNumber);
  130. void
  131. UA_Subscription_answerPublishRequestsNoSubscription(UA_Server *server, UA_Session *session);
  132. UA_Boolean
  133. UA_Subscription_reachedPublishReqLimit(UA_Server *server, UA_Session *session);
  134. #endif /* UA_SUBSCRIPTION_H_ */