mirror of
https://github.com/esphome/esphome.git
synced 2025-01-07 21:31:44 +01:00
Allow preserving WiFi credentials entered with captive_portal (#3813)
This commit is contained in:
parent
3b21d1d81e
commit
4bf94e0757
2 changed files with 27 additions and 1 deletions
|
@ -1,8 +1,9 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
|
import esphome.final_validate as fv
|
||||||
from esphome.components import web_server_base
|
from esphome.components import web_server_base
|
||||||
from esphome.components.web_server_base import CONF_WEB_SERVER_BASE_ID
|
from esphome.components.web_server_base import CONF_WEB_SERVER_BASE_ID
|
||||||
from esphome.const import CONF_ID
|
from esphome.const import CONF_ID, CONF_NETWORKS, CONF_PASSWORD, CONF_SSID, CONF_WIFI
|
||||||
from esphome.core import coroutine_with_priority, CORE
|
from esphome.core import coroutine_with_priority, CORE
|
||||||
|
|
||||||
AUTO_LOAD = ["web_server_base"]
|
AUTO_LOAD = ["web_server_base"]
|
||||||
|
@ -12,6 +13,7 @@ CODEOWNERS = ["@OttoWinter"]
|
||||||
captive_portal_ns = cg.esphome_ns.namespace("captive_portal")
|
captive_portal_ns = cg.esphome_ns.namespace("captive_portal")
|
||||||
CaptivePortal = captive_portal_ns.class_("CaptivePortal", cg.Component)
|
CaptivePortal = captive_portal_ns.class_("CaptivePortal", cg.Component)
|
||||||
|
|
||||||
|
CONF_KEEP_USER_CREDENTIALS = "keep_user_credentials"
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
cv.Schema(
|
cv.Schema(
|
||||||
{
|
{
|
||||||
|
@ -19,12 +21,29 @@ CONFIG_SCHEMA = cv.All(
|
||||||
cv.GenerateID(CONF_WEB_SERVER_BASE_ID): cv.use_id(
|
cv.GenerateID(CONF_WEB_SERVER_BASE_ID): cv.use_id(
|
||||||
web_server_base.WebServerBase
|
web_server_base.WebServerBase
|
||||||
),
|
),
|
||||||
|
cv.Optional(CONF_KEEP_USER_CREDENTIALS, default=False): cv.boolean,
|
||||||
}
|
}
|
||||||
).extend(cv.COMPONENT_SCHEMA),
|
).extend(cv.COMPONENT_SCHEMA),
|
||||||
cv.only_with_arduino,
|
cv.only_with_arduino,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def validate_wifi(config):
|
||||||
|
wifi_conf = fv.full_config.get()[CONF_WIFI]
|
||||||
|
if config.get(CONF_KEEP_USER_CREDENTIALS, False) and (
|
||||||
|
CONF_SSID in wifi_conf
|
||||||
|
or CONF_PASSWORD in wifi_conf
|
||||||
|
or CONF_NETWORKS in wifi_conf
|
||||||
|
):
|
||||||
|
raise cv.Invalid(
|
||||||
|
f"WiFi credentials cannot be used together with {CONF_KEEP_USER_CREDENTIALS}"
|
||||||
|
)
|
||||||
|
return config
|
||||||
|
|
||||||
|
|
||||||
|
FINAL_VALIDATE_SCHEMA = validate_wifi
|
||||||
|
|
||||||
|
|
||||||
@coroutine_with_priority(64.0)
|
@coroutine_with_priority(64.0)
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
paren = await cg.get_variable(config[CONF_WEB_SERVER_BASE_ID])
|
paren = await cg.get_variable(config[CONF_WEB_SERVER_BASE_ID])
|
||||||
|
@ -38,3 +57,6 @@ async def to_code(config):
|
||||||
cg.add_library("WiFi", None)
|
cg.add_library("WiFi", None)
|
||||||
if CORE.is_esp8266:
|
if CORE.is_esp8266:
|
||||||
cg.add_library("DNSServer", None)
|
cg.add_library("DNSServer", None)
|
||||||
|
|
||||||
|
if config.get(CONF_KEEP_USER_CREDENTIALS, False):
|
||||||
|
cg.add_define("USE_CAPTIVE_PORTAL_KEEP_USER_CREDENTIALS")
|
||||||
|
|
|
@ -38,7 +38,11 @@ void WiFiComponent::setup() {
|
||||||
this->last_connected_ = millis();
|
this->last_connected_ = millis();
|
||||||
this->wifi_pre_setup_();
|
this->wifi_pre_setup_();
|
||||||
|
|
||||||
|
#ifndef USE_CAPTIVE_PORTAL_KEEP_USER_CREDENTIALS
|
||||||
uint32_t hash = fnv1_hash(App.get_compilation_time());
|
uint32_t hash = fnv1_hash(App.get_compilation_time());
|
||||||
|
#else
|
||||||
|
uint32_t hash = 88491487UL;
|
||||||
|
#endif
|
||||||
this->pref_ = global_preferences->make_preference<wifi::SavedWifiSettings>(hash, true);
|
this->pref_ = global_preferences->make_preference<wifi::SavedWifiSettings>(hash, true);
|
||||||
|
|
||||||
SavedWifiSettings save{};
|
SavedWifiSettings save{};
|
||||||
|
|
Loading…
Reference in a new issue