WLED/wled00/wled05_init.ino

303 lines
7.0 KiB
Arduino
Raw Normal View History

/*
* Setup code
*/
void wledInit()
{
EEPROM.begin(EEPSIZE);
ledCount = EEPROM.read(229) + ((EEPROM.read(398) << 8) & 0xFF00);
if (ledCount > 1200 || ledCount == 0) ledCount = 30;
#ifndef ARDUINO_ARCH_ESP32
#if LEDPIN == 3
if (ledCount > 300) ledCount = 300; //DMA method uses too much ram
#endif
#endif
Serial.begin(115200);
Serial.setTimeout(50);
strip.init(EEPROM.read(372),ledCount,EEPROM.read(2204)); //init LEDs quickly
2019-02-05 19:40:24 +01:00
#ifdef USEFS
SPIFFS.begin();
#endif
DEBUG_PRINTLN("Load EEPROM");
loadSettingsFromEEPROM(true);
beginStrip();
DEBUG_PRINT("CSSID: ");
DEBUG_PRINT(clientSSID);
2018-02-25 14:46:11 +01:00
userBeginPreConnection();
if (strcmp(clientSSID,"Your_Network") == 0) showWelcomePage = true;
WiFi.persistent(false);
initCon();
DEBUG_PRINTLN("");
DEBUG_PRINT("Connected! IP address: ");
DEBUG_PRINTLN(WiFi.localIP());
if (hueIP[0] == 0)
{
hueIP[0] = WiFi.localIP()[0];
hueIP[1] = WiFi.localIP()[1];
hueIP[2] = WiFi.localIP()[2];
}
2016-11-27 22:37:51 +01:00
if (udpPort > 0 && udpPort != ntpLocalPort)
{
udpConnected = notifierUdp.begin(udpPort);
if (udpConnected && udpRgbPort != udpPort) udpRgbConnected = rgbUdp.begin(udpRgbPort);
}
2017-03-20 19:56:07 +01:00
if (ntpEnabled && WiFi.status() == WL_CONNECTED)
2017-02-07 16:02:27 +01:00
ntpConnected = ntpUdp.begin(ntpLocalPort);
2018-10-04 18:17:01 +02:00
//start captive portal if AP active
if (onlyAP || strlen(apSSID) > 0)
{
2019-02-16 00:21:22 +01:00
dnsServer.setErrorReplyCode(DNSReplyCode::ServerFailure);
dnsServer.start(53, "wled.me", WiFi.softAPIP());
dnsActive = true;
}
2018-10-04 18:17:01 +02:00
prepareIds(); //UUID from MAC (for Alexa and MQTT)
2019-02-05 19:40:24 +01:00
if (strcmp(cmDNS,"x") == 0) //fill in unique mdns default
{
strcpy(cmDNS, "wled-");
strcat(cmDNS, escapedMac.c_str());
}
if (mqttDeviceTopic[0] == 0)
{
strcpy(mqttDeviceTopic, "wled/");
strcat(mqttDeviceTopic, escapedMac.c_str());
}
2018-10-04 18:17:01 +02:00
//smartInit, we only init some resources when connected
if (!onlyAP && WiFi.status() == WL_CONNECTED)
{
mqtt = new AsyncMqttClient();
initMqtt();
2018-10-04 18:17:01 +02:00
}
strip.service();
2018-02-20 22:29:48 +01:00
//HTTP server page init
initServer();
2018-05-22 21:11:19 +02:00
strip.service();
//init Alexa hue emulation
2018-10-04 18:17:01 +02:00
if (alexaEnabled && !onlyAP) alexaInit();
2019-02-16 00:21:22 +01:00
server.begin();
DEBUG_PRINTLN("HTTP server started");
2018-02-20 22:29:48 +01:00
//init ArduinoOTA
2018-10-04 18:17:01 +02:00
if (!onlyAP) {
#ifndef WLED_DISABLE_OTA
2018-10-04 18:17:01 +02:00
if (aOtaEnabled)
{
ArduinoOTA.onStart([]() {
#ifndef ARDUINO_ARCH_ESP32
wifi_set_sleep_type(NONE_SLEEP_T);
#endif
DEBUG_PRINTLN("Start ArduinoOTA");
});
if (strlen(cmDNS) > 0) ArduinoOTA.setHostname(cmDNS);
ArduinoOTA.begin();
}
#endif
2018-10-04 18:17:01 +02:00
strip.service();
2018-10-04 18:17:01 +02:00
// Set up mDNS responder:
if (strlen(cmDNS) > 0 && !onlyAP)
{
MDNS.begin(cmDNS);
DEBUG_PRINTLN("mDNS responder started");
// Add service to MDNS
MDNS.addService("http", "tcp", 80);
2019-02-05 19:40:24 +01:00
MDNS.addService("wled", "tcp", 80);
2018-10-04 18:17:01 +02:00
}
strip.service();
2018-10-04 18:17:01 +02:00
initBlynk(blynkApiKey);
initE131();
2019-02-18 22:34:21 +01:00
reconnectHue();
2018-10-04 18:17:01 +02:00
} else {
e131Enabled = false;
}
2018-02-25 14:46:11 +01:00
userBegin();
2018-11-18 00:31:45 +01:00
if (macroBoot>0) applyMacro(macroBoot);
Serial.println("Ada");
}
2018-02-25 14:46:11 +01:00
2018-11-24 11:52:23 +01:00
void beginStrip()
{
// Initialize NeoPixel Strip and button
strip.setReverseMode(reverseMode);
strip.setColor(0);
strip.setBrightness(255);
2018-11-18 00:31:45 +01:00
pinMode(BTNPIN, INPUT_PULLUP);
if (bootPreset>0) applyPreset(bootPreset, turnOnAtBoot, true, true);
colorUpdated(0);
//disable button if it is "pressed" unintentionally
2018-11-18 00:31:45 +01:00
if(digitalRead(BTNPIN) == LOW) buttonEnabled = false;
}
2018-11-24 11:52:23 +01:00
void initAP(){
2018-07-21 23:21:07 +02:00
bool set = apSSID[0];
if (!set) strcpy(apSSID,"WLED-AP");
WiFi.softAP(apSSID, apPass, apChannel, apHide);
if (!set) apSSID[0] = 0;
}
2018-11-24 11:52:23 +01:00
void initCon()
{
WiFi.disconnect(); //close old connections
if (staticIP[0] != 0)
{
WiFi.config(staticIP, staticGateway, staticSubnet, staticDNS);
} else
{
WiFi.config(0U, 0U, 0U);
}
2018-07-21 23:21:07 +02:00
if (strlen(apSSID)>0)
{
2018-10-04 18:17:01 +02:00
DEBUG_PRINT(" USING AP");
2018-07-21 23:21:07 +02:00
DEBUG_PRINTLN(strlen(apSSID));
initAP();
} else
{
2018-10-04 18:17:01 +02:00
DEBUG_PRINTLN(" NO AP");
WiFi.softAPdisconnect(true);
}
int fail_count = 0;
if (strlen(clientSSID) <1 || strcmp(clientSSID,"Your_Network") == 0)
fail_count = apWaitTimeSecs*2; //instantly go to ap mode
#ifndef ARDUINO_ARCH_ESP32
WiFi.hostname(serverDescription);
#endif
WiFi.begin(clientSSID, clientPass);
#ifdef ARDUINO_ARCH_ESP32
WiFi.setHostname(serverDescription);
#endif
unsigned long lastTry = 0;
bool con = false;
while(!con)
{
yield();
handleTransitions();
handleButton();
handleOverlays();
if (briT) strip.service();
if (millis()-lastTry > 499) {
con = (WiFi.status() == WL_CONNECTED);
lastTry = millis();
DEBUG_PRINTLN("C_NC");
if (!recoveryAPDisabled && fail_count > apWaitTimeSecs*2)
{
WiFi.disconnect();
DEBUG_PRINTLN("Can't connect. Opening AP...");
onlyAP = true;
initAP();
return;
}
fail_count++;
}
}
}
//fill string buffer with build info
2019-02-21 16:32:15 +01:00
void getJsonInfo()
{
olen = 0;
2019-02-21 16:32:15 +01:00
oappend("{\r\n\"ver\":\"");
oappend(versionString);
2019-02-21 16:32:15 +01:00
oappend("\",\r\n\"vid\":");
oappendi(VERSION);
2019-02-21 16:32:15 +01:00
oappend(",\r\n\"leds\":{\r\n");
oappend("\"count\":");
oappendi(ledCount);
oappend(",\r\n\"rgbw\":");
oappend((char*)(useRGBW?"true":"false"));
oappend(",\r\n\"pin\":[");
oappendi(LEDPIN);
oappend("],\r\n\"pwr\":");
oappendi(strip.currentMilliamps);
oappend(",\r\n\"maxpwr\":");
oappendi(strip.ablMilliampsMax);
oappend(",\r\n\"maxseg\":1},\r\n\"name\":\"");
oappend(serverDescription);
oappend("\",\r\n\"udpport\":");
oappendi(udpPort);
2019-02-22 22:53:33 +01:00
oappend(",\r\n\"modecount\":");
oappendi(strip.getModeCount());
oappend(",\r\n\"palettecount\":");
oappendi(strip.getPaletteCount());
#ifdef ARDUINO_ARCH_ESP32
2019-02-21 16:32:15 +01:00
oappend(",\r\n\"arch\":\"esp32\",\r\n\"core\":\"");
oappend((char*)ESP.getSdkVersion());
#else
2019-02-21 16:32:15 +01:00
oappend(",\r\n\"arch\":\"esp8266\",\r\n\"core\":\"");
oappend((char*)ESP.getCoreVersion().c_str());
#endif
2019-02-21 16:32:15 +01:00
oappend("\",\r\n\"uptime\":");
oappendi(millis()/1000);
oappend(",\r\n\"freeheap\":");
oappendi(ESP.getFreeHeap());
oappend(",\r\n\"maxalloc\":");
#ifdef ARDUINO_ARCH_ESP32
oappendi(ESP.getMaxAllocHeap());
#else
oappendi(ESP.getMaxFreeBlockSize());
#endif
oappend(",\r\n\"opt\":[");
#ifndef WLED_DISABLE_ALEXA
2019-02-21 16:32:15 +01:00
oappend("\"alexa\",");
#endif
#ifndef WLED_DISABLE_BLYNK
2019-02-21 16:32:15 +01:00
oappend("\"blynk\",");
#endif
#ifndef WLED_DISABLE_CRONIXIE
2019-02-21 16:32:15 +01:00
oappend("\"cronixie\",");
#endif
#ifdef WLED_DEBUG
oappend("\"debug\",");
#endif
#ifdef USEFS
oappend("\"fs\",");
#endif
#ifndef WLED_DISABLE_HUESYNC
2019-02-21 16:32:15 +01:00
oappend("\"huesync\",");
#endif
#ifndef WLED_DISABLE_MOBILE_UI
2019-02-21 16:32:15 +01:00
oappend("\"mobile-ui\",");
#endif
#ifndef WLED_DISABLE_OTA
2019-02-21 16:32:15 +01:00
oappend("\"ota\"]");
#else
2019-02-21 16:32:15 +01:00
oappend("\"no-ota\"]");
#endif
2019-02-21 16:32:15 +01:00
oappend(",\r\n\"brand\":\"wled\",\r\n\"btype\":\"dev\",\r\n\"mac\":\"");
oappend((char*)escapedMac.c_str());
oappend("\"\r\n}");
}
2018-05-22 21:11:19 +02:00
bool checkClientIsMobile(String useragent)
{
//to save complexity this function is not comprehensive
if (useragent.indexOf("Android") >= 0) return true;
if (useragent.indexOf("iPhone") >= 0) return true;
if (useragent.indexOf("iPod") >= 0) return true;
return false;
}