Remove platform YAML from Snapcast (#101225)
This commit is contained in:
parent
78f827697e
commit
b33d5fece6
3 changed files with 3 additions and 70 deletions
|
@ -51,13 +51,3 @@ class SnapcastConfigFlow(ConfigFlow, domain=DOMAIN):
|
||||||
return self.async_show_form(
|
return self.async_show_form(
|
||||||
step_id="user", data_schema=SNAPCAST_SCHEMA, errors=errors
|
step_id="user", data_schema=SNAPCAST_SCHEMA, errors=errors
|
||||||
)
|
)
|
||||||
|
|
||||||
async def async_step_import(self, import_config: dict[str, str]) -> FlowResult:
|
|
||||||
"""Import a config entry from configuration.yaml."""
|
|
||||||
self._async_abort_entries_match(
|
|
||||||
{
|
|
||||||
CONF_HOST: (import_config[CONF_HOST]),
|
|
||||||
CONF_PORT: (import_config[CONF_PORT]),
|
|
||||||
}
|
|
||||||
)
|
|
||||||
return self.async_create_entry(title=DEFAULT_TITLE, data=import_config)
|
|
||||||
|
|
|
@ -1,24 +1,19 @@
|
||||||
"""Support for interacting with Snapcast clients."""
|
"""Support for interacting with Snapcast clients."""
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
import logging
|
from snapcast.control.server import Snapserver
|
||||||
|
|
||||||
from snapcast.control.server import CONTROL_PORT, Snapserver
|
|
||||||
import voluptuous as vol
|
import voluptuous as vol
|
||||||
|
|
||||||
from homeassistant.components.media_player import (
|
from homeassistant.components.media_player import (
|
||||||
PLATFORM_SCHEMA,
|
|
||||||
MediaPlayerEntity,
|
MediaPlayerEntity,
|
||||||
MediaPlayerEntityFeature,
|
MediaPlayerEntityFeature,
|
||||||
MediaPlayerState,
|
MediaPlayerState,
|
||||||
)
|
)
|
||||||
from homeassistant.config_entries import SOURCE_IMPORT, ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.const import CONF_HOST, CONF_PORT
|
from homeassistant.const import CONF_HOST, CONF_PORT
|
||||||
from homeassistant.core import DOMAIN as HOMEASSISTANT_DOMAIN, HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
from homeassistant.helpers import config_validation as cv, entity_platform
|
from homeassistant.helpers import config_validation as cv, entity_platform
|
||||||
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
||||||
from homeassistant.helpers.issue_registry import IssueSeverity, async_create_issue
|
|
||||||
from homeassistant.helpers.typing import ConfigType, DiscoveryInfoType
|
|
||||||
|
|
||||||
from .const import (
|
from .const import (
|
||||||
ATTR_LATENCY,
|
ATTR_LATENCY,
|
||||||
|
@ -35,12 +30,6 @@ from .const import (
|
||||||
SERVICE_UNJOIN,
|
SERVICE_UNJOIN,
|
||||||
)
|
)
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
|
||||||
|
|
||||||
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
|
|
||||||
{vol.Required(CONF_HOST): cv.string, vol.Optional(CONF_PORT): cv.port}
|
|
||||||
)
|
|
||||||
|
|
||||||
STREAM_STATUS = {
|
STREAM_STATUS = {
|
||||||
"idle": MediaPlayerState.IDLE,
|
"idle": MediaPlayerState.IDLE,
|
||||||
"playing": MediaPlayerState.PLAYING,
|
"playing": MediaPlayerState.PLAYING,
|
||||||
|
@ -93,37 +82,6 @@ async def async_setup_entry(
|
||||||
].hass_async_add_entities = async_add_entities
|
].hass_async_add_entities = async_add_entities
|
||||||
|
|
||||||
|
|
||||||
async def async_setup_platform(
|
|
||||||
hass: HomeAssistant,
|
|
||||||
config: ConfigType,
|
|
||||||
async_add_entities: AddEntitiesCallback,
|
|
||||||
discovery_info: DiscoveryInfoType | None = None,
|
|
||||||
) -> None:
|
|
||||||
"""Set up the Snapcast platform."""
|
|
||||||
async_create_issue(
|
|
||||||
hass,
|
|
||||||
HOMEASSISTANT_DOMAIN,
|
|
||||||
f"deprecated_yaml_{DOMAIN}",
|
|
||||||
breaks_in_ha_version="2023.11.0",
|
|
||||||
is_fixable=False,
|
|
||||||
issue_domain=DOMAIN,
|
|
||||||
severity=IssueSeverity.WARNING,
|
|
||||||
translation_key="deprecated_yaml",
|
|
||||||
translation_placeholders={
|
|
||||||
"domain": DOMAIN,
|
|
||||||
"integration_title": "Snapcast",
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
config[CONF_PORT] = config.get(CONF_PORT, CONTROL_PORT)
|
|
||||||
|
|
||||||
hass.async_create_task(
|
|
||||||
hass.config_entries.flow.async_init(
|
|
||||||
DOMAIN, context={"source": SOURCE_IMPORT}, data=config
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
async def handle_async_join(entity, service_call):
|
async def handle_async_join(entity, service_call):
|
||||||
"""Handle the entity service join."""
|
"""Handle the entity service join."""
|
||||||
if not isinstance(entity, SnapcastClientDevice):
|
if not isinstance(entity, SnapcastClientDevice):
|
||||||
|
|
|
@ -93,18 +93,3 @@ async def test_abort(
|
||||||
|
|
||||||
assert result["type"] == FlowResultType.ABORT
|
assert result["type"] == FlowResultType.ABORT
|
||||||
assert result["reason"] == "already_configured"
|
assert result["reason"] == "already_configured"
|
||||||
|
|
||||||
|
|
||||||
async def test_import(hass: HomeAssistant) -> None:
|
|
||||||
"""Test successful import."""
|
|
||||||
|
|
||||||
result = await hass.config_entries.flow.async_init(
|
|
||||||
DOMAIN,
|
|
||||||
context={"source": config_entries.SOURCE_IMPORT},
|
|
||||||
data=TEST_CONNECTION,
|
|
||||||
)
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
|
|
||||||
assert result["type"] == FlowResultType.CREATE_ENTRY
|
|
||||||
assert result["title"] == "Snapcast"
|
|
||||||
assert result["data"] == {CONF_HOST: "snapserver.test", CONF_PORT: 1705}
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue