-
Notifications
You must be signed in to change notification settings - Fork 42
Frequently Asked Questions
Important
Plex cannot read metadata from MKV files. Pinchflat saves files as MP4 by default so leave those settings alone
There is no explicit media center integration. Instead, Pinchflat can format the filepath and add metadata in a way that is automatically picked up by media center apps. Here's how to do that, including some best practices:
- Ensure Pinchflat's download directory is in a location that's visible to your media center app
- Create a new Media Profile with the "Media Center" preset
- NOTE: you can tweak the parent directory specified in
Output path template
if needed, but it's critical that you don't change anything else about theOutput path template
- NOTE: you can tweak the parent directory specified in
- Set up your media center app to look for TV shows in the directory created above. In the example above, you'd configure it to look in the
/shows/
directory- NOTE: in Plex you likely want to create a new library just for YouTube (Settings > Manage > Libraries > Add Library). You'll want to enable
Prefer local metadata
andUse local assets
in the "Advanced" library settings section. This may not be ideal for all users in which case you could look into an NFO or YouTube agent for Plex. Plex is also expecting to add NFO support sometime in early 2025 which should remove the need for this setting
- NOTE: in Plex you likely want to create a new library just for YouTube (Settings > Manage > Libraries > Add Library). You'll want to enable
- NOTE: I strongly recommend keeping your YouTube content in a separate directory from your normal TV shows. It's good to keep things tidy!
This isn't explicitly supported in-app, but there's a very simple workaround! All you have to do is create a new unlisted playlist on YouTube, add the videos you want to that playlist, and add that playlist as a Source in Pinchflat. Don't forget that you can create + add as many unlisted playlists as you'd like if you want to have different download rules for certain videos!
Indexing is the act of scanning a channel or playlist (aka: Source) for new media.
There are a few ways to do this. Pinchflat's approach is to build a list of all media belonging to a Source, regardless of any filters or preferences you've applied. It then uses your filters on its internal list of known content to decide what to then download. This has a few benefits, but the biggest one is that changing your filters doesn't mean the Source needs to be indexed again.
If the Source is a channel (rather than a playlist), it's only fully indexed once. After that point indexing only looks for new media and changes to recently indexed media. Keep in mind that forcing a source to be indexed from the UI will fully index a channel top-to-bottom.
It's important to set a smart indexing frequency to ensure all sources can be updated in a timely manner. Being too aggressive with indexing can actually result in you waiting longer for new content than if you had set more patient rules!
There's no hard-and-fast rules here, but you should base it on how often the channel uploads and whether you care about getting the latest content immediately. Here are some rough guidelines:
- Is it a channel that uploads multiple times a day? Set it to either 1 hour or 3 hours
- Is it a channel you really care about so you want to index its videos ASAP? Use Fast Indexing
- Is it a channel who's videos are at risk of being deleted within minutes of uploading? Use Fast Indexing
- For all other channels, set it based on the upload schedule. If they upload weekly, set it to index daily. If they upload monthly, set it to index weekly
Pinchflat is configured to only perform a certain number of operations at the same time. This is a necessity since being too aggressive in fetching/downloading content will result in Google rate limiting your IP, causing downloads and indexing to fail. These failures will have a cascading effect, grinding things to a halt. The app is build to gracefully recover from these types of failures but it takes time for Google to ease up on it rate limiting. It's overall very preferable to be more conservative to prevent this situation in the first place.
That said, it's perfectly normal for there to be a substantial delay in downloading if you're adding a bunch of large sources at the same time. Pinchflat uses a few tricks to start downloads as soon as possible but it can still take dozens of hours to do an initial download of a large channel (although subsequent runs can be MUCH faster).
If you want to be sure, check the logs for entries concerning yt-dlp
being called. If those are showing up, the app is still chugging along!
This is expected and can come from a few places.
For the reasons outlined in the question above, it can be due to the app avoiding running too many yt-dlp
commands at the same time. If you have many Sources that should index at the same time, it'll stagger them to prevent you from being rate limited.
The other reason is that the next indexing gets scheduled only after the current one completes. For example: if you set your Media Profile to index every 60 minutes and the indexing task takes 30 minutes to complete, it'll actually run every 90 minutes, since that 60 minute interval was only applied after the 30 minute indexing task completed. This is expected because it's the best way to ensure indexing tasks don't overlap and other tasks can run in a timely-ish manner.
For those reasons, it's not recommended to index a large channel frequently. See above for some guidelines on index frequency.
Fast Indexing is an option you can set per-source. It's a toggle under the "Index Frequency" field.
Normal indexing uses yt-dlp
to scan the source on your specified frequency, but comparatively slow. You also have to remember that only so many indexing operations can run at the same time which can impact your other source's ability to index.
Fast indexing takes a different approach. It still does an initial scan the slow way but after that it uses an RSS feed or API calls to frequently check for new videos. This has the potential to be hundreds of times faster, but it can miss videos in some weird edge cases (eg: uploading dozens of videos within a few minutes of each other). To make up for this limitation, a normal index is still run monthly to catch any videos that were missed by fast indexing. Fast indexing overrides the normal index frequency.
RSS is used by default and you can optionally configure an API key if you need Fast Indexing to be as quick and accurate as possible. Most users are fine with just RSS but the API will give you the fastest and most reliable experience. See the settings page inside Pinchflat for instructions on using the YouTube API.
Fast indexing is not recommended for playlists.
Yes and no. There is no logic for deleting files when they're removed from the source or if you update your filters (and this is not planned). However, you can set a Source to automatically delete media after a certain number of days (docs)
You have a few options!
- If it's a small number of videos that won't be updated frequently, create a new playlist with those videos and use that as the source
- If the titles always contain certain words, enable advanced mode in your Source (upper right) and use a "Title Filter Regex". This will only download videos whose titles match that regular expression.
- If you only want to download after a certain date, set the Source's "Download Cutoff Date" to a
YYYY-MM-DD
date. Only videos uploaded after that date will be downloaded - If you only want videos that meet a certain minimum or maximum duration, enable advanced mode in your Source (upper right) and use the minimum/maximum duration fields
You may want to test your "Title Filter Regex", "Download Cutoff Date", handling of shorts vs. livestreams, etc., before you actually start downloading the content.
The best way to do this is to disable "Download Media" in your Source. The Source will still be indexed, but you can check the "Pending Media" tab when viewing a Source to ensure that only the media you expect is set to be downloaded. NOTE: this page does not update live and you must reload the page to see the latest.
Once you're confident everything is working as expected, update the Source to download media and it'll get to it!
This is not currently possible and is not a planned feature.
Pinchflat will check daily for yt-dlp updates, but if you need to run the command manually you can do this:
- Open the Docker console for Pinchflat as root with
docker exec -it --user root pinchflat bash
- NOTE: you may have to sub out the
--user
name or the container name if you've named things differently
- NOTE: you may have to sub out the
- Run
yt-dlp -U
- That's it! There's no need to restart the container