Class KNXProtocol
java.lang.Object
org.openremote.agent.protocol.AbstractProtocol<KNXAgent,KNXAgentLink>
org.openremote.agent.protocol.knx.KNXProtocol
- All Implemented Interfaces:
org.openremote.model.asset.agent.Protocol<KNXAgent>
,org.openremote.model.protocol.ProtocolAssetImport
public class KNXProtocol
extends AbstractProtocol<KNXAgent,KNXAgentLink>
implements org.openremote.model.protocol.ProtocolAssetImport
This protocol is used to connect to a KNX bus via an IP interface.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected final Map<org.openremote.model.attribute.AttributeRef,
tuwien.auto.calimero.datapoint.Datapoint> protected final Map<org.openremote.model.attribute.AttributeRef,
tuwien.auto.calimero.datapoint.StateDP> protected KNXConnection
static final String
Fields inherited from class org.openremote.agent.protocol.AbstractProtocol
agent, assetService, datapointService, dynamicAttributes, executorService, linkedAttributes, messageBrokerContext, predictedDatapointService, processorLock, producerTemplate, scheduledExecutorService, timerService
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected void
addActionDatapoint
(org.openremote.model.attribute.AttributeRef attributeRef, String groupAddress, String dpt) protected void
addStatusDatapoint
(org.openremote.model.attribute.AttributeRef attributeRef, String groupAddress, String dpt) protected void
createAsset
(tuwien.auto.calimero.datapoint.StateDP datapoint, boolean isStatusGA, Map<String, org.openremote.model.asset.Asset<?>> createdAssets) protected void
doLinkAttribute
(String assetId, org.openremote.model.attribute.Attribute<?> attribute, KNXAgentLink agentLink) Link anAttribute
to its linkedAgent
.protected void
doLinkedAttributeWrite
(KNXAgentLink agentLink, org.openremote.model.attribute.AttributeEvent event, Object processedValue) An Attribute event (write) has been requested for an attribute linked to this protocol.protected void
doStart
(org.openremote.model.Container container) Start this protocol instanceprotected void
doStop
(org.openremote.model.Container container) Stop this protocol instanceprotected void
doUnlinkAttribute
(String assetId, org.openremote.model.attribute.Attribute<?> attribute, KNXAgentLink agentLink) Unlink anAttribute
from its linkedAgent
.Get a URI that describes this specific protocol instanceGet the name for this protocolprotected void
handleKNXValueChange
(org.openremote.model.attribute.AttributeRef attributeRef, Object value) protected void
removeActionDatapoint
(org.openremote.model.attribute.AttributeRef attributeRef) protected void
removeStatusDatapoint
(org.openremote.model.attribute.AttributeRef attributeRef) startAssetImport
(byte[] fileData, Consumer<org.openremote.model.asset.AssetTreeNode[]> assetConsumer) Start the process asynchronously; the implementation can make as many calls as it desires to the assetConsumer with the found assets; when the implementation has finished then the returned future will becomeFuture.isDone()
.Methods inherited from class org.openremote.agent.protocol.AbstractProtocol
getAgent, getLinkedAttributes, linkAttribute, onAgentAttributeChanged, processLinkedAttributeWrite, sendAttributeEvent, sendAttributeEvent, setAssetService, setConnectionStatus, start, stop, toString, unlinkAttribute, updateLinkedAttribute, updateLinkedAttribute
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.openremote.model.asset.agent.Protocol
prefixLogMessage
-
Field Details
-
PROTOCOL_DISPLAY_NAME
- See Also:
-
connection
-
attributeActionMap
protected final Map<org.openremote.model.attribute.AttributeRef,tuwien.auto.calimero.datapoint.Datapoint> attributeActionMap -
attributeStatusMap
protected final Map<org.openremote.model.attribute.AttributeRef,tuwien.auto.calimero.datapoint.StateDP> attributeStatusMap
-
-
Constructor Details
-
KNXProtocol
-
-
Method Details
-
getProtocolName
Description copied from interface:org.openremote.model.asset.agent.Protocol
Get the name for this protocol- Specified by:
getProtocolName
in interfaceorg.openremote.model.asset.agent.Protocol<KNXAgent>
-
doStart
Description copied from class:AbstractProtocol
Start this protocol instance- Specified by:
doStart
in classAbstractProtocol<KNXAgent,
KNXAgentLink> - Throws:
Exception
-
doStop
Description copied from class:AbstractProtocol
Stop this protocol instance- Specified by:
doStop
in classAbstractProtocol<KNXAgent,
KNXAgentLink> - Throws:
Exception
-
doLinkAttribute
protected void doLinkAttribute(String assetId, org.openremote.model.attribute.Attribute<?> attribute, KNXAgentLink agentLink) throws RuntimeException Description copied from class:AbstractProtocol
Link anAttribute
to its linkedAgent
.- Specified by:
doLinkAttribute
in classAbstractProtocol<KNXAgent,
KNXAgentLink> - Throws:
RuntimeException
-
doUnlinkAttribute
protected void doUnlinkAttribute(String assetId, org.openremote.model.attribute.Attribute<?> attribute, KNXAgentLink agentLink) Description copied from class:AbstractProtocol
Unlink anAttribute
from its linkedAgent
.- Specified by:
doUnlinkAttribute
in classAbstractProtocol<KNXAgent,
KNXAgentLink>
-
doLinkedAttributeWrite
protected void doLinkedAttributeWrite(KNXAgentLink agentLink, org.openremote.model.attribute.AttributeEvent event, Object processedValue) Description copied from class:AbstractProtocol
An Attribute event (write) has been requested for an attribute linked to this protocol. The processedValue is the resulting value after applying standard outbound value processing (seeProtocolUtil.doOutboundValueProcessing(org.openremote.model.attribute.AttributeRef, org.openremote.model.asset.agent.AgentLink<?>, java.lang.Object, boolean, java.time.Instant)
). Protocol implementations should generally use the processedValue but may also choose to use the original value for some purpose if required.- Specified by:
doLinkedAttributeWrite
in classAbstractProtocol<KNXAgent,
KNXAgentLink>
-
addActionDatapoint
protected void addActionDatapoint(org.openremote.model.attribute.AttributeRef attributeRef, String groupAddress, String dpt) throws tuwien.auto.calimero.KNXFormatException - Throws:
tuwien.auto.calimero.KNXFormatException
-
removeActionDatapoint
protected void removeActionDatapoint(org.openremote.model.attribute.AttributeRef attributeRef) -
addStatusDatapoint
protected void addStatusDatapoint(org.openremote.model.attribute.AttributeRef attributeRef, String groupAddress, String dpt) throws tuwien.auto.calimero.KNXFormatException - Throws:
tuwien.auto.calimero.KNXFormatException
-
handleKNXValueChange
protected void handleKNXValueChange(org.openremote.model.attribute.AttributeRef attributeRef, Object value) -
removeStatusDatapoint
protected void removeStatusDatapoint(org.openremote.model.attribute.AttributeRef attributeRef) -
getProtocolInstanceUri
Description copied from interface:org.openremote.model.asset.agent.Protocol
Get a URI that describes this specific protocol instance- Specified by:
getProtocolInstanceUri
in interfaceorg.openremote.model.asset.agent.Protocol<KNXAgent>
-
startAssetImport
public Future<Void> startAssetImport(byte[] fileData, Consumer<org.openremote.model.asset.AssetTreeNode[]> assetConsumer) Description copied from interface:org.openremote.model.protocol.ProtocolAssetImport
Start the process asynchronously; the implementation can make as many calls as it desires to the assetConsumer with the found assets; when the implementation has finished then the returned future will becomeFuture.isDone()
. The callee can also cancel the future at any time. If for some reason the process cannot be started or encounters an error then this method should log more details before completing the future.- Specified by:
startAssetImport
in interfaceorg.openremote.model.protocol.ProtocolAssetImport
-
createAsset
-