From edecd89d0ebce14fdba9b24ba5d2b2e6e2b20492 Mon Sep 17 00:00:00 2001 From: Todd Lucas Date: Thu, 29 Feb 2024 18:50:39 -0600 Subject: [PATCH] [ 1.0.3 ] * Updated service `get_show_episodes` to include the `limit_total` argument. * Added service `get_player_queue_info` to retrieve the player queue information. * Added service `get_player_devices` to retrieve player device list. --- CHANGELOG.md | 6 + custom_components/spotifyplus/__init__.py | 50 ++++++- custom_components/spotifyplus/manifest.json | 2 +- custom_components/spotifyplus/media_player.py | 139 ++++++++++++++++-- custom_components/spotifyplus/services.yaml | 87 ++++++++--- custom_components/spotifyplus/strings.json | 28 ++++ .../spotifyplus/translations/en.json | 28 ++++ 7 files changed, 300 insertions(+), 40 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 7539887..e0d3e02 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,6 +6,12 @@ Change are listed in reverse chronological order (newest to oldest). +###### [ 1.0.3 ] - 2024/02/28 + + * Updated service `get_show_episodes` to include the `limit_total` argument. + * Added service `get_player_queue_info` to retrieve the player queue information. + * Added service `get_player_devices` to retrieve player device list. + ###### [ 1.0.2 ] - 2024/02/28 * Updated underlying `spotifywebapiPython` package requirement to version 1.0.31. diff --git a/custom_components/spotifyplus/__init__.py b/custom_components/spotifyplus/__init__.py index d54fac8..f3528c6 100644 --- a/custom_components/spotifyplus/__init__.py +++ b/custom_components/spotifyplus/__init__.py @@ -87,6 +87,8 @@ SERVICE_SPOTIFY_GET_BROWSE_CATEGORYS_LIST:str = 'get_browse_categorys_list' SERVICE_SPOTIFY_GET_CATEGORY_PLAYLISTS:str = 'get_category_playlists' SERVICE_SPOTIFY_GET_FEATURED_PLAYLISTS:str = 'get_featured_playlists' +SERVICE_SPOTIFY_GET_PLAYER_DEVICES:str = 'get_player_devices' +SERVICE_SPOTIFY_GET_PLAYER_QUEUE_INFO:str = 'get_player_queue_info' SERVICE_SPOTIFY_GET_PLAYER_RECENT_TRACKS:str = 'get_player_recent_tracks' SERVICE_SPOTIFY_GET_PLAYLIST:str = 'get_playlist' SERVICE_SPOTIFY_GET_PLAYLIST_FAVORITES:str = 'get_playlist_favorites' @@ -187,6 +189,19 @@ } ) +SERVICE_SPOTIFY_GET_PLAYER_DEVICES_SCHEMA = vol.Schema( + { + vol.Required("entity_id"): cv.entity_id, + vol.Optional("refresh"): cv.boolean, + } +) + +SERVICE_SPOTIFY_GET_PLAYER_QUEUE_INFO_SCHEMA = vol.Schema( + { + vol.Required("entity_id"): cv.entity_id, + } +) + SERVICE_SPOTIFY_GET_PLAYER_RECENT_TRACKS_SCHEMA = vol.Schema( { vol.Required("entity_id"): cv.entity_id, @@ -231,6 +246,7 @@ vol.Optional("limit", default=50): vol.All(vol.Range(min=1,max=50)), vol.Optional("offset", default=0): vol.All(vol.Range(min=0,max=500)), vol.Optional("market"): cv.string, + vol.Optional("limit_total", default=0): vol.All(vol.Range(min=0,max=9999)), } ) @@ -454,6 +470,19 @@ async def service_handle_spotify_serviceresponse(service: ServiceCall) -> Servic _logsi.LogVerbose(STAppMessages.MSG_SERVICE_EXECUTE % (service.service, entity.name)) response = await hass.async_add_executor_job(entity.service_spotify_get_featured_playlists, limit, offset, country, locale, timestamp, limit_total) + elif service.service == SERVICE_SPOTIFY_GET_PLAYER_DEVICES: + + # get spotify connect device list. + refresh = service.data.get("refresh") + _logsi.LogVerbose(STAppMessages.MSG_SERVICE_EXECUTE % (service.service, entity.name)) + response = await hass.async_add_executor_job(entity.service_spotify_get_player_devices, refresh) + + elif service.service == SERVICE_SPOTIFY_GET_PLAYER_QUEUE_INFO: + + # get spotify queue info. + _logsi.LogVerbose(STAppMessages.MSG_SERVICE_EXECUTE % (service.service, entity.name)) + response = await hass.async_add_executor_job(entity.service_spotify_get_player_queue_info) + elif service.service == SERVICE_SPOTIFY_GET_PLAYER_RECENT_TRACKS: # get spotify playlist favorites. @@ -498,8 +527,9 @@ async def service_handle_spotify_serviceresponse(service: ServiceCall) -> Servic limit = service.data.get("limit") offset = service.data.get("offset") market = service.data.get("market") + limit_total = service.data.get("limit_total") _logsi.LogVerbose(STAppMessages.MSG_SERVICE_EXECUTE % (service.service, entity.name)) - response = await hass.async_add_executor_job(entity.service_spotify_get_show_episodes, show_id, limit, offset, market) + response = await hass.async_add_executor_job(entity.service_spotify_get_show_episodes, show_id, limit, offset, market, limit_total) elif service.service == SERVICE_SPOTIFY_GET_SHOW_FAVORITES: @@ -702,6 +732,24 @@ def _GetEntityFromServiceData(hass:HomeAssistant, service:ServiceCall, field_id: supports_response=SupportsResponse.ONLY, ) + _logsi.LogObject(SILevel.Verbose, STAppMessages.MSG_SERVICE_REQUEST_REGISTER % SERVICE_SPOTIFY_GET_PLAYER_DEVICES, SERVICE_SPOTIFY_GET_PLAYER_DEVICES_SCHEMA) + hass.services.async_register( + DOMAIN, + SERVICE_SPOTIFY_GET_PLAYER_DEVICES, + service_handle_spotify_serviceresponse, + schema=SERVICE_SPOTIFY_GET_PLAYER_DEVICES_SCHEMA, + supports_response=SupportsResponse.ONLY, + ) + + _logsi.LogObject(SILevel.Verbose, STAppMessages.MSG_SERVICE_REQUEST_REGISTER % SERVICE_SPOTIFY_GET_PLAYER_QUEUE_INFO, SERVICE_SPOTIFY_GET_PLAYER_QUEUE_INFO_SCHEMA) + hass.services.async_register( + DOMAIN, + SERVICE_SPOTIFY_GET_PLAYER_QUEUE_INFO, + service_handle_spotify_serviceresponse, + schema=SERVICE_SPOTIFY_GET_PLAYER_QUEUE_INFO_SCHEMA, + supports_response=SupportsResponse.ONLY, + ) + _logsi.LogObject(SILevel.Verbose, STAppMessages.MSG_SERVICE_REQUEST_REGISTER % SERVICE_SPOTIFY_GET_PLAYER_RECENT_TRACKS, SERVICE_SPOTIFY_GET_PLAYER_RECENT_TRACKS_SCHEMA) hass.services.async_register( DOMAIN, diff --git a/custom_components/spotifyplus/manifest.json b/custom_components/spotifyplus/manifest.json index 4672a16..8e1cb3b 100644 --- a/custom_components/spotifyplus/manifest.json +++ b/custom_components/spotifyplus/manifest.json @@ -13,6 +13,6 @@ "spotifywebapiPython==1.0.31", "urllib3>=1.21.1,<1.27" ], - "version": "1.0.1", + "version": "1.0.3", "zeroconf": [ "_spotify-connect._tcp.local." ] } diff --git a/custom_components/spotifyplus/media_player.py b/custom_components/spotifyplus/media_player.py index f80607c..3cb1e7e 100644 --- a/custom_components/spotifyplus/media_player.py +++ b/custom_components/spotifyplus/media_player.py @@ -13,8 +13,6 @@ Album, AlbumPageSaved, AlbumPageSimplified, - AlbumSaved, - AlbumSimplified, Artist, ArtistPage, Category, @@ -24,18 +22,15 @@ Episode, EpisodePageSimplified, PlayerPlayState, + PlayerQueueInfo, PlayHistoryPage, Playlist, PlaylistPageSimplified, - PlaylistSimplified, SearchResponse, Show, ShowPageSaved, - ShowSaved, - Track, TrackPage, TrackPageSaved, - TrackSaved, UserProfile ) @@ -270,6 +265,7 @@ def __init__(self, data:InstanceDataSpotifyPlus) -> None: if self.data.spotifyClient.UserProfile.Product == "premium": _logsi.LogVerbose("'%s': MediaPlayer is setting supported features for Spotify Premium user" % self.name) self._attr_supported_features = MediaPlayerEntityFeature.BROWSE_MEDIA \ + | MediaPlayerEntityFeature.MEDIA_ENQUEUE \ | MediaPlayerEntityFeature.NEXT_TRACK \ | MediaPlayerEntityFeature.PAUSE \ | MediaPlayerEntityFeature.PLAY \ @@ -524,9 +520,7 @@ def play_media(self, media_type: MediaType | str, media_id: str, **kwargs: Any) #media_type = media_type.removeprefix(MEDIA_PLAYER_PREFIX) # get enqueue keyword arguments (if any). - enqueue: MediaPlayerEnqueue = kwargs.get( - ATTR_MEDIA_ENQUEUE, MediaPlayerEnqueue.REPLACE - ) + enqueue: MediaPlayerEnqueue = kwargs.get(ATTR_MEDIA_ENQUEUE, MediaPlayerEnqueue.REPLACE) # resolve the device id. # if now playing media does not have a device id set, then use the first device @@ -817,7 +811,7 @@ def service_spotify_get_album_favorites(self, Returns: A dictionary that contains the following keys: - user_profile: A (partial) user profile that retrieved the result. - - result: A `AlbumPageSaved` object that contains playlist information. + - result: A `AlbumPageSaved` object that contains album information. """ apiMethodName:str = 'service_spotify_get_album_favorites' apiMethodParms:SIMethodParmListContext = None @@ -888,7 +882,7 @@ def service_spotify_get_album_new_releases(self, Returns: A dictionary that contains the following keys: - user_profile: A (partial) user profile that retrieved the result. - - result: A `AlbumPageSimplified` object that contains playlist information. + - result: A `AlbumPageSimplified` object that contains album information. """ apiMethodName:str = 'service_spotify_get_album_new_releases' apiMethodParms:SIMethodParmListContext = None @@ -940,7 +934,7 @@ def service_spotify_get_artist(self, Returns: A dictionary that contains the following keys: - user_profile: A (partial) user profile that retrieved the result. - - result: An `Album` object that contains the artist details. + - result: An `Artist` object that contains the artist details. """ apiMethodName:str = 'service_spotify_get_artist' apiMethodParms:SIMethodParmListContext = None @@ -1378,6 +1372,109 @@ def service_spotify_get_featured_playlists(self, _logsi.LeaveMethod(SILevel.Debug, apiMethodName) + def service_spotify_get_player_devices(self, + refresh:bool=True + ) -> dict: + """ + Get information about a user's available Spotify Connect player devices. + + Some device models are not supported and will not be listed in the API response. + + This method requires the `user-read-playback-state` scope. + + Args: + refresh (bool): + True (default) to return real-time information from the spotify web api and + update the cache; otherwise, False to just return the cached value. + + Returns: + A dictionary that contains the following keys: + - user_profile: A (partial) user profile that retrieved the result. + - result: A list of `Device` objects that contain the device details, sorted by name. + """ + apiMethodName:str = 'service_spotify_get_player_devices' + apiMethodParms:SIMethodParmListContext = None + result:PlayerQueueInfo = None + + try: + + # trace. + apiMethodParms = _logsi.EnterMethodParmList(SILevel.Debug, apiMethodName) + _logsi.LogMethodParmList(SILevel.Verbose, "Spotify Get Player Queue Info", apiMethodParms) + + # request information from Spotify Web API. + _logsi.LogVerbose(STAppMessages.MSG_SERVICE_QUERY_WEB_API) + result = self.data.spotifyClient.GetPlayerDevices(refresh) + + # build dictionary result from array. + resultArray:list = [] + item:Device + for item in result: + resultArray.append(item.ToDictionary()) + + # return the (partial) user profile that retrieved the result, as well as the result itself. + return { + "user_profile": self._GetUserProfilePartialDictionary(self.data.spotifyClient.UserProfile), + "result": resultArray + } + + # the following exceptions have already been logged, so we just need to + # pass them back to HA for display in the log (or service UI). + except SpotifyApiError as ex: + raise HomeAssistantError(ex.Message) + except SpotifyWebApiError as ex: + raise HomeAssistantError(ex.Message) + + finally: + + # trace. + _logsi.LeaveMethod(SILevel.Debug, apiMethodName) + + + def service_spotify_get_player_queue_info(self) -> dict: + """ + Get the list of objects that make up the user's playback queue. + + This method requires the `user-read-currently-playing` and `user-read-playback-state` scope. + + Returns: + A dictionary that contains the following keys: + - user_profile: A (partial) user profile that retrieved the result. + - result: A `PlayerQueueInfo` object that contains the player queue information. + """ + apiMethodName:str = 'service_spotify_get_player_queue_info' + apiMethodParms:SIMethodParmListContext = None + result:PlayerQueueInfo = None + + try: + + # trace. + apiMethodParms = _logsi.EnterMethodParmList(SILevel.Debug, apiMethodName) + _logsi.LogMethodParmList(SILevel.Verbose, "Spotify Get Player Queue Info", apiMethodParms) + + # request information from Spotify Web API. + _logsi.LogVerbose(STAppMessages.MSG_SERVICE_QUERY_WEB_API) + result = self.data.spotifyClient.GetPlayerQueueInfo() + + # return the (partial) user profile that retrieved the result, as well as the result itself. + return { + "user_profile": self._GetUserProfilePartialDictionary(self.data.spotifyClient.UserProfile), + "result": result.ToDictionary() + } + + # the following exceptions have already been logged, so we just need to + # pass them back to HA for display in the log (or service UI). + except SpotifyApiError as ex: + raise HomeAssistantError(ex.Message) + except SpotifyWebApiError as ex: + raise HomeAssistantError(ex.Message) + + finally: + + # trace. + _logsi.LeaveMethod(SILevel.Debug, apiMethodName) + + def service_spotify_get_player_recent_tracks(self, limit:int, after:int, @@ -1652,6 +1749,7 @@ def service_spotify_get_show_episodes(self, limit:int, offset:int, market:str=None, + limitTotal:int=None ) -> dict: """ Get Spotify catalog information about a show's episodes. @@ -1659,7 +1757,7 @@ def service_spotify_get_show_episodes(self, Args: showId (str): The Spotify ID for the show. - Example: `38bS44xjbVVZ3No3ByF1dJ` + Example: `6kAsbP8pxwaU2kPibKTuHE` limit (int): The maximum number of items to return in a page of items. Default: 20, Range: 1 to 50. @@ -1674,6 +1772,12 @@ def service_spotify_get_show_episodes(self, Note: If neither market or user country are provided, the content is considered unavailable for the client. Users can view the country that is associated with their account in the account settings. Example: `ES` + limitTotal (int): + The maximum number of items to return for the request. + If specified, this argument overrides the limit and offset argument values + and paging is automatically used to retrieve all available items up to the + maximum count specified. + Default: None (disabled) Returns: A dictionary that contains the following keys: @@ -1692,11 +1796,12 @@ def service_spotify_get_show_episodes(self, apiMethodParms.AppendKeyValue("limit", limit) apiMethodParms.AppendKeyValue("additionaoffsetlTypes", offset) apiMethodParms.AppendKeyValue("market", market) + apiMethodParms.AppendKeyValue("limitTotal", limitTotal) _logsi.LogMethodParmList(SILevel.Verbose, "Spotify Get Show Episodes Service", apiMethodParms) # request information from Spotify Web API. _logsi.LogVerbose(STAppMessages.MSG_SERVICE_QUERY_WEB_API) - result = self.data.spotifyClient.GetShowEpisodes(showId, limit, offset, market) + result = self.data.spotifyClient.GetShowEpisodes(showId, limit, offset, market, limitTotal) # return the (partial) user profile that retrieved the result, as well as the result itself. return { @@ -1960,7 +2065,7 @@ def service_spotify_get_users_top_tracks(self, Returns: A dictionary that contains the following keys: - user_profile: A (partial) user profile that retrieved the result. - - result: An `TrackPage` object of matching results. + - result: A `TrackPage` object of matching results. """ apiMethodName:str = 'service_spotify_get_users_top_tracks' apiMethodParms:SIMethodParmListContext = None @@ -2058,7 +2163,9 @@ def service_spotify_search_playlists(self, Default is False. Returns: - A dictionary representation of a `SearchResponse` object that contain the results. + A dictionary that contains the following keys: + - user_profile: A (partial) user profile that retrieved the result. + - result: A `PlaylistPageSimplified` object of matching results. """ apiMethodName:str = 'service_spotify_search_playlists' apiMethodParms:SIMethodParmListContext = None diff --git a/custom_components/spotifyplus/services.yaml b/custom_components/spotifyplus/services.yaml index cc791b6..c8aeb9c 100644 --- a/custom_components/spotifyplus/services.yaml +++ b/custom_components/spotifyplus/services.yaml @@ -5,7 +5,7 @@ get_album: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -33,7 +33,7 @@ get_album_favorites: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -82,7 +82,7 @@ get_album_new_releases: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -131,7 +131,7 @@ get_artist: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -152,7 +152,7 @@ get_artist_albums: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -215,7 +215,7 @@ get_artists_followed: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -248,14 +248,14 @@ get_artists_followed: number: mode: box -get_browse_categorys: - name: Get Browse Categorys +get_browse_categorys_list: + name: Get Browse Categorys List description: Get a sorted list of ALL categories used to tag items in Spotify. fields: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -290,7 +290,7 @@ get_category_playlists: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -346,7 +346,7 @@ get_featured_playlists: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -402,6 +402,41 @@ get_featured_playlists: number: mode: box +get_player_devices: + name: Get Player Devices + description: Get information about a user's available Spotify Connect player devices. Some device models are not supported and will not be listed in the API response. + fields: + entity_id: + name: Entity ID + description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. + example: "media_player.spotifyplus_username" + required: true + selector: + entity: + integration: spotifyplus + domain: media_player + refresh: + name: Refresh? + description: True to return real-time information from the spotify web api and update the cache; otherwise, False to just return the cached value. + example: "True" + required: false + selector: + boolean: + +get_player_queue_info: + name: Get Player Queue Info + description: Get the list of objects that make up the user's playback queue. + fields: + entity_id: + name: Entity ID + description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. + example: "media_player.spotifyplus_username" + required: true + selector: + entity: + integration: spotifyplus + domain: media_player + get_player_recent_tracks: name: Get Player Recent Tracks description: Get tracks from the current user's recently played tracks; currently doesn't support podcast episodes, and only 50 items may be returned due to spotify limits. @@ -409,7 +444,7 @@ get_player_recent_tracks: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -462,7 +497,7 @@ get_playlist: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -504,7 +539,7 @@ get_playlist_favorites: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -546,7 +581,7 @@ get_show: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -574,7 +609,7 @@ get_show_episodes: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -583,7 +618,7 @@ get_show_episodes: show_id: name: Show Id description: The Spotify ID for the show. - example: "38bS44xjbVVZ3No3ByF1dJ" + example: "6kAsbP8pxwaU2kPibKTuHE" required: true selector: text: @@ -614,6 +649,14 @@ get_show_episodes: required: false selector: text: + limit_total: + name: Limit Total + description: The maximum number of items to return for the request. If specified, this argument overrides the limit and offset argument values and paging is automatically used to retrieve all available items up to the specified limit total. + example: 20 + required: false + selector: + number: + mode: box get_show_favorites: name: Get Show Favorites @@ -622,7 +665,7 @@ get_show_favorites: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -664,7 +707,7 @@ get_track_favorites: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -713,7 +756,7 @@ get_users_top_artists: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -762,7 +805,7 @@ get_users_top_tracks: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: @@ -811,7 +854,7 @@ search_playlists: entity_id: name: Entity ID description: Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API. - example: "media_player.spotify_user_1" + example: "media_player.spotifyplus_username" required: true selector: entity: diff --git a/custom_components/spotifyplus/strings.json b/custom_components/spotifyplus/strings.json index 93023b2..d80de1c 100644 --- a/custom_components/spotifyplus/strings.json +++ b/custom_components/spotifyplus/strings.json @@ -255,6 +255,30 @@ } } }, + "get_player_devices": { + "name": "Get Player Devices", + "description": "Get information about a user's available Spotify Connect player devices. Some device models are not supported and will not be listed in the API response.", + "fields": { + "entity_id": { + "name": "Entity ID", + "description": "Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API." + }, + "refresh": { + "name": "Refresh?", + "description": "True to return real-time information from the spotify web api and update the cache; otherwise, False to just return the cached value." + } + } + }, + "get_player_queue_info": { + "name": "Get Player Queue Info", + "description": "Get the list of objects that make up the user's playback queue.", + "fields": { + "entity_id": { + "name": "Entity ID", + "description": "Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API." + } + } + }, "get_player_recent_tracks": { "name": "Get Player Recent Tracks", "description": "Get tracks from the current user's recently played tracks; currently doesn't support podcast episodes, and only 50 items may be returned due to spotify limits.", @@ -370,6 +394,10 @@ "market": { "name": "Market / Country Code", "description": "An ISO 3166-1 alpha-2 country code. If a country code is specified, only content that is available in that market will be returned. The country associated with the user account will take priority over this parameter." + }, + "limit_total": { + "name": "Limit Total", + "description": "The maximum number of items to return for the request. If specified, this argument overrides the limit and offset argument values and paging is automatically used to retrieve all available items up to the specified limit total." } } }, diff --git a/custom_components/spotifyplus/translations/en.json b/custom_components/spotifyplus/translations/en.json index 93023b2..d80de1c 100644 --- a/custom_components/spotifyplus/translations/en.json +++ b/custom_components/spotifyplus/translations/en.json @@ -255,6 +255,30 @@ } } }, + "get_player_devices": { + "name": "Get Player Devices", + "description": "Get information about a user's available Spotify Connect player devices. Some device models are not supported and will not be listed in the API response.", + "fields": { + "entity_id": { + "name": "Entity ID", + "description": "Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API." + }, + "refresh": { + "name": "Refresh?", + "description": "True to return real-time information from the spotify web api and update the cache; otherwise, False to just return the cached value." + } + } + }, + "get_player_queue_info": { + "name": "Get Player Queue Info", + "description": "Get the list of objects that make up the user's playback queue.", + "fields": { + "entity_id": { + "name": "Entity ID", + "description": "Entity ID of the SpotifyPlus device that will make the request to the Spotify Web API." + } + } + }, "get_player_recent_tracks": { "name": "Get Player Recent Tracks", "description": "Get tracks from the current user's recently played tracks; currently doesn't support podcast episodes, and only 50 items may be returned due to spotify limits.", @@ -370,6 +394,10 @@ "market": { "name": "Market / Country Code", "description": "An ISO 3166-1 alpha-2 country code. If a country code is specified, only content that is available in that market will be returned. The country associated with the user account will take priority over this parameter." + }, + "limit_total": { + "name": "Limit Total", + "description": "The maximum number of items to return for the request. If specified, this argument overrides the limit and offset argument values and paging is automatically used to retrieve all available items up to the specified limit total." } } },