diff options
author | Jannis Voelker <jannis.voelker@basyskom.com> | 2017-11-13 14:34:17 +0100 |
---|---|---|
committer | Frank Meerkoetter <frank.meerkoetter@basyskom.com> | 2017-12-14 10:52:33 +0000 |
commit | 28f2c5d6bc152948a3ce7f22e55db9afcaba1d3c (patch) | |
tree | 5d7138b25642bfc8f98e1f0432e44cbbad6731c0 /src/opcua/client/qopcuaclient.cpp | |
parent | 0e71f5b4a9b6073f527236f5e6ac9d423ebe315b (diff) |
Add async API for data change subscriptions
Subscriptions and monitored items are now handled entirely in the backend,
no objects are passed to the user.
Monitoring of attributes is activated using enableMonitoring() on the node.
Different attributes of the node can be monitored with different intervals.
Subscriptions are shared by default. Parameters allow requesting the creation
of an exclusive subscription or to assign monitored items for attributes to
an existing subscription. disableMonitoring() removes a monitored item.
The enableMonitoringFinished and disableMonitoringFinished signals inform
the user about the success of adding and removing monitored items.
Data changes are reported by the attributeUpdated signal, this also updates
the attribute cache.
Monitoring parameters can be modified using modifyMonitoring(). Changed
settings are reported by the monitoringStatusChanged signal, the value can be
checked by calling monitoringStatus() for an attribute.
Modifying monitoring parameters is currently not supported in freeopcua.
Open62541 allows modifying subscription settings, monitored items can't be
modified.
Change-Id: I3ba5b3f03bd9f0413c98feefa9ad9571f82e8f0d
Reviewed-by: Frank Meerkoetter <frank.meerkoetter@basyskom.com>
Diffstat (limited to 'src/opcua/client/qopcuaclient.cpp')
-rw-r--r-- | src/opcua/client/qopcuaclient.cpp | 17 |
1 files changed, 0 insertions, 17 deletions
diff --git a/src/opcua/client/qopcuaclient.cpp b/src/opcua/client/qopcuaclient.cpp index 86fd7f9..4306af7 100644 --- a/src/opcua/client/qopcuaclient.cpp +++ b/src/opcua/client/qopcuaclient.cpp @@ -241,21 +241,4 @@ QString QOpcUaClient::backend() const return d_func()->m_impl->backend(); } -/*! - Creates a subscription with \a interval milliseconds publishing period - on the server and returns a QOpcUaSubscription object for it. The - subscription may be used to monitor nodes for events or value changes. - The caller becomes the owner of the newly created subscription object. - - For this method to work the client needs to be connected to the server. - A null pointer is returned on error. -*/ -QOpcUaSubscription *QOpcUaClient::createSubscription(quint32 interval) -{ - if (state() != QOpcUaClient::Connected) - return nullptr; - - return d_func()->m_impl->createSubscription(interval); -} - QT_END_NAMESPACE |