mirror of
https://github.com/home-assistant/core.git
synced 2025-07-23 05:07:41 +00:00
Add play media URL support to roku (#64021)
This commit is contained in:
parent
d1831748eb
commit
533d0e4444
@ -3,6 +3,7 @@ DOMAIN = "roku"
|
|||||||
|
|
||||||
# Attributes
|
# Attributes
|
||||||
ATTR_CONTENT_ID = "content_id"
|
ATTR_CONTENT_ID = "content_id"
|
||||||
|
ATTR_FORMAT = "format"
|
||||||
ATTR_KEYWORD = "keyword"
|
ATTR_KEYWORD = "keyword"
|
||||||
ATTR_MEDIA_TYPE = "media_type"
|
ATTR_MEDIA_TYPE = "media_type"
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@ from homeassistant.components.media_player.const import (
|
|||||||
ATTR_MEDIA_EXTRA,
|
ATTR_MEDIA_EXTRA,
|
||||||
MEDIA_TYPE_APP,
|
MEDIA_TYPE_APP,
|
||||||
MEDIA_TYPE_CHANNEL,
|
MEDIA_TYPE_CHANNEL,
|
||||||
|
MEDIA_TYPE_URL,
|
||||||
SUPPORT_BROWSE_MEDIA,
|
SUPPORT_BROWSE_MEDIA,
|
||||||
SUPPORT_NEXT_TRACK,
|
SUPPORT_NEXT_TRACK,
|
||||||
SUPPORT_PAUSE,
|
SUPPORT_PAUSE,
|
||||||
@ -31,6 +32,7 @@ from homeassistant.components.media_player.const import (
|
|||||||
from homeassistant.components.media_player.errors import BrowseError
|
from homeassistant.components.media_player.errors import BrowseError
|
||||||
from homeassistant.config_entries import ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.const import (
|
from homeassistant.const import (
|
||||||
|
ATTR_NAME,
|
||||||
STATE_HOME,
|
STATE_HOME,
|
||||||
STATE_IDLE,
|
STATE_IDLE,
|
||||||
STATE_ON,
|
STATE_ON,
|
||||||
@ -47,6 +49,7 @@ from . import roku_exception_handler
|
|||||||
from .browse_media import build_item_response, library_payload
|
from .browse_media import build_item_response, library_payload
|
||||||
from .const import (
|
from .const import (
|
||||||
ATTR_CONTENT_ID,
|
ATTR_CONTENT_ID,
|
||||||
|
ATTR_FORMAT,
|
||||||
ATTR_KEYWORD,
|
ATTR_KEYWORD,
|
||||||
ATTR_MEDIA_TYPE,
|
ATTR_MEDIA_TYPE,
|
||||||
DOMAIN,
|
DOMAIN,
|
||||||
@ -76,6 +79,11 @@ ATTRS_TO_LAUNCH_PARAMS = {
|
|||||||
ATTR_MEDIA_TYPE: "MediaType",
|
ATTR_MEDIA_TYPE: "MediaType",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ATTRS_TO_PLAY_VIDEO_PARAMS = {
|
||||||
|
ATTR_NAME: "videoName",
|
||||||
|
ATTR_FORMAT: "videoFormat",
|
||||||
|
}
|
||||||
|
|
||||||
SEARCH_SCHEMA = {vol.Required(ATTR_KEYWORD): str}
|
SEARCH_SCHEMA = {vol.Required(ATTR_KEYWORD): str}
|
||||||
|
|
||||||
|
|
||||||
@ -367,25 +375,34 @@ class RokuMediaPlayer(RokuEntity, MediaPlayerEntity):
|
|||||||
"""Tune to channel."""
|
"""Tune to channel."""
|
||||||
extra: dict[str, Any] = kwargs.get(ATTR_MEDIA_EXTRA) or {}
|
extra: dict[str, Any] = kwargs.get(ATTR_MEDIA_EXTRA) or {}
|
||||||
|
|
||||||
if media_type not in (MEDIA_TYPE_APP, MEDIA_TYPE_CHANNEL):
|
if media_type not in (MEDIA_TYPE_APP, MEDIA_TYPE_CHANNEL, MEDIA_TYPE_URL):
|
||||||
_LOGGER.error(
|
_LOGGER.error(
|
||||||
"Invalid media type %s. Only %s and %s are supported",
|
"Invalid media type %s. Only %s, %s and %s are supported",
|
||||||
media_type,
|
media_type,
|
||||||
MEDIA_TYPE_APP,
|
MEDIA_TYPE_APP,
|
||||||
MEDIA_TYPE_CHANNEL,
|
MEDIA_TYPE_CHANNEL,
|
||||||
|
MEDIA_TYPE_URL,
|
||||||
)
|
)
|
||||||
return
|
return
|
||||||
|
|
||||||
if media_type == MEDIA_TYPE_APP:
|
if media_type == MEDIA_TYPE_APP:
|
||||||
params = {
|
params = {
|
||||||
param: extra[attr]
|
param: extra[attr]
|
||||||
for (attr, param) in ATTRS_TO_LAUNCH_PARAMS.items()
|
for attr, param in ATTRS_TO_LAUNCH_PARAMS.items()
|
||||||
if attr in extra
|
if attr in extra
|
||||||
}
|
}
|
||||||
|
|
||||||
await self.coordinator.roku.launch(media_id, params)
|
await self.coordinator.roku.launch(media_id, params)
|
||||||
elif media_type == MEDIA_TYPE_CHANNEL:
|
elif media_type == MEDIA_TYPE_CHANNEL:
|
||||||
await self.coordinator.roku.tune(media_id)
|
await self.coordinator.roku.tune(media_id)
|
||||||
|
elif media_type == MEDIA_TYPE_URL:
|
||||||
|
params = {
|
||||||
|
param: extra[attr]
|
||||||
|
for (attr, param) in ATTRS_TO_PLAY_VIDEO_PARAMS.items()
|
||||||
|
if attr in extra
|
||||||
|
}
|
||||||
|
|
||||||
|
await self.coordinator.roku.play_video(media_id, params)
|
||||||
|
|
||||||
await self.coordinator.async_request_refresh()
|
await self.coordinator.async_request_refresh()
|
||||||
|
|
||||||
|
@ -25,6 +25,7 @@ from homeassistant.components.media_player.const import (
|
|||||||
MEDIA_TYPE_APPS,
|
MEDIA_TYPE_APPS,
|
||||||
MEDIA_TYPE_CHANNEL,
|
MEDIA_TYPE_CHANNEL,
|
||||||
MEDIA_TYPE_CHANNELS,
|
MEDIA_TYPE_CHANNELS,
|
||||||
|
MEDIA_TYPE_URL,
|
||||||
SERVICE_PLAY_MEDIA,
|
SERVICE_PLAY_MEDIA,
|
||||||
SERVICE_SELECT_SOURCE,
|
SERVICE_SELECT_SOURCE,
|
||||||
SUPPORT_BROWSE_MEDIA,
|
SUPPORT_BROWSE_MEDIA,
|
||||||
@ -41,6 +42,7 @@ from homeassistant.components.media_player.const import (
|
|||||||
)
|
)
|
||||||
from homeassistant.components.roku.const import (
|
from homeassistant.components.roku.const import (
|
||||||
ATTR_CONTENT_ID,
|
ATTR_CONTENT_ID,
|
||||||
|
ATTR_FORMAT,
|
||||||
ATTR_KEYWORD,
|
ATTR_KEYWORD,
|
||||||
ATTR_MEDIA_TYPE,
|
ATTR_MEDIA_TYPE,
|
||||||
DOMAIN,
|
DOMAIN,
|
||||||
@ -50,6 +52,7 @@ from homeassistant.components.websocket_api.const import TYPE_RESULT
|
|||||||
from homeassistant.config import async_process_ha_core_config
|
from homeassistant.config import async_process_ha_core_config
|
||||||
from homeassistant.const import (
|
from homeassistant.const import (
|
||||||
ATTR_ENTITY_ID,
|
ATTR_ENTITY_ID,
|
||||||
|
ATTR_NAME,
|
||||||
SERVICE_MEDIA_NEXT_TRACK,
|
SERVICE_MEDIA_NEXT_TRACK,
|
||||||
SERVICE_MEDIA_PAUSE,
|
SERVICE_MEDIA_PAUSE,
|
||||||
SERVICE_MEDIA_PLAY,
|
SERVICE_MEDIA_PLAY,
|
||||||
@ -481,6 +484,30 @@ async def test_services(
|
|||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
|
with patch("homeassistant.components.roku.coordinator.Roku.play_video") as pv_mock:
|
||||||
|
await hass.services.async_call(
|
||||||
|
MP_DOMAIN,
|
||||||
|
SERVICE_PLAY_MEDIA,
|
||||||
|
{
|
||||||
|
ATTR_ENTITY_ID: MAIN_ENTITY_ID,
|
||||||
|
ATTR_MEDIA_CONTENT_TYPE: MEDIA_TYPE_URL,
|
||||||
|
ATTR_MEDIA_CONTENT_ID: "https://awesome.tld/media.mp4",
|
||||||
|
ATTR_MEDIA_EXTRA: {
|
||||||
|
ATTR_NAME: "Sent from HA",
|
||||||
|
ATTR_FORMAT: "mp4",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
blocking=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
pv_mock.assert_called_once_with(
|
||||||
|
"https://awesome.tld/media.mp4",
|
||||||
|
{
|
||||||
|
"videoName": "Sent from HA",
|
||||||
|
"videoFormat": "mp4",
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
with patch("homeassistant.components.roku.coordinator.Roku.remote") as remote_mock:
|
with patch("homeassistant.components.roku.coordinator.Roku.remote") as remote_mock:
|
||||||
await hass.services.async_call(
|
await hass.services.async_call(
|
||||||
MP_DOMAIN,
|
MP_DOMAIN,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user