mirror of
https://github.com/esphome/esphome.git
synced 2024-12-31 18:01:45 +01:00
7c7032c59e
* Implement custom sensor platform
* Update
* Ethernet
* Lint
* Fix
* Login page
* Rename cookie secret
* Update manifest
* Update cookie check logic
* Favicon
* Fix
* Favicon manifest
* Fix
* Fix
* Fix
* Use hostname
* Message
* Temporary commit for screenshot
* Automatic board selection
* Undo temporary commit
* Update esphomeyaml-edge
* In-dashboard editing and hosting files locally
* Update esphomeyaml-edge
* Better ANSI color escaping
* Message
* Lint
* Download Efficiency
* Fix gitlab
* Fix
* Rename extra_libraries to libraries
* Add example
* Update README.md
* Update README.md
* Update README.md
* HassIO -> Hass.io
* Updates
* Add update available notice
* Update
* Fix substitutions
* Better error message
* Re-do dashboard ANSI colors
* Only include FastLED if user says so
* Autoscroll logs
* Remove old checks
* Use safer RedirectText
* Improvements
* Fix
* Use enviornment variable
* Use http://hassio/host/info
* Fix conditions
* Update platformio versions
* Revert "Use enviornment variable"
This reverts commit 7f038eb5d2
.
* Fix
* README update
* Temp
* Better invalid config messages
* Platformio debug
* Improve error messages
* Debug
* Remove debug
* Multi Conf
* Update
* Better paths
* Remove unused
* Fixes
* Lint
* lib_ignore
* Try fix platformio colors
* Fix dashboard scrolling
* Revert
* Lint
* Revert
147 lines
4.6 KiB
Python
147 lines
4.6 KiB
Python
import voluptuous as vol
|
|
|
|
import esphomeyaml.config_validation as cv
|
|
from esphomeyaml.const import CONF_AP, CONF_CHANNEL, CONF_DNS1, CONF_DNS2, CONF_DOMAIN, \
|
|
CONF_GATEWAY, CONF_HOSTNAME, CONF_ID, CONF_MANUAL_IP, CONF_PASSWORD, CONF_POWER_SAVE_MODE, \
|
|
CONF_REBOOT_TIMEOUT, CONF_SSID, CONF_STATIC_IP, CONF_SUBNET
|
|
from esphomeyaml.core import CORE
|
|
from esphomeyaml.cpp_generator import Pvariable, StructInitializer, add
|
|
from esphomeyaml.cpp_types import App, Component, esphomelib_ns, global_ns
|
|
|
|
|
|
def validate_password(value):
|
|
value = cv.string(value)
|
|
if not value:
|
|
return value
|
|
if len(value) < 8:
|
|
raise vol.Invalid(u"WPA password must be at least 8 characters long")
|
|
if len(value) > 63:
|
|
raise vol.Invalid(u"WPA password must be at most 63 characters long")
|
|
return value
|
|
|
|
|
|
def validate_channel(value):
|
|
value = cv.positive_int(value)
|
|
if value < 1:
|
|
raise vol.Invalid("Minimum WiFi channel is 1")
|
|
if value > 14:
|
|
raise vol.Invalid("Maximum WiFi channel is 14")
|
|
return value
|
|
|
|
|
|
AP_MANUAL_IP_SCHEMA = vol.Schema({
|
|
vol.Required(CONF_STATIC_IP): cv.ipv4,
|
|
vol.Required(CONF_GATEWAY): cv.ipv4,
|
|
vol.Required(CONF_SUBNET): cv.ipv4,
|
|
})
|
|
|
|
STA_MANUAL_IP_SCHEMA = AP_MANUAL_IP_SCHEMA.extend({
|
|
vol.Inclusive(CONF_DNS1, 'dns'): cv.ipv4,
|
|
vol.Inclusive(CONF_DNS2, 'dns'): cv.ipv4,
|
|
})
|
|
|
|
WIFI_NETWORK_BASE = vol.Schema({
|
|
vol.Required(CONF_SSID): cv.ssid,
|
|
vol.Optional(CONF_PASSWORD): validate_password,
|
|
vol.Optional(CONF_CHANNEL): validate_channel,
|
|
vol.Optional(CONF_MANUAL_IP): AP_MANUAL_IP_SCHEMA,
|
|
})
|
|
|
|
WIFI_NETWORK_AP = WIFI_NETWORK_BASE.extend({
|
|
vol.Optional(CONF_MANUAL_IP): AP_MANUAL_IP_SCHEMA,
|
|
})
|
|
|
|
WIFI_NETWORK_STA = WIFI_NETWORK_BASE.extend({
|
|
vol.Optional(CONF_MANUAL_IP): STA_MANUAL_IP_SCHEMA,
|
|
})
|
|
|
|
|
|
def validate(config):
|
|
if CONF_PASSWORD in config and CONF_SSID not in config:
|
|
raise vol.Invalid("Cannot have WiFi password without SSID!")
|
|
if (CONF_SSID not in config) and (CONF_AP not in config):
|
|
raise vol.Invalid("Please specify at least an SSID or an Access Point "
|
|
"to create.")
|
|
return config
|
|
|
|
|
|
IPAddress = global_ns.class_('IPAddress')
|
|
ManualIP = esphomelib_ns.struct('ManualIP')
|
|
WiFiComponent = esphomelib_ns.class_('WiFiComponent', Component)
|
|
WiFiAp = esphomelib_ns.struct('WiFiAp')
|
|
|
|
WiFiPowerSaveMode = esphomelib_ns.enum('WiFiPowerSaveMode')
|
|
WIFI_POWER_SAVE_MODES = {
|
|
'NONE': WiFiPowerSaveMode.WIFI_POWER_SAVE_NONE,
|
|
'LIGHT': WiFiPowerSaveMode.WIFI_POWER_SAVE_LIGHT,
|
|
'HIGH': WiFiPowerSaveMode.WIFI_POWER_SAVE_HIGH,
|
|
}
|
|
|
|
CONFIG_SCHEMA = vol.All(vol.Schema({
|
|
cv.GenerateID(): cv.declare_variable_id(WiFiComponent),
|
|
vol.Optional(CONF_SSID): cv.ssid,
|
|
vol.Optional(CONF_PASSWORD): validate_password,
|
|
vol.Optional(CONF_MANUAL_IP): STA_MANUAL_IP_SCHEMA,
|
|
vol.Optional(CONF_AP): WIFI_NETWORK_AP,
|
|
vol.Optional(CONF_HOSTNAME): cv.hostname,
|
|
vol.Optional(CONF_DOMAIN, default='.local'): cv.domain_name,
|
|
vol.Optional(CONF_REBOOT_TIMEOUT): cv.positive_time_period_milliseconds,
|
|
vol.Optional(CONF_POWER_SAVE_MODE): cv.one_of(*WIFI_POWER_SAVE_MODES, upper=True),
|
|
}), validate)
|
|
|
|
|
|
def safe_ip(ip):
|
|
if ip is None:
|
|
return IPAddress(0, 0, 0, 0)
|
|
return IPAddress(*ip.args)
|
|
|
|
|
|
def manual_ip(config):
|
|
if config is None:
|
|
return None
|
|
return StructInitializer(
|
|
ManualIP,
|
|
('static_ip', safe_ip(config[CONF_STATIC_IP])),
|
|
('gateway', safe_ip(config[CONF_GATEWAY])),
|
|
('subnet', safe_ip(config[CONF_SUBNET])),
|
|
('dns1', safe_ip(config.get(CONF_DNS1))),
|
|
('dns2', safe_ip(config.get(CONF_DNS2))),
|
|
)
|
|
|
|
|
|
def wifi_network(config):
|
|
return StructInitializer(
|
|
WiFiAp,
|
|
('ssid', config.get(CONF_SSID, "")),
|
|
('password', config.get(CONF_PASSWORD, "")),
|
|
('channel', config.get(CONF_CHANNEL, -1)),
|
|
('manual_ip', manual_ip(config.get(CONF_MANUAL_IP))),
|
|
)
|
|
|
|
|
|
def to_code(config):
|
|
rhs = App.init_wifi()
|
|
wifi = Pvariable(config[CONF_ID], rhs)
|
|
|
|
if CONF_SSID in config:
|
|
add(wifi.set_sta(wifi_network(config)))
|
|
|
|
if CONF_AP in config:
|
|
add(wifi.set_ap(wifi_network(config[CONF_AP])))
|
|
|
|
if CONF_HOSTNAME in config:
|
|
add(wifi.set_hostname(config[CONF_HOSTNAME]))
|
|
|
|
if CONF_REBOOT_TIMEOUT in config:
|
|
add(wifi.set_reboot_timeout(config[CONF_REBOOT_TIMEOUT]))
|
|
|
|
if CONF_POWER_SAVE_MODE in config:
|
|
add(wifi.set_power_save_mode(WIFI_POWER_SAVE_MODES[config[CONF_POWER_SAVE_MODE]]))
|
|
|
|
|
|
def lib_deps(config):
|
|
if CORE.is_esp8266:
|
|
return 'ESP8266WiFi'
|
|
elif CORE.is_esp32:
|
|
return None
|
|
raise NotImplementedError
|