Compare commits
	
		
			30 Commits
		
	
	
		
			v0.1.1
			...
			8387a0610b
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 8387a0610b | |||
| 764b18e539 | |||
| e5a64c13ed | |||
| 338c90fb8e | |||
| 85c57daf91 | |||
| 5cb5300d15 | |||
| d5ffd87f90 | |||
| 0cff4d019a | |||
| 10b337d43f | |||
| d19bd16561 | |||
| 36ce6f976b | |||
| a4c2d49fb0 | |||
| bad20a7f58 | |||
| c00d2afb27 | |||
|   | 0ae3824e88 | ||
|   | 847dda81be | ||
|   | dc91211889 | ||
| 58bcd731fc | |||
| 6efa5bd0b8 | |||
| 2a3bbc3628 | |||
|   | e322b5ddcd | ||
| 795043a639 | |||
| b0a485d578 | |||
| 3d4399c33d | |||
| a33780a3a7 | |||
| d2cd7f3445 | |||
| b0f6691a7d | |||
| d510cdd50e | |||
| 9b4dd040c1 | |||
| 53ed60151c | 
							
								
								
									
										14
									
								
								.drone.yml
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								.drone.yml
									
									
									
									
									
								
							| @@ -3,21 +3,23 @@ name: default | |||||||
|  |  | ||||||
| steps: | steps: | ||||||
| - name: build | - name: build | ||||||
|   image: python:2 |   image: python:3 | ||||||
|   commands: |   commands: | ||||||
|   - apt-get -y update && apt-get -y install git && pip install platformio |   - pip install platformio | ||||||
|   - pio run |   - pio run | ||||||
| - name: upload | - name: upload | ||||||
|   image: python:2 |   image: python:3 | ||||||
|   commands: |   commands: | ||||||
|   - make otaupload |   - make otaupload | ||||||
|  |   when: | ||||||
|  |     event: tag | ||||||
| - name: release | - name: release | ||||||
|   image: plugins/gitea-release |   image: plugins/gitea-release | ||||||
|   settings: |   settings: | ||||||
|     api_key: ef6a0baa30f8994719e236370290ac9f8bbbdb1d |     api_key:  | ||||||
|  |       from_secret: DRONE_ACCESS_TOKEN | ||||||
|     base_url: https://code.jcktrue.dk |     base_url: https://code.jcktrue.dk | ||||||
|     files: |     files: | ||||||
|       - .pioenvs/nodemcu/firmware.bin |       - .pio/build/nodemcu/firmware.bin | ||||||
|       - .pioenvs/nodemcu/firmware.elf |  | ||||||
|   when: |   when: | ||||||
|     event: tag |     event: tag | ||||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +1,5 @@ | |||||||
| .pioenvs | .pioenvs | ||||||
| .piolibdeps | .piolibdeps | ||||||
|  | .pio | ||||||
| data/homie/config.json | data/homie/config.json | ||||||
| nbproject | nbproject | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								.vscode/.BROWSE.C_CPP.DB
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.vscode/.BROWSE.C_CPP.DB
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										129
									
								
								.vscode/c_cpp_properties.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										129
									
								
								.vscode/c_cpp_properties.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,129 @@ | |||||||
|  | { | ||||||
|  |     "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/DHT sensor library for ESPx_ID2029", | ||||||
|  |                 "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/Homie/src", | ||||||
|  |                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266mDNS/src", | ||||||
|  |                 "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266HTTPClient/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/.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/DHT sensor library for ESPx_ID2029", | ||||||
|  |                     "c:/Users/furyf/Dev/deskcontrol/.pio/libdeps/nodemcu/Homie/src", | ||||||
|  |                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266mDNS/src", | ||||||
|  |                     "C:/Users/furyf/.platformio/packages/framework-arduinoespressif8266/libraries/ESP8266HTTPClient/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/.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
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | { | ||||||
|  | 	// 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
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								.vscode/launch.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | // 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
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | { | ||||||
|  |     "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\\scoop\\apps\\latex\\current\\texmfs\\install\\miktex\\bin\\x64;C:\\Users\\furyf\\scoop\\apps\\latex\\current\\texmfs\\install\\miktex\\bin;C:\\Users\\furyf\\scoop\\apps\\ruby\\current\\gems\\bin;C:\\Users\\furyf\\scoop\\apps\\ruby\\current\\bin;C:\\Users\\furyf\\go\\bin;C:\\Users\\furyf\\scoop\\apps\\composer\\current\\home\\vendor\\bin;C:\\Users\\furyf\\scoop\\apps\\python27\\current\\scripts;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\\scoop\\apps\\latex\\current\\texmfs\\install\\miktex\\bin\\x64;C:\\Users\\furyf\\scoop\\apps\\latex\\current\\texmfs\\install\\miktex\\bin;C:\\Users\\furyf\\scoop\\apps\\ruby\\current\\gems\\bin;C:\\Users\\furyf\\scoop\\apps\\ruby\\current\\bin;C:\\Users\\furyf\\go\\bin;C:\\Users\\furyf\\scoop\\apps\\composer\\current\\home\\vendor\\bin;C:\\Users\\furyf\\scoop\\apps\\python27\\current\\scripts;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" | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										41
									
								
								Jenkinsfile
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										41
									
								
								Jenkinsfile
									
									
									
									
										vendored
									
									
								
							| @@ -1,41 +0,0 @@ | |||||||
| pipeline { |  | ||||||
|     agent { |  | ||||||
|         docker { |  | ||||||
|             image 'debian:stretch-slim'  |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     stages { |  | ||||||
|         stage('Requirements') {  |  | ||||||
|             steps { |  | ||||||
|                 sh 'apt-get -y update && apt-get -y install git python-pip cloc && pip install platformio'  |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         stage('Build') { |  | ||||||
|             steps { |  | ||||||
|                 sh 'pio run' |  | ||||||
|             } |  | ||||||
|             post { |  | ||||||
|                 always { |  | ||||||
|                     archiveArtifacts '.pioenvs/nodemcu/firmware.bin, .pioenvs/nodemcu/firmware.elf' |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         stage('Coverage') { |  | ||||||
|             steps { |  | ||||||
|                 sh 'cloc --by-file --xml --out=.test/cloc.xml src include' |  | ||||||
|             } |  | ||||||
|             post { |  | ||||||
|                 always { |  | ||||||
|                     recordIssues(tools: [taskScanner(ignoreCase: true, includePattern: 'src/*.*', normalTags: 'TODO')]) |  | ||||||
|                     sloccountPublish encoding: '', pattern: '.test/cloc.xml' |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         stage('Upload') { |  | ||||||
|             steps { |  | ||||||
|                 sh 'make otaupload' |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
							
								
								
									
										4
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								Makefile
									
									
									
									
									
								
							| @@ -2,5 +2,5 @@ build: | |||||||
| 	pio run | 	pio run | ||||||
|  |  | ||||||
| otaupload:  | otaupload:  | ||||||
| 	pip install -r .piolibdeps/Homie/scripts/ota_updater/requirements.txt | 	pip install -r .pio/libdeps/nodemcu/Homie/scripts/ota_updater/requirements.txt | ||||||
| 	python .piolibdeps/Homie/scripts/ota_updater/ota_updater.py -l mqtt.jcktrue.dk -i 18fe34f2f987 .pioenvs/nodemcu/firmware.bin | 	python .pio/libdeps/nodemcu/Homie/scripts/ota_updater/ota_updater.py -l mqtt.jcktrue.dk -i 18fe34f2f987 .pio/build/nodemcu/firmware.bin | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
|  | [](https://build.jcktrue.dk/jct/deskcontrol) | ||||||
| # README # | # README # | ||||||
| edit data/homie/config.json | * edit data/homie/config.json | ||||||
| platformio run -t upload | * platformio run -t upload | ||||||
| platformio run -t uploadfs | * platformio run -t uploadfs | ||||||
							
								
								
									
										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 | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -17,11 +17,15 @@ | |||||||
| # Automatic targets - enable auto-uploading | # Automatic targets - enable auto-uploading | ||||||
| # targets = upload | # targets = upload | ||||||
|  |  | ||||||
| [env:nodemcu] | [env] | ||||||
| platform = espressif8266 | platform = espressif8266 | ||||||
| framework = arduino | framework = arduino | ||||||
| board = nodemcu |  | ||||||
| upload_speed=921600 | upload_speed=921600 | ||||||
|  |  | ||||||
| build_flags = -D PIO_FRAMEWORK_ARDUINO_LWIP2_LOW_MEMORY | build_flags = -D PIO_FRAMEWORK_ARDUINO_LWIP2_LOW_MEMORY | ||||||
| lib_deps = https://github.com/homieiot/homie-esp8266.git#develop, Syslog | lib_deps = https://github.com/homieiot/homie-esp8266.git#develop-v3, DHT sensor library for ESPx | ||||||
|  |  | ||||||
|  | [env:nodemcu] | ||||||
|  | board = nodemcu | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										165
									
								
								src/main.cpp
									
									
									
									
									
								
							
							
						
						
									
										165
									
								
								src/main.cpp
									
									
									
									
									
								
							| @@ -1,113 +1,106 @@ | |||||||
| #include <Homie.h> | #include <Homie.h> | ||||||
| #include <Syslog.h> |  | ||||||
| #include <WiFiUdp.h> | #include "DHTesp.h" | ||||||
| WiFiUDP udpClient; | DHTesp dht; | ||||||
| Syslog syslog(udpClient, SYSLOG_PROTO_IETF); | const int TEMPERATURE_INTERVAL = 60; | ||||||
|  | unsigned long lastTemperatureSent = 0; | ||||||
|  |  | ||||||
| const int PIN_RELAY = D1; | const int PIN_RELAY = D1; | ||||||
| int timer = 0; | const int PIN_DHT11 = D2; | ||||||
| HomieNode powerNode("power", "switch"); | #define OUTPUT_SET(x)  digitalWrite(PIN_RELAY, x ? LOW : HIGH) | ||||||
|  | unsigned int timer = 0; | ||||||
|  | unsigned int next_timer_update = 0; | ||||||
|  | HomieNode powerNode("power", "Power", "switch"); | ||||||
|  | HomieNode temperatureNode("temperature", "Temperature", "temperature"); | ||||||
|  |  | ||||||
|  | bool powerStateHandler(const HomieRange& range, const String& value) { | ||||||
|  |     if (value != "on" && value != "off") return false; | ||||||
| bool powerOnHandler(const HomieRange& range, const String& value) { |     powerNode.setProperty("state").send(value); | ||||||
|     if (value != "true" && value != "false") return false; |     powerNode.setProperty("timer").send("0"); | ||||||
|     bool on = (value == "true"); |     timer = 0; | ||||||
|     digitalWrite(PIN_RELAY, on ? LOW : HIGH); |     if(value == "on") { | ||||||
|     powerNode.setProperty("on").send(value); |       OUTPUT_SET(true); | ||||||
|     Homie.getLogger() << "Power is " << (on ? "on" : "off") << endl; |       Homie.getLogger() << "Power is on" << endl; | ||||||
|  |     } else { | ||||||
|  |       OUTPUT_SET(false); | ||||||
|  |       Homie.getLogger() << "Power is off" << endl; | ||||||
|  |     } | ||||||
|      |      | ||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
|  |  | ||||||
| void setupHandler() { | bool powerTimerHandler(const HomieRange& range, const String& value) { | ||||||
|     pinMode(PIN_RELAY, OUTPUT); |     int settimer = value.toInt(); | ||||||
|     digitalWrite(PIN_RELAY, HIGH); |     if(settimer == 0 || settimer > 120)  | ||||||
|  |          return false; | ||||||
|  |  | ||||||
|     powerNode.setProperty("on").send("false"); |     timer = millis() + (settimer * 1000 * 60); | ||||||
|  |     next_timer_update = millis() + 60*1000; | ||||||
|  |     powerNode.setProperty("timer").send(String(settimer)); | ||||||
|  |     powerNode.setProperty("state").send("on"); | ||||||
|  |     Homie.getLogger() << "Power is on for " << settimer << "minutes" << endl; | ||||||
|  |     OUTPUT_SET(true); | ||||||
|  |     return true; | ||||||
| } | } | ||||||
|  |  | ||||||
| void onHomieEvent(const HomieEvent& event) { |  | ||||||
|   switch(event.type) { |  | ||||||
|     case HomieEventType::STANDALONE_MODE: |  | ||||||
|       // Do whatever you want when standalone mode is started |  | ||||||
|       break; |  | ||||||
|     case HomieEventType::CONFIGURATION_MODE: |  | ||||||
|       // Do whatever you want when configuration mode is started |  | ||||||
|       break; |  | ||||||
|     case HomieEventType::NORMAL_MODE: |  | ||||||
|       // Do whatever you want when normal mode is started |  | ||||||
|       break; |  | ||||||
|     case HomieEventType::OTA_STARTED: |  | ||||||
|       // Do whatever you want when OTA is started |  | ||||||
|       break; |  | ||||||
|     case HomieEventType::OTA_PROGRESS: |  | ||||||
|       // Do whatever you want when OTA is in progress |  | ||||||
|  |  | ||||||
|       // You can use event.sizeDone and event.sizeTotal | void setupHandler() { | ||||||
|       break; |   pinMode(PIN_RELAY, OUTPUT); | ||||||
|     case HomieEventType::OTA_FAILED: |   OUTPUT_SET(false); | ||||||
|       // Do whatever you want when OTA is failed |   powerNode.setProperty("state").send("off"); | ||||||
|       break; |   powerNode.setProperty("timer").send("0"); | ||||||
|     case HomieEventType::OTA_SUCCESSFUL: |  | ||||||
|       // Do whatever you want when OTA is successful |  | ||||||
|       break; |  | ||||||
|     case HomieEventType::ABOUT_TO_RESET: |  | ||||||
|       // Do whatever you want when the device is about to reset |  | ||||||
|       break; |  | ||||||
|     case HomieEventType::WIFI_CONNECTED: |  | ||||||
|       // Do whatever you want when Wi-Fi is connected in normal mode |  | ||||||
|       syslog.deviceHostname(Homie.getConfiguration().name); |  | ||||||
|       syslog.appName("deskcontrol"); |  | ||||||
|       syslog.defaultPriority(LOG_ERR); |  | ||||||
|       syslog.log(LOG_INFO, "WiFi Connected, software version: 1.0"); |  | ||||||
|       // You can use event.ip, event.gateway, event.mask |  | ||||||
|       break; |  | ||||||
|     case HomieEventType::WIFI_DISCONNECTED: |  | ||||||
|       // Do whatever you want when Wi-Fi is disconnected in normal mode |  | ||||||
|  |  | ||||||
|       // You can use event.wifiReason |  | ||||||
|       break; |  | ||||||
|     case HomieEventType::MQTT_READY: |  | ||||||
|       // Do whatever you want when MQTT is connected in normal mode |  | ||||||
|       syslog.log(LOG_INFO, "MQTT connected"); |  | ||||||
|       break; |  | ||||||
|     case HomieEventType::MQTT_DISCONNECTED: |  | ||||||
|       // Do whatever you want when MQTT is disconnected in normal mode |  | ||||||
|       syslog.log(LOG_INFO, "MQTT disconnected"); |  | ||||||
|       // You can use event.mqttReason |  | ||||||
|       break; |  | ||||||
|     case HomieEventType::MQTT_PACKET_ACKNOWLEDGED: |  | ||||||
|       // Do whatever you want when an MQTT packet with QoS > 0 is acknowledged by the broker |  | ||||||
|      |      | ||||||
|       // You can use event.packetId |   dht.setup(PIN_DHT11, DHTesp::DHT11); // Connect DHT sensor to GPIO 17 | ||||||
|       break; | } | ||||||
|     case HomieEventType::READY_TO_SLEEP: |  | ||||||
|       // After you've called `prepareToSleep()`, the event is triggered when MQTT is disconnected | void loopHandler() { | ||||||
|       break; |   if(timer) | ||||||
|     case HomieEventType::SENDING_STATISTICS: |   { | ||||||
|       // Do whatever you want when statistics are sent in normal mode |     if(timer < millis())  | ||||||
|       break; |     { //Timer has expired. (Ignore the wraparound...) | ||||||
|  |       timer = 0; | ||||||
|  |       OUTPUT_SET(false); | ||||||
|  |       powerNode.setProperty("timer").send("0"); | ||||||
|  |       powerNode.setProperty("state").send("off"); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if(next_timer_update && millis() > next_timer_update) { | ||||||
|  |       next_timer_update = millis() + 60*1000; | ||||||
|  |       unsigned int time_remaining = timer - millis(); | ||||||
|  |       unsigned int min_left = time_remaining / (60*1000); | ||||||
|  |       powerNode.setProperty("timer").send(String(min_left)); | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if (millis() - lastTemperatureSent >= TEMPERATURE_INTERVAL * 1000UL || lastTemperatureSent == 0) | ||||||
|  |   { | ||||||
|  |     float humidity = dht.getHumidity(); | ||||||
|  |     float temperature = dht.getTemperature(); | ||||||
|  |  | ||||||
|  |     Homie.getLogger() << "Temperature: " << temperature << "°C " << humidity << "% Humidty" << endl; | ||||||
|  |     temperatureNode.setProperty("temperature").send(String(temperature)); | ||||||
|  |     temperatureNode.setProperty("humidity").send(String(humidity)); | ||||||
|  |     lastTemperatureSent = millis(); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| void setup() { | void setup() { | ||||||
|     syslog.server("192.168.1.100", 514); |  | ||||||
|      |  | ||||||
|  |  | ||||||
|     Serial.begin(115200); |     Serial.begin(115200); | ||||||
|  |  | ||||||
|     Serial << endl << endl; |     Homie_setFirmware("deskcontrol", "0.4.2"); | ||||||
|     Serial << "Firmware 0.0.1" << endl; |  | ||||||
|     Serial << endl << endl; |  | ||||||
|      |      | ||||||
|     Homie_setFirmware("deskcontrol", "1.0.0"); |     Homie.disableResetTrigger(); | ||||||
|     Homie_setBrand("FuryFire"); |     powerNode.advertise("state").settable(powerStateHandler); | ||||||
|  |     powerNode.advertise("timer").settable(powerTimerHandler); | ||||||
|  |  | ||||||
|     powerNode.advertise("on").settable(powerOnHandler); |     temperatureNode.advertise("humidity"); | ||||||
|  |     temperatureNode.advertise("temperature"); | ||||||
|  |  | ||||||
|     Homie.setSetupFunction(setupHandler); |     Homie.setSetupFunction(setupHandler); | ||||||
|     Homie.onEvent(onHomieEvent); // before Homie.setup()  |     Homie.setLoopFunction(loopHandler); | ||||||
|  |  | ||||||
|     Homie.setup(); |     Homie.setup(); | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user