Get All Movies for a Resolution
Plex can play movies in many different resolutions. If a library contains thousands of movies, it can be difficult to find movies that are available in a specific resolution. This API command will return a list of movies for a specified resolution that are available on the Plex server.
URL
GET http://{ip_address}:32400/library/sections/{id}/resolution/{resolution}?X-Plex-Token={plex_token}&{filter}
Parameters
Name | Description |
---|---|
ip_address | The IP address of the Plex Media server. |
plex_token | The Plex token. |
id | The key associated with a movies/video library. This key can be found by calling the Libraries API command and looking for a movies library. |
resolution | The resolution of the movies to return. See the Resolution table below for the value. |
filter | (Optional) The filter to apply to the response. See the Filtering section below for parameters that can be used to filter the response. |
Return Status
HTTP Code | Description |
---|---|
200 | Success - The request was successful. |
401 | Unauthorized - The Plex token provided was not valid. |
Response
XML string value that lists the all the movies in the library. An example of the XML returned from the request is shown below:
<?xml version="1.0" encoding="UTF-8"?> <MediaContainer size="140" allowSync="1" art="/:/resources/movie-fanart.jpg" identifier="com.plexapp.plugins.library" librarySectionID="2" librarySectionTitle="Movies" librarySectionUUID="493a64e7-b541-4667-b050-d702beebf2f6" mediaTagPrefix="/system/bundle/media/flags/" mediaTagVersion="1698877656" sortAsc="1" thumb="/:/resources/movie.png" title1="Movies" title2="1080" viewGroup="movie" viewMode="131624"> <Video ratingKey="1416" key="/library/metadata/1416" guid="plex://movie/5d776d057a53e9001e74ed5d" studio="Dune Entertainment" type="movie" title="Avatar" titleSort="Avatar 01" contentRating="PG-13" summary="A paraplegic Marine dispatched to the moon Pandora on a unique mission becomes torn between following his orders and protecting the world he feels is his home." rating="8.1" audienceRating="8.2" viewCount="4" skipCount="1" lastViewedAt="1678244163" year="2009" tagline="Enter the world of Pandora." thumb="/library/metadata/1416/thumb/1701596598" art="/library/metadata/1416/art/1701596598" duration="9701779" originallyAvailableAt="2009-12-16" addedAt="1421027988" updatedAt="1701596598" audienceRatingImage="rottentomatoes://image.rating.upright" chapterSource="media" primaryExtraKey="/library/metadata/282482" ratingImage="rottentomatoes://image.rating.ripe"> <Media id="71855" duration="9701779" bitrate="15378" width="1916" height="1078" aspectRatio="1.78" audioChannels="6" audioCodec="dca" videoCodec="h264" videoResolution="1080" container="mkv" videoFrameRate="24p" audioProfile="dts" videoProfile="high"> <Part id="71980" key="/library/parts/71980/1449134841/file.mkv" duration="9701779" file="M:\Media\Movies\Avatar (2009)\Avatar (2009) [1080p h.264][AAC DTS DTS-HD].mkv" size="18649138726" audioProfile="dts" container="mkv" videoProfile="high" /> </Media> <Genre tag="Action" /> <Genre tag="Adventure" /> <Country tag="United States of America" /> <Country tag="United Kingdom" /> <Director tag="James Cameron" /> <Writer tag="James Cameron" /> <Role tag="Sam Worthington" /> <Role tag="Zoe Saldaña" /> <Role tag="Stephen Lang" /> </Video> ... </MediaContainer>
The XML returned provides a list of the all movies in a library for the specified resolution that are available on the Plex server. The root is the MediaContainer
element. This element contains a few attributes that provide overall information about the movies on the server.
Attribute | Description |
---|---|
size | The number of libraries. |
allowSync | 1 - allow syncing content. 0 - don't allow syncing content. |
art | Background artwork used to represent the library. |
identifier | The type of item. |
librarySectionID | The unique key associated with the library. |
librarySectionTitle | The title of the library. |
librarySectionUUID | Unique GUID identifier for the library. |
mediaTagPrefix | Prefix for the media tag. |
mediaTagVersion | Media tag version. Note: This could be a date and time value. |
sortAsc | 1 - the library is sorted in ascending order. 0 - the library is sorted in descending order. |
thumb | The thumbnail for the library. |
title1 | The title of the library. Note: This appears to be internally created, and can't be changed by the server owner. |
title2 | A descriptive title for the library. |
viewGroup | The group type used to view the library. |
viewMode | Unknown integer value. |
Within the MediaContainer
there are one or more Video
child elements. Each Video
element represents one movie available on the Plex server.
Attribute | Description |
---|---|
ratingKey | A key associated with the item. |
key | The relative URL of the item information. |
guid | The unique identifier comprised of the Plex agent and item identifier for the agent. |
studio | The name of the item studio. |
type | The type of media. |
title | The title of the item. |
contentRating | The content rating associated with the item. |
summary | A summary of the item. |
rating | The rating for the item. |
audienceRating | The audience rating for the item. |
skipCount | The skip count. |
year | The year the item was released. |
tagline | The tagline associated with the item. |
thumb | The thumbnail for the item. |
art | The background artwork used to represent the item. |
duration | The length of the item in milliseconds. |
originallyAvailableAt | The original release date of the item. |
addedAt | The date and time, in Unix time, the item was added to the library. |
updatedAt | The date and time in epoch time, the item was updated in the library. |
audienceRatingImage | The image associated with the audience rating. |
chapterSource | The chapter source type. |
ratingImage | The image associated with the rating. |
Within the Video
there are one or more Media
child elements. Each Media
element represents one media file of the movie available on the Plex server.
If there are two media files associated with the movie, such as a 1080p and 480p version, then there would be two Media
child elements in the Video
element.
Attribute | Description |
---|---|
id | Unique ID associated with the item. |
duration | The length of the item in milliseconds. |
bitrate | The bitrate of the item. |
width | The width of the item. |
height | The height of the item. |
aspectRatio | The aspect ratio of the item. |
audioChannels | The number of audio channels. |
audioCodec | The audio codec used to encode the audio. |
videoCodec | The video codec used to encode the video. |
videoResolution | The video resolution. |
container | The item container. |
videoFrameRate | The framerate standard used for the video. |
audioProfile | The audio profile of the media. |
videoProfile | The video profile of the media. |
Within the Media
there are one or more Part
child elements. Each Part
element represents one part of the movie. If the movie has been added to the Plex server as a multi-part movie, then each of those parts will be represented by one Part
child element.
Attribute | Description |
---|---|
id | Unique ID associated with the part. |
key | The unique relative path for the part that is used at its key. |
duration | The length of the part in milliseconds. |
file | The file associated with the part. |
size | The file size of the part. |
audioProfile | The audio profile associated with the audio part. |
container | The type of media container. |
videoProfile | The video profile associated with the video part. |
Also within the Video
element there are multiple additional child elements that provide more details about the movie. These child elements include Genre
, Director
, Writer
, Country
, Collection
, and Role
.
Within each of these child elements is a single tag
attribute that provides the information for the element. There could be multiple of the same child element within the Video
, such as multiple directors or writers.
Attribute | Description |
---|---|
tag | A genre of the movie. |
Attribute | Description |
---|---|
tag | A director of the movie. |
Attribute | Description |
---|---|
tag | A writer for the movie |
Attribute | Description |
---|---|
tag | A country of origin for the movie. |
Attribute | Description |
---|---|
tag | The name of a collection containing the movie. |
Attribute | Description |
---|---|
tag | The name of a person with a role in the movie. |
Filtering
To reduce the number of items returned, you can filter the API response to only return items that meet a specific criteria.
For more information, check out the Filter page.
The results from this endpoint can be filtered by adding the following optional parameters to the request:
Parameter | Description |
---|---|
addedAt | Gets all the movies that were added based on the condition. Can use different conditions: equals (=), less than and equals (<=), greater and equals (>=). There must be an equals sign or the response will be a 400 Bad Request error. The value is in epoch time. |
audienceRating | Gets all movies that match the audience rating condition. Can use different conditions: equals (=), less than and equals (<=), greater and equals (>=). There must be an equals sign or the response will be a 400 Bad Request error. |
contentRating | Gets all movies that match the content rating. This value is case-sensitive. |
duration | Gets all the movies that match the condition on the movie duration. Can use different conditions: equals (=), less than and equals (<=), greater and equals (>=). There must be an equals sign or the response will be a 400 Bad Request error. This value is is milliseconds. |
file | Will match any part of the file name for the movie. The value provide is not case-sensitive. |
lastViewedAt | Gets all the movies that were last viewed based on the condition. Can use different conditions: equals (=), less than and equals (<=), greater and equals (>=). There must be an equals sign or the response will be a 400 Bad Request error. The value is in epoch time. |
originallyAvailableAt | Gets all the movies that match were originally available time based on the condition. Can use different conditions: equals (=), less than and equals (<=), greater and equals (>=). There must be an equals sign or the response will be a 400 Bad Request error. Must be in the format YYYY or YYY-MM-DD. |
rating | Gets all the movies that match the rating based on the condition. Can use different conditions: equals (=), less than and equals (<=), greater and equals (>=). There must be an equals sign or the response will be a 400 Bad Request error. |
studio | Will match any part of the studio name. The value provide is not case-sensitive. |
title | Will match any part of the movie title. The value provide is not case-sensitive. |
updatedAt | Gets all the movies that were updated base on the condition. Can use different conditions: equals (=), less than and equals (<=), greater and equals (>=). There must be an equals sign or the response will be a 400 Bad Request error. The value is in epoch time. |
viewCount | Gets all the movies that were viewed a specified number of times. Can use different conditions: equals (=), less than and equals (<=), greater and equals (>=). There must be an equals sign or the response will be a 400 Bad Request error. |
year | Gets all the movies that were released in a specific year(s) based on the condition. Can use different conditions: equals (=), less than and equals (<=), greater and equals (>=). There must be an equals sign or the response will be a 400 Bad Request error. |
Remarks
Resolution
If you were to send a request to the Plex server without the resolution value, then a response with all the possible resolution values will be returned. The values returned will include all the available resolutions for the library.
The resolution value specified in the command are listed in the following table.The value column contains the value to use the command.
Value | Description |
---|---|
sd | Standard definition lower than 480p. |
480 | Standard definition - 480p. |
720 | High-definition - 720. |
1080 | Full high-definition - 1080p. |
4K | Ultra high-definition - 4K. |
Examples
curl -X GET http://{ip_address}:32400/library/sections/{id}/resolution/{resolution}?X-Plex-Token={plex_token}
import requests plex_url = http://{ip_address}:32400/library/sections/{id}/resolution/{resolution}?X-Plex-Token={plex_token} response = requests.get(plex_url) print(response.text)
$response = Invoke-RestMethod 'http://{ip_address}:32400/library/sections/{id}/resolution/{resolution}?X-Plex-Token={plex_token}' -Method 'GET' Write-Output $response