Skip to content

Latest commit

 

History

History
97 lines (77 loc) · 5.11 KB

FB_OUTPUT_SWITCH_MQTT.md

File metadata and controls

97 lines (77 loc) · 5.11 KB

FB_OUTPUT_SWITCH_MQTT

General

Can be switched using pulses that are high for one clock cycle (for example from FB_INPUT_PUSHBUTTON_MQTT), maintains output state through powercycles.

Block diagram

FB_OUTPUT_SWITCH_MQTT

INPUT(S)

  • TOGGLE: when high the output OUT gets toggled. input should one be high for one clockcycle.
  • PRIOHIGH: when high the output OUT is set to high, has priority over the TOGGLE and PRIOLOW input.
  • PRIOLOW: when high the output OUT is set to low, has priority over the TOGGLE input.

OUTPUT(S)

  • OUT: output to switch digital output on and off. Can be connected to a relay for example.

METHOD(S)

  • InitMQTT: enables MQTT events on the FB: sets the MQTT publish topic & subscribe topic, registers to the callbackcollector and sets the pointer to the MQTTPublishQueue.
  • PublishRecived: callback method called by the callbackcollector when a message is received on the subscribed topic by the callbackcollector.

MQTT Event Behaviour

Requires method call InitMQTT to enable MQTT capabilities.

Event Description MQTT payload QOS Retain flag Published on startup
Output changes to high The digtal output changes state to high. TRUE 2 FALSE yes
Output changes to low The digtal output changes state to low. FALSE 2 FALSE yes

MQTT publish topic is a concatination of the publish prefix and the function block name.

MQTT Subscription Behaviour

Requires method call InitMQTT to enable MQTT capabilities. Commands are executed by the FB if the topic MQTTSubscribeTopic matches the MQTT topic and the payload exists in the table below.

Command Description expected payload Additional notes
Change output to high Request to change output to high. TRUE Command executed when PRIOHIGH and PRIOLOW inputs are low.
Change output to low Request to change output to low. FALSE Command executed when PRIOHIGH and PRIOLOW inputs are low.

MQTT subscription topic is a concatenation of the subscribe prefix variable and the function block name.

Code example

  • variables initiation:
MQTTPubSwitchPrefix     :STRING(100) := 'WAGO-PFC200/Out/DigitalOutputs/';
MQTTSubSwitchPrefix     :STRING(100) := 'WAGO-PFC200/In/DigitalOutputs/';
FB_DO_SW_001            :FB_OUTPUT_SWITCH_MQTT;
  • Init MQTT method call (called once during startup):
FB_DO_SW_001.InitMQTT(MQTTPublishPrefix:= ADR(MQTTPubSwitchPrefix),                 (* pointer to string prefix for the MQTT publish topic *)
    MQTTSubscribePrefix:= ADR(MQTTSubSwitchPrefix),                                 (* pointer to string prefix for the MQTT subscribe topic *)
    MQTTTopicSuffix := 'FB_DO_SW_001',                                              (* value to suffix the the MQTT topic, should be unique for each FB *)
    pMQTTPublishQueue := ADR(MQTTVariables.fbMQTTPublishQueue),                     (* pointer to MQTTPublishQueue to send a new MQTT event *)
    pMQTTCallbackCollector := ADR(MQTTVariables.collector_FB_OUTPUT_SWITCH_MQTT)    (* pointer to CallbackCollector to receive MQTT subscription events *)
);

The MQTT publish topic in this code example will be WAGO-PFC200/Out/DigitalOutputs/FB_DO_SW_001 (MQTTPubSwitchPrefix variable + function block name). The subscription topic will be WAGO-PFC200/In/DigitalOutputs/FB_DO_SW_001 (MQTTSubSwitchPrefix variable + function block name).

  • checking for events to switch the digital output (cyclic):
FB_DO_SW_001(OUT=>  DO_001,                 (* couple the function block to the physical output *)
    PRIOHIGH:=      FALSE,                  (* brings the output high regardless of other input values *)
    PRIOLOW:=       FALSE                   (* brings the output low regardless of other input values. NOTE: Priohigh overrules Priolow input *)
    TOGGLE:=        FB_DI_PB_009.SINGLE     (* for toggling the output *)	
);
  • integration with FB_INPUT_PUSHBUTTON_MQTT:
FB_DO_SW_001(OUT=>  DO_001,                 (* couple the function block to the physical output *)
    PRIOHIGH:=      FALSE,                  (* brings the output high regardless of other input values *)
    PRIOLOW:=       FALSE,                  (* brings the output low regardless of other input values. NOTE: Priohigh overrules Priolow input *)
    TOGGLE:=        FB_DI_PB_001.SINGLE     (* for toggling the output *)	
);

Home Assistant YAML

To integrate with Home Assistant use the YAML code below in your MQTT lights config:

- platform: MQTT
  name: "FB_DO_SW_001"
  state_topic: "WAGO-PFC200/Out/DigitalOutputs/FB_DO_SW_001"
  command_topic: "WAGO-PFC200/In/DigitalOutputs/FB_DO_SW_001"
  payload_on: "TRUE"
  payload_off: "FALSE"
  qos: 2
  optimistic: false
  availability_topic: "Devices/WAGO-PFC200/availability"
  payload_available: "online"
  payload_not_available: "offline"