ua_subscription.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  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. #ifndef UA_SUBSCRIPTION_H_
  5. #define UA_SUBSCRIPTION_H_
  6. #include "ua_util.h"
  7. #include "ua_types.h"
  8. #include "ua_types_generated.h"
  9. #include "ua_session.h"
  10. /*****************/
  11. /* MonitoredItem */
  12. /*****************/
  13. typedef enum {
  14. UA_MONITOREDITEMTYPE_CHANGENOTIFY = 1,
  15. UA_MONITOREDITEMTYPE_STATUSNOTIFY = 2,
  16. UA_MONITOREDITEMTYPE_EVENTNOTIFY = 4
  17. } UA_MonitoredItemType;
  18. typedef struct MonitoredItem_queuedValue {
  19. TAILQ_ENTRY(MonitoredItem_queuedValue) listEntry;
  20. UA_UInt32 clientHandle;
  21. UA_DataValue value;
  22. } MonitoredItem_queuedValue;
  23. typedef TAILQ_HEAD(QueuedValueQueue, MonitoredItem_queuedValue) QueuedValueQueue;
  24. typedef struct UA_MonitoredItem {
  25. LIST_ENTRY(UA_MonitoredItem) listEntry;
  26. /* Settings */
  27. UA_Subscription *subscription;
  28. UA_UInt32 itemId;
  29. UA_MonitoredItemType monitoredItemType;
  30. UA_TimestampsToReturn timestampsToReturn;
  31. UA_MonitoringMode monitoringMode;
  32. UA_NodeId monitoredNodeId;
  33. UA_UInt32 attributeID;
  34. UA_UInt32 clientHandle;
  35. UA_Double samplingInterval; // [ms]
  36. UA_UInt32 currentQueueSize;
  37. UA_UInt32 maxQueueSize;
  38. UA_Boolean discardOldest;
  39. UA_String indexRange;
  40. // TODO: dataEncoding is hardcoded to UA binary
  41. UA_DataChangeTrigger trigger;
  42. /* Sample Callback */
  43. UA_UInt64 sampleCallbackId;
  44. UA_Boolean sampleCallbackIsRegistered;
  45. /* Sample Queue */
  46. UA_ByteString lastSampledValue;
  47. QueuedValueQueue queue;
  48. } UA_MonitoredItem;
  49. UA_MonitoredItem * UA_MonitoredItem_new(void);
  50. void MonitoredItem_delete(UA_Server *server, UA_MonitoredItem *monitoredItem);
  51. void UA_MoniteredItem_SampleCallback(UA_Server *server, UA_MonitoredItem *monitoredItem);
  52. UA_StatusCode MonitoredItem_registerSampleCallback(UA_Server *server, UA_MonitoredItem *mon);
  53. UA_StatusCode MonitoredItem_unregisterSampleCallback(UA_Server *server, UA_MonitoredItem *mon);
  54. /****************/
  55. /* Subscription */
  56. /****************/
  57. typedef struct UA_NotificationMessageEntry {
  58. TAILQ_ENTRY(UA_NotificationMessageEntry) listEntry;
  59. UA_NotificationMessage message;
  60. } UA_NotificationMessageEntry;
  61. /* We use only a subset of the states defined in the standard */
  62. typedef enum {
  63. /* UA_SUBSCRIPTIONSTATE_CLOSED */
  64. /* UA_SUBSCRIPTIONSTATE_CREATING */
  65. UA_SUBSCRIPTIONSTATE_NORMAL,
  66. UA_SUBSCRIPTIONSTATE_LATE,
  67. UA_SUBSCRIPTIONSTATE_KEEPALIVE
  68. } UA_SubscriptionState;
  69. typedef TAILQ_HEAD(ListOfNotificationMessages, UA_NotificationMessageEntry) ListOfNotificationMessages;
  70. struct UA_Subscription {
  71. LIST_ENTRY(UA_Subscription) listEntry;
  72. /* Settings */
  73. UA_Session *session;
  74. UA_UInt32 lifeTimeCount;
  75. UA_UInt32 maxKeepAliveCount;
  76. UA_Double publishingInterval; /* in ms */
  77. UA_UInt32 subscriptionID;
  78. UA_UInt32 notificationsPerPublish;
  79. UA_Boolean publishingEnabled;
  80. UA_UInt32 priority;
  81. /* Runtime information */
  82. UA_SubscriptionState state;
  83. UA_UInt32 sequenceNumber;
  84. UA_UInt32 currentKeepAliveCount;
  85. UA_UInt32 currentLifetimeCount;
  86. UA_UInt32 lastMonitoredItemId;
  87. /* Publish Callback */
  88. UA_UInt64 publishCallbackId;
  89. UA_Boolean publishCallbackIsRegistered;
  90. /* MonitoredItems */
  91. LIST_HEAD(UA_ListOfUAMonitoredItems, UA_MonitoredItem) monitoredItems;
  92. /* When the last publish response could not hold all available
  93. * notifications, in the next iteration, start at the monitoreditem with
  94. * this id. If zero, start at the first monitoreditem. */
  95. UA_UInt32 lastSendMonitoredItemId;
  96. /* Retransmission Queue */
  97. ListOfNotificationMessages retransmissionQueue;
  98. UA_UInt32 retransmissionQueueSize;
  99. };
  100. UA_Subscription * UA_Subscription_new(UA_Session *session, UA_UInt32 subscriptionID);
  101. void UA_Subscription_deleteMembers(UA_Subscription *subscription, UA_Server *server);
  102. UA_StatusCode Subscription_registerPublishCallback(UA_Server *server, UA_Subscription *sub);
  103. UA_StatusCode Subscription_unregisterPublishCallback(UA_Server *server, UA_Subscription *sub);
  104. UA_StatusCode
  105. UA_Subscription_deleteMonitoredItem(UA_Server *server, UA_Subscription *sub,
  106. UA_UInt32 monitoredItemID);
  107. UA_MonitoredItem *
  108. UA_Subscription_getMonitoredItem(UA_Subscription *sub, UA_UInt32 monitoredItemID);
  109. void UA_Subscription_publishCallback(UA_Server *server, UA_Subscription *sub);
  110. UA_StatusCode
  111. UA_Subscription_removeRetransmissionMessage(UA_Subscription *sub, UA_UInt32 sequenceNumber);
  112. void
  113. UA_Subscription_answerPublishRequestsNoSubscription(UA_Server *server, UA_Session *session);
  114. #endif /* UA_SUBSCRIPTION_H_ */