You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Plex-Meta-Manager/docs/kometa/install/files.md

7.3 KiB

Configuration Files

Kometa is configured via YAML files. These files are used to define the various components of Kometa. The configuration files are stored in the /config directory of the Kometa container.

There is one required configuration file, config.yml, and several optional configuration files.

config.yml

config.yml is the main [and only required] configuration file for Kometa. This is where you configure global settings like your Plex server details, the libraries you want Kometa to act on, any external services you want to use, and other global settings.

Collections, overlays, and metadata changes are not defined in config.yml. These are defined in separate files.

Generally speaking, things that are documented as being part of the config.yml file can only be in the config.yml file. Things that are documented as being in other files can only be in those files.

There are a few exceptions to this general rule, but those exceptions are for the most part settings that override values that have been specified in the config.yml. For example, config.yml contains a default collection_order, and a collection file can override that order. "Larger" things like collection definitions can only be in collection files.

The Kometa Defaults

One thing that seems like a bit of an exception are the defaults. These are linked with libraries in the config.yml file and are customized with template variables in the config.yml file, a system which is generally unique to the defaults.

There are defaults that create collections, overlays, and playlists. There are no default metadata files.

The defaults are referenced in the config.yml under a library with the default file type:

libraries:
  Movies:
    collection_files:
      - default: imdb
      - default: genre
    overlay_files:
      - default: resolution
      - default: ribbon

Typically, the defaults can be customized with template variables:

libraries:
  Movies:
    collection_files:
      - default: imdb
        template_variables:
          use_lowest: false 
      - default: genre
        template_variables:
          sep_style: red 
    overlay_files:
      - default: resolution
        template_variables:
          use_576p: false
          use_480p: false
      - default: ribbon
        template_variables:
          style: black
          weight_metacritic: 35
          use_common: false

The specifics of what template variables are available for a given default are found on the wiki page for each default, which you can find starting here.

Like the rest of the external files, these default references cannot be moved out of the config.yml file.

???+ tip

Why can't I move the defaults out of the `config.yml` file?

This:
```yaml
    - default: whatever
```
is shorthand for:
```yaml
    - file: internal/path/to/whatever.yml
```
So, like any other file reference [`file`,`folder`,`url`,`git`,`repo`], it can't be moved out of the `config.yml` file.

Collection files

Collections are defined in separate collection files. They can be used to create collections of movies, TV shows, or music. They can also be used to apply labels or make other changes to items based on builders without actually creating collections.

A collection file can contain one or more collections.

Collection files are optional; you may not want or need any of your own if you are leveraging the defaults.

The simplest collection file would look like this:

collections: 
  Top 50 Grossing Films of All Time (Worldwide):
    tmdb_list: 10 

One collection with a name and a builder that defines the criteria for the collection.

That would go in a file like config/my-neat-collection.yml and be referenced in the config.yml file like this:

libraries:
  Movies:
    collection_files:
      - file: config/my-neat-collection.yml

Overlay files

The next most frequently used file type is the overlay file. Overlays are used to apply graphic overlays to your posters in Plex.

A minimal overlay file would look like this:

overlays:
  4K:
    plex_search:
      all:
        resolution: 4K

One overlay with a name and a builder that defines the criteria for the collection.

This would go in a file like config/my-neat-overlay.yml and be referenced in the config.yml file like this:

libraries:
  Movies:
    overlay_files:
      - file: config/my-neat-overlay.yml

Metadata files

Probably the most uncommon library-level file type is the metadata file. Metadata files are used to apply metadata changes to your items in Plex; these are things like changing the year, the title, the artwork, the summary, etc.

Metadata files don't use builders; they use a different format. A minimal metadata file would look like this:

metadata:
  Godzilla (1954):
    match:
      title: Godzilla
      year: 1954
    content_rating: R

One metadata change [content_rating] with a name and a match criteria.

Metadata files use the criteria in the match key to find individual items (like this one which finds a movie titled "Godzilla" released in 1954), and then the specified changes [in this case setting the content rating to R] are applied to the [probably one] thing that matches the criteria.

This would go in a file like config/my-neat-metadata.yml and be referenced in the config.yml file like this:

libraries:
  Movies:
    metadata_files:
      - file: config/my-neat-metadata.yml

Playlist files

Playlists are defined in separate playlist files. They can be used to create playlists of movies, TV shows, or music.

Playlists are defined in a similar way to collections, but they can span libraries, where collections are library-specific.

A playlist file can contain one or more playlists.

The simplest playlist file would look like this:

playlists: 
  Marvel Cinematic Universe Chronological Order:
    trakt_list: https://trakt.tv/users/donxy/lists/marvel-cinematic-universe

One playlist with a name and a builder that produces the list of items to put in the playlist.

Kometa defaults to pulling items for the playlist from two libraries with specific names: Movies and TV Shows. If you want to pull from different libraries [if, for example your libraries are not named Movies and TV Shows], you can specify that in the playlist file.

playlists: 
  Marvel Cinematic Universe Chronological Order:
    libraries: My Movie Library, My TV Library, My 4K Library  
    trakt_list: https://trakt.tv/users/donxy/lists/marvel-cinematic-universe

This would go in a file like config/my-neat-playlist.yml and be referenced in the config.yml file like this:

libraries:
  Movies:
...
  TV Shows:
...
playlist_files:
  - file: config/my-neat-playlist.yml

Note that the playlist_files key is at the top level of the config.yml file, not under a specific library. This is because playlists can span libraries.