123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181 |
- /* This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/.
- *
- * Copyright 2015-2017 (c) Fraunhofer IOSB (Author: Julius Pfrommer)
- * Copyright 2015 (c) Chris Iatrou
- * Copyright 2015-2016 (c) Sten Grüner
- * Copyright 2015 (c) Oleksiy Vasylyev
- * Copyright 2017 (c) Florian Palm
- * Copyright 2017 (c) Stefan Profanter, fortiss GmbH
- * Copyright 2017 (c) Mattias Bornhager
- */
- #ifndef UA_SUBSCRIPTION_H_
- #define UA_SUBSCRIPTION_H_
- #include "ua_util.h"
- #include "ua_types.h"
- #include "ua_types_generated.h"
- #include "ua_session.h"
- /**
- * MonitoredItems create Notifications. Subscriptions collect Notifications from
- * (several) MonitoredItems and publish them to the client.
- *
- * Notifications are put into two queues at the same time. One for the
- * MonitoredItem that generated the notification. Here we can remove it if the
- * space reserved for the MonitoredItem runs full. The second queue is the
- * "global" queue for all Notifications generated in a Subscription. For
- * publication, the notifications are taken out of the "global" queue in the
- * order of their creation.
- */
- /*****************/
- /* MonitoredItem */
- /*****************/
- typedef enum {
- UA_MONITOREDITEMTYPE_CHANGENOTIFY = 1,
- UA_MONITOREDITEMTYPE_STATUSNOTIFY = 2,
- UA_MONITOREDITEMTYPE_EVENTNOTIFY = 4
- } UA_MonitoredItemType;
- /* Not used yet. Placeholder for a future event implementation. */
- typedef struct UA_Event {
- UA_Int32 eventId;
- } UA_Event;
- struct UA_MonitoredItem;
- typedef struct UA_MonitoredItem UA_MonitoredItem;
- typedef struct UA_Notification {
- TAILQ_ENTRY(UA_Notification) listEntry;
- TAILQ_ENTRY(UA_Notification) globalEntry;
- UA_MonitoredItem *mon;
- /* See the monitoredItemType of the MonitoredItem */
- union {
- UA_Event event;
- UA_DataValue value;
- } data;
- } UA_Notification;
- typedef TAILQ_HEAD(NotificationQueue, UA_Notification) NotificationQueue;
- struct UA_MonitoredItem {
- LIST_ENTRY(UA_MonitoredItem) listEntry;
- UA_Subscription *subscription;
- UA_UInt32 monitoredItemId;
- UA_UInt32 clientHandle;
- /* Settings */
- UA_MonitoredItemType monitoredItemType;
- UA_TimestampsToReturn timestampsToReturn;
- UA_MonitoringMode monitoringMode;
- UA_NodeId monitoredNodeId;
- UA_UInt32 attributeId;
- UA_String indexRange;
- UA_Double samplingInterval; // [ms]
- UA_UInt32 maxQueueSize;
- UA_Boolean discardOldest;
- // TODO: dataEncoding is hardcoded to UA binary
- UA_DataChangeTrigger trigger;
- /* Sample Callback */
- UA_UInt64 sampleCallbackId;
- UA_ByteString lastSampledValue;
- UA_Boolean sampleCallbackIsRegistered;
- /* Notification Queue */
- NotificationQueue queue;
- UA_UInt32 queueSize;
- };
- UA_MonitoredItem * UA_MonitoredItem_new(UA_MonitoredItemType);
- void MonitoredItem_delete(UA_Server *server, UA_MonitoredItem *monitoredItem);
- void UA_MonitoredItem_SampleCallback(UA_Server *server, UA_MonitoredItem *monitoredItem);
- UA_StatusCode MonitoredItem_registerSampleCallback(UA_Server *server, UA_MonitoredItem *mon);
- UA_StatusCode MonitoredItem_unregisterSampleCallback(UA_Server *server, UA_MonitoredItem *mon);
- /* Remove entries until mon->maxQueueSize is reached. Sets infobits for lost
- * data if required. */
- void MonitoredItem_ensureQueueSpace(UA_MonitoredItem *mon);
- /****************/
- /* Subscription */
- /****************/
- typedef struct UA_NotificationMessageEntry {
- TAILQ_ENTRY(UA_NotificationMessageEntry) listEntry;
- UA_NotificationMessage message;
- } UA_NotificationMessageEntry;
- /* We use only a subset of the states defined in the standard */
- typedef enum {
- /* UA_SUBSCRIPTIONSTATE_CLOSED */
- /* UA_SUBSCRIPTIONSTATE_CREATING */
- UA_SUBSCRIPTIONSTATE_NORMAL,
- UA_SUBSCRIPTIONSTATE_LATE,
- UA_SUBSCRIPTIONSTATE_KEEPALIVE
- } UA_SubscriptionState;
- typedef TAILQ_HEAD(ListOfNotificationMessages, UA_NotificationMessageEntry) ListOfNotificationMessages;
- struct UA_Subscription {
- LIST_ENTRY(UA_Subscription) listEntry;
- UA_Session *session;
- UA_UInt32 subscriptionId;
- /* Settings */
- UA_UInt32 lifeTimeCount;
- UA_UInt32 maxKeepAliveCount;
- UA_Double publishingInterval; /* in ms */
- UA_UInt32 notificationsPerPublish;
- UA_Boolean publishingEnabled;
- UA_UInt32 priority;
- /* Runtime information */
- UA_SubscriptionState state;
- UA_UInt32 sequenceNumber;
- UA_UInt32 currentKeepAliveCount;
- UA_UInt32 currentLifetimeCount;
- /* Publish Callback */
- UA_UInt64 publishCallbackId;
- UA_Boolean publishCallbackIsRegistered;
- /* MonitoredItems */
- UA_UInt32 lastMonitoredItemId; /* increase the identifiers */
- LIST_HEAD(UA_ListOfUAMonitoredItems, UA_MonitoredItem) monitoredItems;
- UA_UInt32 monitoredItemsSize;
- /* Global list of notifications from the MonitoredItems */
- NotificationQueue notificationQueue;
- UA_UInt32 notificationQueueSize;
- UA_UInt32 readyNotifications; /* Notifications to be sent out now (already late) */
- /* Retransmission Queue */
- ListOfNotificationMessages retransmissionQueue;
- UA_UInt32 retransmissionQueueSize;
- };
- UA_Subscription * UA_Subscription_new(UA_Session *session, UA_UInt32 subscriptionId);
- void UA_Subscription_deleteMembers(UA_Server *server, UA_Subscription *sub);
- UA_StatusCode Subscription_registerPublishCallback(UA_Server *server, UA_Subscription *sub);
- UA_StatusCode Subscription_unregisterPublishCallback(UA_Server *server, UA_Subscription *sub);
- void UA_Subscription_addMonitoredItem(UA_Subscription *sub, UA_MonitoredItem *newMon);
- UA_MonitoredItem * UA_Subscription_getMonitoredItem(UA_Subscription *sub, UA_UInt32 monitoredItemId);
- UA_StatusCode
- UA_Subscription_deleteMonitoredItem(UA_Server *server, UA_Subscription *sub,
- UA_UInt32 monitoredItemId);
- void UA_Subscription_publish(UA_Server *server, UA_Subscription *sub);
- UA_StatusCode UA_Subscription_removeRetransmissionMessage(UA_Subscription *sub, UA_UInt32 sequenceNumber);
- void UA_Subscription_answerPublishRequestsNoSubscription(UA_Server *server, UA_Session *session);
- UA_Boolean UA_Subscription_reachedPublishReqLimit(UA_Server *server, UA_Session *session);
- #endif /* UA_SUBSCRIPTION_H_ */
|