Vaillant VRC 720/2-3 - how to write TimeSlots? #1497
Replies: 3 comments 2 replies
-
|
The ccTimer definitions, I presume, address the external circuit pump, not the one inside the bai or ehp as the values read are only time intervals (start;end), not the start;end;temp like for hwc and zones (z1,z2...) still unclear how to read _Config |
Beta Was this translation helpful? Give feedback.
-
|
Ok, it was a bit tricky, but I succeeded to set the timeslots. So, first I found in the 15.ctlv2.tsp the definition like this: and in _templates.tsp the definition of wTimeSlotWithTemp: So, it is necessary to send slotIndex, which I assumed is the 0,1,2 from the end of Z1Timer_Monday0. So, index=0, count=1 I sent: So I set 20 degrees for the hole day of Monday. Sure, the read commands are only for checking. Next, obviously, I tried to write slot index 1 and 2, but: didn't work. Two hours and a pause later, I made some mistakes, and it initiated the second timeslot: See that first command So, in conclusion, the system do the changes after it receives all the slots defined with the second value (3 in our case) like this: Notice the slotcount=3 from the first position in So it remains unknown the Z1Timer_Config varible. |
Beta Was this translation helpful? Give feedback.
-
|
Hi, I use ebusd with mqtt -> HA. All TimeSlots are not editable via HomeAssistant. @john30 is that expected behavior? mqtt-hassio.cfg# Configuration file for ebusd MQTT integration with Home Assistant (https://www.home-assistant.io/).
# Use this file with ebusd in MQTT JSON mode to have many seen messages automatically appear on HA. This is achieved by
# using the MQTT Discovery feature of Home Assistant (see https://www.home-assistant.io/integrations/mqtt#mqtt-discovery).
# The commandline options to ebusd should contain e.g.:
# --mqttport=1883 --mqttjson --mqttint=/etc/ebusd/mqtt-hassio.cfg
# This file allows flexible construction of MQTT topics and payloads depending on message and field definitions as well
# as global status topics.
# It is a set of named variables (or constants) with the name on the left of an equal sign and the value on the right,
# where only the value is allowed to contain references to other variables.
# A reference to a variable is escaped by a leading "%" character in front of the variable name consisting of only
# alphabetic characters or the underscore. A double percent character "%%" is replaced by a single "%" in the value.
# Curly braces may be used to separate a variable explicitly from the rest, e.g. as "%{version}" instead of "%version".
# Every variable without an underscore in the name is automatically made available as well with an uppercase name and a
# normalized value composed of only alphanumeric characters or underscore (i.e. suitable for being part of a topic).
# When using "?=" instead of only the equal sign in a variable definition, the variable value is set to empty when one
# of the variables referred to is empty or missing.
# The variable replacements are constructed for each message and/or field (depending on whether the topic is field
# specific or not) in the following order:
# 1. predefined constants from ebusd, i.e.
# %version the ebusd version number.
# %prefix the invariable prefix part of the "--mqtttopic" configuration option, defaults to "ebusd/".
# %prefixn the same as %prefix but without trailing slashes or underscores.
# 2. variables referring to constants only (directly or indirectly).
# 3. circuit and message specific variables:
# %circuit the circuit name.
# %name the message name.
# %priority the message poll priority (or 0).
# %level the message access level (or empty).
# %messagecomment the message comment.
# %direction the message direction ("r", "w", "u", or "uw").
# %topic the message update topic built from the mqtttopic configuration option (only if the topic is not field
# specific) and/or the %topic variable defined here.
# 4. the direction mapped from variables named "direction_map-%direction" with the actual direction in the suffix.
# Available as "%direction_map".
# 5. the field type mapped from variables named "type_map-%direction-%type" or "type_map-%type" as fallback with the
# field type and the optional direction in the suffix. The variable including the direction is evaluated first and
# if it is missing or the result is empty, the variable excluding the direction is used instead.
# This is also an implicit field type filter as missing or empty mappings are not published at all.
# Available as "%type_map".
# 6. other field specific variables for each field (only once for each message if the topic is field specific):
# %index the numeric field index (excluding ignored fields).
# %field the field name and key for JSON objects (equals the field index if no name is defined or the names are not
# unique in the message).
# %fieldname the field name (and nothing else like in %field, might be empty though!)
# %fieldnamemult the field name unless there is a single field only (similar to %fieldname)
# %type the field type (one of "number", "list", "string", "date", "time", or "datetime").
# %basetype the base data type ID (e.g. "UCH").
# %comment the field comment (if any).
# %unit the field unit (if any).
# %min, %max, and %step the minimum/maximum possible value and step value for number fields.
# %topic the field (or message) update topic built from the mqtttopic configuration option and/or the %topic variable
# defined here.
# 7. optional field type switch in "%type_switch" using the value of the variable named "type_switch-by" and matching it
# against the value lines of the variable named "type_switch-%type" with the field type in the suffix.
# The value of such a variable needs to be a constant list of string pairs with one pair per line. Each pair is
# separated by "=" and the left part is the value set to the "type_switch" variable when the wildcard pattern in the
# right part matches the value of the "type_switch-by" value. The list is traversed from top to bottom with the
# first match stopping the evaluation. Optionally, "type_switch-names" can be used to define a list of variable
# names to be set in addition to the "type_switch" variable, in which case a list of variable names (comma
# separated) is expected as "type_switch-names" value and the appropriate values to set on the left side of each
# match list entry.
# Available as "%type_switch" and optionally by the set of fields as defined in "%type_switch-names".
# 8. optional field type part mapping in "%type_part" for each field type in variables named "type_part-%type" with the
# field type in the suffix (or the value of the "type_part-by" variable).
# 9. if the %fields_payload variable is used, then it is set to the concatenation of all fields of the message:
# %field_payload is expected to build a single field payload.
# %field-separator is the separator placed between consecutive field payloads.
# %fields_payload is set to the concatenation of all fields of the message, separated by %field-separator.
# 10. %definition-topic, %definition-payload, and %definition-retain to build the message definition topic and payload
# and determine the retain value.
# Before constructing the variable replacements, the messages and fields can optionally be filtered in order to use
# certain message definitions only. All of these criteria are applied, so they are basically combined by "AND".
# Filters with a "partial match" mention in the documentation allow using a limited glob/regex inspired case insensitive
# matching with the following options:
# - "|" allows defining alternatives, e.g. "a|b" matches "but" as well as "all".
# - "^" matches the beginning of the input, e.g. "^al" matches "al" but not "hal".
# - "$" matches the end of the input, e.g. "al$" matches "hal" but not "all".
# - "*" matches a single arbitrary length wildcard part in the middle (can only be used once per filter/alternative),
# e.g. "^a*l$" matches "all" but not "always".
# include only messages having data sent at least once (only checked for passive or read messages, not for active write)
# when set to 1. If set to >1, then all messages passing the other filter criteria (including active read messages) will
# automatically be set to have a poll priority of at most this value, so these are automatically being polled.
# HA integration: filtering only seen messages to avoid unnecessary "pollution" and auto-poll all matched messages
filter-seen = 2
# include only messages having a priority less than or equal to the specified value.
#filter-priority =
# include only messages having the specified circuit (partial match, alternatives and wildcard supported).
#filter-circuit =
# exclude messages having the specified circuit (partial match, alternatives and wildcard supported).
#filter-non-circuit =
# include only messages having the specified name (partial match, alternatives and wildcard supported).
# HA integration: filter to some useful names for monitoring the heating circuit
#filter-name = status|temp|count|energy|power|runtime|hours|starts|mode|curve|^load$|^party$|sensor|maintenance|error|pressure
#filter-name = status|temp|count|maintenance|error|pressure
filter-name = ^mc|^hwc|frost|setmode|veto|pumpstatus|flowtemp|flowrate|^ReturnTemp$|^storagetemp$|cirpump|^outsidetemp$|maintenance|error|^waterpressure$|positionvalve|boilerblock|^flame$|^z|sfmode|^wp$|averageIgnitiontime|maxIgnitiontime|minIgnitiontime|IonisationVoltageLevel|starts
# exclude messages having the specified name (partial match, alternatives and wildcard supported).
#filter-non-name = h*min|h*max|hwcflowtemp|^hc3|^ext
# include only messages having the specified level (partial match, alternatives and wildcard supported).
# Note: This is a filter on top of the messages already filtered implicitly for the ebusd "mqtt" user (if any).
# Note: Since the empty string matches all levels, an explicit check for empty string (with "^$") needs to be used for
# including only messages without a level.
filter-level = ^$
# include only messages having the specified direction ("r", "w", "u", or "uw". partial match, alternatives and wildcard supported).
# HA integration: writable messages excluded for now
#filter-direction = r|u #######<<<<<<<<<<<<<<<<<<<< deaktiviert für unten
# HA integration: for including writable messages, use this line or overwrite with '--mqttvar=filter-direction=r|u|^w'.
filter-direction = r|u|^w
# include only fields having the specified name (partial match, alternatives and wildcard supported).
#filter-field =
# exclude fields having the specified name (partial match, alternatives and wildcard supported).
# HA integration: exclude the useless sensor ok/cutoff info from temperature sensor.
filter-non-field = ^sensor$
# HA integration: home assistant configuration topics prefix
haprefix = homeassistant
# HA integration: the area of all entities in home assistant
area = Heating
# HA integration: circuit specific part used as device entity for message definitions below
circuit_part = {
"identifiers":"%{PREFIX}_%CIRCUIT",
"manufacturer":"ebusd.eu",
"name":"%prefixn %circuit",
"via_device":"%PREFIXN",
"sw_version":"%version",
"suggested_area":"%area"
}
# the field type mapped from variables named "type_map-%direction-%type" or "type_map-%type" as fallback with the
# field type and the optional direction in the suffix. The variable including the direction is evaluated first and
# if it is missing or the result is empty, the variable excluding the direction is used instead.
# This is also an implicit field type filter as missing or empty mappings are not published at all.
type_map-number = number
type_map-list = string
type_map-time = time
type_map-date = date
type_map-datetime = datetime
# HA integration: skip string types completely
type_map-string =
# field type switch designator, see below.
# HA integration: this is used to set several variable values depending on the field type, message name+field name, and unit.
type_switch-by = %name%field,%unit
# field type switch variables names to use in addition to %type_switch in case of multiple keys (separated by comma).
# HA integration: var names for topic/class/state/sub values mapped from field type, message name+field name, and unit.
type_switch-names = type_topic,type_class,type_state,type_sub
# field type switch for each field type and optionally direction (between dash before the field type) available as
# %type_switch (as well as the variable names defined in "type_switch-names" if any).
# The value needs to be a constant list of string pairs with one pair per line. Each pair is separated by "=" and the
# left part is the value set to the type_switch variable (as well as the variable names defined in %type_switch-names)
# when the wildcard string in the right part matched the "type_switch-by" value. The list is traversed from top to
# bottom stopping at the first match. If direction specific definitions exist, these are traversed first. If no line
# matches at all, the variable(s) are set to the empty string.
# HA integration: the mapping list for (potentially) writable number entities field type, message name+field name, and unit.
type_switch-w-number =
number,temperature, = temp|,°C$
number,temperature, = temp|,K$
number,, = integral|,°min$
number,power_factor, = power*%%
number,power, = power|,kW$|,W$
number,voltage, = volt|,V$
number,current, = current,|currentvalue,|,A$
number,pressure, = bar$
number,gas, = gas*/min$
number,humidity, = humid*%%$
number,, = curve,|curvevalue,
# HA integration: the mapping list for numeric sensor entities field type, message name+field name, and unit.
type_switch-number =
sensor,,total_increasing = poweron|count,|countvalue,
sensor,temperature,measurement = temp|,°C$
sensor,temperature,measurement = temp|,K$
sensor,power_factor,measurement = power*%%
sensor,power,measurement = power|,kW$|,W$
sensor,voltage,measurement = volt|,V$
sensor,current,measurement = current,|currentvalue,|,A$
sensor,,measurement = integral|,°min$
sensor,energy,total_increasing = energy|,Wh$
sensor,yield,total_increasing = total*,Wh$
sensor,,total_increasing = hours|,h$
sensor,,total_increasing = starts*,$
sensor,pressure,measurement = bar$
sensor,gas,measurement = gas*/min$
sensor,humidity,measurement = humid*%%$
sensor,, =
# HA integration: the mapping list for (potentially) writable binary switch entities field type, message name+field name, and unit.
type_switch-w-list =
switch,, = onoff
switch,,,yesno = yesno
select,, =
# HA integration: the mapping list for rather binary sensor entities field type, message name+field name, and unit.
type_switch-list =
binary_sensor,,measurement = onoff
binary_sensor,,measurement,yesno = yesno
sensor,,,list =
# HA integration: the mapping list for (potentially) writable string entities containing a time value field type, message name+field name, and unit.
type_switch-w-time =
text,,,time = from,|to,|time2,|timer
text,,,time3 = time,|timevalue,
type_switch-time =
sensor,,,time = from,|to,|time2,|timer
sensor,,,time3 = time,|timevalue,
# HA integration: the mapping list for (potentially) writable string entities containing a date value field type, message name+field name, and unit.
type_switch-w-date =
text,,,date =
type_switch-date =
sensor,,, =
# HA integration: the mapping list for (potentially) writable string entities containing a datetime value field type, message name+field name, and unit.
type_switch-w-datetime =
text,,,datetime =
type_switch-datetime =
sensor,,, =
# HA integration: currently unused mapping lists for non-numeric/non-binary entities.
#type_switch-string =
# sensor,, =
# HA integration: optional variable with the entity device class for numbers
type_class_number ?= ,
"device_class":"%type_class"
# HA integration: optional variable with the entity device class for sensors
type_class_sensor ?= ,
"device_class":"%type_class"
# HA integration: optional variable with the entity state class
state_class ?= ,
"state_class":"%type_state"
# HA integration: optional variable with the entity unit
unit_of_measurement ?= ,
"unit_of_measurement":"%unit"
# HA integration: optional variable with the minimum numeric value
min_number ?= ,
"min":%min
# HA integration: optional variable with the maximum numeric value
max_number ?= ,
"max":%max
# HA integration: optional variable with the numeric step value
step_number ?= ,
"step":%step
# field type part suffix to use instead of the field type itself, see below.
# HA integration: %type_part variable mapped from the mapped %type_topic and optional %type_sub
type_part-by = %type_topic%type_sub
# field type part mappings for each field type (or the "type_part-by" variable value) in the suffix (available as
# %type_part).
# HA integration: %type_part variable for number %type_topic
type_part-number = ,
"command_topic":"%topic/set"%min_number%max_number%step_number%unit_of_measurement%state_class%type_class_number
# HA integration: %type_part variable for sensor %type_topic
type_part-sensor = %unit_of_measurement%state_class%type_class_sensor
# HA integration: %type_part variable for switch %type_topic
type_part-switch = ,
"command_topic":"%topic/set",
"payload_on":"on",
"payload_off":"off"%state_class
type_part-switchyesno = ,
"command_topic":"%topic/set",
"payload_on":"yes",
"payload_off":"no"%state_class
# HA integration: %type_part variable for binary_sensor %type_topic
type_part-binary_sensor = ,
"payload_on":"on",
"payload_off":"off"%state_class
type_part-binary_sensoryesno = ,
"payload_on":"yes",
"payload_off":"no"%state_class
# HA integration: %type_part variable for text %type_topic
type_part-texttime = ,
"command_topic":"%topic/set",
"pattern": "^[012][0-9]:[0-5][0-9]$"%state_class
type_part-texttime3 = ,
"command_topic":"%topic/set",
"pattern": "^[012][0-9]:[0-5][0-9]:[0-5][0-9]$"%state_class
# HA integration: %type_part variable for date %type_topic
type_part-textdate = ,
"command_topic":"%topic/set",
"pattern": "^[0-3][0-9].[01][0-9].20[0-3][0-9]$"%state_class
# HA integration: %type_part variable for datetime %type_topic
type_part-textdatetime = ,
"command_topic":"%topic/set",
"pattern": "^[0-3][0-9].[01][0-9].20[0-3][0-9] [012][0-9]:[0-5][0-9]$"%state_class
# optional format string for converting a fields value list into %field_values.
# "$value" and "$text" are being replaced by the corresponding part.
field_values-entry = "$text"
# optional separator for concatenating of field value list items.
field_values-separator = ,
# optional prefix for surrounding field value list items.
field_values-prefix = [
# optional suffix for surrounding field value list items.
field_values-suffix = ]
# HA integration: %type_part variable for select %type_topic and sensor with list of known values
type_part-select = ,
"command_topic":"%topic/set",
"options":%field_values
type_part-sensorlist = ,
"device_class":"enum",
"options":%field_values
# the field specific part (evaluated after the message specific part).
# HA integration: set to the mapped %type_part from above
field_payload = %type_part
# the message definition config topic, payload, and retain setting.
# HA integration: the config topic for HA's MQTT discovery for the ebusd message definition found.
# set to conditionally to avoid incomplete configs.
definition-topic ?= %haprefix/%type_topic/%{TOPIC}_%FIELD/config
# HA integration: this is the config topic payload for HA's MQTT discovery.
definition-payload = {
"unique_id":"%{TOPIC}_%FIELD",
"name":"%name %fieldnamemult",
"device":%circuit_part,
"value_template":"{{value_json[\"%field\"].value}}",
"state_topic":"%topic"%field_payload
}
#definition-retain = 0
# the message value topic (if other than the default). If set here, it will be replaced by the "--mqtttopic"
# configuration option only if that one contains at least one variable. If the the "--mqtttopic" configuration option
# does not contain any variable, it is taken as prefix and can be used here as well.
# HA integration: use the prefix from --mqtttopic and non field specific topic for the actual data
topic = %prefix/%circuit/%name
# HA integration: global part used as device entity for the global config topics
global_device = {
"identifiers":"%PREFIXN",
"manufacturer":"ebusd.eu",
"name":"%prefixn",
"sw_version":"%version",
"suggested_area":"%area"
}
# HA integration: common prefix for global parts
global_prefix = {
"unique_id":"%TOPIC",
"device":%global_device,
"state_topic":"%topic",
"name":"global %name"
# HA integration: boolean suffix for global parts
global_boolean_suffix = ,
"payload_on":"true",
"payload_off":"false"
}
# the common global config topic, payload, and retain setting (used by running, version, signal, uptime, updatecheck,
# and scan if not otherwise defined explicitly).
# HA integration: the config topic for HA's MQTT discovery for the ebusd global parts.
def_global-topic = %haprefix/sensor/%TOPIC/config
def_global-payload = %global_prefix
}
#def_global-retain = 0
# individual global running, version, signal, uptime, updatecheck, and scan config topic, payload, and retain setting.
def_global_running-topic = %haprefix/binary_sensor/%TOPIC/config
def_global_running-payload = %global_prefix,
"device_class":"running"%global_boolean_suffix
def_global_version-topic =
def_global_uptime-payload = %global_prefix,
"device_class":"duration",
"state_class":"total_increasing",
"unit_of_measurement":"s"
}
def_global_signal-topic = %haprefix/binary_sensor/%TOPIC/config
def_global_signal-payload = %global_prefix,
"device_class":"connectivity"%global_boolean_suffix
def_global_updatecheck-topic = %haprefix/update/%TOPIC/config
def_global_updatecheck-payload = %global_prefix,
"value_template":"{%% set my_new = value_json|truncate(255)|regex_replace(find=',.*| available|revision v|version v|OK',replace='') %%}{%% if my_new == '' %%}{%% set my_new = '%version' %%}{%% endif %%}{{ {'installed_version':'%version','latest_version':my_new,'entity_picture':'https://ebusd.eu/logo-32x32.png','release_url':'https://github.com/john30/ebusd/releases/latest'} | tojson }}"
}
# optional secondary update check for the enhanced eBUS device (consuming the same topic though!)
def_global_updatecheck_device-topic = %haprefix/update/%{TOPIC}_device/config
def_global_updatecheck_device-payload = {
"unique_id":"%{TOPIC}_device",
"device":{
"identifiers":"%{PREFIXN}_device",
"manufacturer":"ebusd.eu",
"name":"%prefixn eBUS device",
"via_device":"%PREFIXN",
"suggested_area":"%area"
},
"state_topic":"%topic",
"name":"%name",
"value_template":"{%% set my_new = value_json|truncate(255)|regex_replace(find='^[^,]*|, device firmware |,.*| available',replace='') %%}{%% set my_ds = 'v31/firmware/' %%}{%% if my_new is search('up to date') %%}{%% set my_ds = my_new|regex_replace(find=' .*',replace='/') %%}{%% set my_new = 'current' %%}{%% set my_cur = 'current' %%}{%% else %%}{%% set my_cur = 'old' %%}{%% if my_new is search(' ') %%}{%% set my_ds = my_new|regex_replace(find=' .*',replace='/') %%}{%% set my_new = my_new|regex_replace(find='.* ',replace='') %%}{%% else %%}{%% if my_new == '' %%}{%% set my_new = 'current' %%}{%% set my_cur = 'current' %%}{%% endif %%}{%% endif %%}{%% endif %%}{{ {'installed_version':my_cur,'latest_version':my_new,'entity_picture':'https://adapter.ebusd.eu/'+my_ds+'favicon.ico','release_url':'https://adapter.ebusd.eu/'+my_ds+'ChangeLog'} | tojson }}"
}
# the topic and payload to listen to in order to republish all config messages.
# HA integration: force republish of all configs when HA goes down and comes up again.
config_restart-topic = %haprefix/status
config_restart-payload = online
ebusd-info: Thanks in advance! |
Beta Was this translation helpful? Give feedback.

Uh oh!
There was an error while loading. Please reload this page.
-
Hello Dear Community,
Anybody knows how to write TimeSlots on Vaillant VRC 720/2-3?
config file has this Timers, let's say for Monday:
There are different entrys for read, one for each Slot, and one for write, as we can see above. While it is very clear how to read:
Z1Timer_Monday0 htm=00:00;htm_1=24:00;slottemp=12.0 [Temperature stored in the slot. Degrees Celsius]meaning Monday in slot0 from 0:00 to 24:00 keep 12 degrees. It is unclear for me how to write new values in:
w,,z1Timer.Monday,timer heating monday,,,,00,,,wTimeSlotWithTemp,,,as could be more timeslots per day.
Also, while I understand
ctlv3 Z1Timer_Timeframes = 1;1;1;1;1;1;1as how many timeslots each day has, this is read only. I do not understand what this Timer.Config means:
r,,z1Timer.Config,timer Configuration(static atm? describes featue set?),,,B555,a30000,,,HEX:9,,,Configurationwith values:
ctlv3 Z1Timer_Config = 00 0c 0a 05 01 0c 05 1e 00One last question, what does it referes to the ccTimer definitions? I have read that .cc is circulation circuit, but I don't see the context of timeslot for circulation.
Thank you
Beta Was this translation helpful? Give feedback.
All reactions