Add unique id property for Vizio devices so they get added to entity registry (#30497)
* add unique id property for Vizio devices so they get added to entity registry * update requirements * small change to make code more readable * update to use f-string for consistency * fix property name * set unique_id to none if serial number couldnt be found * set unique_id to none * ESN should be globally unique so no device type needed. pyvizio will set ESN to None if ESN is unobtainablepull/30501/head
parent
30076d1843
commit
2ac5862eda
|
@ -3,7 +3,7 @@
|
||||||
"name": "Vizio",
|
"name": "Vizio",
|
||||||
"documentation": "https://www.home-assistant.io/integrations/vizio",
|
"documentation": "https://www.home-assistant.io/integrations/vizio",
|
||||||
"requirements": [
|
"requirements": [
|
||||||
"pyvizio==0.0.7"
|
"pyvizio==0.0.9"
|
||||||
],
|
],
|
||||||
"dependencies": [],
|
"dependencies": [],
|
||||||
"codeowners": ["@raman325"]
|
"codeowners": ["@raman325"]
|
||||||
|
|
|
@ -64,9 +64,7 @@ def validate_auth(config):
|
||||||
token = config.get(CONF_ACCESS_TOKEN)
|
token = config.get(CONF_ACCESS_TOKEN)
|
||||||
if config[CONF_DEVICE_CLASS] == "tv" and (token is None or token == ""):
|
if config[CONF_DEVICE_CLASS] == "tv" and (token is None or token == ""):
|
||||||
raise vol.Invalid(
|
raise vol.Invalid(
|
||||||
"When '{}' is 'tv' then '{}' is required.".format(
|
f"When '{CONF_DEVICE_CLASS}' is 'tv' then '{CONF_ACCESS_TOKEN}' is required.",
|
||||||
CONF_DEVICE_CLASS, CONF_ACCESS_TOKEN
|
|
||||||
),
|
|
||||||
path=[CONF_ACCESS_TOKEN],
|
path=[CONF_ACCESS_TOKEN],
|
||||||
)
|
)
|
||||||
return config
|
return config
|
||||||
|
@ -135,6 +133,7 @@ class VizioDevice(MediaPlayerDevice):
|
||||||
self._supported_commands = SUPPORTED_COMMANDS[device_type]
|
self._supported_commands = SUPPORTED_COMMANDS[device_type]
|
||||||
self._device = Vizio(DEVICE_ID, host, DEFAULT_NAME, token, device_type)
|
self._device = Vizio(DEVICE_ID, host, DEFAULT_NAME, token, device_type)
|
||||||
self._max_volume = float(self._device.get_max_volume())
|
self._max_volume = float(self._device.get_max_volume())
|
||||||
|
self._unique_id = self._device.get_esn()
|
||||||
|
|
||||||
@util.Throttle(MIN_TIME_BETWEEN_SCANS, MIN_TIME_BETWEEN_FORCED_SCANS)
|
@util.Throttle(MIN_TIME_BETWEEN_SCANS, MIN_TIME_BETWEEN_FORCED_SCANS)
|
||||||
def update(self):
|
def update(self):
|
||||||
|
@ -196,6 +195,11 @@ class VizioDevice(MediaPlayerDevice):
|
||||||
"""Flag device features that are supported."""
|
"""Flag device features that are supported."""
|
||||||
return self._supported_commands
|
return self._supported_commands
|
||||||
|
|
||||||
|
@property
|
||||||
|
def unique_id(self):
|
||||||
|
"""Return the unique id of the device."""
|
||||||
|
return self._unique_id
|
||||||
|
|
||||||
def turn_on(self):
|
def turn_on(self):
|
||||||
"""Turn the device on."""
|
"""Turn the device on."""
|
||||||
self._device.pow_on()
|
self._device.pow_on()
|
||||||
|
|
|
@ -1693,7 +1693,7 @@ pyversasense==0.0.6
|
||||||
pyvesync==1.1.0
|
pyvesync==1.1.0
|
||||||
|
|
||||||
# homeassistant.components.vizio
|
# homeassistant.components.vizio
|
||||||
pyvizio==0.0.7
|
pyvizio==0.0.9
|
||||||
|
|
||||||
# homeassistant.components.velux
|
# homeassistant.components.velux
|
||||||
pyvlx==0.2.12
|
pyvlx==0.2.12
|
||||||
|
|
Loading…
Reference in New Issue