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/local.md

636 lines
23 KiB

3 years ago
# Local Walkthrough
9 months ago
This article will walk you through getting Kometa set up and running. It will cover:
3 years ago
1. Retrieving the Kometa code
2. Installing requirements
3. Setting up the initial config file
4. Creating some sample collections using the defaults
5. Setting up a collection file and creating a sample collection.
6. Adding some default overlays.
3 years ago
The specific steps you will be taking:
1. Verify that the version of Python installed is between 3.9 and 3.13.
2. Verify that the Git tools are installed and install them if not
3. Use `git` to retrieve the code
4. Install requirements [extra bits of code required for Kometa]
5. Gather two things that the script requires:
- TMDb API Key
- Plex URL and Token
6. Then, iteratively:
- use `python` to run the script
- use a text editor to modify a couple of text files until you have a working config file and a single working collection file.
9 months ago
Note that running a Python script is inherently a pretty technical process. If you are unable or unwilling to learn the rudiments of using tools like python and git, you should probably strongly consider running Kometa in [Docker](docker.md). That will eliminate the Python and git installs from this process and make it as simple as it can be.
9 months ago
If the idea of editing YAML files by hand is daunting, this may not be the tool for you. All the configuration of Kometa is done via YAML text files, so if you are unable or unwilling to learn how those work, you should stop here.
9 months ago
Finally, this walkthrough is intended to give you a basic grounding in how to get the script running. It doesn't cover how to create your own collections, or how to add overlays, or any of the myriad other things Kometa is capable of. It provides a simple "Getting Started" guide for those for whom the standard install instructions make no sense; presumably because you've never run a Python script before.
3 years ago
## Prerequisites.
Nearly anywhere you see
```txt
3 years ago
something like this
```
Thats a command youre going to type or paste into your terminal (OSX or Linux) or Powershell (Windows). In some cases it's displaying *output* from a command you've typed, but the difference should be apparent in context.
???+ warning ""
This walkthrough is going to be pretty pedantic. Im assuming youre reading it because you have no idea how to get a Python script going, so Im proceeding from the assumption that you want to be walked through every little detail. Youre going to deliberately cause errors and then fix them as you go through it. This is to help you understand what exactly is going on behind the scenes so that when you see these sorts of problems in the wild you will have some background to understand whats happening. If I only give you the happy path, then when you make a typo later on youll have no idea where that typo might be or why its breaking things.
I am assuming you do not have any of these tools already installed. When writing this up I started with a brand new Windows 10 install.
3 years ago
This walkthrough involves typing commands into a command window. On Mac OS X or Linux, you can use your standard terminal window, whether that's the builtin Terminal app or something like iTerm. On Windows, you should use PowerShell. There are other options for command windows in Windows, but if you want this to work as written, which I assume is the case since you've read this far, you should use Powershell.
3 years ago
???+ danger "Important"
3 years ago
9 months ago
This walkthrough is assuming you are doing the entire process on the same platform; i.e. you're installing Kometa and editing its config files on a single Linux, Windows, or OS X machine. It doesn't account for situations like running Kometa on a Linux machine while editing the config files on your Windows box.
### Prepare a small test library [optional]
{%
include-markdown "./wt/wt-test-library.md"
%}
### Starting up your terminal.
3 years ago
Since most of this is typing commands into a terminal, you'll need to have a terminal open.
3 years ago
=== ":fontawesome-brands-linux: Linux"
If your Linux system is remote to your computer, connect to it via SSH. That SSH session is the terminal you will be using, so leave it open.
If you are running this on a desktop Linux machine, start up the Terminal application. That window will be the terminal you will type commands into throughout this walkthrough, so leave it open.
=== ":fontawesome-brands-apple: macOS"
Open the Terminal app; this window will be the place you type commands throughout this walkthrough, so leave it open. The Terminal app is in Applications -> Utilities.
3 years ago
You can also use iTerm or some other terminal app if you wish. If you don't know what that means, use Terminal.
=== ":fontawesome-brands-windows: Windows"
Use the Start menu to open PowerShell. This will be the window into which you type commands throughout this walkthrough, so leave it open.
3 years ago
### Installing Python.
In order to run a Python script. the first thing you'll need is a Python interpreter. This is typically already present on Linux and Mac, but will probably have to be installed on Windows.
First let's check if it's installed already [type this into your terminal]:
``` { .shell }
python3 --version
```
If this doesn't return a version between `3.9` and `3.13`, you'll need to installed a supported version of Python.
=== ":fontawesome-brands-linux: Linux"
Describing a python install for any arbitrary linux is out of scope here, but if you're using Ubuntu, [this](https://techviewleo.com/how-to-install-python-on-ubuntu-linux/) might be useful.
=== ":fontawesome-brands-apple: macOS"
Follow the instructions here: [Installing Python 3 on Mac OS X](https://docs.python-guide.org/starting/install3/osx/)
=== ":fontawesome-brands-windows: Windows"
Before installing Python, try again without the `3`:
3 years ago
```
python --version
```
Depending on the version of Python, you may need to use one or the other. If this works, you're ready to go, just substitute `python` for `python3` in the couple places it appears below.
Go to http://www.python.org/download and download Python 3.13. **Kometa has not been tested and may be non-functional on any version of Python beyond 3.13**
Once downloaded, run the installer. Tick “Add to path” checkbox at the bottom and click “Install Now”.
For Windows 10, you will need to enable scripts in PowerShell. Follow the instructions [here](https://windowsloop.com/enable-powershell-scripts-execution-windows-10) to do so. If you skip this step you're going to hit a hard stop in a moment.
3 years ago
---
### Installing git
9 months ago
To copy the Kometa code to your machine, we'll be using git. This may be installed on Mac or Linux, and probably isn't in Windows.
First let's check if it's installed already [type this into your terminal]:
``` { .shell }
git --version
```
If this doesn't return a version number, you'll need to get git installed.
=== ":fontawesome-brands-linux: Linux"
3 years ago
The git install is discussed here: [Download for Linux and Unix](https://git-scm.com/download/linux)
3 years ago
=== ":fontawesome-brands-apple: macOS"
The git install is discussed here: [Git - Downloading Package](https://git-scm.com/download/mac)
=== ":fontawesome-brands-windows: Windows"
Download the installer from [here](https://git-scm.com/download/windows)
Run the install; you can probably just accept the defaults and click through except for the step that asks you to choose an editor; you probably want to choose something other than the default there:
![Git Install](images/wt-git-install.png)
This install comes with its own command line interface. **Do not use this interface in this walkthrough**. Continue to do everything here in Powershell.
3 years ago
---
9 months ago
### Retrieving the Kometa code
3 years ago
Now we're going to use `git` to make a copy of the code on your local computer.
Clone the repo into your home directory and go into that directory [type this into your terminal]:
3 years ago
``` { .shell }
3 years ago
cd ~
9 months ago
git clone https://github.com/Kometa-Team/Kometa
cd Kometa
3 years ago
```
Now `git checkout` to the branch reflecting the version of the wiki you are reading, as some functionality may be dependent on this. If you are reading the latest version of the wiki, no `git checkout` is required.
=== ":fontawesome-brands-github: develop"
git checkout develop
=== ":fontawesome-brands-github: nightly"
git checkout nightly
**NOTE: The rest of this walkthrough assumes you are staying in this directory in this terminal/Powershell window.**
9 months ago
**IMPORTANT: In the future, when you want to run Kometa at the command line, you have to be in this directory.**
9 months ago
When you open a command window to run Kometa, the first step will always be:
``` { .shell }
cd ~
9 months ago
cd Kometa
```
9 months ago
There are parts of the code that are assuming and expecting that you will be in this directory when you run Kometa [the fonts used in overlays are one example]. Be sure that you are always in this directory when you run Kometa.
<details>
<summary>What did that do?</summary>
``` { .shell }
cd ~
```
This changes to your home directory, which will be something like `/home/yourname` or `/Users/yourname` or `C:\Users\YourName` depending on the platform.
``` { .shell }
9 months ago
git clone https://github.com/Kometa-Team/Kometa
```
9 months ago
This uses `git` to make a copy of (`clone`) the Kometa code from where it is stored on `github`.
``` { .shell }
9 months ago
cd Kometa
```
This moves into the directory that was created by the `clone` command.
</details>
3 years ago
Later on you can move it elsewhere if you want, but for now put it there. This will ensure that everything to follow works just like it says here. Presumably youre reading this because the other docs are unclear to you. Dont make unilateral changes to my assumptions while doing this.
<details>
<summary>Why use git instead of downloading the release ZIP?</summary>
Retrieving the code with `git` makes updating simpler. When you want to update to the newest version, you can go into this directory and type:
``` { .shell }
3 years ago
git pull
```
No need to download a new ZIP, decompress it, etc.
Also, if you are asked to [or want to] switch to the latest develop or nightly code, you can do so with:
``` { .shell }
3 years ago
git checkout develop
```
``` { .shell }
git checkout nightly
```
3 years ago
</details>
---
### Setting up a virtual environment
This walkthrough is going to use a "virtual environment", since that provides a simple way to keep the requirements for a given thing self-contained; think of it as a "sandbox" for this script. It also provides a clean way to recover from mistakes, and keeps the host system clean.
=== ":fontawesome-brands-linux: Linux"
[type this into your terminal]
``` { .shell }
9 months ago
python3 -m venv kometa-venv
```
If you see an error like:
``` { .shell .nocopy }
9 months ago
Error: Command '['/home/mroche/Kometa/kometa-venv/bin/python3', '-Im', 'ensurepip', '--upgrade', '--default-pip']' returned non-zero exit status 1.
```
You probably need to make sure the Python 3.9-specific virtualenv support library is installed:
[type this into your terminal]
``` { .shell }
sudo apt-get install python3.9-venv
```
Then try the original venv command above again.
=== ":fontawesome-brands-apple: macOS"
[type this into your terminal]
``` { .shell }
9 months ago
python3 -m venv kometa-venv
```
=== ":fontawesome-brands-windows: Windows"
[type this into your terminal]
``` { .shell }
9 months ago
python -m venv kometa-venv
```
If you see:
``` { .shell .nocopy }
Python was not found; run without arguments to install from the Microsoft Store, or disable this shortcut from Settings > Manage App Execution Aliases.
```
You apparently didn't check the “Add to path” checkbox above under [installing Python](#installing-python). "Repair" your Python install and check "add python to environment variables".
3 years ago
<details>
<summary>What did that do?</summary>
``` { .shell }
9 months ago
python3 -m venv kometa-venv
```
9 months ago
This tells Python3 to use the `venv` module to create a virtual environment called `kometa-venv`. The only visible effect will be the creation of a `kometa-venv` directory.
</details>
That command will not produce any output if it works; it will display an error if a problem occurs. If everything is fine, you will be looking at something like this:
``` { .shell .nocopy}
9 months ago
> python -m venv kometa-venv
>
```
If you aren't looking at an error, you're ready to move on.
3 years ago
That will create the virtual environment, and then you need to activate it:
=== ":fontawesome-brands-linux: Linux"
[type this into your terminal]
``` { .shell }
9 months ago
source kometa-venv/bin/activate
```
=== ":fontawesome-brands-apple: macOS"
[type this into your terminal]
``` { .shell }
9 months ago
source kometa-venv/bin/activate
```
=== ":fontawesome-brands-windows: Windows"
[type this into your terminal]
```
9 months ago
.\kometa-venv\Scripts\activate
```
If you see something like this:
```powershell
9 months ago
.\kometa-venv\Scripts\activate : File C:\Users\mroche\Kometa\kometa-venv\Scripts\Activate.ps1 cannot be loaded because running scripts is disabled on this system. For more information, see about_Execution_Policies at https:/go.microsoft.com/fwlink LinkID=135170.
At line:1 char:1
9 months ago
+ .\kometa-venv\Scripts\activate
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : SecurityError: (:) [], PSSecurityException
+ FullyQualifiedErrorId : UnauthorizedAccess
```
You apparently skipped the "enable scripts in Powershell" step above under [installing Python](#installing-python) for Windows.
You will need to take care of that before moving on. Follow the instructions [here](https://windowsloop.com/enable-powershell-scripts-execution-windows-10).
Once you have done that, try the activation step again.
That command will not produce any output if it works; it will display an error if a problem occurs.
You may see a change in your prompt, something like this:
``` { .shell }
9 months ago
➜ Kometa git:(master) ✗ source kometa-venv/bin/activate
(kometa-venv) ➜ Kometa git:(master) ✗
```
9 months ago
Note that the prompt now shows the name of the virtual environment. You may not see this; it's dependent on *your* terminal configuration, not anything to do with Python or Kometa.
<details>
<summary>What did that do?</summary>
9 months ago
This tells Python to make the virtual environment "active", which means to use the copy of python that is available there, install all support libraries there, etc. This keeps the Kometa code and its runtime environment totally separate from your host machine's environment.
3 years ago
</details>
9 months ago
An advantage of doing this in a virtual environment is that in the event something goes wrong with this part of the setup, you can delete that kometa-venv directory and do the setup again.
3 years ago
**IMPORTANT: In the future, when you want to run the script, you will need to do this "activation" step every time. Not the venv creation, just the activation**:
=== ":fontawesome-brands-linux: Linux"
[type this into your terminal]
``` { .shell }
9 months ago
source kometa-venv/bin/activate
```
=== ":fontawesome-brands-apple: macOS"
[type this into your terminal]
``` { .shell }
9 months ago
source kometa-venv/bin/activate
```
=== ":fontawesome-brands-windows: Windows"
[type this into your terminal]
```
9 months ago
.\kometa-venv\Scripts\activate
```
3 years ago
### Installing requirements
9 months ago
Kometa, like every other Python script, depends on support libraries that manage things like connections to Plex, or getting things from the internet, or writing files and so on.
3 years ago
These support libraries are called “requirements”, and they are defined in that file called `requirements.txt`. To install them, type the following command [type this into your terminal]:
3 years ago
``` { .shell }
3 years ago
python -m pip install -r requirements.txt
```
You should see something like this [Ive removed a few lines for space, and the specific versions may have changed since this was captured]:
``` { .shell .nocopy }
3 years ago
Collecting PlexAPI==4.7.0
Downloading PlexAPI-4.7.0-py3-none-any.whl (133 kB)
|████████████████████████████████| 133 kB 821 kB/s
Collecting tmdbv3api==1.7.6
Downloading tmdbv3api-1.7.6-py2.py3-none-any.whl (17 kB)
...
Installing collected packages: urllib3, idna, charset-normalizer, certifi, six, ruamel.yaml.clib, requests, tmdbv3api, tenacity, ruamel.yaml, tenacity, PlexAPI, pillow, pathvalidate, lxml, arrapi
Running setup.py install for tenacity ... done
3 years ago
Running setup.py install for arrapi ... done
Successfully installed PlexAPI-4.7.0 arrapi-1.1.3 certifi-2021.10.8 charset-normalizer-2.0.7 idna-3.3 lxml-4.6.3 pathvalidate-2.4.1 pillow-8.3.2 requests-2.26.0 tenacity-8.3.0 ruamel.yaml-0.17.10 ruamel.yaml.clib-0.2.6 tenacity-8.3.0 six-1.16.0 tmdbv3api-1.7.6 urllib3-1.26.7
3 years ago
WARNING: You are using pip version 21.1.3; however, version 21.3 is available.
9 months ago
You should consider upgrading via the '/Users/mroche/Kometa/kometa-venv/bin/python -m pip install --upgrade pip' command.
3 years ago
```
Don't worry about the WARNING about `pip version thus-and-such` if it comes up.
3 years ago
<details>
<summary>`Encountered error while trying to install package.`</summary>
<br />
If you see an error that ends in something like this:
``` { .shell .nocopy }
...
building 'lxml.etree' extension
error: Microsoft Visual C++ 14.0 or greater is required. Get it with "Microsoft C++ Build Tools": https://visualstudio.microsoft.com/visual-cpp-build-tools/
[end of output]
note: This error originates from a subprocess, and is likely not a problem with pip.
error: legacy-install-failure
× Encountered error while trying to install package.
╰─> lxml
```
You've hit the error we were referring to above with the Python version being too recent. Probably you are running Python 3.11 in late 2022 or Python 3.12 shortly after its release. Deactivate and delete the virtual environment and create one based on the previous Python release [which may involve removing Python and reinstalling the older version depending on platform], then try this step again.
</details>
<details>
<summary>What did that do?</summary>
9 months ago
This told Python to use the `pip` module to install some libraries that Kometa needs.
</details>
### Verify install and create config template
Running the script at this point will verify that all is well and will create a template config for you to start with.
3 years ago
{%
include-markdown "./wt/wt-run-shell.md"
%}
3 years ago
You should see something like this:
``` { .shell .nocopy }
Configuration file (config.yml) created at /SOME/PATH/TO/Kometa/config/config.yml. Please open this file and update it with your API keys and other required settings.
3 years ago
```
If, instead, you see something like:
``` { .shell .nocopy }
Traceback (most recent call last):
File "/some/path/to/Kometa/kometa.py", line 1, in <module>
import argparse, os, platform, re, sys, time, uuid, requests
ModuleNotFoundError: No module named 'requests'
3 years ago
```
You either haven't activated the virtual environment OR you haven't installed the requirements [OR you've done both these things but you installed the requirements outside the virtual environment]. Review the previous two steps.
3 years ago
### Create a directory to quiet an error later
3 years ago
The default config file contains a reference to a directory that will show an error in the output later. That error can safely be ignored, but it causes some confusion with new users from time to time.
3 years ago
We'll create it here so the error doesn't show up later.
3 years ago
=== ":fontawesome-brands-linux: Linux"
[type this into your terminal]
``` { .shell }
mkdir config/assets
```
=== ":fontawesome-brands-apple: macOS"
[type this into your terminal]
``` { .shell }
mkdir config/assets
```
=== ":fontawesome-brands-windows: Windows"
[type this into your terminal]
```
mkdir config\assets
```
3 years ago
### Setting up the initial config file
3 years ago
{%
include-markdown "./wt/wt-01-basic-config.md"
%}
3 years ago
#### Editing the config file
Open the config file in an editor:
3 years ago
{% include-markdown "./wt/wt-editor.md" %}
3 years ago
{% include-markdown "./wt/wt-02-config-bad-library.md" %}
3 years ago
#### Testing the config file
3 years ago
Save the file:
3 years ago
{% include-markdown "./wt/wt-save.md" %}
3 years ago
9 months ago
Then run Kometa again:
{% include-markdown "./wt/wt-run-shell.md" %}
{% include-markdown "./wt/wt-03-lib-err-and-fix.md" %}
### Creating a few sample collections
{% include-markdown "./wt/wt-04-default-intro.md" %}
9 months ago
So let's run Kometa and see this happen:
{% include-markdown "./wt/wt-run-shell.md" %}
{% include-markdown "./wt/wt-04b-default-after.md" %}
### Setting up a collection file and creating a sample collection
{% include-markdown "./wt/wt-05-local-file.md" %}
3 years ago
Save the file:
3 years ago
{% include-markdown "./wt/wt-save.md" %}
3 years ago
9 months ago
Then run Kometa again:
3 years ago
{% include-markdown "./wt/wt-run-shell.md" %}
3 years ago
{% include-markdown "./wt/wt-06-local-after.md" %}
3 years ago
### Adding Overlays to movies
3 years ago
{% include-markdown "./wt/wt-07-overlay-add.md" %}
3 years ago
Save the file:
3 years ago
{% include-markdown "./wt/wt-save.md" %}
3 years ago
9 months ago
Then run Kometa again:
3 years ago
{% include-markdown "./wt/wt-run-shell.md" %}
3 years ago
{% include-markdown "./wt/wt-08-overlay-after.md" %}
{% include-markdown "./wt/wt-09-next-steps.md" %}
3 years ago
When you are done, deactivate the virtual environment:
[type this into your terminal]
``` { .shell }
3 years ago
deactivate
```
## Other Topics
3 years ago
### Scheduling
{%
include-markdown "./wt/wt-10-scheduling.md"
%}
9 months ago
### I want to update to the latest version of Kometa
3 years ago
=== ":fontawesome-brands-linux: Linux"
[type this into your terminal]
``` { .shell }
9 months ago
cd ~/Kometa
git pull
9 months ago
source kometa-venv/bin/activate
python -m pip install -r requirements.txt
```
=== ":fontawesome-brands-apple: macOS"
[type this into your terminal]
``` { .shell }
9 months ago
cd ~/Kometa
git pull
9 months ago
source kometa-venv/bin/activate
python -m pip install -r requirements.txt
```
=== ":fontawesome-brands-windows: Windows"
[type this into your terminal]
```
9 months ago
cd ~\Kometa
git pull
9 months ago
.\kometa-venv\Scripts\activate
python -m pip install -r requirements.txt
```
3 years ago
### I want to use the develop branch
3 years ago
=== ":fontawesome-brands-linux: Linux"
[type this into your terminal]
``` { .shell }
9 months ago
cd ~/Kometa
git checkout develop
git pull
9 months ago
source kometa-venv/bin/activate
python -m pip install -r requirements.txt
```
=== ":fontawesome-brands-apple: macOS"
[type this into your terminal]
``` { .shell }
9 months ago
cd ~/Kometa
git checkout develop
git pull
9 months ago
source kometa-venv/bin/activate
python -m pip install -r requirements.txt
```
=== ":fontawesome-brands-windows: Windows"
[type this into your terminal]
```
9 months ago
cd ~/Kometa
git checkout develop
git pull
9 months ago
.\kometa-venv\Scripts\activate
python -m pip install -r requirements.txt
```
3 years ago
### I want to use the nightly branch
3 years ago
Follow the instructions for the `develop` branch above, substituting `nightly` for `develop`
3 years ago
### I want to use the master branch
Follow the instructions for the `develop` branch above, substituting `master` for `develop`
3 years ago
The installation of requirements every time is probably overkill, but it's harmless and ensures that you always get any new versions or new requirements.