Fork of the espurna firmware for `mhsw` switches
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

220 lines
7.3 KiB

8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
7 years ago
8 years ago
8 years ago
8 years ago
7 years ago
8 years ago
8 years ago
  1. //------------------------------------------------------------------------------
  2. // GENERAL
  3. //------------------------------------------------------------------------------
  4. #define SERIAL_BAUDRATE 115200
  5. #define HOSTNAME DEVICE
  6. #define BUFFER_SIZE 1024
  7. #define HEARTBEAT_INTERVAL 300000
  8. //--------------------------------------------------------------------------------
  9. // EEPROM
  10. //--------------------------------------------------------------------------------
  11. #define EEPROM_RELAY_STATUS 0
  12. #define EEPROM_ENERGY_COUNT 1
  13. #define EEPROM_DATA_END 5
  14. //--------------------------------------------------------------------------------
  15. // BUTTON
  16. //--------------------------------------------------------------------------------
  17. #define BUTTON_EVENT_NONE 0
  18. #define BUTTON_EVENT_PRESSED 1
  19. #define BUTTON_EVENT_CLICK 2
  20. #define BUTTON_EVENT_DBLCLICK 3
  21. #define BUTTON_EVENT_LNGCLICK 4
  22. #define BUTTON_MODE_NONE 0
  23. #define BUTTON_MODE_TOGGLE 1
  24. #define BUTTON_MODE_AP 2
  25. #define BUTTON_MODE_RESET 3
  26. #define BUTTON_MODE_PULSE 4
  27. #define BUTTON_DEFAULT_MODE BUTTON_MODE_TOGGLE
  28. //--------------------------------------------------------------------------------
  29. // RELAY
  30. //--------------------------------------------------------------------------------
  31. #define RELAY_MODE_OFF 0
  32. #define RELAY_MODE_ON 1
  33. #define RELAY_MODE_SAME 2
  34. #define RELAY_MODE_TOOGLE 3
  35. #define RELAY_SYNC_ANY 0
  36. #define RELAY_SYNC_NONE_OR_ONE 1
  37. #define RELAY_SYNC_ONE 2
  38. #define RELAY_SYNC_SAME 3
  39. #define RELAY_PULSE_NONE 0
  40. #define RELAY_PULSE_OFF 1
  41. #define RELAY_PULSE_ON 2
  42. #define RELAY_PROVIDER_RELAY 0
  43. #define RELAY_PROVIDER_DUAL 1
  44. #define RELAY_PROVIDER_MY9291 2
  45. #ifndef RELAY_PROVIDER
  46. #define RELAY_PROVIDER RELAY_PROVIDER_RELAY
  47. #endif
  48. // Pulse time in seconds
  49. #define RELAY_PULSE_TIME 1
  50. // 0 means OFF, 1 ON and 2 whatever was before
  51. #define RELAY_MODE RELAY_MODE_OFF
  52. // 0 means ANY, 1 zero or one and 2 one and only one
  53. #define RELAY_SYNC RELAY_SYNC_ANY
  54. // 0 means no pulses, 1 means normally off, 2 normally on
  55. #define RELAY_PULSE_MODE RELAY_PULSE_NONE
  56. //--------------------------------------------------------------------------------
  57. // I18N
  58. //--------------------------------------------------------------------------------
  59. #define TMP_CELSIUS 0
  60. #define TMP_FAHRENHEIT 1
  61. #define TMP_UNITS TMP_CELSIUS
  62. //--------------------------------------------------------------------------------
  63. // LED
  64. //--------------------------------------------------------------------------------
  65. // All defined LEDs in the board can be managed through MQTT
  66. // except the first one when LED_AUTO is set to 1.
  67. // If LED_AUTO is set to 1 the board will use first defined LED to show wifi status.
  68. #define LED_AUTO 1
  69. // -----------------------------------------------------------------------------
  70. // WIFI & WEB
  71. // -----------------------------------------------------------------------------
  72. #define WIFI_RECONNECT_INTERVAL 300000
  73. #define WIFI_MAX_NETWORKS 5
  74. #define ADMIN_PASS "fibonacci"
  75. #define FORCE_CHANGE_PASS 1
  76. #define HTTP_USERNAME "admin"
  77. #define WS_BUFFER_SIZE 5
  78. #define WS_TIMEOUT 1800000
  79. #define WEBSERVER_PORT 80
  80. #define DNS_PORT 53
  81. #define ENABLE_MDNS 1
  82. #define WEB_MODE_NORMAL 0
  83. #define WEB_MODE_PASSWORD 1
  84. #define AP_MODE AP_MODE_ALONE
  85. // This option builds the firmware with the web interface embedded.
  86. // You first have to build the data.h file that holds the contents
  87. // of the web interface by running "gulp buildfs_embed"
  88. #ifndef EMBEDDED_WEB
  89. #define EMBEDDED_WEB 0
  90. #endif
  91. // -----------------------------------------------------------------------------
  92. // OTA & NOFUSS
  93. // -----------------------------------------------------------------------------
  94. #define OTA_PORT 8266
  95. #define NOFUSS_SERVER ""
  96. #define NOFUSS_INTERVAL 3600000
  97. // -----------------------------------------------------------------------------
  98. // MQTT
  99. // -----------------------------------------------------------------------------
  100. #ifndef MQTT_USE_ASYNC
  101. #define MQTT_USE_ASYNC 0
  102. #endif
  103. #define MQTT_SERVER ""
  104. #define MQTT_PORT 1883
  105. #define MQTT_TOPIC "/test/switch/{identifier}"
  106. #define MQTT_RETAIN true
  107. #define MQTT_QOS 0
  108. #define MQTT_KEEPALIVE 30
  109. #define MQTT_RECONNECT_DELAY 10000
  110. #define MQTT_TRY_INTERVAL 30000
  111. #define MQTT_MAX_TRIES 12
  112. #define MQTT_SKIP_RETAINED 1
  113. #define MQTT_SKIP_TIME 1000
  114. #define MQTT_ACTION_TOPIC "/action"
  115. #define MQTT_RELAY_TOPIC "/relay"
  116. #define MQTT_LED_TOPIC "/led"
  117. #define MQTT_COLOR_TOPIC "/color"
  118. #define MQTT_BUTTON_TOPIC "/button"
  119. #define MQTT_IP_TOPIC "/ip"
  120. #define MQTT_VERSION_TOPIC "/version"
  121. #define MQTT_HEARTBEAT_TOPIC "/status"
  122. #define MQTT_ACTION_RESET "reset"
  123. #define MQTT_CONNECT_EVENT 0
  124. #define MQTT_DISCONNECT_EVENT 1
  125. #define MQTT_MESSAGE_EVENT 2
  126. // Custom get and set postfixes
  127. // Use something like "/status" or "/set", with leading slash
  128. #define MQTT_USE_GETTER ""
  129. #define MQTT_USE_SETTER ""
  130. // -----------------------------------------------------------------------------
  131. // I2C
  132. // -----------------------------------------------------------------------------
  133. #define ENABLE_I2C 0
  134. #define I2C_SDA_PIN 4
  135. #define I2C_SCL_PIN 14
  136. #define I2C_CLOCK_STRETCH_TIME 200
  137. #define I2C_SCL_FREQUENCY 1000
  138. // -----------------------------------------------------------------------------
  139. // MY9291
  140. // -----------------------------------------------------------------------------
  141. #define MY9291_DI_PIN 13
  142. #define MY9291_DCKI_PIN 15
  143. #define MY9291_COMMAND MY9291_COMMAND_DEFAULT
  144. #define MY9291_COLOR_RED 0
  145. #define MY9291_COLOR_GREEN 0
  146. #define MY9291_COLOR_BLUE 0
  147. #define MY9291_COLOR_WHITE 192
  148. // -----------------------------------------------------------------------------
  149. // DOMOTICZ
  150. // -----------------------------------------------------------------------------
  151. #ifndef ENABLE_DOMOTICZ
  152. #define ENABLE_DOMOTICZ 1
  153. #endif
  154. #define DOMOTICZ_IN_TOPIC "domoticz/in"
  155. #define DOMOTICZ_OUT_TOPIC "domoticz/out"
  156. // -----------------------------------------------------------------------------
  157. // NTP
  158. // -----------------------------------------------------------------------------
  159. #define NTP_SERVER "pool.ntp.org"
  160. #define NTP_TIME_OFFSET 1
  161. #define NTP_DAY_LIGHT true
  162. #define NTP_UPDATE_INTERVAL 1800
  163. // -----------------------------------------------------------------------------
  164. // FAUXMO
  165. // -----------------------------------------------------------------------------
  166. // This setting defines whether Alexa support should be built into the firmware
  167. #ifndef ENABLE_FAUXMO
  168. #define ENABLE_FAUXMO 1
  169. #endif
  170. // This is default value for the fauxmoEnabled setting that defines whether
  171. // this device should be discoberable and respond to Alexa commands.
  172. // Both ENABLE_FAUXMO and fauxmoEnabled should be 1 for Alexa support to work.
  173. #define FAUXMO_ENABLED 1