Compare commits
	
		
			18 Commits
		
	
	
		
			v0.3.2
			...
			91a29db8ed
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 91a29db8ed | |||
| 7a37df2fff | |||
| b5498b7173 | |||
| 0287456f1e | |||
| 019592f1ad | |||
| c1c07a4003 | |||
|   | cf380443a7 | ||
|   | b8e68bed7c | ||
| 8387a0610b | |||
| 764b18e539 | |||
| e5a64c13ed | |||
| 338c90fb8e | |||
| 85c57daf91 | |||
| 5cb5300d15 | |||
| d5ffd87f90 | |||
| 0cff4d019a | |||
| 10b337d43f | |||
| d19bd16561 | 
							
								
								
									
										12
									
								
								.drone.yml
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								.drone.yml
									
									
									
									
									
								
							| @@ -6,6 +6,7 @@ steps: | |||||||
|   image: python:3 |   image: python:3 | ||||||
|   commands: |   commands: | ||||||
|   - pip install platformio |   - pip install platformio | ||||||
|  |   - pio check | ||||||
|   - pio run |   - pio run | ||||||
| - name: upload | - name: upload | ||||||
|   image: python:3 |   image: python:3 | ||||||
| @@ -16,10 +17,17 @@ steps: | |||||||
| - name: release | - name: release | ||||||
|   image: plugins/gitea-release |   image: plugins/gitea-release | ||||||
|   settings: |   settings: | ||||||
|     api_key: a7f3afc9f77e721951e48b4af66d7565700b7a2e |     api_key:  | ||||||
|  |       from_secret: DRONE_ACCESS_TOKEN | ||||||
|     base_url: https://code.jcktrue.dk |     base_url: https://code.jcktrue.dk | ||||||
|     files: |     files: | ||||||
|       - .pio/build/nodemcu/firmware.bin |       - .pio/build/nodemcu/firmware.bin | ||||||
|       - .pio/build/nodemcu/firmware.elf |     checksum: | ||||||
|  |       - md5 | ||||||
|  |       - sha1 | ||||||
|  |       - sha256 | ||||||
|  |       - sha512 | ||||||
|  |       - adler32 | ||||||
|  |       - crc32 | ||||||
|   when: |   when: | ||||||
|     event: tag |     event: tag | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -3,3 +3,4 @@ | |||||||
| .pio | .pio | ||||||
| data/homie/config.json | data/homie/config.json | ||||||
| nbproject | nbproject | ||||||
|  | .vscode | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								.vscode/.BROWSE.C_CPP.DB
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.vscode/.BROWSE.C_CPP.DB
									
									
									
									
										vendored
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								.vscode/.BROWSE.C_CPP.DB-shm
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.vscode/.BROWSE.C_CPP.DB-shm
									
									
									
									
										vendored
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								.vscode/.BROWSE.C_CPP.DB-wal
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.vscode/.BROWSE.C_CPP.DB-wal
									
									
									
									
										vendored
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										129
									
								
								.vscode/c_cpp_properties.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										129
									
								
								.vscode/c_cpp_properties.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,129 +0,0 @@ | |||||||
| { |  | ||||||
|     "configurations": [ |  | ||||||
|         { |  | ||||||
|             "name": "!!! WARNING !!! AUTO-GENERATED FILE, PLEASE DO NOT MODIFY IT AND USE https://docs.platformio.org/page/projectconf/section_env_build.html#build-flags" |  | ||||||
|         }, |  | ||||||
|         { |  | ||||||
|             "name": "Win32", |  | ||||||
|             "includePath": [ |  | ||||||
|                 "c:/Users/furyf/Dev/deskcontrol/src", |  | ||||||
|                 "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/Homie/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266HTTPClient/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266mDNS/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/Ticker", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/DNSServer/src", |  | ||||||
|                 "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/ESP Async WebServer_ID306/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/Hash/src", |  | ||||||
|                 "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/Bounce2_ID1106/src", |  | ||||||
|                 "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/AsyncMqttClient_ID346/src", |  | ||||||
|                 "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/ESPAsyncTCP_ID305/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266WiFi/src", |  | ||||||
|                 "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/ArduinoJson_ID64/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/tools/sdk/include", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/tools/sdk/libc/xtensa-lx106-elf/include", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/cores/esp8266", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/tools/sdk/lwip2/include", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/variants/nodemcu", |  | ||||||
|                 "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/Syslog_ID1506/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ArduinoOTA", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/EEPROM", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266AVRISP/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266HTTPUpdateServer/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266LLMNR", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266NetBIOS", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266SSDP", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266SdFat/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266WebServer/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266WiFiMesh/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266httpUpdate/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/Ethernet/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/GDBStub/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/SD/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/SDFS/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/SPI", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/SPISlave/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/Servo/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/SoftwareSerial/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/TFT_Touch_Shield_V2", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/Wire", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/esp8266/src", |  | ||||||
|                 "C:/Users/furyf/.platformio/packages/tool-unity", |  | ||||||
|                 "" |  | ||||||
|             ], |  | ||||||
|             "browse": { |  | ||||||
|                 "limitSymbolsToIncludedHeaders": true, |  | ||||||
|                 "databaseFilename": "${workspaceRoot}/.vscode/.browse.c_cpp.db", |  | ||||||
|                 "path": [ |  | ||||||
|                     "c:/Users/furyf/Dev/deskcontrol/src", |  | ||||||
|                     "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/Homie/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266HTTPClient/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266mDNS/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/Ticker", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/DNSServer/src", |  | ||||||
|                     "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/ESP Async WebServer_ID306/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/Hash/src", |  | ||||||
|                     "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/Bounce2_ID1106/src", |  | ||||||
|                     "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/AsyncMqttClient_ID346/src", |  | ||||||
|                     "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/ESPAsyncTCP_ID305/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266WiFi/src", |  | ||||||
|                     "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/ArduinoJson_ID64/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/tools/sdk/include", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/tools/sdk/libc/xtensa-lx106-elf/include", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/cores/esp8266", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/tools/sdk/lwip2/include", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/variants/nodemcu", |  | ||||||
|                     "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/Syslog_ID1506/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ArduinoOTA", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/EEPROM", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266AVRISP/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266HTTPUpdateServer/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266LLMNR", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266NetBIOS", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266SSDP", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266SdFat/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266WebServer/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266WiFiMesh/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266httpUpdate/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/Ethernet/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/GDBStub/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/SD/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/SDFS/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/SPI", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/SPISlave/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/Servo/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/SoftwareSerial/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/TFT_Touch_Shield_V2", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/Wire", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/esp8266/src", |  | ||||||
|                     "C:/Users/furyf/.platformio/packages/tool-unity", |  | ||||||
|                     "" |  | ||||||
|                 ] |  | ||||||
|             }, |  | ||||||
|             "defines": [ |  | ||||||
|                 "PLATFORMIO=40000", |  | ||||||
|                 "ESP8266", |  | ||||||
|                 "ARDUINO_ARCH_ESP8266", |  | ||||||
|                 "ARDUINO_ESP8266_NODEMCU", |  | ||||||
|                 "PIO_FRAMEWORK_ARDUINO_LWIP2_LOW_MEMORY", |  | ||||||
|                 "F_CPU=80000000L", |  | ||||||
|                 "__ets__", |  | ||||||
|                 "ICACHE_FLASH", |  | ||||||
|                 "ARDUINO=10805", |  | ||||||
|                 "ARDUINO_BOARD=\"PLATFORMIO_NODEMCU\"", |  | ||||||
|                 "FLASHMODE_QIO", |  | ||||||
|                 "LWIP_OPEN_SRC", |  | ||||||
|                 "NONOSDK221=1", |  | ||||||
|                 "TCP_MSS=536", |  | ||||||
|                 "LWIP_FEATURES=1", |  | ||||||
|                 "LWIP_IPV6=0", |  | ||||||
|                 "VTABLES_IN_FLASH", |  | ||||||
|                 "" |  | ||||||
|             ], |  | ||||||
|             "intelliSenseMode": "clang-x64", |  | ||||||
|             "cStandard": "c99", |  | ||||||
|             "cppStandard": "c++11", |  | ||||||
|             "compilerPath": "\"C:/Users/furyf/.platformio/packages/toolchain-xtensa/bin/xtensa-lx106-elf-gcc.exe\" -mlongcalls -mtext-section-literals" |  | ||||||
|         } |  | ||||||
|     ], |  | ||||||
|     "version": 4 |  | ||||||
| } |  | ||||||
							
								
								
									
										7
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,7 +0,0 @@ | |||||||
| { |  | ||||||
| 	// See http://go.microsoft.com/fwlink/?LinkId=827846 |  | ||||||
| 	// for the documentation about the extensions.json format |  | ||||||
| 	"recommendations": [ |  | ||||||
| 		"platformio.platformio-ide" |  | ||||||
| 	] |  | ||||||
| } |  | ||||||
							
								
								
									
										32
									
								
								.vscode/launch.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										32
									
								
								.vscode/launch.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,32 +0,0 @@ | |||||||
| // AUTOMATICALLY GENERATED FILE. PLEASE DO NOT MODIFY IT MANUALLY |  | ||||||
|  |  | ||||||
| // PIO Unified Debugger |  | ||||||
| // |  | ||||||
| // Documentation: https://docs.platformio.org/page/plus/debugging.html |  | ||||||
| // Configuration: https://docs.platformio.org/page/projectconf/section_env_debug.html |  | ||||||
|  |  | ||||||
| { |  | ||||||
|     "version": "0.2.0", |  | ||||||
|     "configurations": [ |  | ||||||
|         { |  | ||||||
|             "type": "platformio-debug", |  | ||||||
|             "request": "launch", |  | ||||||
|             "name": "PIO Debug", |  | ||||||
|             "executable": "c:/Users/furyf/Dev/deskcontrol/.pio/build/nodemcu/firmware.elf", |  | ||||||
|             "toolchainBinDir": "C:/Users/furyf/.platformio/packages/toolchain-xtensa/bin", |  | ||||||
|             "preLaunchTask": { |  | ||||||
|                 "type": "PlatformIO", |  | ||||||
|                 "task": "Pre-Debug" |  | ||||||
|             }, |  | ||||||
|             "internalConsoleOptions": "openOnSessionStart" |  | ||||||
|         }, |  | ||||||
|         { |  | ||||||
|             "type": "platformio-debug", |  | ||||||
|             "request": "launch", |  | ||||||
|             "name": "PIO Debug (skip Pre-Debug)", |  | ||||||
|             "executable": "c:/Users/furyf/Dev/deskcontrol/.pio/build/nodemcu/firmware.elf", |  | ||||||
|             "toolchainBinDir": "C:/Users/furyf/.platformio/packages/toolchain-xtensa/bin", |  | ||||||
|             "internalConsoleOptions": "openOnSessionStart" |  | ||||||
|         } |  | ||||||
|     ] |  | ||||||
| } |  | ||||||
							
								
								
									
										6
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +0,0 @@ | |||||||
| { |  | ||||||
|     "terminal.integrated.env.windows": { |  | ||||||
|         "PATH": "C:\\Program Files (x86)\\STMicroelectronics\\st_toolset\\asm;C:\\Program Files (x86)\\Common Files\\Oracle\\Java\\javapath;C:\\WINDOWS\\system32;C:\\WINDOWS;C:\\WINDOWS\\System32\\Wbem;C:\\WINDOWS\\System32\\WindowsPowerShell\\v1.0\\;C:\\WINDOWS\\System32\\OpenSSH\\;C:\\Program Files (x86)\\STMicroelectronics\\STM32 ST-LINK Utility\\ST-LINK Utility;C:\\Program Files\\doxygen\\bin;C:\\Program Files (x86)\\QuickTime\\QTSystem\\;C:\\Users\\furyf\\scoop\\apps\\nodejs\\current\\bin;C:\\Users\\furyf\\scoop\\apps\\nodejs\\current;C:\\Users\\furyf\\go\\bin;C:\\Users\\furyf\\scoop\\apps\\composer\\current\\home\\vendor\\bin;C:\\Users\\furyf\\scoop\\apps\\ruby\\current\\gems\\bin;C:\\Users\\furyf\\scoop\\apps\\ruby\\current\\bin;C:\\Users\\furyf\\scoop\\apps\\python27\\current\\scripts;C:\\Users\\furyf\\scoop\\apps\\latex\\current\\texmfs\\install\\miktex\\bin;C:\\Users\\furyf\\scoop\\apps\\gcc\\current\\bin;C:\\Users\\furyf\\scoop\\apps\\nmap\\current\\bin;C:\\Users\\furyf\\AppData\\Local\\Programs\\Python\\Launcher\\;C:\\Users\\furyf\\scoop\\shims;C:\\Users\\furyf\\AppData\\Local\\Microsoft\\WindowsApps;C:\\Users\\furyf\\scoop\\apps\\msys\\current\\bin;C:\\Users\\furyf\\AppData\\Local\\Programs\\Microsoft VS Code\\bin;C:\\System\\PATH;%USERPROFILE%\\AppData\\Local\\Microsoft\\WindowsApps;C:\\Program Files (x86)\\STMicroelectronics\\st_toolset\\asm;C:\\Program Files (x86)\\Common Files\\Oracle\\Java\\javapath;C:\\WINDOWS\\system32;C:\\WINDOWS;C:\\WINDOWS\\System32\\Wbem;C:\\WINDOWS\\System32\\WindowsPowerShell\\v1.0\\;C:\\WINDOWS\\System32\\OpenSSH\\;C:\\Program Files (x86)\\STMicroelectronics\\STM32 ST-LINK Utility\\ST-LINK Utility;C:\\Program Files\\doxygen\\bin;C:\\Program Files (x86)\\QuickTime\\QTSystem\\;C:\\Users\\furyf\\scoop\\apps\\nodejs\\current\\bin;C:\\Users\\furyf\\scoop\\apps\\nodejs\\current;C:\\Users\\furyf\\go\\bin;C:\\Users\\furyf\\scoop\\apps\\composer\\current\\home\\vendor\\bin;C:\\Users\\furyf\\scoop\\apps\\ruby\\current\\gems\\bin;C:\\Users\\furyf\\scoop\\apps\\ruby\\current\\bin;C:\\Users\\furyf\\scoop\\apps\\python27\\current\\scripts;C:\\Users\\furyf\\scoop\\apps\\latex\\current\\texmfs\\install\\miktex\\bin;C:\\Users\\furyf\\scoop\\apps\\gcc\\current\\bin;C:\\Users\\furyf\\scoop\\apps\\nmap\\current\\bin;C:\\Users\\furyf\\AppData\\Local\\Programs\\Python\\Launcher\\;C:\\Users\\furyf\\scoop\\shims;C:\\Users\\furyf\\AppData\\Local\\Microsoft\\WindowsApps;C:\\Users\\furyf\\scoop\\apps\\msys\\current\\bin;C:\\Users\\furyf\\AppData\\Local\\Programs\\Microsoft VS Code\\bin;C:\\System\\PATH;%USERPROFILE%\\AppData\\Local\\Microsoft\\WindowsApps", |  | ||||||
|         "PLATFORMIO_CALLER": "vscode" |  | ||||||
|     } |  | ||||||
| } |  | ||||||
							
								
								
									
										15
									
								
								data/homie/config.example.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								data/homie/config.example.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | { | ||||||
|  |   "name": "deskcontrol", | ||||||
|  |   "wifi": { | ||||||
|  |     "ssid": "<SSID>", | ||||||
|  |     "password": "<PASS>" | ||||||
|  |   }, | ||||||
|  |   "mqtt": { | ||||||
|  |     "host": "<Domain>", | ||||||
|  |     "port": 1883, | ||||||
|  |     "auth": false | ||||||
|  |   }, | ||||||
|  |   "ota": { | ||||||
|  |     "enabled": true | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										15
									
								
								include/config.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								include/config.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | #ifndef CONFIG_H | ||||||
|  | #define CONFIG_H | ||||||
|  |  | ||||||
|  | #ifndef VERSION | ||||||
|  | //SEMVER style version | ||||||
|  | #define VERSION          "0.4.5-Dev" | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #define CONFIG_SERIAL_BAUDRATE  115200 | ||||||
|  |  | ||||||
|  | #define CONFIG_IO_RELAY         D1 | ||||||
|  | #define CONFIG_IO_DHT11         D2 | ||||||
|  |  | ||||||
|  | #define CONFIG_TEMPERATURE_SEND_INTERVAL 60 | ||||||
|  | #endif | ||||||
| @@ -1,33 +1,12 @@ | |||||||
| # |  | ||||||
| # Project Configuration File |  | ||||||
| # |  | ||||||
| # A detailed documentation with the EXAMPLES is located here: |  | ||||||
| # http://docs.platformio.org/en/latest/projectconf.html |  | ||||||
| # |  | ||||||
|  |  | ||||||
| # A sign `#` at the beginning of the line indicates a comment |  | ||||||
| # Comment lines are ignored. |  | ||||||
|  |  | ||||||
| # Simple and base environment |  | ||||||
| # [env:mybaseenv] |  | ||||||
| # platform = %INSTALLED_PLATFORM_NAME_HERE% |  | ||||||
| # framework = |  | ||||||
| # board = |  | ||||||
| # |  | ||||||
| # Automatic targets - enable auto-uploading |  | ||||||
| # targets = upload |  | ||||||
|  |  | ||||||
| [env] | [env] | ||||||
| platform = espressif8266 | platform = espressif8266 | ||||||
| framework = arduino | framework = arduino | ||||||
|  |  | ||||||
| upload_speed=921600 | upload_speed=921600 | ||||||
|  |  | ||||||
| build_flags = -D PIO_FRAMEWORK_ARDUINO_LWIP2_LOW_MEMORY | build_flags = -DPIO_FRAMEWORK_ARDUINO_LWIP2_LOW_MEMORY -DVERSION=${sysenv.DRONE_SEMVER} | ||||||
| lib_deps = https://github.com/homieiot/homie-esp8266.git#develop-v3 | lib_deps = https://github.com/homieiot/homie-esp8266.git#develop-v3, DHT sensor library for ESPx | ||||||
|  |  | ||||||
| [env:nodemcu] | [env:nodemcu] | ||||||
| board = nodemcu | board = nodemcu | ||||||
|  |  | ||||||
| [env:nodemcuv2] |  | ||||||
| board = nodemcuv2 |  | ||||||
							
								
								
									
										90
									
								
								src/main.cpp
									
									
									
									
									
								
							
							
						
						
									
										90
									
								
								src/main.cpp
									
									
									
									
									
								
							| @@ -1,21 +1,33 @@ | |||||||
| #include <Homie.h> | #include "config.h" | ||||||
| #include <WiFiUdp.h> |  | ||||||
|  |  | ||||||
| const int PIN_RELAY = D1; | #include <Homie.h> | ||||||
| #define OUTPUT_SET(x)  digitalWrite(PIN_RELAY, x ? LOW : HIGH) | #include "DHTesp.h" | ||||||
|  | DHTesp dht; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #define OUTPUT_SET(x)  digitalWrite(CONFIG_IO_RELAY, x ? LOW : HIGH) | ||||||
| unsigned int timer = 0; | unsigned int timer = 0; | ||||||
| unsigned int next_timer_update = 0; | unsigned int next_timer_update = 0; | ||||||
| HomieNode powerNode("power", "Power", "switch"); | HomieNode powerNode("power", "Power", "switch"); | ||||||
|  | HomieNode temperatureNode("temperature", "Temperature", "temperature"); | ||||||
|  |  | ||||||
| bool powerStateHandler(const HomieRange& range, const String& value) { | bool powerStateHandler(const HomieRange& range, const String& value) | ||||||
|     if (value != "on" && value != "off") return false; | { | ||||||
|  |     if (value != "on" && value != "off")  | ||||||
|  |     { | ||||||
|  |       return false; | ||||||
|  |     } | ||||||
|     powerNode.setProperty("state").send(value); |     powerNode.setProperty("state").send(value); | ||||||
|     powerNode.setProperty("timer").send("0"); |     powerNode.setProperty("timer").send("0"); | ||||||
|     timer = 0; |     timer = 0; | ||||||
|     if(value == "on") { |  | ||||||
|  |     if(value == "on") | ||||||
|  |     { | ||||||
|       OUTPUT_SET(true); |       OUTPUT_SET(true); | ||||||
|       Homie.getLogger() << "Power is on" << endl; |       Homie.getLogger() << "Power is on" << endl; | ||||||
|     } else { |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|       OUTPUT_SET(false); |       OUTPUT_SET(false); | ||||||
|       Homie.getLogger() << "Power is off" << endl; |       Homie.getLogger() << "Power is off" << endl; | ||||||
|     } |     } | ||||||
| @@ -23,7 +35,8 @@ bool powerStateHandler(const HomieRange& range, const String& value) { | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
|  |  | ||||||
| bool powerTimerHandler(const HomieRange& range, const String& value) { | bool powerTimerHandler(const HomieRange& range, const String& value) | ||||||
|  | { | ||||||
|     int settimer = value.toInt(); |     int settimer = value.toInt(); | ||||||
|     if(settimer == 0 || settimer > 120)  |     if(settimer == 0 || settimer > 120)  | ||||||
|          return false; |          return false; | ||||||
| @@ -38,14 +51,19 @@ bool powerTimerHandler(const HomieRange& range, const String& value) { | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void setupHandler() { | void setupHandler() | ||||||
|     pinMode(PIN_RELAY, OUTPUT); | { | ||||||
|     OUTPUT_SET(false); |  | ||||||
|     powerNode.setProperty("state").send("off"); |   pinMode(CONFIG_IO_RELAY, OUTPUT); | ||||||
|     powerNode.setProperty("timer").send("0"); |   OUTPUT_SET(false); | ||||||
|  |   powerNode.setProperty("state").send("off"); | ||||||
|  |   powerNode.setProperty("timer").send("0"); | ||||||
|  |  | ||||||
|  |   dht.setup(CONFIG_IO_DHT11, DHTesp::DHT11); // Connect DHT sensor to GPIO 17 | ||||||
| } | } | ||||||
|  |  | ||||||
| void loopHandler() { | void loopHandleTimer()  | ||||||
|  | { | ||||||
|   if(timer) |   if(timer) | ||||||
|   { |   { | ||||||
|     if(timer < millis())  |     if(timer < millis())  | ||||||
| @@ -56,30 +74,60 @@ void loopHandler() { | |||||||
|       powerNode.setProperty("state").send("off"); |       powerNode.setProperty("state").send("off"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if(next_timer_update && millis() > next_timer_update) { |     if(next_timer_update && millis() > next_timer_update) | ||||||
|  |     { | ||||||
|       next_timer_update = millis() + 60*1000; |       next_timer_update = millis() + 60*1000; | ||||||
|       unsigned int time_remaining = timer - millis(); |       unsigned int time_remaining = timer - millis(); | ||||||
|       unsigned int min_left = time_remaining / (60*1000); |       unsigned int min_left = time_remaining / (60*1000); | ||||||
|       powerNode.setProperty("timer").send(String(min_left)); |       powerNode.setProperty("timer").send(String(min_left)); | ||||||
|  |  | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void loopHandleTemperature()  | ||||||
|  | { | ||||||
|  |   static unsigned long lastTemperatureSent = 0; | ||||||
|  |   if (millis() - lastTemperatureSent >= CONFIG_TEMPERATURE_SEND_INTERVAL * 1000UL || lastTemperatureSent == 0) | ||||||
|  |   { | ||||||
|  |     float humidity = dht.getHumidity(); | ||||||
|  |     float temperature = dht.getTemperature(); | ||||||
|  |  | ||||||
| void setup() { |     Homie.getLogger() << "Temperature: " << temperature << "°C " << humidity << "% Humidty" << endl; | ||||||
|     Serial.begin(115200); |     temperatureNode.setProperty("temperature").send(String(temperature)); | ||||||
|  |     temperatureNode.setProperty("humidity").send(String(humidity)); | ||||||
|  |     lastTemperatureSent = millis(); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|     Homie_setFirmware("deskcontrol", "0.3.2"); | void loopHandler() | ||||||
|  | { | ||||||
|  |   loopHandleTimer(); | ||||||
|  |   loopHandleTemperature(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void setup() | ||||||
|  | { | ||||||
|  |     Serial.begin(CONFIG_SERIAL_BAUDRATE); | ||||||
|  |  | ||||||
|  |     Homie_setFirmware("deskcontrol", VERSION); | ||||||
|      |      | ||||||
|     Homie.disableResetTrigger(); |     Homie.disableResetTrigger(); | ||||||
|  |  | ||||||
|  |     //Power | ||||||
|     powerNode.advertise("state").settable(powerStateHandler); |     powerNode.advertise("state").settable(powerStateHandler); | ||||||
|     powerNode.advertise("timer").settable(powerTimerHandler); |     powerNode.advertise("timer").settable(powerTimerHandler); | ||||||
|  |  | ||||||
|  |     //Temperature | ||||||
|  |     temperatureNode.advertise("humidity"); | ||||||
|  |     temperatureNode.advertise("temperature"); | ||||||
|  |  | ||||||
|     Homie.setSetupFunction(setupHandler); |     Homie.setSetupFunction(setupHandler); | ||||||
|     Homie.setLoopFunction(loopHandler); |     Homie.setLoopFunction(loopHandler); | ||||||
|  |  | ||||||
|     Homie.setup(); |     Homie.setup(); | ||||||
| } | } | ||||||
|  |  | ||||||
| void loop() { | void loop() | ||||||
|  | { | ||||||
|     Homie.loop(); |     Homie.loop(); | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user