mirror of
https://github.com/Tautulli/Tautulli.git
synced 2025-07-12 16:22:57 -07:00
Bump plexapi from 4.15.4 to 4.15.10 (#2251)
* Bump plexapi from 4.15.4 to 4.15.10 Bumps [plexapi](https://github.com/pkkid/python-plexapi) from 4.15.4 to 4.15.10. - [Release notes](https://github.com/pkkid/python-plexapi/releases) - [Commits](https://github.com/pkkid/python-plexapi/compare/4.15.4...4.15.10) --- updated-dependencies: - dependency-name: plexapi dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> * Update plexapi==4.15.10 --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: JonnyWong16 <9099342+JonnyWong16@users.noreply.github.com> [skip ci]
This commit is contained in:
parent
040972bcba
commit
b1c0972077
16 changed files with 413 additions and 189 deletions
|
@ -3,6 +3,8 @@ import os
|
|||
from pathlib import Path
|
||||
from urllib.parse import quote_plus
|
||||
|
||||
from typing import Any, Dict, List, Optional, TypeVar
|
||||
|
||||
from plexapi import media, utils
|
||||
from plexapi.base import Playable, PlexPartialObject, PlexHistory, PlexSession
|
||||
from plexapi.exceptions import BadRequest
|
||||
|
@ -14,6 +16,9 @@ from plexapi.mixins import (
|
|||
from plexapi.playlist import Playlist
|
||||
|
||||
|
||||
TAudio = TypeVar("TAudio", bound="Audio")
|
||||
|
||||
|
||||
class Audio(PlexPartialObject, PlayedUnplayedMixin):
|
||||
""" Base class for all audio objects including :class:`~plexapi.audio.Artist`,
|
||||
:class:`~plexapi.audio.Album`, and :class:`~plexapi.audio.Track`.
|
||||
|
@ -22,6 +27,7 @@ class Audio(PlexPartialObject, PlayedUnplayedMixin):
|
|||
addedAt (datetime): Datetime the item was added to the library.
|
||||
art (str): URL to artwork image (/library/metadata/<ratingKey>/art/<artid>).
|
||||
artBlurHash (str): BlurHash string for artwork image.
|
||||
distance (float): Sonic Distance of the item from the seed item.
|
||||
fields (List<:class:`~plexapi.media.Field`>): List of field objects.
|
||||
guid (str): Plex GUID for the artist, album, or track (plex://artist/5d07bcb0403c64029053ac4c).
|
||||
index (int): Plex index number (often the track number).
|
||||
|
@ -53,6 +59,7 @@ class Audio(PlexPartialObject, PlayedUnplayedMixin):
|
|||
self.addedAt = utils.toDatetime(data.attrib.get('addedAt'))
|
||||
self.art = data.attrib.get('art')
|
||||
self.artBlurHash = data.attrib.get('artBlurHash')
|
||||
self.distance = utils.cast(float, data.attrib.get('distance'))
|
||||
self.fields = self.findItems(data, media.Field)
|
||||
self.guid = data.attrib.get('guid')
|
||||
self.index = utils.cast(int, data.attrib.get('index'))
|
||||
|
@ -125,6 +132,37 @@ class Audio(PlexPartialObject, PlayedUnplayedMixin):
|
|||
|
||||
return myplex.sync(sync_item, client=client, clientId=clientId)
|
||||
|
||||
def sonicallySimilar(
|
||||
self: TAudio,
|
||||
limit: Optional[int] = None,
|
||||
maxDistance: Optional[float] = None,
|
||||
**kwargs,
|
||||
) -> List[TAudio]:
|
||||
"""Returns a list of sonically similar audio items.
|
||||
|
||||
Parameters:
|
||||
limit (int): Maximum count of items to return. Default 50 (server default)
|
||||
maxDistance (float): Maximum distance between tracks, 0.0 - 1.0. Default 0.25 (server default).
|
||||
**kwargs: Additional options passed into :func:`~plexapi.base.PlexObject.fetchItems`.
|
||||
|
||||
Returns:
|
||||
List[:class:`~plexapi.audio.Audio`]: list of sonically similar audio items.
|
||||
"""
|
||||
|
||||
key = f"{self.key}/nearest"
|
||||
params: Dict[str, Any] = {}
|
||||
if limit is not None:
|
||||
params['limit'] = limit
|
||||
if maxDistance is not None:
|
||||
params['maxDistance'] = maxDistance
|
||||
key += utils.joinArgs(params)
|
||||
|
||||
return self.fetchItems(
|
||||
key,
|
||||
cls=type(self),
|
||||
**kwargs,
|
||||
)
|
||||
|
||||
|
||||
@utils.registerPlexObject
|
||||
class Artist(
|
||||
|
@ -189,7 +227,7 @@ class Artist(
|
|||
""" Returns a list of :class:`~plexapi.audio.Album` objects by the artist. """
|
||||
return self.section().search(
|
||||
libtype='album',
|
||||
filters={'artist.id': self.ratingKey},
|
||||
filters={**kwargs.pop('filters', {}), 'artist.id': self.ratingKey},
|
||||
**kwargs
|
||||
)
|
||||
|
||||
|
@ -251,7 +289,7 @@ class Artist(
|
|||
@utils.registerPlexObject
|
||||
class Album(
|
||||
Audio,
|
||||
UnmatchMatchMixin, RatingMixin,
|
||||
SplitMergeMixin, UnmatchMatchMixin, RatingMixin,
|
||||
ArtMixin, PosterMixin, ThemeUrlMixin,
|
||||
AlbumEditMixins
|
||||
):
|
||||
|
@ -389,6 +427,7 @@ class Track(
|
|||
chapterSource (str): Unknown
|
||||
collections (List<:class:`~plexapi.media.Collection`>): List of collection objects.
|
||||
duration (int): Length of the track in milliseconds.
|
||||
genres (List<:class:`~plexapi.media.Genre`>): List of genre objects.
|
||||
grandparentArt (str): URL to album artist artwork (/library/metadata/<grandparentRatingKey>/art/<artid>).
|
||||
grandparentGuid (str): Plex GUID for the album artist (plex://artist/5d07bcb0403c64029053ac4c).
|
||||
grandparentKey (str): API URL of the album artist (/library/metadata/<grandparentRatingKey>).
|
||||
|
@ -411,6 +450,8 @@ class Track(
|
|||
primaryExtraKey (str) API URL for the primary extra for the track.
|
||||
ratingCount (int): Number of listeners who have scrobbled this track, as reported by Last.fm.
|
||||
skipCount (int): Number of times the track has been skipped.
|
||||
sourceURI (str): Remote server URI (server://<machineIdentifier>/com.plexapp.plugins.library)
|
||||
(remote playlist item only).
|
||||
viewOffset (int): View offset in milliseconds.
|
||||
year (int): Year the track was released.
|
||||
"""
|
||||
|
@ -425,6 +466,7 @@ class Track(
|
|||
self.chapterSource = data.attrib.get('chapterSource')
|
||||
self.collections = self.findItems(data, media.Collection)
|
||||
self.duration = utils.cast(int, data.attrib.get('duration'))
|
||||
self.genres = self.findItems(data, media.Genre)
|
||||
self.grandparentArt = data.attrib.get('grandparentArt')
|
||||
self.grandparentGuid = data.attrib.get('grandparentGuid')
|
||||
self.grandparentKey = data.attrib.get('grandparentKey')
|
||||
|
@ -445,6 +487,7 @@ class Track(
|
|||
self.primaryExtraKey = data.attrib.get('primaryExtraKey')
|
||||
self.ratingCount = utils.cast(int, data.attrib.get('ratingCount'))
|
||||
self.skipCount = utils.cast(int, data.attrib.get('skipCount'))
|
||||
self.sourceURI = data.attrib.get('source') # remote playlist item
|
||||
self.viewOffset = utils.cast(int, data.attrib.get('viewOffset', 0))
|
||||
self.year = utils.cast(int, data.attrib.get('year'))
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue