How to Prevent Plex from Changing Movie Posters
When Plex updates the metadata for movies on your server it may also change the movie poster to one it finds online. If you have carefully set your posters for your movies this can be frustrating to have Plex change the posters.
To prevent this from happening, there are a few things you can do in Plex to keep your own selected posters from being changed.
The next few sections will describe the methods you can use to keep your movie posters from being changed by Plex.
Storing and using your movie posters
The first method is simply to store the movie poster in the same folder as your movies, and then have Plex use that poster.
This works best when you each of your movies in its folder, that way it keeps things organized on your hard drive.
Poster naming conventions
To store posters in a folder containing a single movie, you would use the following poster naming convention:
Movies/MovieName (Release Date)/PosterName.ext
The PosterName
value can be one of the following:
- cover
- default
- folder
- movie
- poster
For example, for The Godfather, you would do something like the following:
Movies /The Godfather (1972) /The Godfather (1972).mkv /poster.jpg
You can still store your posters even if all your movies are in a single folder.
The naming convention for movie posters stored in a single movies folder is as follows:
Moves/MovieName (Release Date).ext
For example, The Godfather (1972).jpg
would be the name of a poster for The GodFather.
You can have multiple posters for a movie by appending a number after the file name, such as:
poster-1.jpg
or
The Godfather (1972)-1.jpg
The first poster doesn't need a number appended, however, any additional posters should include a number.
If you have carefully set your movie posters and would like to download them, you can use the script documented in How to Download Movie Posters from Your Plex Server.
Enable local assets Plex movie agent
Once you have the poster files added to the same folder as your movie files, you will need to enable the movie library in Plex to use the local assets.
To do that, use the following steps:
- Log into your Plex server as an administrator, and then hover your mouse over the movie library you wish to edit, click the three dots, and then select the Manage Library->Edit... option.
- From the Edit Movies dialog, click the Advanced option on the left, then scroll down and click the Use local assets checkbox, and then click the Save Changes button.
After doing the above steps, Plex will now use the local posters for your movies instead of the ones it downloads from the Internet.
Locking the movie poster using the Plex API for a single movie
Sometimes the reason Plex may change movie posters is because the posters aren't "locked."
When you make changes to metadata for a media item in Plex, you will notice that a lock icon beside the field you change changes from a gray color to an orange color.
An orange lock means the field has been "locked" and indicates that Plex won't update that field when metadata for that media item is refreshed.
There is no lock indicator for movie posters in Plex, so you can't manually enable the lock on a poster.
You can use the Plex API to lock the poster by calling the Update Movie Details API command.
The steps to lock the movie poster using the Plex API are as follows:
- Call the Get Libraries API to find the key associated with the movie library.
- Get the key of the movie by calling the Get All Movies API command.
- With both the movie library key and the movie key, you can lock the movie poster for the movie using the following command:
curl -X PUT http://{ip_address]:32400/library/sections/{library_key}/all?type=1&id={movie_key}&thumb.locked=1&X-Plex-Token={plex_token}
import requests plex_url = http://{ip_address}:32400/library/sections/{library_key}/all?type=1&id={movie_key}&thumb.locked=1&X-Plex-Token={plex_token} response = requests.put(plex_url) print(response.text)
$response = Invoke-RestMethod 'http://{ip_address}:32400/library/sections/{library_key}/all?type=1&id={movie_key}&thumb.locked=1&X-Plex-Token={plex_token}' -Method 'PUT' Write-Output $response
Locking all movie posters using the API
You can easily lock the posters for all movies on your Plex server with a simple script.
The Python script below will lock the posters for all movies on a Plex server:
import os import requests import xml.etree.ElementTree as ET plex_url = os.environ.get('PLEX_URL') plex_token = os.environ.get('PLEX_TOKEN') library = {library_id} def get_all_media(): """ Gets all media for a library. Keyword arguments: id -- the id of the library """ response = requests.get('{0}/library/sections/{1}/all?X-Plex-Token={2}'.format(plex_url, library, plex_token)) if response.ok: root = ET.fromstring(response.content) return root else: return None def get_movie_key(video_tag): """ Gets the key associated with the video. Keyword arguments: video_tag -- the video tag returned by the Plex API """ key = video_tag.get('ratingKey') if key: return key else: return None def lock_poster(movie_key): """ Locks the movie's posters so it can't be changed by Plex. Keyword arguments: movie_key -- the key associated with the movie """ response = requests.put('{0}/library/sections/{1}/all?type=1&id={2}&thumb.locked=1&X-Plex-Token={3}'.format(plex_url, library, movie_key, plex_token)) if response.status_code != 200: print("Couldn't lock the poster. Status code: {0}".format(response.status_code)) root = get_all_media() for video_tag in root.findall('Video'): movie_key = get_movie_key(video_tag) if not movie_key: print('The key associated with the movie was not found.') continue lock_poster(movie_key)
How to use the script
To use the script, you will need to do the following:
- Install Python.
- After Python is installed, run the following
pip
command to install the dependencies:pip install requests
- Copy the above script and save it as a Python file, for example:
lock_movie_posters.py
- Edit the script to replace
{library_id}
with the movies library ID from your Plex server. - Create an environment variable called
PLEX_URL
and set it to the URL of your Plex server. For example:http://localhost:32400
. - Create an environment variable called
PLEX_TOKEN
and set it to your Plex token.
What does the script do?
The above script will make multiple calls to the Plex API to perform the following steps:
- It gets all the movie files by calling the Get All Movies API command. This is done in the
get_all_media
function. - Once all the movies have been retrieved, it will loop through all the movies and then call the
get_movie_key
function to get the key for each movie in the library. - Next, the
lock_poster
function is called to lock the poster for the movie. This URL is the Update a Movie endpoint.
Using Plex Meta Manager
Another method of preventing Plex from changing your movie posters is to setup and use Plex Meta Manager
Plex Meta Manager is a popular tool for managing metadata for your media libraries, including managing posters. You can even display overlays over your posters that can display specific information about the movie.
I don't currently use this tool, but I have heard good things about it, so may check it out someday.
At this time, though, I like to keep my Plex installation simple to prevent me from having to perform too much maintenance on it.
The above sections provided different methods of preventing Plex from changing the movie posters that you have set up yourself. If you have carefully curated your posters, you can try one of the methods to protect the time you have spent to make Plex the way you want.