2017-05-13 12:02:10 +01:00
/*
2019-10-27 10:13:24 +00:00
my_user_config . h - user specific configuration for Tasmota
2017-05-13 12:02:10 +01:00
2021-01-01 12:44:04 +00:00
Copyright ( C ) 2021 Theo Arends
2017-05-13 12:02:10 +01:00
This program is free software : you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation , either version 3 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
2018-10-26 16:13:17 +01:00
# ifndef _MY_USER_CONFIG_H_
# define _MY_USER_CONFIG_H_
2017-10-18 17:22:34 +01:00
2017-01-28 13:41:01 +00:00
/*********************************************************************************************\
2018-04-05 14:26:16 +01:00
* This file consists of TWO sections .
2017-01-28 13:41:01 +00:00
*
2018-04-05 14:26:16 +01:00
* SECTION 1 :
* The first section contains PARAMETERS overriding flash settings if define CFG_HOLDER is CHANGED .
* All parameters can be persistent changed online using commands via MQTT , WebConsole or Serial .
* Corresponding MQTT / Serial / Console commands are shown in [ brackets ]
*
* SECTION 2 :
* The second section contains Enabled and Disabled FEATURES allowing different program size .
* Changes in this section do NOT need a change of define CFG_HOLDER .
*
* ATTENTION :
2018-04-05 15:13:17 +01:00
* Users are advised to use the user_config_override . h file for most changes .
2017-01-28 13:41:01 +00:00
\ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2018-04-05 14:26:16 +01:00
/*********************************************************************************************\
* SECTION 1
2018-04-05 15:13:17 +01:00
* - After initial load any change here only take effect if CFG_HOLDER is changed too
2018-04-05 14:26:16 +01:00
\ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2017-01-28 13:41:01 +00:00
2018-04-05 14:26:16 +01:00
// -- Master parameter control --------------------
2019-07-28 23:36:22 +01:00
# define CFG_HOLDER 4617 // [Reset 1] Change this value (max 32000) to load SECTION1 configuration parameters to flash
2020-08-17 13:19:53 +01:00
// If following define is disabled it increases configuration corruption detection BUT
// it only allows firmware upgrades starting from version 6.6.0.11
2018-04-02 10:24:36 +01:00
2018-04-05 14:26:16 +01:00
// -- Project -------------------------------------
2019-10-27 11:04:08 +00:00
# define PROJECT "tasmota" // PROJECT is used as the default topic delimiter
2018-12-15 14:55:51 +00:00
// If not selected the default will be SONOFF_BASIC
2020-06-17 13:19:20 +01:00
//#define MODULE SONOFF_BASIC // [Module] Select default module from tasmota_template.h
# ifdef ESP8266
# define FALLBACK_MODULE SONOFF_BASIC // [Module2] Select default module on fast reboot where USER_MODULE is user template
2020-12-20 15:40:49 +00:00
//#define USER_TEMPLATE "{\"NAME\":\"Generic\",\"GPIO\":[1,1,1,1,1,1,1,1,1,1,1,1,1,1],\"FLAG\":0,\"BASE\":18}" // [Template] Set JSON template
2020-11-28 11:46:17 +00:00
# endif // ESP8266
# ifdef ESP32
2020-06-17 13:19:20 +01:00
# define FALLBACK_MODULE WEMOS // [Module2] Select default module on fast reboot where USER_MODULE is user template
2020-06-24 15:37:02 +01:00
//#define USER_TEMPLATE "{\"NAME\":\"ESP32-DevKit\",\"GPIO\":[1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,1,0,1,1,1,0,0,0,0,1,1,1,1,1,0,0,1],\"FLAG\":0,\"BASE\":1}" // [Template] Set JSON template
2020-11-28 11:46:17 +00:00
# endif // ESP32
2018-04-02 10:24:36 +01:00
2017-01-28 13:41:01 +00:00
# define SAVE_DATA 1 // [SaveData] Save changed parameters to Flash (0 = disable, 1 - 3600 seconds)
2020-01-20 17:49:57 +00:00
# define SAVE_STATE true // [SetOption0] Save changed power state to Flash (false = disable, true = enable)
2019-01-30 13:34:31 +00:00
# define BOOT_LOOP_OFFSET 1 // [SetOption36] Number of boot loops before starting restoring defaults (0 = disable, 1..200 = boot loops offset)
2017-01-28 13:41:01 +00:00
2021-06-15 09:15:36 +01:00
// -- Wi-Fi ---------------------------------------
2019-09-08 16:30:17 +01:00
# define WIFI_IP_ADDRESS "0.0.0.0" // [IpAddress1] Set to 0.0.0.0 for using DHCP or enter a static IP address
# define WIFI_GATEWAY "192.168.1.1" // [IpAddress2] If not using DHCP set Gateway IP address
# define WIFI_SUBNETMASK "255.255.255.0" // [IpAddress3] If not using DHCP set Network mask
# define WIFI_DNS "192.168.1.1" // [IpAddress4] If not using DHCP set DNS IP address (might be equal to WIFI_GATEWAY)
2017-03-25 16:24:11 +00:00
2021-06-15 09:15:36 +01:00
# define STA_SSID1 "" // [Ssid1] Wi-Fi SSID
# define STA_PASS1 "" // [Password1] Wi-Fi password
# define STA_SSID2 "" // [Ssid2] Optional alternate AP Wi-Fi SSID
# define STA_PASS2 "" // [Password2] Optional alternate AP Wi-Fi password
2020-02-10 12:54:27 +00:00
# define WIFI_AP_PASSPHRASE "" // AccessPoint passphrase. For WPA2 min 8 char, for open use "" (max 63 char).
2021-06-15 09:15:36 +01:00
# define WIFI_CONFIG_TOOL WIFI_RETRY // [WifiConfig] Default tool if Wi-Fi fails to connect (default option: 4 - WIFI_RETRY)
2019-10-22 15:34:25 +01:00
// (WIFI_RESTART, WIFI_MANAGER, WIFI_RETRY, WIFI_WAIT, WIFI_SERIAL, WIFI_MANAGER_RESET_ONLY)
// The configuration can be changed after first setup using WifiConfig 0, 2, 4, 5, 6 and 7.
2020-04-13 11:27:53 +01:00
# define WIFI_ARP_INTERVAL 0 // [SetOption41] Send gratuitous ARP interval
2021-06-15 09:15:36 +01:00
# define WIFI_SCAN_AT_RESTART false // [SetOption56] Scan Wi-Fi network at restart for configured AP's
# define WIFI_SCAN_REGULARLY true // [SetOption57] Scan Wi-Fi network every 44 minutes for configured AP's
2017-09-02 13:37:02 +01:00
2017-01-28 13:41:01 +00:00
// -- Syslog --------------------------------------
2018-02-10 14:13:27 +00:00
# define SYS_LOG_HOST "" // [LogHost] (Linux) syslog host
2017-01-28 13:41:01 +00:00
# define SYS_LOG_PORT 514 // [LogPort] default syslog UDP port
2018-04-12 13:01:43 +01:00
# define SYS_LOG_LEVEL LOG_LEVEL_NONE // [SysLog] (LOG_LEVEL_NONE, LOG_LEVEL_ERROR, LOG_LEVEL_INFO, LOG_LEVEL_DEBUG, LOG_LEVEL_DEBUG_MORE)
# define SERIAL_LOG_LEVEL LOG_LEVEL_INFO // [SerialLog] (LOG_LEVEL_NONE, LOG_LEVEL_ERROR, LOG_LEVEL_INFO, LOG_LEVEL_DEBUG, LOG_LEVEL_DEBUG_MORE)
# define WEB_LOG_LEVEL LOG_LEVEL_INFO // [WebLog] (LOG_LEVEL_NONE, LOG_LEVEL_ERROR, LOG_LEVEL_INFO, LOG_LEVEL_DEBUG, LOG_LEVEL_DEBUG_MORE)
2019-10-04 09:24:21 +01:00
# define MQTT_LOG_LEVEL LOG_LEVEL_NONE // [MqttLog] (LOG_LEVEL_NONE, LOG_LEVEL_ERROR, LOG_LEVEL_INFO, LOG_LEVEL_DEBUG, LOG_LEVEL_DEBUG_MORE)
2017-01-28 13:41:01 +00:00
// -- Ota -----------------------------------------
2020-11-07 16:52:56 +00:00
# ifdef ESP8266
2020-10-28 12:24:22 +00:00
# define OTA_URL "http: //ota.tasmota.com/tasmota/release/tasmota.bin.gz" // [OtaUrl]
2020-11-28 11:46:17 +00:00
# endif // ESP8266
# ifdef ESP32
2020-11-28 14:43:49 +00:00
# define OTA_URL "http: //ota.tasmota.com/tasmota32/release/tasmota32.bin" // [OtaUrl]
2020-11-28 11:46:17 +00:00
# endif // ESP32
2018-03-02 14:38:37 +00:00
2017-01-28 13:41:01 +00:00
// -- MQTT ----------------------------------------
2020-01-20 17:49:57 +00:00
# define MQTT_USE true // [SetOption3] Select default MQTT use (false = Off, true = On)
2018-03-02 14:38:37 +00:00
2021-06-15 09:15:36 +01:00
# define MQTT_KEEPALIVE 30 // [MqttKeepAlive] Number of seconds between KeepAlive messages
# define MQTT_SOCKET_TIMEOUT 4 // [MqttTimeout] Number of seconds before Mqtt connection timeout
# define MQTT_WIFI_CLIENT_TIMEOUT 200 // [MqttWifiTimeout] Number of milliseconds before Mqtt Wi-Fi timeout
2021-03-18 16:44:10 +00:00
2018-04-05 14:26:16 +01:00
# define MQTT_HOST "" // [MqttHost]
2020-10-18 19:06:27 +01:00
# define MQTT_FINGERPRINT1 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 // [MqttFingerprint1] (auto-learn)
# define MQTT_FINGERPRINT2 0xDA,0x39,0xA3,0xEE,0x5E,0x6B,0x4B,0x0D,0x32,0x55,0xBF,0xEF,0x95,0x60,0x18,0x90,0xAF,0xD8,0x07,0x09 // [MqttFingerprint2] (invalid)
2018-04-05 14:26:16 +01:00
# define MQTT_PORT 1883 // [MqttPort] MQTT port (10123 on CloudMQTT)
# define MQTT_USER "DVES_USER" // [MqttUser] MQTT user
# define MQTT_PASS "DVES_PASS" // [MqttPassword] MQTT password
2017-01-28 13:41:01 +00:00
2020-01-20 17:49:57 +00:00
# define MQTT_BUTTON_RETAIN false // [ButtonRetain] Button may send retain flag (false = off, true = on)
# define MQTT_POWER_RETAIN false // [PowerRetain] Power status message may send retain flag (false = off, true = on)
# define MQTT_SWITCH_RETAIN false // [SwitchRetain] Switch may send retain flag (false = off, true = on)
2020-01-21 11:36:44 +00:00
# define MQTT_SENSOR_RETAIN false // [SensorRetain] Sensor may send retain flag (false = off, true = on)
2021-02-22 08:11:36 +00:00
# define MQTT_INFO_RETAIN false // [InfoRetain] Info may send retain flag (false = off, true = on)
# define MQTT_STATE_RETAIN false // [StateRetain] State may send retain flag (false = off, true = on)
2020-02-16 09:31:19 +00:00
# define MQTT_NO_HOLD_RETAIN false // [SetOption62] Disable retain flag on HOLD messages
2020-08-30 14:44:28 +01:00
# define MQTT_NO_RETAIN false // [SetOption104] No Retain - disable all MQTT retained messages, some brokers don't support it: AWS IoT, Losant
2017-01-28 13:41:01 +00:00
2017-03-29 17:42:05 +01:00
# define MQTT_STATUS_OFF "OFF" // [StateText1] Command or Status result when turned off (needs to be a string like "0" or "Off")
# define MQTT_STATUS_ON "ON" // [StateText2] Command or Status result when turned on (needs to be a string like "1" or "On")
# define MQTT_CMND_TOGGLE "TOGGLE" // [StateText3] Command to send when toggling (needs to be a string like "2" or "Toggle")
2017-06-06 22:23:23 +01:00
# define MQTT_CMND_HOLD "HOLD" // [StateText4] Command to send when button is kept down for over KEY_HOLD_TIME * 0.1 seconds (needs to be a string like "HOLD")
2017-01-28 13:41:01 +00:00
2017-05-08 12:21:45 +01:00
// -- MQTT topics ---------------------------------
2018-04-05 14:26:16 +01:00
// Example "tasmota/bedroom/%topic%/%prefix%/" up to 80 characers
2017-05-08 12:21:45 +01:00
# define MQTT_FULLTOPIC "%prefix% / %topic% / " // [FullTopic] Subscribe and Publish full topic name - Legacy topic
// %prefix% token options
2019-10-27 11:04:08 +00:00
# define SUB_PREFIX "cmnd" // [Prefix1] Tasmota devices subscribe to %prefix%/%topic% being SUB_PREFIX/MQTT_TOPIC and SUB_PREFIX/MQTT_GRPTOPIC
# define PUB_PREFIX "stat" // [Prefix2] Tasmota devices publish to %prefix%/%topic% being PUB_PREFIX/MQTT_TOPIC
# define PUB_PREFIX2 "tele" // [Prefix3] Tasmota devices publish telemetry data to %prefix%/%topic% being PUB_PREFIX2/MQTT_TOPIC/UPTIME, POWER and TIME
2017-05-08 12:21:45 +01:00
// May be named the same as PUB_PREFIX
// %topic% token options (also ButtonTopic and SwitchTopic)
2020-05-26 16:08:13 +01:00
# define MQTT_TOPIC PROJECT "_%06X" // [Topic] unique MQTT device topic including (part of) device MAC address
2019-10-27 11:04:08 +00:00
# define MQTT_GRPTOPIC "tasmotas" // [GroupTopic] MQTT Group topic
2020-01-20 17:49:57 +00:00
# define MQTT_GROUPTOPIC_FORMAT false // [SetOption75] GroupTopic replaces %topic% (false) or fixed topic cmnd/grouptopic (true)
2018-08-05 19:01:50 +01:00
# define MQTT_BUTTON_TOPIC "0" // [ButtonTopic] MQTT button topic, "0" = same as MQTT_TOPIC, set to 'PROJECT "_BTN_%06X"' for unique topic including device MAC address
# define MQTT_SWITCH_TOPIC "0" // [SwitchTopic] MQTT button topic, "0" = same as MQTT_TOPIC, set to 'PROJECT "_SW_%06X"' for unique topic including device MAC address
2020-05-26 16:08:13 +01:00
# define MQTT_CLIENT_ID "DVES_%06X" // [MqttClient] Also fall back topic using last 6 characters of MAC address or use "DVES_%12X" for complete MAC address
2017-05-08 12:21:45 +01:00
2017-01-28 13:41:01 +00:00
// -- MQTT - Telemetry ----------------------------
# define TELE_PERIOD 300 // [TelePeriod] Telemetry (0 = disable, 10 - 3600 seconds)
2020-01-20 17:49:57 +00:00
# define TELE_ON_POWER false // [SetOption59] send tele/STATE together with stat/RESULT (false = Disable, true = Enable)
2017-01-28 13:41:01 +00:00
// -- MQTT - Domoticz -----------------------------
2018-04-05 14:26:16 +01:00
# define DOMOTICZ_UPDATE_TIMER 0 // [DomoticzUpdateTimer] Send relay status (0 = disable, 1 - 3600 seconds)
2017-01-28 13:41:01 +00:00
2018-01-18 15:19:28 +00:00
// -- MQTT - Home Assistant Discovery -------------
2020-01-20 17:49:57 +00:00
# define HOME_ASSISTANT_DISCOVERY_ENABLE false // [SetOption19] Home Assistant Discovery (false = Disable, true = Enable)
# define HASS_AS_LIGHT false // [SetOption30] Enforce HAss autodiscovery as light
2020-06-18 18:43:18 +01:00
//#define DEEPSLEEP_LWT_HA_DISCOVERY // Enable LWT topic and its payloads for read-only sensors (Status sensor not included) and binary_sensors on HAss Discovery (Commented out: all read-only sensors and binary_sensors
// won't be shown as OFFLINE on Home Assistant when the device is DeepSleeping - NOTE: This is only for read-only sensors and binary_sensors, relays will be shown as OFFLINE)
2020-01-20 17:49:57 +00:00
// -- MQTT - Options ------------------------------
# define MQTT_RESULT_COMMAND false // [SetOption4] Switch between MQTT RESULT or COMMAND
# define MQTT_LWT_MESSAGE false // [SetOption10] Switch between MQTT LWT OFFLINE or empty message
# define MQTT_POWER_FORMAT false // [SetOption26] Switch between POWER or POWER1 for single power devices
# define MQTT_APPEND_TIMEZONE false // [SetOption52] Append timezone to JSON time
2020-02-16 09:31:19 +00:00
# define MQTT_BUTTON_SWITCH_FORCE_LOCAL false // [SetOption61] Force local operation when button/switch topic is set (false = off, true = on)
2020-01-20 17:49:57 +00:00
# define MQTT_INDEX_SEPARATOR false // [SetOption64] Enable "_" instead of "-" as sensor index separator
# define MQTT_TUYA_RECEIVED false // [SetOption66] Enable TuyaMcuReceived messages over Mqtt
2020-08-30 14:44:28 +01:00
# define MQTT_TLS_ENABLED false // [SetOption103] Enable TLS mode (requires TLS version)
2018-01-18 15:19:28 +00:00
2017-01-28 13:41:01 +00:00
// -- HTTP ----------------------------------------
2018-04-05 14:26:16 +01:00
# define WEB_SERVER 2 // [WebServer] Web server (0 = Off, 1 = Start as User, 2 = Start as Admin)
# define WEB_PASSWORD "" // [WebPassword] Web server Admin mode Password for WEB_USERNAME (empty string = Disable)
2019-10-27 11:04:08 +00:00
# define FRIENDLY_NAME "Tasmota" // [FriendlyName] Friendlyname up to 32 characters used by webpages and Alexa
2018-04-05 14:26:16 +01:00
# define EMULATION EMUL_NONE // [Emulation] Select Belkin WeMo (single relay/light) or Hue Bridge emulation (multi relay/light) (EMUL_NONE, EMUL_WEMO or EMUL_HUE)
2020-08-30 14:44:28 +01:00
# define EMULATION_HUE_1ST_GEN false // [Emulation] Force SetOption109 1 - if you only have Echo Dot 2nd gen devices
2019-12-09 14:15:16 +00:00
# define CORS_DOMAIN "" // [Cors] CORS Domain for preflight requests
2020-01-20 17:49:57 +00:00
// -- HTTP Options --------------------------------
# define GUI_SHOW_HOSTNAME false // [SetOption53] Show hostname and IP address in GUI main menu
2019-10-28 08:54:23 +00:00
// -- HTTP GUI Colors -----------------------------
2019-04-09 08:37:29 +01:00
// HTML hex color codes. Only 3 and 6 digit hex string values are supported!! See https://www.w3schools.com/colors/colors_hex.asp
2019-11-06 10:16:43 +00:00
// Light theme - pre v7
// WebColor {"WebColor":["#000","#fff","#f2f2f2","#000","#fff","#000","#fff","#f00","#008000","#fff","#1fa3ec","#0e70a4","#d43535","#931f1f","#47c266","#5aaf6f","#fff","#999","#000"]}
2019-10-28 08:54:23 +00:00
/*
2019-04-09 08:37:29 +01:00
# define COLOR_TEXT "#000" // [WebColor1] Global text color - Black
# define COLOR_BACKGROUND "#fff" // [WebColor2] Global background color - White
# define COLOR_FORM "#f2f2f2" // [WebColor3] Form background color - Greyish
# define COLOR_INPUT_TEXT "#000" // [WebColor4] Input text color - Black
# define COLOR_INPUT "#fff" // [WebColor5] Input background color - White
# define COLOR_CONSOLE_TEXT "#000" // [WebColor6] Console text color - Black
# define COLOR_CONSOLE "#fff" // [WebColor7] Console background color - White
# define COLOR_TEXT_WARNING "#f00" // [WebColor8] Warning text color - Red
2019-11-06 10:16:43 +00:00
# define COLOR_TEXT_SUCCESS "#008000" // [WebColor9] Success text color - Dark lime green
2019-04-09 08:37:29 +01:00
# define COLOR_BUTTON_TEXT "#fff" // [WebColor10] Button text color - White
2019-11-06 10:16:43 +00:00
# define COLOR_BUTTON "#1fa3ec" // [WebColor11] Button color - Vivid blue
# define COLOR_BUTTON_HOVER "#0e70a4" // [WebColor12] Button color when hovered over - Dark blue
# define COLOR_BUTTON_RESET "#d43535" // [WebColor13] Restart/Reset/Delete button color - Strong red
# define COLOR_BUTTON_RESET_HOVER "#931f1f" // [WebColor14] Restart/Reset/Delete button color when hovered over - Dark red
# define COLOR_BUTTON_SAVE "#47c266" // [WebColor15] Save button color - Moderate lime green
# define COLOR_BUTTON_SAVE_HOVER "#5aaf6f" // [WebColor16] Save button color when hovered over - Dark moderate lime green
2019-04-09 08:37:29 +01:00
# define COLOR_TIMER_TAB_TEXT "#fff" // [WebColor17] Config timer tab text color - White
2019-11-06 10:16:43 +00:00
# define COLOR_TIMER_TAB_BACKGROUND "#999" // [WebColor18] Config timer tab background color - Dark gray
# define COLOR_TITLE_TEXT "#000" // [WebColor19] Title text color - Whiteish
*/
// Dark theme
// WebColor {"WebColor":["#eaeaea","#252525","#4f4f4f","#000","#ddd","#65c115","#1f1f1f","#ff5661","#008000","#faffff","#1fa3ec","#0e70a4","#d43535","#931f1f","#47c266","#5aaf6f","#faffff","#999","#eaeaea"]}
# define COLOR_TEXT "#eaeaea" // [WebColor1] Global text color - Very light gray
# define COLOR_BACKGROUND "#252525" // [WebColor2] Global background color - Very dark gray (mostly black)
# define COLOR_FORM "#4f4f4f" // [WebColor3] Form background color - Very dark gray
# define COLOR_INPUT_TEXT "#000" // [WebColor4] Input text color - Black
# define COLOR_INPUT "#ddd" // [WebColor5] Input background color - Very light gray
# define COLOR_CONSOLE_TEXT "#65c115" // [WebColor6] Console text color - Strong Green
# define COLOR_CONSOLE "#1f1f1f" // [WebColor7] Console background color - Very dark gray (mostly black)
# define COLOR_TEXT_WARNING "#ff5661" // [WebColor8] Warning text color - Brick Red
# define COLOR_TEXT_SUCCESS "#008000" // [WebColor9] Success text color - Dark lime green
# define COLOR_BUTTON_TEXT "#faffff" // [WebColor10] Button text color - Very pale (mostly white) cyan
# define COLOR_BUTTON "#1fa3ec" // [WebColor11] Button color - Vivid blue
# define COLOR_BUTTON_HOVER "#0e70a4" // [WebColor12] Button color when hovered over - Dark blue
# define COLOR_BUTTON_RESET "#d43535" // [WebColor13] Restart/Reset/Delete button color - Strong red
# define COLOR_BUTTON_RESET_HOVER "#931f1f" // [WebColor14] Restart/Reset/Delete button color when hovered over - Dark red
# define COLOR_BUTTON_SAVE "#47c266" // [WebColor15] Save button color - Moderate lime green
# define COLOR_BUTTON_SAVE_HOVER "#5aaf6f" // [WebColor16] Save button color when hovered over - Dark moderate lime green
# define COLOR_TIMER_TAB_TEXT "#faffff" // [WebColor17] Config timer tab text color - Very pale (mostly white) cyan.
# define COLOR_TIMER_TAB_BACKGROUND "#999" // [WebColor18] Config timer tab background color - Dark gray
# define COLOR_TITLE_TEXT "#eaeaea" // [WebColor19] Title text color - Very light gray
2017-01-28 13:41:01 +00:00
2020-01-21 11:36:44 +00:00
// -- KNX -----------------------------------------
# define KNX_ENABLED false // [Knx_Enabled] Enable KNX protocol
# define KNX_ENHANCED false // [Knx_Enhanced] Enable KNX Enhanced Mode
2019-01-14 09:57:01 +00:00
// -- mDNS ----------------------------------------
2020-01-20 17:49:57 +00:00
# define MDNS_ENABLED false // [SetOption55] Use mDNS (false = Disable, true = Enable)
2019-01-14 09:57:01 +00:00
2017-01-28 13:41:01 +00:00
// -- Time - Up to three NTP servers in your region
2017-03-12 17:36:33 +00:00
# define NTP_SERVER1 "pool.ntp.org" // [NtpServer1] Select first NTP server by name or IP address (129.250.35.250)
# define NTP_SERVER2 "nl.pool.ntp.org" // [NtpServer2] Select second NTP server by name or IP address (5.39.184.5)
# define NTP_SERVER3 "0.nl.pool.ntp.org" // [NtpServer3] Select third NTP server by name or IP address (93.94.224.67)
2017-01-28 13:41:01 +00:00
2018-05-13 18:43:48 +01:00
// -- Time - Start Daylight Saving Time and timezone offset from UTC in minutes
2018-10-26 16:13:17 +01:00
# define TIME_DST_HEMISPHERE North // [TimeDst] Hemisphere (0 or North, 1 or South)
# define TIME_DST_WEEK Last // Week of month (0 or Last, 1 or First, 2 or Second, 3 or Third, 4 or Fourth)
# define TIME_DST_DAY Sun // Day of week (1 or Sun, 2 or Mon, 3 or Tue, 4 or Wed, 5 or Thu, 6 or Fri, 7 or Sat)
# define TIME_DST_MONTH Mar // Month (1 or Jan, 2 or Feb, 3 or Mar, 4 or Apr, 5 or May, 6 or Jun, 7 or Jul, 8 or Aug, 9 or Sep, 10 or Oct, 11 or Nov, 12 or Dec)
# define TIME_DST_HOUR 2 // Hour (0 to 23)
# define TIME_DST_OFFSET +120 // Offset from UTC in minutes (-780 to +780)
2018-05-13 18:43:48 +01:00
// -- Time - Start Standard Time and timezone offset from UTC in minutes
2018-10-26 16:13:17 +01:00
# define TIME_STD_HEMISPHERE North // [TimeStd] Hemisphere (0 or North, 1 or South)
# define TIME_STD_WEEK Last // Week of month (0 or Last, 1 or First, 2 or Second, 3 or Third, 4 or Fourth)
# define TIME_STD_DAY Sun // Day of week (1 or Sun, 2 or Mon, 3 or Tue, 4 or Wed, 5 or Thu, 6 or Fri, 7 or Sat)
# define TIME_STD_MONTH Oct // Month (1 or Jan, 2 or Feb, 3 or Mar, 4 or Apr, 5 or May, 6 or Jun, 7 or Jul, 8 or Aug, 9 or Sep, 10 or Oct, 11 or Nov, 12 or Dec)
# define TIME_STD_HOUR 3 // Hour (0 to 23)
# define TIME_STD_OFFSET +60 // Offset from UTC in minutes (-780 to +780)
2018-05-13 18:43:48 +01:00
2018-04-05 14:26:16 +01:00
// -- Location ------------------------------------
# define LATITUDE 48.858360 // [Latitude] Your location to be used with sunrise and sunset
# define LONGITUDE 2.294442 // [Longitude] Your location to be used with sunrise and sunset
2017-01-28 13:41:01 +00:00
// -- Application ---------------------------------
2018-04-05 14:26:16 +01:00
# define APP_TIMEZONE 1 // [Timezone] +1 hour (Amsterdam) (-13 .. 14 = hours from UTC, 99 = use TIME_DST/TIME_STD)
# define APP_LEDSTATE LED_POWER // [LedState] Function of led
// (LED_OFF, LED_POWER, LED_MQTTSUB, LED_POWER_MQTTSUB, LED_MQTTPUB, LED_POWER_MQTTPUB, LED_MQTT, LED_POWER_MQTT)
2019-04-10 13:26:36 +01:00
# define APP_LEDMASK 0xFFFF // [LedMask] Assign Relay to Power led (0xFFFF is default)
2020-01-20 17:49:57 +00:00
# define APP_ENABLE_LEDLINK false // [SetOption31] Enable link led blinking
2017-01-28 13:41:01 +00:00
# define APP_PULSETIME 0 // [PulseTime] Time in 0.1 Sec to turn off power for relay 1 (0 = disabled)
2018-04-05 14:26:16 +01:00
# define APP_POWERON_STATE POWER_ALL_SAVED // [PowerOnState] Power On Relay state
// (POWER_ALL_OFF, POWER_ALL_ON, POWER_ALL_SAVED_TOGGLE, POWER_ALL_SAVED, POWER_ALL_ALWAYS_ON, POWER_ALL_OFF_PULSETIME_ON)
2017-01-28 13:41:01 +00:00
# define APP_BLINKTIME 10 // [BlinkTime] Time in 0.1 Sec to blink/toggle power for relay 1
# define APP_BLINKCOUNT 10 // [BlinkCount] Number of blinks (0 = 32000)
2020-01-20 17:49:57 +00:00
2020-11-12 10:48:13 +00:00
# define APP_NORMAL_SLEEP false // [SetOption60] Enable normal sleep instead of dynamic sleep
2019-11-24 18:35:54 +00:00
# define APP_SLEEP 0 // [Sleep] Sleep time to lower energy consumption (0 = Off, 1 - 250 mSec),
2020-10-13 11:02:44 +01:00
# define PWM_MAX_SLEEP 10 // Sleep will be lowered to this value when light is on, to avoid flickering, and when buzzer is on for better on/off period accuracy
2017-01-28 13:41:01 +00:00
2018-08-27 11:01:20 +01:00
# define KEY_DEBOUNCE_TIME 50 // [ButtonDebounce] Number of mSeconds button press debounce time
2017-06-16 13:33:49 +01:00
# define KEY_HOLD_TIME 40 // [SetOption32] Number of 0.1 seconds to hold Button or external Pushbutton before sending HOLD message
2020-01-20 17:49:57 +00:00
# define KEY_DISABLE_MULTIPRESS false // [SetOption1] Disable button multipress
# define KEY_SWAP_DOUBLE_PRESS false // [SetOption11] Swap button single and double press functionality
# define KEY_ONLY_SINGLE_PRESS false // [SetOption13] Enable only single press to speed up button press recognition
2021-03-02 21:47:40 +00:00
# define MQTT_BUTTONS false // [SetOption73] Detach buttons from relays and send multi-press and hold MQTT messages instead
2018-08-27 11:01:20 +01:00
# define SWITCH_DEBOUNCE_TIME 50 // [SwitchDebounce] Number of mSeconds switch press debounce time
2020-01-15 15:12:55 +00:00
# define SWITCH_MODE TOGGLE // [SwitchMode] TOGGLE, FOLLOW, FOLLOW_INV, PUSHBUTTON, PUSHBUTTON_INV, PUSHBUTTONHOLD, PUSHBUTTONHOLD_INV, PUSHBUTTON_TOGGLE, TOGGLEMULTI, FOLLOWMULTI, FOLLOWMULTI_INV (the wall switch state)
2021-03-02 21:47:40 +00:00
# define MQTT_SWITCHES false // [SetOption114] Detach switches from relays and send MQTT messages instead
2017-01-28 13:41:01 +00:00
2020-01-20 17:49:57 +00:00
# define TEMP_CONVERSION false // [SetOption8] Return temperature in (false = Celsius or true = Fahrenheit)
# define PRESSURE_CONVERSION false // [SetOption24] Return pressure in (false = hPa or true = mmHg)
2017-05-03 17:19:13 +01:00
# define TEMP_RESOLUTION 1 // [TempRes] Maximum number of decimals (0 - 3) showing sensor Temperature
# define HUMIDITY_RESOLUTION 1 // [HumRes] Maximum number of decimals (0 - 3) showing sensor Humidity
# define PRESSURE_RESOLUTION 1 // [PressRes] Maximum number of decimals (0 - 3) showing sensor Pressure
# define ENERGY_RESOLUTION 3 // [EnergyRes] Maximum number of decimals (0 - 5) showing energy usage in kWh
2018-12-15 14:55:51 +00:00
# define CALC_RESOLUTION 3 // [CalcRes] Maximum number of decimals (0 - 7) used in commands ADD, SUB, MULT and SCALE
2017-01-28 13:41:01 +00:00
2020-01-20 17:49:57 +00:00
# define APP_FLASH_CYCLE false // [SetOption12] Switch between dynamic or fixed slot flash save location
# define APP_NO_RELAY_SCAN false // [SetOption63] Don't scan relay power state at restart
# define APP_DISABLE_POWERCYCLE false // [SetOption65] Disable fast power cycle detection for device reset
2020-01-21 11:36:44 +00:00
# define DEEPSLEEP_BOOTCOUNT false // [SetOption76] Enable incrementing bootcount when deepsleep is enabled
2020-01-20 17:49:57 +00:00
2020-06-22 21:36:54 +01:00
# define APP_INTERLOCK_MODE false // [Interlock] Relay interlock mode
# define APP_INTERLOCK_GROUP_1 0xFF // [Interlock] Relay bitmask for interlock group 1 (0xFF if undef)
//#define APP_INTERLOCK_GROUP_2 0x00 // [Interlock] Relay bitmask for interlock group 2 (0x00 if undef)
//#define APP_INTERLOCK_GROUP_3 0x00 // [Interlock] Relay bitmask for interlock group 3 (0x00 if undef)
//#define APP_INTERLOCK_GROUP_4 0x00 // [Interlock] Relay bitmask for interlock group 4 (0x00 if undef)
2020-01-20 17:49:57 +00:00
// -- Lights --------------------------------------
2020-01-21 11:36:44 +00:00
# define WS2812_LEDS 30 // [Pixels] Number of WS2812 LEDs to start with (max is 512)
2020-01-20 17:49:57 +00:00
# define LIGHT_MODE true // [SetOption15] Switch between commands PWM or COLOR/DIMMER/CT/CHANNEL
# define LIGHT_CLOCK_DIRECTION false // [SetOption16] Switch WS2812 clock between clockwise or counter-clockwise
# define LIGHT_COLOR_RADIX false // [SetOption17] Switch between decimal or hexadecimal color output (false = hexadecimal, true = decimal)
# define LIGHT_PAIRS_CO2 false // [SetOption18] Enable Pair light signal with CO2 sensor
# define LIGHT_POWER_CONTROL false // [SetOption20] Enable power control in relation to Dimmer/Color/Ct changes
# define LIGHT_CHANNEL_MODE false // [SetOption68] Enable multi-channels PWM instead of Color PWM
# define LIGHT_SLIDER_POWER false // [SetOption77] Do not power off if slider moved to far left
# define LIGHT_ALEXA_CT_RANGE false // [SetOption82] Reduced CT range for Alexa
2020-04-22 18:43:57 +01:00
# define LIGHT_PWM_CT_MODE false // [SetOption92] Set PWM Mode from regular PWM to ColorTemp control (Xiaomi Philips ...) a.k.a. module 48 mode
2020-08-30 14:44:28 +01:00
# define LIGHT_WHITE_BLEND_MODE false // [SetOption105] White Blend Mode - used to be `RGBWWTable` last value `0`, now deprecated in favor of this option
# define LIGHT_VIRTUAL_CT false // [SetOption106] Virtual CT - Creates a virtual White ColorTemp for RGBW lights
# define LIGHT_VIRTUAL_CT_CW false // [SetOption107] Virtual CT Channel - signals whether the hardware white is cold CW (true) or warm WW (false)
2020-12-29 18:31:27 +00:00
# define LIGHT_VIRTUAL_CT_POINTS 3 // Number of reference points for Virtual CT (min 2, default 3)
2020-01-20 17:49:57 +00:00
// -- Energy --------------------------------------
# define ENERGY_VOLTAGE_ALWAYS false // [SetOption21] Enable show voltage even if powered off
# define ENERGY_DDS2382_MODE false // [SetOption71] Enable DDS2382 different Modbus registers for Active Energy (#6531)
2020-01-21 11:36:44 +00:00
# define ENERGY_HARDWARE_TOTALS false // [SetOption72] Enable hardware energy total counter as reference (#6561)
2020-01-20 17:49:57 +00:00
// -- Other Options -------------------------------
2020-01-21 11:36:44 +00:00
# define TIMERS_ENABLED false // [Timers] Enable Timers
2020-01-20 17:49:57 +00:00
# define RF_DATA_RADIX false // [SetOption28] RF receive data format (false = hexadecimal, true = decimal)
# define IR_DATA_RADIX false // [SetOption29] IR receive data format (false = hexadecimal, true = decimal)
# define TUYA_SETOPTION_20 false // [SetOption54] Apply SetOption20 settings to Tuya device
2021-04-19 11:25:53 +01:00
# define TUYA_TEMP_SET_RES 1 // [TuyaTempSetRes] Maximum number of decimals (0 - 3) showing sensor TemperatureSet
2020-01-20 17:49:57 +00:00
# define IR_ADD_RAW_DATA false // [SetOption58] Add IR Raw data to JSON message
# define BUZZER_ENABLE false // [SetOption67] Enable buzzer when available
# define DS18X20_PULL_UP false // [SetOption74] Enable internal pullup for single DS18x20 sensor
# define COUNTER_RESET false // [SetOption79] Enable resetting of counters after telemetry was sent
# define SHUTTER_SUPPORT false // [SetOption80] Enable shutter support
# define PCF8574_INVERT_PORTS false // [SetOption81] Invert all ports on PCF8574 devices
# define ZIGBEE_FRIENDLY_NAMES false // [SetOption83] Enable Zigbee FriendlyNames instead of ShortAddresses when possible
2021-03-02 21:47:40 +00:00
# define ZIGBEE_DISTINCT_TOPICS false // [SetOption89] Enable unique device topic based on Zigbee device ShortAddr
2020-08-30 14:44:28 +01:00
# define ZIGBEE_RMV_ZBRECEIVED false // [SetOption100] Remove ZbReceived form JSON message
# define ZIGBEE_INDEX_EP false // [SetOption101] Add the source endpoint as suffix to attributes, ex `Power3` instead of `Power` if sent from endpoint 3
2020-01-20 17:49:57 +00:00
2018-04-05 14:26:16 +01:00
/*********************************************************************************************\
* END OF SECTION 1
*
* SECTION 2
* - Enable a feature by removing both // in front of it
* - Disable a feature by preceding it with //
\ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
// -- Localization --------------------------------
// If non selected the default en-GB will be used
2020-12-27 20:30:06 +00:00
//#define MY_LANGUAGE af_AF // Afrikaans in South Africa
2020-05-05 16:09:48 +01:00
//#define MY_LANGUAGE bg_BG // Bulgarian in Bulgaria
//#define MY_LANGUAGE cs_CZ // Czech in Czech
//#define MY_LANGUAGE de_DE // German in Germany
//#define MY_LANGUAGE el_GR // Greek in Greece
//#define MY_LANGUAGE en_GB // English in Great Britain. Enabled by Default
//#define MY_LANGUAGE es_ES // Spanish in Spain
//#define MY_LANGUAGE fr_FR // French in France
2021-03-24 05:26:35 +00:00
//#define MY_LANGUAGE fy_NL // Frysk in Nederland
2020-05-05 16:09:48 +01:00
//#define MY_LANGUAGE he_HE // Hebrew in Israel
//#define MY_LANGUAGE hu_HU // Hungarian in Hungary
//#define MY_LANGUAGE it_IT // Italian in Italy
//#define MY_LANGUAGE ko_KO // Korean in Korea
2021-03-24 05:26:35 +00:00
//#define MY_LANGUAGE nl_NL // Dutch in the Nederland
2020-05-05 16:09:48 +01:00
//#define MY_LANGUAGE pl_PL // Polish in Poland
//#define MY_LANGUAGE pt_BR // Portuguese in Brazil
//#define MY_LANGUAGE pt_PT // Portuguese in Portugal
//#define MY_LANGUAGE ro_RO // Romanian in Romania
//#define MY_LANGUAGE ru_RU // Russian in Russia
//#define MY_LANGUAGE sk_SK // Slovak in Slovakia
//#define MY_LANGUAGE sv_SE // Swedish in Sweden
//#define MY_LANGUAGE tr_TR // Turkish in Turkey
//#define MY_LANGUAGE uk_UA // Ukrainian in Ukraine
2020-10-12 10:53:18 +01:00
//#define MY_LANGUAGE vi_VN // Vietnamese in Vietnam
2020-05-05 16:09:48 +01:00
//#define MY_LANGUAGE zh_CN // Chinese (Simplified) in China
//#define MY_LANGUAGE zh_TW // Chinese (Traditional) in Taiwan
2018-04-05 14:26:16 +01:00
2018-07-15 16:30:38 +01:00
// -- Wifi Config tools ---------------------------
2021-06-15 09:15:36 +01:00
# define WIFI_SOFT_AP_CHANNEL 1 // Soft Access Point Channel number between 1 and 13 as used by Wi-Fi Manager web GUI
2018-07-14 14:35:56 +01:00
// -- OTA -----------------------------------------
//#define USE_ARDUINO_OTA // Add optional support for Arduino OTA (+13k code)
2018-04-25 11:06:53 +01:00
// -- MQTT ----------------------------------------
2020-09-27 11:51:50 +01:00
# define MQTT_LWT_OFFLINE "Offline" // MQTT LWT offline topic message
# define MQTT_LWT_ONLINE "Online" // MQTT LWT online topic message
# define MQTT_TELE_RETAIN 0 // Tele messages may send retain flag (0 = off, 1 = on)
# define MQTT_CLEAN_SESSION 1 // Mqtt clean session connection (0 = No clean session, 1 = Clean session (default))
2018-04-25 11:06:53 +01:00
2018-04-05 14:26:16 +01:00
// -- MQTT - Domoticz -----------------------------
# define USE_DOMOTICZ // Enable Domoticz (+6k code, +0.3k mem)
# define DOMOTICZ_IN_TOPIC "domoticz / in" // Domoticz Input Topic
# define DOMOTICZ_OUT_TOPIC "domoticz / out" // Domoticz Output Topic
// -- MQTT - Home Assistant Discovery -------------
2021-04-10 17:20:15 +01:00
# define USE_HOME_ASSISTANT // Enable Home Assistant Discovery Support (+12k code, +6 bytes mem)
2020-08-14 21:02:55 +01:00
# define HOME_ASSISTANT_DISCOVERY_PREFIX "homeassistant" // Home Assistant discovery prefix
2020-08-15 19:23:37 +01:00
# define HOME_ASSISTANT_LWT_TOPIC "homeassistant / status" // home Assistant Birth and Last Will Topic (default = homeassistant/status)
2020-08-14 21:02:55 +01:00
# define HOME_ASSISTANT_LWT_SUBSCRIBE true // Subscribe to Home Assistant Birth and Last Will Topic (default = true)
2018-04-05 14:26:16 +01:00
2021-04-10 17:20:15 +01:00
// -- MQTT - Tasmota Discovery ---------------------
//#define USE_TASMOTA_DISCOVERY // Enable Tasmota Discovery support (+2k code)
2019-06-11 13:30:07 +01:00
// -- MQTT - TLS - AWS IoT ------------------------
2019-06-19 08:49:48 +01:00
// Using TLS starting with version v6.5.0.16 compilation will only work using Core 2.4.2 and 2.5.2. No longer supported: 2.3.0
//#define USE_MQTT_TLS // Use TLS for MQTT connection (+34.5k code, +7.0k mem and +4.8k additional during connection handshake)
2019-11-24 09:26:57 +00:00
// #define USE_MQTT_TLS_CA_CERT // Force full CA validation instead of fingerprints, slower, but simpler to use. (+2.2k code, +1.9k mem during connection handshake)
2019-11-29 17:28:25 +00:00
// This includes the LetsEncrypt CA in tasmota_ca.ino for verifying server certificates
2019-07-12 07:11:40 +01:00
// #define USE_MQTT_TLS_FORCE_EC_CIPHER // Force Elliptic Curve cipher (higher security) required by some servers (automatically enabled with USE_MQTT_AWS_IOT) (+11.4k code, +0.4k mem)
2020-09-08 20:22:52 +01:00
// #define USE_MQTT_AWS_IOT_LIGHT // Enable MQTT for AWS IoT in light mode, with user/password instead of private certificate
// #define USE_MQTT_AWS_IOT // [Deprecated] Enable MQTT for AWS IoT - requires a private key (+11.9k code, +0.4k mem)
2019-10-27 11:04:08 +00:00
// Note: you need to generate a private key + certificate per device and update 'tasmota/tasmota_aws_iot.cpp'
2019-10-27 10:13:24 +00:00
// Full documentation here: https://github.com/arendst/Tasmota/wiki/AWS-IoT
2021-01-16 17:07:01 +00:00
// #define USE_MQTT_TLS_DROP_OLD_FINGERPRINT // If you use fingerprint (i.e. not CA) validation, the algorithm changed to a more secure one.
// Any valid fingerprint with the old algo will be automatically updated to the new algo.
// Enable this if you want to disable the old algo check, which should be more secure
2020-11-14 18:19:45 +00:00
// for USE_4K_RSA (support for 4096 bits certificates, instead of 2048), you need to uncommend `-DUSE_4K_RSA` in `build_flags` from `platform.ini` or `platform_override.ini`
2021-05-13 18:12:21 +01:00
// -- MQTT - TLS - Azure IoT & IoT Central ---------
// Starting with version v9.4.0.3 added support for both Azure IoT Hub and IoT Central
//#define USE_MQTT_TLS // REQUIRED Use TLS for MQTT connection (+34.5k code, +7.0k mem and +4.8k additional during connection handshake)
// #define USE_MQTT_AZURE_IOT // REQUIRED Enable accesss to IoT Hub without DPS using a preshared key: https://tasmota.github.io/docs/Azure-IoT-Hub/ Enable MQTT for Azure IoT Hub (+1k code)
// #define USE_MQTT_AZURE_DPS_SCOPEID // OPTIONAL Enables Azure Device Provisioning Service (DPS) for provision at scale, REQUIRED for IoT Central. Uses the REST over HTTPS protocol (+4k memory)
// #define USE_MQTT_AZURE_DPS_PRESHAREDKEY // OPTIONAL The Preshared Key of DPS https://github.com/tasmota/docs/blob/development/docs/Azure-IoT-Central.md
// #define USE_MQTT_AZURE_DPS_SCOPE_ENDPOINT // OPTIONAL Defaults to "https://global.azure-devices-provisioning.net/", can be changed for Azure China, Azure Germany or others.
2019-06-05 10:44:52 +01:00
2020-06-11 16:30:33 +01:00
// -- Telegram Protocol ---------------------------
//#define USE_TELEGRAM // Support for Telegram protocol (+49k code, +7.0k mem and +4.8k additional during connection handshake)
# define USE_TELEGRAM_FINGERPRINT "\xB2\x72\x47\xA6\x69\x8C\x3C\x69\xF9\x58\x6C\xF3\x60\x02\xFB\x83\xFA\x8B\x1F\x23" // Telegram api.telegram.org TLS public key fingerpring
// #define USE_MQTT_TLS_CA_CERT // Use certificate instead of fingerprint
2018-04-18 16:28:45 +01:00
// -- KNX IP Protocol -----------------------------
2018-07-23 04:54:25 +01:00
//#define USE_KNX // Enable KNX IP Protocol Support (+9.4k code, +3k7 mem)
# define USE_KNX_WEB_MENU // Enable KNX WEB MENU (+8.3k code, +144 mem)
2018-04-18 16:28:45 +01:00
2018-04-05 14:26:16 +01:00
// -- HTTP ----------------------------------------
2021-06-15 09:15:36 +01:00
# define USE_WEBSERVER // Enable web server and Wi-Fi Manager (+66k code, +8k mem)
2018-04-05 14:26:16 +01:00
# define WEB_PORT 80 // Web server Port for User and Admin mode
# define WEB_USERNAME "admin" // Web server Admin mode user name
2019-06-12 16:32:25 +01:00
// #define USE_JAVASCRIPT_ES6 // Enable ECMAScript6 syntax using less JavaScript code bytes (fails on IE11)
2021-06-15 09:15:36 +01:00
# define USE_ENHANCED_GUI_WIFI_SCAN // Enable Wi-Fi scan output with BSSID (+0k5 code)
2019-08-19 09:36:42 +01:00
// #define USE_WEBSEND_RESPONSE // Enable command WebSend response message (+1k code)
2019-05-20 14:09:42 +01:00
# define USE_EMULATION_HUE // Enable Hue Bridge emulation for Alexa (+14k code, +2k mem common)
# define USE_EMULATION_WEMO // Enable Belkin WeMo emulation for Alexa (+6k code, +2k mem common)
2020-11-24 19:29:28 +00:00
// #define USE_CCLOADER // Enable CCLoader FW upgrade tool (for CC25xx devices)
2018-04-05 14:26:16 +01:00
// -- mDNS ----------------------------------------
2020-12-08 10:49:11 +00:00
//#define USE_DISCOVERY // Enable mDNS for the following services (+8k code or +23.5k code with core 2_5_x, +0.3k mem)
2018-04-05 14:26:16 +01:00
# define WEBSERVER_ADVERTISE // Provide access to webserver by name <Hostname>.local/
# define MQTT_HOST_DISCOVERY // Find MQTT host server (overrides MQTT_HOST if found)
// -- Time ----------------------------------------
# define USE_TIMERS // Add support for up to 16 timers (+2k2 code)
# define USE_TIMERS_WEB // Add timer webpage support (+4k5 code)
# define USE_SUNRISE // Add support for Sunrise and sunset tools (+16k)
2018-04-23 10:37:46 +01:00
# define SUNRISE_DAWN_ANGLE DAWN_NORMAL // Select desired Dawn Angle from (DAWN_NORMAL, DAWN_CIVIL, DAWN_NAUTIC, DAWN_ASTRONOMIC)
2018-04-05 14:26:16 +01:00
2020-04-10 19:51:15 +01:00
// -- Ping ----------------------------------------
2020-04-15 17:55:04 +01:00
// #define USE_PING // Enable Ping command (+2k code)
2020-04-10 19:51:15 +01:00
2020-06-07 16:21:29 +01:00
// -- Compression ---------------------------------
# define USE_UNISHOX_COMPRESSION // Add support for string compression in Rules or Scripts
2020-06-06 19:04:10 +01:00
2019-05-18 12:34:52 +01:00
// -- Rules or Script ----------------------------
2020-05-10 13:39:13 +01:00
// Select none or only one of the below defines USE_RULES or USE_SCRIPT
2019-07-09 09:48:03 +01:00
# define USE_RULES // Add support for rules (+8k code)
2020-06-07 16:21:29 +01:00
// #define USE_EXPRESSION // Add support for expression evaluation in rules (+3k2 code, +64 bytes mem)
// #define SUPPORT_IF_STATEMENT // Add support for IF statement in rules (+4k2 code, -332 bytes mem)
2021-05-02 16:57:03 +01:00
// #define USER_RULE1 "<Any rule1 data>" // Add rule1 data saved at initial firmware load or when command reset is executed
// #define USER_RULE2 "<Any rule2 data>" // Add rule2 data saved at initial firmware load or when command reset is executed
// #define USER_RULE3 "<Any rule3 data>" // Add rule3 data saved at initial firmware load or when command reset is executed
2020-06-07 16:21:29 +01:00
2019-07-09 09:48:03 +01:00
//#define USE_SCRIPT // Add support for script (+17k code)
2021-05-02 16:57:03 +01:00
// #define USE_SCRIPT_FATFS 4 // Script: Add FAT FileSystem Support
2019-03-07 16:47:14 +00:00
// #define SUPPORT_MQTT_EVENT // Support trigger event with MQTT subscriptions (+3k5 code)
2018-04-13 16:42:11 +01:00
2021-05-02 16:57:03 +01:00
//#define USER_BACKLOG "<Any command separated by a semicolon (;)>" // Add commands executed at firmware load or when command reset is executed
2021-03-20 17:44:35 +00:00
2019-07-14 21:08:19 +01:00
// -- Optional modules ----------------------------
2020-06-30 15:58:36 +01:00
# define ROTARY_V1 // Add support for Rotary Encoder as used in MI Desk Lamp (+0k8 code)
2020-07-02 17:13:14 +01:00
# define ROTARY_MAX_STEPS 10 // Rotary step boundary
2019-10-15 14:37:22 +01:00
# define USE_SONOFF_RF // Add support for Sonoff Rf Bridge (+3k2 code)
# define USE_RF_FLASH // Add support for flashing the EFM8BB1 chip on the Sonoff RF Bridge. C2CK must be connected to GPIO4, C2D to GPIO5 on the PCB (+2k7 code)
2019-10-14 17:15:43 +01:00
# define USE_SONOFF_SC // Add support for Sonoff Sc (+1k1 code)
2019-09-03 12:23:05 +01:00
# define USE_TUYA_MCU // Add support for Tuya Serial MCU
2019-07-14 21:08:19 +01:00
# define TUYA_DIMMER_ID 0 // Default dimmer Id
2021-03-29 12:15:30 +01:00
# define USE_TUYA_TIME // Add support for Set Time in Tuya MCU
2019-07-14 21:08:19 +01:00
# define USE_ARMTRONIX_DIMMERS // Add support for Armtronix Dimmers (+1k4 code)
2019-10-17 11:20:26 +01:00
# define USE_PS_16_DZ // Add support for PS-16-DZ Dimmer (+2k code)
2019-10-15 14:37:22 +01:00
# define USE_SONOFF_IFAN // Add support for Sonoff iFan02 and iFan03 (+2k code)
# define USE_BUZZER // Add support for a buzzer (+0k6 code)
# define USE_ARILUX_RF // Add support for Arilux RF remote controller (+0k8 code, 252 iram (non 2.3.0))
2020-02-27 14:10:42 +00:00
# define USE_SHUTTER // Add Shutter support for up to 4 shutter with different motortypes (+11k code)
2019-11-11 10:29:15 +00:00
# define USE_DEEPSLEEP // Add support for deepsleep (+1k code)
2021-06-15 09:15:36 +01:00
# define USE_EXS_DIMMER // Add support for ES-Store Wi-Fi Dimmer (+1k5 code)
2020-02-27 10:16:38 +00:00
// #define EXS_MCU_CMNDS // Add command to send MCU commands (+0k8 code)
2019-12-30 13:23:37 +00:00
//#define USE_HOTPLUG // Add support for sensor HotPlug
2020-04-24 15:12:43 +01:00
# define USE_DEVICE_GROUPS // Add support for device groups (+5k5 code)
# define DEVICE_GROUPS_ADDRESS 239,255,250,250 // Device groups multicast address
# define DEVICE_GROUPS_PORT 4447 // Device groups multicast port
2020-04-26 17:04:12 +01:00
# define USE_DEVICE_GROUPS_SEND // Add support for the DevGroupSend command (+0k6 code)
2020-10-20 02:12:41 +01:00
# define USE_PWM_DIMMER // Add support for MJ-SD01/acenx/NTONPOWER PWM dimmers (+2k3 code, DGR=0k7)
# define USE_PWM_DIMMER_REMOTE // Add support for remote switches to PWM Dimmer (requires USE_DEVICE_GROUPS) (+0k6 code)
2020-02-27 16:48:27 +00:00
//#define USE_KEELOQ // Add support for Jarolift rollers by Keeloq algorithm (+4k5 code)
2020-03-01 14:31:08 +00:00
# define USE_SONOFF_D1 // Add support for Sonoff D1 Dimmer (+0k7 code)
2020-11-17 11:25:48 +00:00
# define USE_SHELLY_DIMMER // Add support for Shelly Dimmer (+3k code)
# define SHELLY_CMDS // Add command to send co-processor commands (+0k3 code)
# define SHELLY_FW_UPGRADE // Add firmware upgrade option for co-processor (+3k4 code)
2020-11-18 07:47:23 +00:00
// #define SHELLY_VOLTAGE_MON // Add support for reading voltage and current measurment (-0k0 code)
2019-07-14 21:08:19 +01:00
2019-10-06 16:19:05 +01:00
// -- Optional light modules ----------------------
2021-06-13 16:37:40 +01:00
# define USE_LIGHT // Add support for light control
2019-10-06 16:19:05 +01:00
# define USE_WS2812 // WS2812 Led string using library NeoPixelBus (+5k code, +1k mem, 232 iram) - Disable by //
2021-03-10 19:38:19 +00:00
// #define USE_WS2812_DMA // ESP8266 only, DMA supports only GPIO03 (= Serial RXD) (+1k mem). When USE_WS2812_DMA is enabled expect Exceptions on Pow
# define USE_WS2812_RMT 0 // ESP32 only, hardware RMT support (default). Specify the RMT channel 0..7. This should be preferred to software bit bang.
// #define USE_WS2812_I2S 0 // ESP32 only, hardware I2S support. Specify the I2S channel 0..2. This is exclusive from RMT. By default, prefer RMT support
2020-10-05 18:03:40 +01:00
// #define USE_WS2812_INVERTED // Use inverted data signal
2020-12-17 15:33:26 +00:00
# define USE_WS2812_HARDWARE NEO_HW_WS2812 // Hardware type (NEO_HW_WS2812, NEO_HW_WS2812X, NEO_HW_WS2813, NEO_HW_SK6812, NEO_HW_LC8812, NEO_HW_APA106, NEO_HW_P9813)
2019-10-06 16:19:05 +01:00
# define USE_WS2812_CTYPE NEO_GRB // Color type (NEO_RGB, NEO_GRB, NEO_BRG, NEO_RBG, NEO_RGBW, NEO_GRBW)
2019-10-06 17:05:17 +01:00
# define USE_MY92X1 // Add support for MY92X1 RGBCW led controller as used in Sonoff B1, Ailight and Lohas
2019-10-06 16:19:05 +01:00
# define USE_SM16716 // Add support for SM16716 RGB LED controller (+0k7 code)
# define USE_SM2135 // Add support for SM2135 RGBCW led control as used in Action LSC (+0k6 code)
2019-10-17 11:20:26 +01:00
# define USE_SONOFF_L1 // Add support for Sonoff L1 led control
2020-03-18 11:32:13 +00:00
# define USE_ELECTRIQ_MOODL // Add support for ElectriQ iQ-wifiMOODL RGBW LED controller (+0k3 code)
2020-04-13 23:55:12 +01:00
# define USE_LIGHT_PALETTE // Add support for color palette (+0k7 code)
2020-12-29 18:31:27 +00:00
# define USE_LIGHT_VIRTUAL_CT // Add support for Virtual White Color Temperature (+1.1k code)
2020-04-25 23:49:34 +01:00
# define USE_DGR_LIGHT_SEQUENCE // Add support for device group light sequencing (requires USE_DEVICE_GROUPS) (+0k2 code)
2019-10-06 16:19:05 +01:00
2019-07-14 21:08:19 +01:00
// -- Counter input -------------------------------
2019-06-16 15:43:23 +01:00
# define USE_COUNTER // Enable inputs as counter (+0k8 code)
2018-02-07 16:50:02 +00:00
// -- Internal Analog input -----------------------
2019-05-13 14:56:01 +01:00
//#define USE_ADC_VCC // Display Vcc in Power status. Disable for use as Analog input on selected devices
2017-03-14 17:03:25 +00:00
2018-02-07 16:50:02 +00:00
// -- One wire sensors ----------------------------
2019-10-16 10:51:38 +01:00
# define USE_DS18x20 // Add support for DS18x20 sensors with id sort, single scan and read retry (+2k6 code)
2019-09-25 15:28:54 +01:00
// #define W1_PARASITE_POWER // Optimize for parasite powered sensors
2017-01-28 13:41:01 +00:00
2017-12-27 13:10:55 +00:00
// -- I2C sensors ---------------------------------
2018-12-18 17:36:53 +00:00
# define USE_I2C // I2C using library wire (+10k code, 0k2 mem, 124 iram)
2021-03-02 21:47:40 +00:00
# define I2CDRIVERS_0_31 0xFFFFFFFF // Enable I2CDriver0 to I2CDriver31
# define I2CDRIVERS_32_63 0xFFFFFFFF // Enable I2CDriver32 to I2CDriver63
# define I2CDRIVERS_64_95 0xFFFFFFFF // Enable I2CDriver64 to I2CDriver95
2018-08-18 17:11:22 +01:00
2018-01-05 11:26:19 +00:00
# ifdef USE_I2C
2020-02-27 14:10:42 +00:00
// #define USE_SHT // [I2cDriver8] Enable SHT1X sensor (+1k4 code)
// #define USE_HTU // [I2cDriver9] Enable HTU21/SI7013/SI7020/SI7021 sensor (I2C address 0x40) (+1k5 code)
// #define USE_BMP // [I2cDriver10] Enable BMP085/BMP180/BMP280/BME280 sensors (I2C addresses 0x76 and 0x77) (+4k4 code)
2018-12-15 14:55:51 +00:00
// #define USE_BME680 // Enable support for BME680 sensor using Bosch BME680 library (+4k code)
2020-02-27 14:10:42 +00:00
// #define USE_BH1750 // [I2cDriver11] Enable BH1750 sensor (I2C address 0x23 or 0x5C) (+0k5 code)
2019-11-11 10:29:15 +00:00
// #define USE_VEML6070 // [I2cDriver12] Enable VEML6070 sensor (I2C addresses 0x38 and 0x39) (+1k5 code)
2018-10-26 16:13:17 +01:00
# define USE_VEML6070_RSET 270000 // VEML6070, Rset in Ohm used on PCB board, default 270K = 270000ohm, range for this sensor: 220K ... 1Meg
# define USE_VEML6070_SHOW_RAW // VEML6070, shows the raw value of UV-A
2019-11-11 10:29:15 +00:00
// #define USE_ADS1115 // [I2cDriver13] Enable ADS1115 16 bit A/D converter (I2C address 0x48, 0x49, 0x4A or 0x4B) based on Adafruit ADS1x15 library (no library needed) (+0k7 code)
// #define USE_INA219 // [I2cDriver14] Enable INA219 (I2C address 0x40, 0x41 0x44 or 0x45) Low voltage and current sensor (+1k code)
// #define USE_INA226 // [I2cDriver35] Enable INA226 (I2C address 0x40, 0x41 0x44 or 0x45) Low voltage and current sensor (+2k3 code)
2020-02-27 14:10:42 +00:00
// #define USE_SHT3X // [I2cDriver15] Enable SHT3x (I2C address 0x44 or 0x45) or SHTC3 (I2C address 0x70) sensor (+0k7 code)
2019-11-11 10:29:15 +00:00
// #define USE_TSL2561 // [I2cDriver16] Enable TSL2561 sensor (I2C address 0x29, 0x39 or 0x49) using library Joba_Tsl2561 (+2k3 code)
// #define USE_TSL2591 // [I2cDriver40] Enable TSL2591 sensor (I2C address 0x29) using library Adafruit_TSL2591 (+1k6 code)
// #define USE_MGS // [I2cDriver17] Enable Xadow and Grove Mutichannel Gas sensor using library Multichannel_Gas_Sensor (+10k code)
2018-02-18 17:39:28 +00:00
# define MGS_SENSOR_ADDR 0x04 // Default Mutichannel Gas sensor i2c address
2019-11-11 10:29:15 +00:00
// #define USE_SGP30 // [I2cDriver18] Enable SGP30 sensor (I2C address 0x58) (+1k1 code)
// #define USE_SI1145 // [I2cDriver19] Enable SI1145/46/47 sensor (I2C address 0x60) (+1k code)
2020-02-27 14:10:42 +00:00
// #define USE_LM75AD // [I2cDriver20] Enable LM75AD sensor (I2C addresses 0x48 - 0x4F) (+0k5 code)
2019-11-11 10:29:15 +00:00
// #define USE_APDS9960 // [I2cDriver21] Enable APDS9960 Proximity Sensor (I2C address 0x39). Disables SHT and VEML6070 (+4k7 code)
2020-05-06 20:30:36 +01:00
# define USE_APDS9960_GESTURE // Enable APDS9960 Gesture feature (+2k code)
# define USE_APDS9960_PROXIMITY // Enable APDS9960 Proximity feature (>50 code)
# define USE_APDS9960_COLOR // Enable APDS9960 Color feature (+0.8k code)
# define USE_APDS9960_STARTMODE 0 // Default to enable Gesture mode
2021-03-20 06:59:34 +00:00
// #define USE_MCP230xx // [I2cDriver22] Enable MCP23008/MCP23017 - Must define I2C Address in #define USE_MCP230xx_ADDR below - range 0x20 - 0x27 (+5k1 code)
2019-11-08 16:48:19 +00:00
// #define USE_MCP230xx_ADDR 0x20 // Enable MCP23008/MCP23017 I2C Address to use (Must be within range 0x20 through 0x26 - set according to your wired setup)
2021-03-20 06:59:34 +00:00
// #define USE_MCP230xx_OUTPUT // Enable MCP23008/MCP23017 OUTPUT support through sensor29 commands (+2k2 code)
2018-08-09 11:02:46 +01:00
// #define USE_MCP230xx_DISPLAYOUTPUT // Enable MCP23008/MCP23017 to display state of OUTPUT pins on Web UI (+0k2 code)
2019-11-11 10:29:15 +00:00
// #define USE_PCA9685 // [I2cDriver1] Enable PCA9685 I2C HW PWM Driver - Must define I2C Address in #define USE_PCA9685_ADDR below - range 0x40 - 0x47 (+1k4 code)
2018-10-26 16:13:17 +01:00
// #define USE_PCA9685_ADDR 0x40 // Enable PCA9685 I2C Address to use (Must be within range 0x40 through 0x47 - set according to your wired setup)
// #define USE_PCA9685_FREQ 50 // Define default PWM frequency in Hz to be used (must be within 24 to 1526) - If other value is used, it will rever to 50Hz
2019-11-11 10:29:15 +00:00
// #define USE_MPR121 // [I2cDriver23] Enable MPR121 controller (I2C addresses 0x5A, 0x5B, 0x5C and 0x5D) in input mode for touch buttons (+1k3 code)
// #define USE_CCS811 // [I2cDriver24] Enable CCS811 sensor (I2C address 0x5A) (+2k2 code)
2021-03-31 14:04:24 +01:00
// #define USE_CCS811_V2 // [I2cDriver24] Enable CCS811 sensor (I2C addresses 0x5A and 0x5B) (+2k8 code)
2019-11-11 10:29:15 +00:00
// #define USE_MPU6050 // [I2cDriver25] Enable MPU6050 sensor (I2C address 0x68 AD0 low or 0x69 AD0 high) (+3K3 of code and 188 Bytes of RAM)
2018-12-15 14:55:51 +00:00
// #define USE_MPU6050_DMP // Enable in MPU6050 to use the DMP on the chip, should create better results (+8k6 of code)
2021-06-15 09:15:36 +01:00
// #define USE_DS3231 // [I2cDriver26] Enable DS3231 external RTC in case no Wi-Fi is avaliable. See docs in the source file (+1k2 code)
2018-10-26 16:13:17 +01:00
// #define USE_RTC_ADDR 0x68 // Default I2C address 0x68
2019-11-11 10:29:15 +00:00
// #define USE_MGC3130 // [I2cDriver27] Enable MGC3130 Electric Field Effect Sensor (I2C address 0x42) (+2k7 code, 0k3 mem)
// #define USE_MAX44009 // [I2cDriver28] Enable MAX44009 Ambient Light sensor (I2C addresses 0x4A and 0x4B) (+0k8 code)
// #define USE_SCD30 // [I2cDriver29] Enable Sensiron SCd30 CO2 sensor (I2C address 0x61) (+3k3 code)
// #define USE_SPS30 // [I2cDriver30] Enable Sensiron SPS30 particle sensor (I2C address 0x69) (+1.7 code)
# define USE_ADE7953 // [I2cDriver7] Enable ADE7953 Energy monitor as used on Shelly 2.5 (I2C address 0x38) (+1k5)
// #define USE_VL53L0X // [I2cDriver31] Enable VL53L0x time of flight sensor (I2C address 0x29) (+4k code)
2021-01-22 15:48:41 +00:00
// #define USE_VL53L1X // [I2cDriver54] Enable VL53L1X time of flight sensor (I2C address 0x29) using Pololu VL53L1X library (+2k9 code)
// #define USE_TOF10120 // [I2cDriver57] Enable TOF10120 time of flight sensor (I2C address 0x52) (+0k6 code)
2019-11-11 10:29:15 +00:00
// #define USE_MLX90614 // [I2cDriver32] Enable MLX90614 ir temp sensor (I2C address 0x5a) (+0.6k code)
// #define USE_CHIRP // [I2cDriver33] Enable CHIRP soil moisture sensor (variable I2C address, default 0x20)
// #define USE_PAJ7620 // [I2cDriver34] Enable PAJ7620 gesture sensor (I2C address 0x73) (+2.5k code)
// #define USE_PCF8574 // [I2cDriver2] Enable PCF8574 I/O Expander (I2C addresses 0x20 - 0x26 and 0x39 - 0x3F) (+1k9 code)
2021-03-11 16:28:35 +00:00
// #define USE_PCF8574_SENSOR // enable PCF8574 inputs and outputs in SENSOR message
// #define USE_PCF8574_DISPLAYINPUT // enable PCF8574 inputs display in Web page
// #define USE_PCF8574_MQTTINPUT // enable MQTT message & rule process on input change detection : stat/%topic%/PCF8574_INP = {"Time":"2021-03-07T16:19:23+01:00","PCF8574-1_INP":{"D1":1}}
2019-11-11 10:29:15 +00:00
// #define USE_HIH6 // [I2cDriver36] Enable Honeywell HIH Humidity and Temperature sensor (I2C address 0x27) (+0k6)
2019-12-17 21:29:16 +00:00
// #define USE_DHT12 // [I2cDriver41] Enable DHT12 humidity and temperature sensor (I2C address 0x5C) (+0k7 code)
2019-12-28 10:35:44 +00:00
// #define USE_DS1624 // [I2cDriver42] Enable DS1624, DS1621 temperature sensor (I2C addresses 0x48 - 0x4F) (+1k2 code)
2020-08-27 10:44:24 +01:00
// #define USE_AHT1x // [I2cDriver43] Enable AHT10/15 humidity and temperature sensor (I2C address 0x38, 0x39) (+0k8 code)
2021-03-11 16:28:35 +00:00
// #define USE_AHT2x // [I2cDriver43] Enable AHT20 instead of AHT1x humidity and temperature sensor (I2C address 0x38) (+0k8 code)
2020-02-22 11:18:20 +00:00
// #define USE_WEMOS_MOTOR_V1 // [I2cDriver44] Enable Wemos motor driver V1 (I2C addresses 0x2D - 0x30) (+0k7 code)
// #define WEMOS_MOTOR_V1_ADDR 0x30 // Default I2C address 0x30
// #define WEMOS_MOTOR_V1_FREQ 1000 // Default frequency
2020-03-14 11:43:02 +00:00
// #define USE_HDC1080 // [I2cDriver45] Enable HDC1080 temperature/humidity sensor (I2C address 0x40) (+1k5 code)
2020-04-10 14:13:01 +01:00
// #define USE_IAQ // [I2cDriver46] Enable iAQ-core air quality sensor (I2C address 0x5a) (+0k6 code)
2020-04-11 13:51:08 +01:00
// #define USE_AS3935 // [I2cDriver48] Enable AS3935 Franklin Lightning Sensor (I2C address 0x03) (+5k4 code)
2020-05-12 20:24:44 +01:00
// #define USE_VEML6075 // [I2cDriver49] Enable VEML6075 UVA/UVB/UVINDEX Sensor (I2C address 0x10) (+2k1 code)
// #define USE_VEML7700 // [I2cDriver50] Enable VEML7700 Ambient Light sensor (I2C addresses 0x10) (+4k5 code)
2020-06-02 07:35:49 +01:00
// #define USE_MCP9808 // [I2cDriver51] Enable MCP9808 temperature sensor (I2C addresses 0x18 - 0x1F) (+0k9 code)
2020-06-12 11:38:52 +01:00
// #define USE_HP303B // [I2cDriver52] Enable HP303B temperature and pressure sensor (I2C address 0x76 or 0x77) (+6k2 code)
2020-09-14 10:49:33 +01:00
// #define USE_MLX90640 // [I2cDriver53] Enable MLX90640 IR array temperature sensor (I2C address 0x33) (+20k code)
2020-10-26 07:11:07 +00:00
// #define USE_EZOPH // [I2cDriver55] Enable support for EZO's pH sensor (+0k3 code) - Shared EZO code required for any EZO device (+1k2 code)
// #define USE_EZOORP // [I2cDriver55] Enable support for EZO's ORP sensor (+0k3 code) - Shared EZO code required for any EZO device (+1k2 code)
// #define USE_EZORTD // [I2cDriver55] Enable support for EZO's RTD sensor (+0k2 code) - Shared EZO code required for any EZO device (+1k2 code)
// #define USE_EZOHUM // [I2cDriver55] Enable support for EZO's HUM sensor (+0k3 code) - Shared EZO code required for any EZO device (+1k2 code)
// #define USE_EZOEC // [I2cDriver55] Enable support for EZO's EC sensor (+0k3 code) - Shared EZO code required for any EZO device (+1k2 code)
// #define USE_EZOCO2 // [I2cDriver55] Enable support for EZO's CO2 sensor (+0k2 code) - Shared EZO code required for any EZO device (+1k2 code)
2020-10-27 10:38:54 +00:00
// #define USE_EZOO2 // [I2cDriver55] Enable support for EZO's O2 sensor (+0k3 code) - Shared EZO code required for any EZO device (+1k2 code)
2020-10-29 09:34:44 +00:00
// #define USE_EZOPRS // [I2cDriver55] Enable support for EZO's PRS sensor (+0k7 code) - Shared EZO code required for any EZO device (+1k2 code)
2020-11-01 09:28:43 +00:00
// #define USE_EZOFLO // [I2cDriver55] Enable support for EZO's FLO sensor (+0k4 code) - Shared EZO code required for any EZO device (+1k2 code)
2020-11-02 08:26:35 +00:00
// #define USE_EZODO // [I2cDriver55] Enable support for EZO's DO sensor (+0k3 code) - Shared EZO code required for any EZO device (+1k2 code)
2020-11-03 11:38:28 +00:00
// #define USE_EZORGB // [I2cDriver55] Enable support for EZO's RGB sensor (+0k5 code) - Shared EZO code required for any EZO device (+1k2 code)
2020-11-07 09:41:22 +00:00
// #define USE_EZOPMP // [I2cDriver55] Enable support for EZO's PMP sensor (+0k3 code) - Shared EZO code required for any EZO device (+1k2 code)
2021-01-22 15:48:41 +00:00
// #define USE_SEESAW_SOIL // [I2cDriver56] Enable Capacitice Soil Moisture & Temperature Sensor (I2C addresses 0x36 - 0x39) (+1k3 code)
2021-06-11 12:27:34 +01:00
// #define USE_MPU_ACCEL // [I2cDriver58] Enable MPU6886/MPU9250 - found in M5Stack - support both I2C buses on ESP32 (I2C address 0x68) (+2k code)
// #define USE_BM8563 // [I2cDriver59] Enable BM8563 RTC - found in M5Stack - support both I2C buses on ESP32 (I2C address 0x51) (+2.5k code)
2020-10-25 08:21:01 +00:00
2018-10-26 16:13:17 +01:00
// #define USE_DISPLAY // Add I2C Display Support (+2k code)
# define USE_DISPLAY_MODES1TO5 // Enable display mode 1 to 5 in addition to mode 0
2019-11-11 10:29:15 +00:00
# define USE_DISPLAY_LCD // [DisplayModel 1] [I2cDriver3] Enable Lcd display (I2C addresses 0x27 and 0x3F) (+6k code)
# define USE_DISPLAY_SSD1306 // [DisplayModel 2] [I2cDriver4] Enable SSD1306 Oled 128x64 display (I2C addresses 0x3C and 0x3D) (+16k code)
# define USE_DISPLAY_MATRIX // [DisplayModel 3] [I2cDriver5] Enable 8x8 Matrix display (I2C adresseses see below) (+11k code)
2018-10-26 16:13:17 +01:00
# define MTX_ADDRESS1 0x71 // [DisplayAddress1] I2C address of first 8x8 matrix module
# define MTX_ADDRESS2 0x74 // [DisplayAddress2] I2C address of second 8x8 matrix module
# define MTX_ADDRESS3 0x75 // [DisplayAddress3] I2C address of third 8x8 matrix module
# define MTX_ADDRESS4 0x72 // [DisplayAddress4] I2C address of fourth 8x8 matrix module
# define MTX_ADDRESS5 0x73 // [DisplayAddress5] I2C address of fifth 8x8 matrix module
# define MTX_ADDRESS6 0x76 // [DisplayAddress6] I2C address of sixth 8x8 matrix module
# define MTX_ADDRESS7 0x00 // [DisplayAddress7] I2C address of seventh 8x8 matrix module
# define MTX_ADDRESS8 0x00 // [DisplayAddress8] I2C address of eigth 8x8 matrix module
2020-04-10 14:33:10 +01:00
# define USE_DISPLAY_SEVENSEG // [DisplayModel 11] [I2cDriver47] Enable sevenseg display (I2C 0x70-0x77) (<+11k code)
2020-11-25 16:30:25 +00:00
// #define USE_DISPLAY_SEVENSEG_COMMON_ANODE // Enable support for common anode sevenseg displays
2020-07-12 07:33:25 +01:00
// Multiple sevenseg displays are logically arranged vertically with MTX_ADDRESS1 at y=0,
// MTX_ADDRESS2 at y=1, up to MTX_ADDRESS8 at y=7
// Command: DisplayText [yn]8888
// will display 8888 at sevenseg display at I2C address MTX_ADDRESS(n-1)
2020-07-14 09:42:41 +01:00
// Each segment may be address Command: DisplayText [xn]m
// where n is 0..4 (4 digits and middle :) and m is decimal for bitmap of which segment to turn on.
// Reference: https://cdn-learn.adafruit.com/downloads/pdf/adafruit-led-backpack.pdf
2020-07-12 07:16:29 +01:00
// #define SEVENSEG_ADDRESS1 0x70 // No longer used. Use MTX_ADDRESS1 - MTX_ADDRESS8 instead to specify I2C address of sevenseg displays
2019-11-11 10:29:15 +00:00
// #define USE_DISPLAY_SH1106 // [DisplayModel 7] [I2cDriver6] Enable SH1106 Oled 128x64 display (I2C addresses 0x3C and 0x3D)
2018-01-05 11:26:19 +00:00
# endif // USE_I2C
2021-05-25 17:53:10 +01:00
// -- Universal Display Driver ---------------------------------
// #define USE_UNIVERSAL_DISPLAY // New universal display driver for both I2C and SPI
# define MAX_TOUCH_BUTTONS 16 // Virtual touch buttons
2018-04-05 14:26:16 +01:00
// -- SPI sensors ---------------------------------
2020-01-02 08:54:58 +00:00
//#define USE_SPI // Hardware SPI using GPIO12(MISO), GPIO13(MOSI) and GPIO14(CLK) in addition to two user selectable GPIOs(CS and DC)
2020-11-30 16:54:40 +00:00
2018-04-05 14:26:16 +01:00
# ifdef USE_SPI
2020-01-02 15:58:20 +00:00
// #define USE_NRF24 // Add SPI support for NRF24L01(+) (+2k6 code)
# define USE_MIBLE // BLE-bridge for some Mijia-BLE-sensors (+4k7 code)
2020-11-30 16:54:40 +00:00
// #define USE_DISPLAY // Add SPI Display support for 320x240 and 480x320 TFT
# define USE_DISPLAY_ILI9341 // [DisplayModel 4] Enable ILI9341 Tft 480x320 display (+19k code)
// #define USE_DISPLAY_EPAPER_29 // [DisplayModel 5] Enable e-paper 2.9 inch display (+19k code)
// #define USE_DISPLAY_EPAPER_42 // [DisplayModel 6] Enable e-paper 4.2 inch display
// #define USE_DISPLAY_ILI9488 // [DisplayModel 8] [I2cDriver38] (Touch)
2021-01-01 14:05:58 +00:00
// #define USE_DISPLAY_SSD1351 // [DisplayModel 9] Enable SSD1351 module
2020-11-30 16:54:40 +00:00
// #define USE_DISPLAY_RA8876 // [DisplayModel 10] [I2cDriver39] (Touch)
2021-01-01 14:05:58 +00:00
// #define USE_DISPLAY_ST7789 // [DisplayModel 12] Enable ST7789 module
2021-01-01 15:05:06 +00:00
// #define USE_DISPLAY_SSD1331 // [DisplayModel 14] Enable SSD1331 module
2020-11-30 16:54:40 +00:00
// #define USE_RC522 // Add support for MFRC522 13.56Mhz Rfid reader (+6k code)
2020-12-06 15:32:07 +00:00
// #define USE_RC522_DATA_FUNCTION // Add support for reading data block content (+0k4 code)
// #define USE_RC522_TYPE_INFORMATION // Add support for showing card type (+0k4 code)
2018-04-05 14:26:16 +01:00
# endif // USE_SPI
2021-02-17 11:32:36 +00:00
//#define USE_DISPLAY // Add Display support
// #define USE_DISPLAY_TM1637 // [DisplayModel 15] Enable TM1637 module
2018-02-07 16:50:02 +00:00
// -- Serial sensors ------------------------------
2020-02-27 14:10:42 +00:00
//#define USE_MHZ19 // Add support for MH-Z19 CO2 sensor (+2k code)
//#define USE_SENSEAIR // Add support for SenseAir K30, K70 and S8 CO2 sensor (+2k3 code)
2017-12-27 13:10:55 +00:00
# define CO2_LOW 800 // Below this CO2 value show green light (needs PWM or WS2812 RG(B) led and enable with SetOption18 1)
# define CO2_HIGH 1200 // Above this CO2 value show red light (needs PWM or WS2812 RG(B) led and enable with SetOption18 1)
2020-02-27 14:10:42 +00:00
//#define USE_PMS5003 // Add support for PMS5003 and PMS7003 particle concentration sensor (+1k3 code)
2019-10-16 11:10:48 +01:00
//#define PMS_MODEL_PMS3003 // Enable support of PMS3003 instead of PMS5003/PMS7003 (needs the USE_PMS5003 above)
2020-02-27 14:10:42 +00:00
//#define USE_NOVA_SDS // Add support for SDS011 and SDS021 particle concentration sensor (+1k5 code)
2019-10-17 12:10:43 +01:00
# define STARTING_OFFSET 30 // Turn on NovaSDS XX-seconds before tele_period is reached
2019-11-06 13:05:17 +00:00
//#define USE_HPMA // Add support for Honeywell HPMA115S0 particle concentration sensor (+1k4)
2020-08-17 15:25:24 +01:00
//#define USE_SR04 // Add support for HC-SR04 ultrasonic devices (+1k code)
2021-03-19 09:44:47 +00:00
# define SR04_MAX_SENSOR_DISTANCE 500 // Set sensor max detection distance
2020-08-17 15:25:24 +01:00
//#define USE_DYP // Add support for DYP ME-007 ultrasonic distance sensor, serial port version (+0k5 code)
2018-03-20 13:31:11 +00:00
# define USE_SERIAL_BRIDGE // Add support for software Serial Bridge (+0k8 code)
2020-06-15 18:22:56 +01:00
//#define USE_TCP_BRIDGE // Add support for Serial to TCP bridge (+1.3k code)
2021-04-30 10:17:34 +01:00
//#define USE_MP3_PLAYER // Use of the DFPlayer Mini MP3 Player RB-DFR-562 commands: play, pause, stop, track, volume and reset
2018-10-26 16:13:17 +01:00
# define MP3_VOLUME 10 // Set the startup volume on init, the range can be 0..30(max)
2021-04-30 10:17:34 +01:00
// #define USE_DY_SV17F // Use of DY-SV17F MP3 Player commands: play, stop, track and volume
2018-12-18 17:36:53 +00:00
//#define USE_AZ7798 // Add support for AZ-Instrument 7798 CO2 datalogger (+1k6 code)
2019-02-08 07:59:33 +00:00
//#define USE_PN532_HSU // Add support for PN532 using HSU (Serial) interface (+1k8 code, 140 bytes mem)
// #define USE_PN532_DATA_FUNCTION // Add sensor40 command support for erase, setting data block content (+1k7 code, 388 bytes mem)
// #define USE_PN532_DATA_RAW // Allow DATA block to be used by non-alpha-numberic data (+ 80 bytes code, 48 bytes ram)
2019-08-19 10:47:59 +01:00
//#define USE_RDM6300 // Add support for RDM6300 125kHz RFID Reader (+0k8)
2019-08-25 11:29:48 +01:00
//#define USE_IBEACON // Add support for bluetooth LE passive scan of ibeacon devices (uses HM17 module)
2020-02-07 09:50:06 +00:00
//#define USE_GPS // Add support for GPS and NTP Server for becoming Stratus 1 Time Source (+3k1 code, +132 bytes RAM)
// #define USE_FLOG // Add support for GPS logging in OTA's Flash (Experimental) (+2k9 code, +8 bytes RAM)
2020-04-21 10:06:30 +01:00
//#define USE_HM10 // (ESP8266 only) Add support for HM-10 as a BLE-bridge (+9k3 code)
2020-03-01 13:20:19 +00:00
//#define USE_HRXL // Add support for MaxBotix HRXL-MaxSonar ultrasonic range finders (+0k7)
2020-06-18 15:05:55 +01:00
//#define USE_TASMOTA_CLIENT // Add support for Arduino Uno/Pro Mini via serial interface including flashing (+2k6 code, 64 mem)
# define USE_TASMOTA_CLIENT_FLASH_SPEED 57600 // Usually 57600 for 3.3V variants and 115200 for 5V variants
# define USE_TASMOTA_CLIENT_SERIAL_SPEED 57600 // Depends on the sketch that is running on the Uno/Pro Mini
2020-05-07 15:03:27 +01:00
//#define USE_OPENTHERM // Add support for OpenTherm (+15k code)
2020-10-02 14:10:21 +01:00
//#define USE_MIEL_HVAC // Add support for Mitsubishi Electric HVAC serial interface (+5k code)
2021-02-28 11:37:02 +00:00
//#define USE_PROJECTOR_CTRL // Add support for LCD/DLP Projector serial control interface (+2k code)
// #define USE_PROJECTOR_CTRL_NEC // Use codes for NEC
// #define USE_PROJECTOR_CTRL_OPTOMA // Use codes for OPTOMA
2020-11-12 13:24:36 +00:00
//#define USE_AS608 // Add support for AS608 optical and R503 capacitive fingerprint sensor (+3k code)
// #define USE_AS608_MESSAGES // Add verbose error messages (+0k4 code)
2021-03-20 15:20:23 +00:00
//#define USE_TFMINIPLUS // Add support for TFmini Plus (TFmini, TFmini-S) LiDAR modules via UART interface (+0k8)
2018-12-18 17:36:53 +00:00
2019-10-15 18:49:33 +01:00
// -- Power monitoring sensors --------------------
2021-06-13 16:37:40 +01:00
# define USE_ENERGY_SENSOR // Add support for Energy Monitors (+14k code)
2019-08-01 14:46:12 +01:00
# define USE_ENERGY_MARGIN_DETECTION // Add support for Energy Margin detection (+1k6 code)
# define USE_ENERGY_POWER_LIMIT // Add additional support for Energy Power Limit detection (+1k2 code)
2021-04-06 11:08:07 +01:00
# define USE_ENERGY_DUMMY // Add support for dummy Energy monitor allowing user values (+0k7 code)
2021-06-13 16:37:40 +01:00
# define USE_HLW8012 // Add support for HLW8012, BL0937 or HJL-01 Energy Monitor for Sonoff Pow and WolfBlitz
# define USE_CSE7766 // Add support for CSE7766 Energy Monitor for Sonoff S31 and Pow R2
2018-12-18 17:36:53 +00:00
# define USE_PZEM004T // Add support for PZEM004T Energy monitor (+2k code)
# define USE_PZEM_AC // Add support for PZEM014,016 Energy monitor (+1k1 code)
# define USE_PZEM_DC // Add support for PZEM003,017 Energy monitor (+1k1 code)
# define USE_MCP39F501 // Add support for MCP39F501 Energy monitor as used in Shelly 2 (+3k1 code)
2021-02-14 11:22:08 +00:00
//#define USE_SDM72 // Add support for Eastron SDM72-Modbus energy monitor (+0k3 code)
# define SDM72_SPEED 9600 // SDM72-Modbus RS485 serial speed (default: 9600 baud)
// #define SDM72_IMPEXP // Show additonal import/export active energy and power in MQTT and Web (+0k5 code)
2019-10-18 11:28:29 +01:00
//#define USE_SDM120 // Add support for Eastron SDM120-Modbus energy monitor (+1k1 code)
2019-09-10 14:14:51 +01:00
# define SDM120_SPEED 2400 // SDM120-Modbus RS485 serial speed (default: 2400 baud)
2019-10-18 11:28:29 +01:00
//#define USE_SDM630 // Add support for Eastron SDM630-Modbus energy monitor (+0k6 code)
2019-09-15 16:06:23 +01:00
# define SDM630_SPEED 9600 // SDM630-Modbus RS485 serial speed (default: 9600 baud)
2020-10-03 14:06:52 +01:00
// #define SDM630_IMPORT // Show import active energy in MQTT and Web (+0k3 code)
2019-09-10 14:14:51 +01:00
//#define USE_DDS2382 // Add support for Hiking DDS2382 Modbus energy monitor (+0k6 code)
# define DDS2382_SPEED 9600 // Hiking DDS2382 Modbus RS485 serial speed (default: 9600 baud)
2019-10-03 13:18:04 +01:00
//#define USE_DDSU666 // Add support for Chint DDSU666 Modbus energy monitor (+0k6 code)
# define DDSU666_SPEED 9600 // Chint DDSU666 Modbus RS485 serial speed (default: 9600 baud)
2019-10-17 18:30:55 +01:00
//#define USE_SOLAX_X1 // Add support for Solax X1 series Modbus log info (+3k1 code)
2019-10-17 17:22:11 +01:00
# define SOLAXX1_SPEED 9600 // Solax X1 Modbus RS485 serial speed (default: 9600 baud)
# define SOLAXX1_PV2 // Solax X1 using second PV
2020-02-10 14:18:11 +00:00
//#define USE_LE01MR // Add support for F&F LE-01MR Modbus energy monitor (+1k code)
# define LE01MR_SPEED 9600 // LE-01MR modbus baudrate (default: 9600)
# define LE01MR_ADDR 1 // LE-01MR modbus address (default: 0x01)
2020-06-07 16:21:29 +01:00
# define USE_BL0940 // Add support for BL0940 Energy monitor as used in Blitzwolf SHP-10 (+1k6 code)
2020-06-17 14:00:48 +01:00
//#define USE_TELEINFO // Add support for Teleinfo via serial RX interface (+5k2 code, +168 RAM + SmartMeter LinkedList Values RAM)
2020-07-12 16:52:24 +01:00
//#define USE_IEM3000 // Add support for Schneider Electric iEM3000-Modbus series energy monitor (+0k8 code)
# define IEM3000_SPEED 19200 // iEM3000-Modbus RS485 serial speed (default: 19200 baud)
# define IEM3000_ADDR 1 // iEM3000-Modbus modbus address (default: 0x01)
2020-10-02 15:37:43 +01:00
//#define USE_WE517 // Add support for Orno WE517-Modbus energy monitor (+1k code)
2020-02-10 14:18:11 +00:00
2018-02-07 16:50:02 +00:00
// -- Low level interface devices -----------------
2019-06-16 16:03:41 +01:00
# define USE_DHT // Add support for DHT11, AM2301 (DHT21, DHT22, AM2302, AM2321) and SI7021 Temperature and Humidity sensor (1k6 code)
2020-06-04 10:36:58 +01:00
//#define USE_MAX31855 // Add support for MAX31855/MAX6675 K-Type thermocouple sensor using softSPI
2019-07-30 16:57:08 +01:00
//#define USE_MAX31865 // Add support for MAX31865 RTD sensors using softSPI
2021-02-01 07:45:30 +00:00
# define MAX31865_PTD_WIRES 2 // PTDs come in several flavors, pick yours. Specific settings per sensor possible with MAX31865_PTD_WIRES1..MAX31865_PTD_WIRES6
# define MAX31865_PTD_RES 100 // Nominal PTD resistance at 0°C (100Ω for a PT100, 1000Ω for a PT1000, YMMV!). Specific settings per sensor possible with MAX31865_PTD_RES1..MAX31865_PTD_RES6
# define MAX31865_REF_RES 430 // Reference resistor (Usually 430Ω for a PT100, 4300Ω for a PT1000). Specific settings per sensor possible with MAX31865_REF_RES1..MAX31865_REF_RES6
# define MAX31865_PTD_BIAS 0 // To calibrate your not-so-good PTD. Specific settings per sensor possible with MAX31865_PTD_BIAS1..MAX31865_PTD_BIAS6
2020-06-17 16:22:41 +01:00
//#define USE_LMT01 // Add support for TI LMT01 temperature sensor, count pulses on single GPIO (+0k5 code)
2021-01-16 14:39:33 +00:00
//#define USE_WIEGAND // Add support for 24/26/32/34 bit RFID Wiegand interface (D0/D1) (+1k7 code)
2019-07-29 16:44:49 +01:00
2019-08-30 19:41:01 +01:00
// -- IR Remote features - all protocols from IRremoteESP8266 --------------------------
// IR Full Protocols mode is activated through platform.io only.
2019-10-27 11:44:37 +00:00
// Either use 'default_envs = tasmota-ircustom' and disable some features here to keep code not too big
// or use 'default_envs = tasmota-ir' for a pre-packaged IR-dedicated firmware
// When using 'tasmota-ircustom' or 'tasmota-ir', parameters below
2019-08-30 19:41:01 +01:00
// (USE_IR_REMOTE, USE_IR_RECEIVE, USE_IR_HVAC...) are IGNORED.
//
// Code impact of IR full protocols is +81k code, 3k mem
// You can reduce this size by disabling some protocols in "lib/IRremoteESP8266.x.x.x/src/IRremoteESP8266.h"
// -- IR Remote features - subset of IR protocols --------------------------
2018-12-18 17:36:53 +00:00
# define USE_IR_REMOTE // Send IR remote commands using library IRremoteESP8266 and ArduinoJson (+4k3 code, 0k3 mem, 48 iram)
2020-12-29 09:35:44 +00:00
# define IR_SEND_INVERTED false // Invert the output. (default = false) e.g. LED is illuminated when GPIO is LOW rather than HIGH.
// Setting inverted to something other than the default could easily destroy your IR LED if you are overdriving it.
// Unless you REALLY know what you are doing, don't change this.
# define IR_SEND_USE_MODULATION true // Do we do frequency modulation during transmission? i.e. If not, assume a 100% duty cycle.
2019-07-21 15:03:20 +01:00
# define USE_IR_SEND_NEC // Support IRsend NEC protocol
# define USE_IR_SEND_RC5 // Support IRsend Philips RC5 protocol
# define USE_IR_SEND_RC6 // Support IRsend Philips RC6 protocol
2018-12-18 17:36:53 +00:00
# define USE_IR_RECEIVE // Support for IR receiver (+7k2 code, 264 iram)
2018-12-15 14:55:51 +00:00
# define IR_RCV_BUFFER_SIZE 100 // Max number of packets allowed in capture buffer (default 100 (*2 bytes ram))
# define IR_RCV_TIMEOUT 15 // Number of milli-Seconds of no-more-data before we consider a message ended (default 15)
2019-05-27 10:56:14 +01:00
# define IR_RCV_MIN_UNKNOWN_SIZE 6 // Set the smallest sized "UNKNOWN" message packets we actually care about (default 6, max 255)
2020-12-26 18:45:06 +00:00
# define IR_RCV_WHILE_SENDING 0 // Turns on receiver while sending messages, i.e. receive your own. This is unreliable and can cause IR timing issues
2019-08-09 21:52:33 +01:00
2019-08-10 12:31:05 +01:00
// -- Zigbee interface ----------------------------
2020-03-15 13:27:15 +00:00
//#define USE_ZIGBEE // Enable serial communication with Zigbee CC2530 flashed with ZNP (+49k code, +3k mem)
2020-07-29 09:31:38 +01:00
# define USE_ZIGBEE_ZNP // Enable ZNP protocol, needed for CC2530 based devices
// #define USE_ZIGBEE_EZSP // Enable EZSP protocol, needed for EFR32 EmberZNet based devices, like Sonoff Zigbee bridge
// Note: USE_ZIGBEE_ZNP and USE_ZIGBEE_EZSP are mutually incompatible, you must select exactly one
2021-04-22 13:49:38 +01:00
// #define USE_ZIGBEE_EEPROM // Use the EEPROM from the Sonoff ZBBridge to save Zigbee configuration and data
2020-07-29 09:31:38 +01:00
# define USE_ZIGBEE_CHANNEL 11 // Zigbee Channel (11-26)
# define USE_ZIGBEE_TXRADIO_DBM 20 // Tx Radio power in dBm (only for EZSP, EFR32 can go up to 20 dBm)
2020-05-26 16:08:13 +01:00
2019-12-22 16:47:45 +00:00
# define USE_ZIGBEE_COALESCE_ATTR_TIMER 350 // timer to coalesce attribute values (in ms)
2021-01-09 16:58:57 +00:00
# define USE_ZIGBEE_DEBOUNCE_COMMANDS 200 // if commands are received from the same device/endpoint with same ZCL transaction number, discard packet in this time window (ms)
2020-06-15 19:13:05 +01:00
# define USE_ZIGBEE_MODELID "Tasmota Z2T" // reported "ModelId" (cluster 0000 / attribute 0005)
# define USE_ZIGBEE_MANUFACTURER "Tasmota" // reported "Manufacturer" (cluster 0000 / attribute 0004)
2020-11-11 16:31:48 +00:00
# define USE_ZBBRIDGE_TLS // TLS support for zbbridge
2020-11-11 11:09:18 +00:00
# define USE_ZIGBEE_ZBBRIDGE_EEPROM 0x50 // I2C id for the ZBBridge EEPROM
2021-05-22 17:03:58 +01:00
// #define USE_ZIGBEE_FORCE_NO_CHILDREN // This feature forces `CONFIG_MAX_END_DEVICE_CHILDREN` to zero which means that the coordinator does not accept any direct child. End-devices must pair through a router.
// This may mitigate some battery drain issues with IKEA devices.
// **DO NOT USE UNLESS YOU KNOW EXACTLY WHAT YOU'RE DOING** See #10413
2019-08-09 21:52:33 +01:00
2021-01-10 15:04:12 +00:00
// Auto-binding constants, see `Z_autoAttributeReporting`
// Below are the threshold for attribute reporting
2021-01-22 17:17:40 +00:00
# define USE_ZIGBEE_AUTOBIND_BATTVOLTAGE 0.2 // V
# define USE_ZIGBEE_AUTOBIND_BATTPERCENT 5 // %
2021-01-10 15:04:12 +00:00
# define USE_ZIGBEE_AUTOBIND_TEMPERATURE 0.5 // °C
# define USE_ZIGBEE_AUTOBIND_HEATDEMAND 10 // %
# define USE_ZIGBEE_AUTOBIND_PRESSURE 1 // hPA
# define USE_ZIGBEE_AUTOBIND_ILLUMINANCE 5 // lux
# define USE_ZIGBEE_AUTOBIND_HUMIDITY 1.0 // %
2021-02-18 15:27:03 +00:00
# define USE_ZIGBEE_AUTOBIND_LIFT 1.0 // %
2021-01-10 15:04:12 +00:00
// Below are the Max Thresholds for reporting time (in seconds)
# define USE_ZIGBEE_MAXTIME_BATT 4*60*60 // 4h
# define USE_ZIGBEE_MAXTIME_TRV 60*10 // 10m
# define USE_ZIGBEE_MAXTIME_SENSOR 60*60 // 1h
# define USE_ZIGBEE_MAXTIME_LIGHT 60*60 // 1h
2021-02-18 15:27:03 +00:00
# define USE_ZIGBEE_MAXTIME_LIFT 4*60*60 // 4h
2021-01-10 15:04:12 +00:00
2019-10-15 19:00:57 +01:00
// -- Other sensors/drivers -----------------------
2017-02-14 13:27:08 +00:00
2018-08-18 17:11:22 +01:00
//#define USE_TM1638 // Add support for TM1638 switches copying Switch1 .. Switch8 (+1k code)
2020-02-27 14:10:42 +00:00
//#define USE_HX711 // Add support for HX711 load cell (+1k5 code)
2018-10-26 16:13:17 +01:00
// #define USE_HX711_GUI // Add optional web GUI to HX711 as scale (+1k8 code)
2018-06-28 16:40:37 +01:00
2020-02-20 17:50:43 +00:00
// Select none or only one of the below defines
2020-02-29 15:11:59 +00:00
//#define USE_TX20_WIND_SENSOR // Add support for La Crosse TX20 anemometer (+2k6/0k8 code)
//#define USE_TX23_WIND_SENSOR // Add support for La Crosse TX23 anemometer (+2k7/1k code)
2018-10-26 16:13:17 +01:00
2020-05-07 15:03:27 +01:00
//#define USE_WINDMETER // Add support for analog anemometer (+2k2 code)
2020-12-22 15:47:24 +00:00
//#define USE_FTC532 // Add support for FTC532 8-button touch controller (+0k6 code)
2020-08-19 15:40:07 +01:00
//#define USE_RC_SWITCH // Add support for RF transceiver using library RcSwitch (+2k7 code, 460 iram)
2018-10-26 16:13:17 +01:00
2018-12-15 14:55:51 +00:00
//#define USE_RF_SENSOR // Add support for RF sensor receiver (434MHz or 868MHz) (+0k8 code)
// #define USE_THEO_V2 // Add support for decoding Theo V2 sensors as documented on https://sidweb.nl using 434MHz RF sensor receiver (+1k4 code)
2018-12-16 13:28:33 +00:00
// #define USE_ALECTO_V2 // Add support for decoding Alecto V2 sensors like ACH2010, WS3000 and DKW2012 weather stations using 868MHz RF sensor receiver (+1k7 code)
2018-12-15 14:55:51 +00:00
2019-03-28 10:14:09 +00:00
//#define USE_HRE // Add support for Badger HR-E Water Meter (+1k4 code)
2019-10-15 19:49:02 +01:00
//#define USE_A4988_STEPPER // Add support for A4988/DRV8825 stepper-motor-driver-circuit (+10k5 code)
2019-03-28 10:14:09 +00:00
2021-01-07 14:07:14 +00:00
//#define USE_PROMETHEUS // Add support for https://prometheus.io/ metrics exporting over HTTP /metrics endpoint
2021-01-20 12:56:57 +00:00
//#define USE_NEOPOOL // Add support for Sugar Valley NeoPool Controller - also known under brands Hidrolife, Aquascenic, Oxilife, Bionet, Hidroniser, UVScenic, Station, Brilix, Bayrol and Hay (+6k flash, +60 mem)
// #define NEOPOOL_MODBUS_ADDRESS 1 // Any modbus address
2020-05-07 16:02:22 +01:00
// -- Thermostat control ----------------------------
2020-05-10 13:58:38 +01:00
//#define USE_THERMOSTAT // Add support for Thermostat
2020-05-07 16:02:22 +01:00
# define THERMOSTAT_CONTROLLER_OUTPUTS 1 // Number of outputs to be controlled independently
# define THERMOSTAT_SENSOR_NAME "DS18B20" // Name of the local sensor to be used
2020-12-09 20:11:19 +00:00
# define THERMOSTAT_SENSOR_NUMBER 1 // Number of local sensors to be used
2020-05-07 16:02:22 +01:00
# define THERMOSTAT_RELAY_NUMBER 1 // Default output relay number for the first controller (+i for following ones)
# define THERMOSTAT_SWITCH_NUMBER 1 // Default input switch number for the first controller (+i for following ones)
2020-05-10 22:00:57 +01:00
# define THERMOSTAT_TIME_ALLOW_RAMPUP 300 // Default time after last target update to allow ramp-up controller phase in minutes
2020-05-07 16:02:22 +01:00
# define THERMOSTAT_TIME_RAMPUP_MAX 960 // Default time maximum ramp-up controller duration in minutes
2020-05-10 22:00:57 +01:00
# define THERMOSTAT_TIME_RAMPUP_CYCLE 30 // Default time ramp-up cycle in minutes
2020-05-07 16:02:22 +01:00
# define THERMOSTAT_TIME_SENS_LOST 30 // Maximum time w/o sensor update to set it as lost in minutes
# define THERMOSTAT_TEMP_SENS_NUMBER 1 // Default temperature sensor number
# define THERMOSTAT_TIME_MANUAL_TO_AUTO 60 // Default time without input switch active to change from manual to automatic in minutes
# define THERMOSTAT_TIME_RESET 12000 // Default reset time of the PI controller in seconds
# define THERMOSTAT_TIME_PI_CYCLE 30 // Default cycle time for the thermostat controller in minutes
# define THERMOSTAT_TIME_MAX_ACTION 20 // Default maximum thermostat time per cycle in minutes
# define THERMOSTAT_TIME_MIN_ACTION 4 // Default minimum thermostat time per cycle in minutes
# define THERMOSTAT_TIME_MIN_TURNOFF_ACTION 3 // Default minimum turnoff time in minutes, below it the thermostat will be held on
# define THERMOSTAT_PROP_BAND 4 // Default proportional band of the PI controller in degrees celsius
# define THERMOSTAT_TEMP_RESET_ANTI_WINDUP 8 // Default range where reset antiwindup is disabled, in tenths of degrees celsius
# define THERMOSTAT_TEMP_HYSTERESIS 1 // Default range hysteresis for temperature PI controller, in tenths of degrees celsius
# define THERMOSTAT_TEMP_FROST_PROTECT 40 // Default minimum temperature for frost protection, in tenths of degrees celsius
# define THERMOSTAT_TEMP_RAMPUP_DELTA_IN 4 // Default minimum delta temperature to target to get into rampup mode, in tenths of degrees celsius
# define THERMOSTAT_TEMP_RAMPUP_DELTA_OUT 2 // Default minimum delta temperature to target to get out of the rampup mode, in tenths of degrees celsius
# define THERMOSTAT_TEMP_PI_RAMPUP_ACC_E 200 // Default accumulated error when switching from ramp-up controller to PI in hundreths of degrees celsius
# define THERMOSTAT_TIME_OUTPUT_DELAY 180 // Default output delay between state change and real actuation event (f.i. valve open/closed)
# define THERMOSTAT_TEMP_INIT 180 // Default init target temperature for the thermostat controller
# define THERMOSTAT_TIME_MAX_OUTPUT_INCONSIST 3 // Default maximum time where the input and the outpus shall differ (for diagnostic) in minutes
2020-05-14 21:44:32 +01:00
# define THERMOSTAT_TIME_MAX_AUTOTUNE 21600 // Maximum time for the PI autotune function to complete in seconds
# define THERMOSTAT_DUTYCYCLE_AUTOTUNE 35 // Default duty cycle (in % over PI cycle time) for the step response of the autotune PI function
# define THERMOSTAT_PEAKNUMBER_AUTOTUNE 8 // Default number of peak temperatures (max or min) to be used for the autotune PI function
# define THERMOSTAT_TEMP_BAND_NO_PEAK_DET 1 // Default temperature band in thenths of degrees celsius within no peak will be detected
# define THERMOSTAT_TIME_STD_DEV_PEAK_DET_OK 10 // Default standard deviation in minutes of the oscillation periods within the peak detection is successful
2020-04-17 09:31:53 +01:00
2021-01-10 14:47:26 +00:00
// -- PID and Timeprop ------------------------------ // Both together will add +12k1 code
// #define use TIMEPROP // Add support for the timeprop feature (+9k1 code)
2021-01-06 22:09:23 +00:00
// For details on the configuration please see the header of tasmota/xdrv_48_timeprop.ino
2021-01-10 14:47:26 +00:00
// #define USE_PID // Add suport for the PID feature (+11k2 code)
2021-01-06 22:09:23 +00:00
// For details on the configuration please see the header of tasmota/xdrv_49_pid.ino
2021-01-07 14:07:14 +00:00
// -- End of general directives ---------------------
2019-10-15 19:03:13 +01:00
2020-06-15 17:36:26 +01:00
/*********************************************************************************************\
* ESP32 only features
\ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# ifdef ESP32
2020-06-16 17:36:49 +01:00
//#define USE_ETHERNET // Add support for ethernet (Currently fixed for Olimex ESP32-PoE)
2021-01-27 13:27:05 +00:00
// #define USE_WT32_ETH01 // Add support for Wireless-Tag WT32-ETH01
// #define ETH_TYPE 0 // [EthType] 0 = ETH_PHY_LAN8720, 1 = ETH_PHY_TLK110, 2 = ETH_PHY_IP101
2021-02-02 17:02:24 +00:00
// #define ETH_ADDRESS 1 // [EthAddress] 0 = PHY0 .. 31 = PHY31
2021-01-27 13:27:05 +00:00
// #define ETH_CLKMODE 0 // [EthClockMode] 0 = ETH_CLOCK_GPIO0_IN, 1 = ETH_CLOCK_GPIO0_OUT, 2 = ETH_CLOCK_GPIO16_OUT, 3 = ETH_CLOCK_GPIO17_OUT
2020-06-16 17:36:49 +01:00
// Olimex ESP32-PoE
2020-06-17 17:14:50 +01:00
# define ETH_TYPE 0 // [EthType] 0 = ETH_PHY_LAN8720, 1 = ETH_PHY_TLK110, 2 = ETH_PHY_IP101
2021-02-02 17:02:24 +00:00
# define ETH_ADDRESS 0 // [EthAddress] 0 = PHY0 .. 31 = PHY31
2020-06-16 17:36:49 +01:00
# define ETH_CLKMODE 3 // [EthClockMode] 0 = ETH_CLOCK_GPIO0_IN, 1 = ETH_CLOCK_GPIO0_OUT, 2 = ETH_CLOCK_GPIO16_OUT, 3 = ETH_CLOCK_GPIO17_OUT
2020-06-17 14:27:12 +01:00
// wESP32-PoE
2020-06-17 17:14:50 +01:00
// #define ETH_TYPE 0 // [EthType] 0 = ETH_PHY_LAN8720, 1 = ETH_PHY_TLK110, 2 = ETH_PHY_IP101
2021-02-02 17:02:24 +00:00
// #define ETH_ADDRESS 0 // [EthAddress] 0 = PHY0 .. 31 = PHY31
2020-06-17 14:27:12 +01:00
// #define ETH_CLKMODE 0 // [EthClockMode] 0 = ETH_CLOCK_GPIO0_IN, 1 = ETH_CLOCK_GPIO0_OUT, 2 = ETH_CLOCK_GPIO16_OUT, 3 = ETH_CLOCK_GPIO17_OUT
2020-06-16 17:36:49 +01:00
2020-08-04 15:33:05 +01:00
# define USE_ADC // Add support for ADC on GPIO32 to GPIO39
2020-06-16 17:36:49 +01:00
//#define USE_SPI // Add support for hardware SPI
2021-02-14 11:22:08 +00:00
//#define USE_MI_ESP32 // Add support for ESP32 as a BLE-bridge (+9k2 mem, +292k flash)
//#define USE_BLE_ESP32 // Add support for ESP32 as a BLE-bridge (+9k2? mem, +292k? flash)
2021-01-17 17:08:54 +00:00
//#define USE_IBEACON // Add support for bluetooth LE passive scan of ibeacon devices (uses HM17 module)
//#define USE_IBEACON_ESP32
2020-06-16 17:36:49 +01:00
//#define USE_WEBCAM // Add support for webcam
2020-06-15 17:36:26 +01:00
2021-03-31 11:49:16 +01:00
# define USE_BERRY // Enable Berry scripting language
2021-03-31 16:41:11 +01:00
//#define USE_BERRY_PSRAM // Allocate Berry memory in PSRAM if PSRAM is connected - this might be slightly slower but leaves main memory intact
2021-03-31 11:49:16 +01:00
2021-03-03 11:44:09 +00:00
# define USE_CSE7761 // Add support for CSE7761 Energy monitor as used in Sonoff Dual R3
2021-04-19 07:40:11 +01:00
// -- LVGL Graphics Library ---------------------------------
2021-05-21 21:31:15 +01:00
//#define USE_LVGL // LVGL Engine, requires Berry (+382KB)
2021-05-12 10:16:10 +01:00
# define USE_LVGL_PSRAM // Allocate LVGL memory in PSRAM if PSRAM is connected - this might be slightly slower but leaves main memory intact
# define USE_LVGL_MAX_SLEEP 10 // max sleep in ms when LVGL is enabled, more than 10ms will make display less responsive
2021-05-21 21:31:15 +01:00
# define USE_LVGL_PNG_DECODER // include a PNG image decoder from file system (+16KB)
//#define USE_LVGL_FREETYPE // Use the FreeType renderer to display fonts using native TTF files in file system (+77KB flash)
2021-05-12 10:16:10 +01:00
# define LV_USE_FT_CACHE_MANAGER 1 // define whether glyphs are cached by FreeType library
# define USE_LVGL_FREETYPE_MAX_FACES 64 // max number of FreeType faces in cache
# define USE_LVGL_FREETYPE_MAX_SIZES 4 // max number of sizes in cache
# define USE_LVGL_FREETYPE_MAX_BYTES 16*1024 // max bytes in cache
2021-05-20 18:34:51 +01:00
# define USE_LVGL_FREETYPE_MAX_BYTES_PSRAM 64*1024 // max bytes in cache when using PSRAM
2021-05-12 10:16:10 +01:00
# define USE_LVGL_BG_DEFAULT 0x000000 // Default color for the uninitialized background screen (black)
2021-05-21 21:31:15 +01:00
// Disabling select widgets that will be rarely used in Tasmota (-13KB)
# define BE_LV_WIDGET_ARC 1
# define BE_LV_WIDGET_BAR 1
# define BE_LV_WIDGET_BTN 1
# define BE_LV_WIDGET_BTNMATRIX 1
# define BE_LV_WIDGET_CALENDAR 0
# define BE_LV_WIDGET_CANVAS 1
# define BE_LV_WIDGET_CHART 1
# define BE_LV_WIDGET_CHECKBOX 1
# define BE_LV_WIDGET_CONT 1
# define BE_LV_WIDGET_CPICKER 1
# define BE_LV_WIDGET_DROPDOWN 1
# define BE_LV_WIDGET_GAUGE 1
# define BE_LV_WIDGET_IMG 1
# define BE_LV_WIDGET_IMGBTN 1
# define BE_LV_WIDGET_KEYBOARD 0
# define BE_LV_WIDGET_LABEL 1
# define BE_LV_WIDGET_LED 1
# define BE_LV_WIDGET_LINE 1
# define BE_LV_WIDGET_LINEMETER 1
# define BE_LV_WIDGET_LIST 1
# define BE_LV_WIDGET_MSGBOX 1
# define BE_LV_WIDGET_OBJMASK 1
# define BE_LV_WIDGET_TEMPL 1
# define BE_LV_WIDGET_PAGE 1
# define BE_LV_WIDGET_ROLLER 1
# define BE_LV_WIDGET_SLIDER 1
# define BE_LV_WIDGET_SPINBOX 1
# define BE_LV_WIDGET_SPINNER 1
# define BE_LV_WIDGET_SWITCH 1
# define BE_LV_WIDGET_TABLE 1
# define BE_LV_WIDGET_TABVIEW 1
# define BE_LV_WIDGET_TEXTAREA 1
# define BE_LV_WIDGET_TILEVIEW 1
# define BE_LV_WIDGET_WIN 0
2021-04-19 07:40:11 +01:00
2020-11-28 11:46:17 +00:00
# endif // ESP32
2020-06-15 17:36:26 +01:00
2018-06-24 16:50:42 +01:00
/*********************************************************************************************\
2019-08-08 14:17:39 +01:00
* Debug features
2018-06-24 16:50:42 +01:00
\ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2019-08-08 15:24:11 +01:00
//#define DEBUG_TASMOTA_CORE // Enable core debug messages
2019-08-08 14:17:39 +01:00
//#define DEBUG_TASMOTA_DRIVER // Enable driver debug messages
//#define DEBUG_TASMOTA_SENSOR // Enable sensor debug messages
2018-06-24 16:50:42 +01:00
//#define USE_DEBUG_DRIVER // Use xdrv_99_debug.ino providing commands CpuChk, CfgXor, CfgDump, CfgPeek and CfgPoke
2018-04-23 10:37:46 +01:00
/*********************************************************************************************\
2018-08-31 13:47:49 +01:00
* Optional firmware configurations
2020-04-10 09:52:22 +01:00
* Select none or just one for optional features and sensors as configured in tasmota_configurations . h
2018-08-31 13:47:49 +01:00
* See RELEASENOTES . md for selected features
2017-03-05 14:07:30 +00:00
\ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2019-12-17 14:13:47 +00:00
//#define FIRMWARE_LITE // Create tasmota-lite with no sensors
2019-10-27 11:44:37 +00:00
//#define FIRMWARE_SENSORS // Create tasmota-sensors with useful sensors enabled
//#define FIRMWARE_KNX_NO_EMULATION // Create tasmota-knx with KNX but without Emulation
//#define FIRMWARE_DISPLAYS // Create tasmota-display with display drivers enabled
//#define FIRMWARE_IR // Create tasmota-ir with IR full protocols activated, and many sensors disabled
//#define FIRMWARE_IR_CUSTOM // Create tasmota customizable with special marker to add all IR protocols
//#define FIRMWARE_MINIMAL // Create tasmota-minimal as intermediate firmware for OTA-MAGIC
2017-03-05 14:07:30 +00:00
2017-01-28 13:41:01 +00:00
/*********************************************************************************************\
* No user configurable items below
\ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2019-08-31 13:44:49 +01:00
# ifdef USE_CONFIG_OVERRIDE
# include "user_config_override.h" // Configuration overrides for my_user_config.h
# endif
2020-09-08 20:22:52 +01:00
# if defined(USE_DISCOVERY) && (defined(USE_MQTT_AWS_IOT) || defined(USE_MQTT_AWS_IOT_LIGHT))
2019-06-05 10:44:52 +01:00
# error "Select either USE_DISCOVERY or USE_MQTT_AWS_IOT, mDNS takes too much code space and is not needed for AWS IoT"
# endif
2020-03-30 11:52:09 +01:00
# if defined(USE_RULES) && defined(USE_SCRIPT)
# error "Select either USE_RULES or USE_SCRIPT. They can't both be used at the same time"
# endif
2020-06-10 19:14:46 +01:00
/*********************************************************************************************\
* Post - process compile options for TLS
\ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# if defined(USE_MQTT_TLS) || defined(USE_SENDMAIL) || defined(USE_TELEGRAM)
# define USE_TLS // flag indicates we need to include TLS code
# if defined(USE_MQTT_AWS_IOT) || defined(USE_TELEGRAM)
# define USE_MQTT_TLS_FORCE_EC_CIPHER // AWS IoT and TELEGRAM require EC Cipher
# endif
# endif
2018-10-26 16:13:17 +01:00
# endif // _MY_USER_CONFIG_H_