Skip to main content

A utility to trigger Plex partial-scans on NFS configurations, on which inotify is not supported

Project description


Preview

Plex NFS Watchdog

A utility to trigger Plex partial-scans on NFS configurations, on which inotify is not supported



Table of Contents
  1. 📖 About The Project
  2. ⚙️ Getting Started
  3. 💫 Contributing
  4. 🤝 Support
  5. ⚠️ License
  6. 🛠️ Built With

:book: About The Project

Inotify is a Linux kernel subsystem that allows monitoring changes to files and directories in real-time. It is commonly used by applications to watch for changes in files or directories and respond accordingly.

Plex makes use of inotify to perform partial scans when a file is added or removed from a directory. This allows Plex to update its library without having to perform a full scan.

Running Plex Media Server with the library located on Network File System (NFS) mounted directories will not trigger such partial scans because inotify doesn't work on NFS. When a file is changed on an NFS mount, it doesn't trigger an inotify event on the client side.

Plex NFS Watchdog is a utility that can be installed on the machine that produces inotify to monitors directories for changes and triggers a partial scan on the Plex Media Server instance installed in a different machine when a change is detected by invoking the Plex API.

(back to top)

:gear: Getting Started

To use Plex NFS Watchdog you must ensure that on all machines involved the Plex's Library sections use the same folder name. The folder path can be different on each machine, but the folder name must be the same.

This is important because the utility will use the folder name to trigger the partial scan.

For example, if you have a library section called "Movies" and the folder name is "Movies", the utility will trigger a partial scan on the "Movies" library section when a change is detected in the "Movies" folder.

(back to top)

Prerequisites

Obtain the Plex Authentication Token for your Plex Media Server instance. You can find instructions on how to do this here.

(back to top)

Installation

You can install this tool as a Python Module using pip or executing the script directly.

  • If you want to install the tool as a Python Module:
    • Install the module using pip: pip install plex-nfs-watchdog
    • You can run the tool using: plex-nfs-watchdog
  • If you want to use the script directly:
    • Clone the repository anywhere on your pc:

      git clone https://github.com/LightDestory/PlexNFSWatchdog

    • Install the requirements using pip (create a venv if you want):

      pip install -r requirements.txt

    • Run directly from source:

      python ./src/plex_nfs_watchdog/plex_nfs_watchdog.py

(back to top)

Docker Support

You can also run this tool using Docker Compose.

  • Clone the repository:

    • Download the project by running:
      git clone https://github.com/LightDestory/PlexNFSWatchdog
      cd PlexNFSWatchdog
      
  • Create a .env file in the root of the project:

    • You can use the provided .env.example file as a reference and rename/copy it to .env.
    • Define the necessary environment variables such as your Plex server address, token, paths to watch, scan interval, and event listeners. See Usage for more details on what to set these variables to.
  • Modify compose.yml to match your setup:

    • Ensure the volume paths correctly map to your actual media directories, the same ones you've specified to be watched in the .env file.
  • Build and start the container:

    • Run the following command to start the service in detached mode:

      docker compose up -d --build
      
    • Check logs to monitor the process:

      docker logs -f plexnfswatchdog
      
    • Restart the container if needed:

      docker compose restart plexnfswatchdog
      
    • Stop and remove the container:

      docker compose down
      

(back to top)

Usage

This utility requires the following arguments to work:

Argument Role
--scan | -s Manually triggers a partial-scan on the given paths
--daemon | -d Starts a watchdog daemon to automatically triggers a partial-scan on the given paths
Requires: --interval and --listeners
--paths | -p [PATHS...] A list of folder paths
--host | -H HOST The host of the Plex server
Default: http://localhost:32400
--token | -t TOKEN The token of the Plex server
--interval | -i INTERVAL [OPTIONAL] The interval in seconds to wait between partial-scans. Defaults to 60
--listeners | -l [LISTENERS...] [OPTIONAL] The event type to watch: move, modify, create, delete, io_close, io_open
--allow-folder Allow folder events to trigger the daemon mode. Defaults to False
--always-overwrite-config Always overwrite the config file with the provided host and token if they are different. Defaults to False
  • Manual Scan example:
    plex-nfs-watchdog --scan --paths /path/to/library_section1/section_chield1 --host http://localhost:32400 --token YOUR_TOKEN
  • Daemon Scan example:
    plex-nfs-watchdog --daemon --paths /path/to/library_section1 --host http://localhost:32400 --token YOUR_TOKEN --interval 150 --listeners move modify create delete

(back to top)

Notes

After the first successful run, a cache config file containing Plex's host and token will be created in the user's home directory. This file will be used for subsequent runs, so you don't have to provide them every time.

(back to top)

:dizzy: Contributing

If you are interested in contributing, please refer to Contributing Guidelines for more information and take a look at open issues. Ask any questions you may have and you will be provided guidance on how to get started.

Thank you for considering contributing.

(back to top)

:handshake: Support

If you find value in my work, please consider making a donation to help me create, and improve my projects.

Your donation will go a long way in helping me continue to create free software that can benefit people around the world.

Buy Me a Hot Chocolate at ko-fi.com

(back to top)

:warning: License

The content of this repository is distributed under the GNU GPL-3.0 License. See LICENSE for more information.

(back to top)

:hammer_and_wrench: Built With

(back to top)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

plex_nfs_watchdog-0.0.16.tar.gz (26.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

plex_nfs_watchdog-0.0.16-py3-none-any.whl (25.0 kB view details)

Uploaded Python 3

File details

Details for the file plex_nfs_watchdog-0.0.16.tar.gz.

File metadata

  • Download URL: plex_nfs_watchdog-0.0.16.tar.gz
  • Upload date:
  • Size: 26.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for plex_nfs_watchdog-0.0.16.tar.gz
Algorithm Hash digest
SHA256 15b428ef9ceed10428d32d3be155e5f5abca8e3d3d3e6fb0ddbaebb851039331
MD5 2f9915857ab1d2723baad42d8490e7c3
BLAKE2b-256 bad47e1c31347f7eba8693c5792f2346b8192be20ef755ae59f8c91e2dff58f3

See more details on using hashes here.

Provenance

The following attestation bundles were made for plex_nfs_watchdog-0.0.16.tar.gz:

Publisher: python-publish.yml on LightDestory/PlexNFSWatchdog

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file plex_nfs_watchdog-0.0.16-py3-none-any.whl.

File metadata

File hashes

Hashes for plex_nfs_watchdog-0.0.16-py3-none-any.whl
Algorithm Hash digest
SHA256 1a3e39b9fafdbc77966fddf692c183bfd91a07822f4aea4388eae1a02971fc05
MD5 6a81403588113469057e827bff2cd905
BLAKE2b-256 0c98c3edc0b1994d6ba28a8c2fef70b4a4d1c607d97b63d8ddc80d4e2e0e60b1

See more details on using hashes here.

Provenance

The following attestation bundles were made for plex_nfs_watchdog-0.0.16-py3-none-any.whl:

Publisher: python-publish.yml on LightDestory/PlexNFSWatchdog

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page