committed by
							
								 GitHub
								GitHub
							
						
					
				
				
				  
				  No known key found for this signature in database
				  
				  	
						GPG Key ID: 4AEE18F83AFDEB23
				  	
				  
				
			
		
		
		
	
				 5 changed files with 1177 additions and 1175 deletions
			
			
		- 
					6.gitignore
- 
					1039html/website.html
- 
					263html/websiteMgmt.h
- 
					88src/main.cpp
- 
					954src/websiteMgmt.h
						
							
						
						
							1039
	
						
						html/website.html
						
							File diff suppressed because it is too large
							
							
								
									View File
								
							
						
					
				File diff suppressed because it is too large
							
							
								
									View File
								
							
						| @ -1,263 +0,0 @@ | |||||
| static const char mgtWebsite[] PROGMEM = "<!DOCTYPE html>\ |  | ||||
| <html lang=\"de\">\ |  | ||||
|   <head>\ |  | ||||
|     <title>ESPuino-Konfiguration</title>\ |  | ||||
|     <meta charset=\"utf-8\">\ |  | ||||
|     <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">\ |  | ||||
|     <link rel=\"stylesheet\" href=\"https://ts-cs.de/css/bootstrap.min.css\">\ |  | ||||
|     <script src=\"https://ts-cs.de/js/jquery.min.js\"></script>\ |  | ||||
|     <script src=\"https://ts-cs.de/js/popper.min.js\"></script>\ |  | ||||
|     <script src=\"https://ts-cs.de/js/bootstrap.min.js\"></script>\ |  | ||||
|   </head>\ |  | ||||
|   <body>\ |  | ||||
|     <nav class=\"navbar navbar-expand-sm bg-primary navbar-dark\">\ |  | ||||
|       <button class=\"navbar-toggler\" type=\"button\" data-toggle=\"collapse\" data-target=\"#navbarSupportedContent\" aria-controls=\"navbarSupportedContent\" aria-expanded=\"false\" aria-label=\"Toggle navigation\">\ |  | ||||
|         <span class=\"navbar-toggler-icon\"></span>\ |  | ||||
|       </button>\ |  | ||||
|       <a class=\"navbar-brand\">\ |  | ||||
|         <img src=\"./tonuino_logo.png\" width=\"30\" height=\"30\" class=\"d-inline-block align-top\" alt=\"\" />\ |  | ||||
|         Tonuino\ |  | ||||
|       </a>\ |  | ||||
|       <div class=\"collapse navbar-collapse\" id=\"collapsibleNavbar\">\ |  | ||||
|         <ul class=\"navbar-nav mr-auto\">\ |  | ||||
|           <li class=\"nav-item\">\ |  | ||||
|             <a class=\"nav-link\" href=\"#wifiConfig\">WLAN</a>\ |  | ||||
|           </li>\ |  | ||||
|           <li class=\"nav-item\">\ |  | ||||
|             <a class=\"nav-link\" href=\"#rfidMusicTags\">RFID-Zuweisungen</a>\ |  | ||||
|           </li>\ |  | ||||
|           <li class=\"nav-item\">\ |  | ||||
|             <a class=\"nav-link\" href=\"#rfidModTags\">RFID-Modifikationen</a>\ |  | ||||
|           </li>\ |  | ||||
|           <li class=\"nav-item\">\ |  | ||||
|             <a class=\"nav-link\" href=\"#mqttConfig\">MQTT</a>\ |  | ||||
|           </li>\ |  | ||||
|           <li class=\"nav-item\">\ |  | ||||
|             <a class=\"nav-link\" href=\"#ftpConfig\">FTP</a>\ |  | ||||
|           </li>\ |  | ||||
|           <li class=\"nav-item\">\ |  | ||||
|             <a class=\"nav-link\" href=\"#generalConfig\">Allgemein</a>\ |  | ||||
|           </li>\ |  | ||||
|         </ul>\ |  | ||||
|       </div>\ |  | ||||
|     </nav>\ |  | ||||
|     <br />\ |  | ||||
|     <div class=\"container\" id=\"wifiConfig\">\ |  | ||||
|       <h2>WLAN-Konfiguration</h2>\ |  | ||||
|       <form action=\"#wifiConfig\" method=\"GET\">\ |  | ||||
|         <div class=\"form-group col-md-6\">\ |  | ||||
|           <label for=\"SSID\">WLAN-Name (SSID):</label>\ |  | ||||
|           <input type=\"text\" class=\"form-control\" id=\"SSID\" placeholder=\"SSID\" name=\"SSID\" required>\ |  | ||||
|           <div class=\"invalid-feedback\">\ |  | ||||
|             Bitte SSID des WLANs eintragen.\ |  | ||||
|           </div>\ |  | ||||
|           <label for=\"pwd\">Passwort:</label>\ |  | ||||
|           <input type=\"password\" class=\"form-control\" id=\"pwd\" placeholder=\"Passwort\" name=\"pwd\" required>\ |  | ||||
|         </div>\ |  | ||||
|         <button type=\"reset\" class=\"btn btn-secondary\">Reset</button>\ |  | ||||
|         <button type=\"submit\" class=\"btn btn-primary\" onclick=\"wifiConfig()\">Absenden</button>\ |  | ||||
|       </form>\ |  | ||||
|     </div>\ |  | ||||
|     <div class=\"container my-5\" id=\"rfidMusicTags\">\ |  | ||||
|         <h2>RFID-Zuweisungen</h2>\ |  | ||||
|         <form action=\"#rfidMusicTags\" method=\"GET\">\ |  | ||||
|             <div class=\"form-group col-md-6\">\ |  | ||||
|                 <label for=\"rfidIdMusic\">RFID-Chip-Nummer</label>\ |  | ||||
|                 <input type=\"text\" class=\"form-control\" id=\"rfidIdMusic\" maxlength=\"12\" pattern=\"[0-9]{12}\" placeholder=\"012345678912\" name=\"rfidIdMusic\" required>\ |  | ||||
|                 <label for=\"fileOrUrl\">Datei, Verzeichnis oder URL (URL nur für Webradio)</label>\ |  | ||||
|                 <input type=\"text\" class=\"form-control\" id=\"fileOrUrl\" maxlength=\"255\" placeholder=\"z.B. /mp3/Hoerspiele/Yakari/Yakari_und_seine_Freunde.mp3\" name=\"fileOrUrl\" required>\ |  | ||||
|                 <label for=\"playMode\">Abspielmodus</label>\ |  | ||||
|                 <select class=\"form-control\" id=\"playMode\" name=\"playMode\">\ |  | ||||
|                     <option value=\"1\">Einzelner Titel</option>\ |  | ||||
|                     <option value=\"2\">Einzelner Titel (Endlosschleife)</option>\ |  | ||||
|                     <option value=\"3\">Hörbuch</option>\ |  | ||||
|                     <option value=\"4\">Hörbuch (Endlosschleife)</option>\ |  | ||||
|                     <option value=\"5\">Alle Titel eines Verzeichnis (sortiert)</option>\ |  | ||||
|                     <option value=\"6\">Alle Titel eines Verzeichnis (zufällig)</option>\ |  | ||||
|                     <option value=\"7\">Alle Titel eines Verzeichnis (sortiert, Endlosschleife)</option>\ |  | ||||
|                     <option value=\"8\">Alle Titel eines Verzeichnis (zufällig, Endlosschleife)</option>\ |  | ||||
|                     <option value=\"9\">Webradio</option>\ |  | ||||
|                 </select>\ |  | ||||
|           </div>\ |  | ||||
|           <button type=\"reset\" class=\"btn btn-secondary\">Reset</button>\ |  | ||||
|           <button type=\"submit\" class=\"btn btn-primary\" onclick=\"rfidAssign()\">Absenden</button>\ |  | ||||
|         </form>\ |  | ||||
|     </div>\ |  | ||||
|     <div class=\"container my-5\" id=\"rfidModTags\">\ |  | ||||
|         <h2>RFID-Modifkationen</h2>\ |  | ||||
|         <form class=\"needs-validation\" action=\"#rfidModTags\" method=\"GET\" novalidate>\ |  | ||||
|             <div class=\"form-group col-md-6\">\ |  | ||||
|                 <label for=\"rfidIdMod\">RFID-Chip-Nummer</label>\ |  | ||||
|                 <input type=\"text\" class=\"form-control\" id=\"rfidIdMod\" maxlength=\"12\" pattern=\"[0-9]{12}\" placeholder=\"012345678912\" name=\"rfidIdMod\" required>\ |  | ||||
|                 <div class=\"invalid-feedback\">\ |  | ||||
|                   Bitte eine 12-stellige Zahl eingeben.\ |  | ||||
|                 </div>\ |  | ||||
|                 <label for=\"modId\">Abspielmodus</label>\ |  | ||||
|                 <select class=\"form-control\" id=\"modId\" name=\"modId\">\ |  | ||||
|                     <option value=\"100\">Tastensperre</option>\ |  | ||||
|                     <option value=\"101\">Schlafen nach 15 Minuten</option>\ |  | ||||
|                     <option value=\"102\">Schlafen nach 30 Minuten</option>\ |  | ||||
|                     <option value=\"103\">Schlafen nach 1 Stunde</option>\ |  | ||||
|                     <option value=\"104\">Schlafen nach 2 Stunden</option>\ |  | ||||
|                     <option value=\"105\">Schlafen nach Ende des Titels</option>\ |  | ||||
|                     <option value=\"106\">Schlafen nach Ende der Playlist</option>\ |  | ||||
|                     <option value=\"110\">Wiederhole Playlist (endlos)</option>\ |  | ||||
|                     <option value=\"111\">Wiederhole Titel (endlos)</option>\ |  | ||||
|                     <option value=\"112\">Dimme LEDs (Nachtmodus)</option>\ |  | ||||
|                 </select>\ |  | ||||
|           </div>\ |  | ||||
|           <button type=\"reset\" class=\"btn btn-secondary\">Reset</button>\ |  | ||||
|           <button type=\"submit\" class=\"btn btn-primary\" onclick=\"rfidMods()\">Absenden</button>\ |  | ||||
|         </form>\ |  | ||||
|     </div>\ |  | ||||
|     <div class=\"container my-5\" id=\"mqttConfig\">\ |  | ||||
|         <h2>MQTT-Konfiguration</h2>\ |  | ||||
|         <form class=\"needs-validation\" action=\"#mqttConfig\" method=\"GET\" novalidate>\ |  | ||||
|             <div class=\"form-check col-md-6\">\ |  | ||||
|                 <input class=\"form-check-input\" type=\"checkbox\" value=\"1\" id=\"mqttEnable\" name=\"mqttEnable\" %MQTT_ENABLE%>\ |  | ||||
|                 <label class=\"form-check-label\" for=\"mqttEnable\">\ |  | ||||
|                   MQTT aktivieren\ |  | ||||
|                 </label>\ |  | ||||
|             </div>\ |  | ||||
|             <div class=\"form-group my-2 col-md-6\">\ |  | ||||
|                 <label for=\"mqttServer\">MQTT-Server (IP-Adresse)</label>\ |  | ||||
|                 <input type=\"text\" class=\"form-control\" id=\"mqttServer\" pattern=\"^((\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.){3}(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$\" minlength=\"7\" maxlength=\"15\" placeholder=\"z.B. 192.168.2.89\" name=\"mqttServer\" value=\"%MQTT_SERVER%\">\ |  | ||||
|                 <div class=\"invalid-feedback\">\ |  | ||||
|                   Bitte eine gültige IPv4-Adresse eingeben, z.B. 192.168.2.89.\ |  | ||||
|                 </div>\ |  | ||||
|             </div>\ |  | ||||
|           <button type=\"reset\" class=\"btn btn-secondary\">Reset</button>\ |  | ||||
|           <button type=\"submit\" class=\"btn btn-primary\" onclick=\"mqttSettings()\">Absenden</button>\ |  | ||||
|         </form>\ |  | ||||
|     </div>\ |  | ||||
|     <div class=\"container\" id=\"ftpConfig\">\ |  | ||||
|         <h2>FTP-Konfiguration</h2>\ |  | ||||
|         <form action=\"#ftpConfig\" method=\"GET\">\ |  | ||||
|           <div class=\"form-group col-md-6\">\ |  | ||||
|             <label for=\"ftpUser\">FTP-Benutzername:</label>\ |  | ||||
|             <input type=\"text\" class=\"form-control\" id=\"ftpUser\" maxlength=\"32\" placeholder=\"Benutzername\" name=\"ftpUser\" value=\"%FTP_USER%\" required>\ |  | ||||
|             <label for=\"pwd\">Passwort:</label>\ |  | ||||
|             <input type=\"password\" class=\"form-control\" id=\"ftpPwd\" maxlength=\"32\" placeholder=\"Passwort\" name=\"ftpPwd\" value=\"%FTP_PWD%\" required>\ |  | ||||
|           </div>\ |  | ||||
|           <button type=\"reset\" class=\"btn btn-secondary\">Reset</button>\ |  | ||||
|           <button type=\"submit\" class=\"btn btn-primary\" onClick=\"ftpSettings()\">Absenden</button>\ |  | ||||
|         </form>\ |  | ||||
|     </div>\ |  | ||||
|     <div class=\"container my-5\" id=\"generalConfig\">\ |  | ||||
|         <h2>Allgemeine Konfiguration</h2>\ |  | ||||
|         <form action=\"#generalConfig\" method=\"GET\">\ |  | ||||
|             <div class=\"form-group col-md-6\">\ |  | ||||
|                 <label for=\"initialVolume\">Lautstärke nach dem Einschalten</label>\ |  | ||||
|                 <input type=\"number\" min=\"1\" max=\"21\" class=\"form-control\" id=\"initialVolume\" name=\"initialVolume\" value=\"%INIT_VOLUME%\" required>\ |  | ||||
|                 <label for=\"maxVolume\">Maximale Lautstärke</label>\ |  | ||||
|                 <input type=\"number\" min=\"1\" max=\"21\" class=\"form-control\" id=\"maxVolume\" name=\"maxVolume\" value=\"%MAX_VOLUME%\" required>\ |  | ||||
|             </div>\ |  | ||||
|             <div class=\"form-group col-md-6\">\ |  | ||||
|                 <label for=\"initBrightness\">Neopixel-Helligkeit nach dem Einschalten</label>\ |  | ||||
|                 <input type=\"number\" min=\"0\" max=\"255\" class=\"form-control\" id=\"initBrightness\" name=\"initBrightness\" value=\"%INIT_LED_BRIGHTBESS%\" required>\ |  | ||||
|                 <label for=\"nightBrightness\">Neopixel-Helligkeit im Nachtmodus</label>\ |  | ||||
|                 <input type=\"number\" min=\"0\" max=\"255\" class=\"form-control\" id=\"nightBrightness\" name=\"nightBrightness\" value=\"%NIGHT_LED_BRIGHTBESS%\" required>\ |  | ||||
|             </div>\ |  | ||||
|             <div class=\"form-group col-md-6\">\ |  | ||||
|                 <label for=\"inactivityTime\">Deep-Sleep nach Inaktivität (Minuten)</label>\ |  | ||||
|                 <input type=\"number\" min=\"1\" max=\"1440\" class=\"form-control\" id=\"inactivityTime\" name=\"inactivityTime\" value=\"%MAX_INACTIVITY%\" required>\ |  | ||||
|             </div>\ |  | ||||
|           <button type=\"reset\" class=\"btn btn-secondary\">Reset</button>\ |  | ||||
|           <button type=\"submit\" class=\"btn btn-primary\" onClick=\"genSettings()\">Absenden</button>\ |  | ||||
|         </form>\ |  | ||||
|         <script>\ |  | ||||
|           (function() {\ |  | ||||
|             'use strict';\ |  | ||||
|             window.addEventListener('load', function() {\ |  | ||||
|               // Fetch all the forms we want to apply custom Bootstrap validation styles to\ |  | ||||
|               var forms = document.getElementsByClassName('needs-validation');\ |  | ||||
|               // Loop over them and prevent submission\ |  | ||||
|               var validation = Array.prototype.filter.call(forms, function(form) {\ |  | ||||
|                 form.addEventListener('submit', function(event) {\ |  | ||||
|                   if (form.checkValidity() === false) {\ |  | ||||
|                     event.preventDefault();\ |  | ||||
|                     event.stopPropagation();\ |  | ||||
|                   }\ |  | ||||
|                   form.classList.add('was-validated');\ |  | ||||
|                 }, false);\ |  | ||||
|               });\ |  | ||||
|             }, false);\ |  | ||||
|           });\ |  | ||||
| \ |  | ||||
|           let socket = new WebSocket(\"ws://%IPv4%:81/ws\");\ |  | ||||
| \ |  | ||||
|           function genSettings() {\ |  | ||||
| \ |  | ||||
|             var myObj = {\ |  | ||||
|               \"general\": {\ |  | ||||
|                 iVol: document.getElementById('initialVolume').value,\ |  | ||||
|                 mVol: document.getElementById('maxVolume').value,\ |  | ||||
|                 iBright: document.getElementById('initBrightness').value,\ |  | ||||
|                 nBright: document.getElementById('nightBrightness').value,\ |  | ||||
|                 iTime: document.getElementById('inactivityTime').value\ |  | ||||
|               }\ |  | ||||
|             };\ |  | ||||
|             var myJSON = JSON.stringify(myObj);\ |  | ||||
|             socket.send(myJSON);\ |  | ||||
|           }\ |  | ||||
| \ |  | ||||
|           function ftpSettings() {\ |  | ||||
|             var myObj = {\ |  | ||||
|               \"ftp\": {\ |  | ||||
|                 ftpUser: document.getElementById('ftpUser').value,\ |  | ||||
|                 ftpPwd: document.getElementById('ftpPwd').value\ |  | ||||
|               }\ |  | ||||
|             };\ |  | ||||
|             var myJSON = JSON.stringify(myObj);\ |  | ||||
|             socket.send(myJSON);\ |  | ||||
|           }\ |  | ||||
| \ |  | ||||
|           function mqttSettings() {\ |  | ||||
|             var myObj = {\ |  | ||||
|               \"mqtt\": {\ |  | ||||
|                 enable: document.getElementById('mqttEnable').value,\ |  | ||||
|                 server: document.getElementById('mqttServer').value\ |  | ||||
|               }\ |  | ||||
|             };\ |  | ||||
|             var myJSON = JSON.stringify(myObj);\ |  | ||||
|             socket.send(myJSON);\ |  | ||||
|           }\ |  | ||||
| \ |  | ||||
|           function rfidMods() {\ |  | ||||
|             var myObj = {\ |  | ||||
|               \"rfidMod\": {\ |  | ||||
|                 rfidId: document.getElementById('rfidIdMod').value,\ |  | ||||
|                 modId: document.getElementById('modId').value\ |  | ||||
|               }\ |  | ||||
|             };\ |  | ||||
|             var myJSON = JSON.stringify(myObj);\ |  | ||||
|             socket.send(myJSON);\ |  | ||||
|           }\ |  | ||||
| \ |  | ||||
|           function rfidAssign() {\ |  | ||||
|             var myObj = {\ |  | ||||
|               \"rfidAssign\": {\ |  | ||||
|                 rfidId: document.getElementById('rfidIdMusic').value,\ |  | ||||
|                 fileOrUrl: document.getElementById('fileOrUrl').value,\ |  | ||||
|                 playmode: document.getElementById('playMode').value\ |  | ||||
|               }\ |  | ||||
|             };\ |  | ||||
|             var myJSON = JSON.stringify(myObj);\ |  | ||||
|             socket.send(myJSON);\ |  | ||||
|           }\ |  | ||||
| \ |  | ||||
|           function wifiConfig() {\ |  | ||||
|             var myObj = {\ |  | ||||
|               \"wifiConfig\": {\ |  | ||||
|                 ssid: document.getElementById('SSID').value,\ |  | ||||
|                 pwd: document.getElementById('pwd').value\ |  | ||||
|               }\ |  | ||||
|             };\ |  | ||||
|             var myJSON = JSON.stringify(myObj);\ |  | ||||
|             socket.send(myJSON);\ |  | ||||
|           }\ |  | ||||
|         </script>\ |  | ||||
|     </div>\ |  | ||||
|   </body>\ |  | ||||
| </html>\ |  | ||||
| "; |  | ||||
						
							
						
						
							954
	
						
						src/websiteMgmt.h
						
							File diff suppressed because it is too large
							
							
								
									View File
								
							
						
					
				File diff suppressed because it is too large
							
							
								
									View File
								
							
						
						Write
						Preview
					
					
					Loading…
					
					Cancel
						Save
					
		Reference in new issue