Seasonwatch is an application that helps you keep track of when new seasons of your favorite TV shows are released. Streaming services will sometimes try to deduce what shows you are interested in and highlight them for you when there is a new season, but Seasonwatch will do it completely deterministically – and you don't even have to be subscribed to any streaming service. Just let it run regularly (e.g. through cron) and you will have complete control of your watchlist!
- Python >= 3.10
libgirepository
(Arch Linux, Ubuntu) (for showing notifications)
Download the wheel from the release page here on GitHub and install it with:
$ pip install seasonwatch-<the version you want to install>-py3-none-any.whl
Alternatively, clone the repository and run the following in it:
$ poetry build
$ pip install dist/<your newly built package>
You can also run it using poetry directly if you just want to try it:
$ poetry run seasonwatch
In order to use Seasonwatch, you need to have a TMDB API Read Access Token.
Getting one is free, and you get it by registering on
https://www.themoviedb.org and then creating an API key according to the
documentation. Creating an API key also
gives you an API Read Access Token. Once you have it, manually edit your
configuration file (usually ~/.config/seasonwatchrc
) or run:
$ seasonwatch configure
TMDB API Read Access Token: <your token, then Enter>
Testing token...
Token is valid!
Write new config file, losing all comments? (Y/n): <Y>
Successfully set TMDB token!
You can interactively add a new TV show to your database by running the below command. You'll be prompted to fill in the title of the TV show, the ID, and the last season you've seen. For example, if you've just watched season 3 of The Expanse and want to be notified when the next season is released, you'd fill in it like so:
$ seasonwatch tv --add
What the show should be called: The Expanse
ID of the show (after 'tv/' in the URL on TMDB): 63639
Last watched season: 3
title: The Expanse
TMDB ID: 63639
Last watched season: 3
Does this look ok? (Y/n) Y
Add more shows? (y/N)
You can use anything you want as the title. The ID is in the URL of the TV show on TMDB. In this case, the page on TMDB for the TV show is: https://www.themoviedb.org/tv/63639-the-expanse
The ID is the number that comes after tv/
in the URL, and before the title of
the TV show. That is, "63639".
You can verify that the TV show is added to the database by running:
$ seasonwatch tv --list
┌────────────────────────────────┬─────────────────────┬──────────────────────────────────────┐
│ Title │ Last watched season │ Hyperlink │
├────────────────────────────────┼─────────────────────┼──────────────────────────────────────┤
│ The Expanse │ 3 │ https://www.themoviedb.org/tv/63639 │
└────────────────────────────────┴─────────────────────┴──────────────────────────────────────┘
Just run Seasonwatch like so:
$ seasonwatch
Season 4 of The Expanse is out already!
You will be shown notifications for shows that are already out or coming out soon, and the information for all shows in your database will be printed on the command line. It might be a good idea to automate the running of the script with a cron job that runs it regularly. Even when run in the background, Seasonwatch will show you desktop notifications.
The IMDb API is no longer working, so from version 0.3.0 onward, TMDB is used instead. If your database was created before then, you will be asked to migrate when running Seasonwatch for the first time after installing the new version. There is a helper that will suggest corresponding TMDB IDs for your old shows.
Seasonwatch currently supports checking for new TV show seasons only. Version 0.3.0 has been released and is ready to be used for this purpose.
Report bugs under the issues tab here on GitHub.
The release process is automated and happens through the Release workflow. It just needs to be triggered by pushing a tag. Instructions for creating a release:
- Create a pull request toward the
dev
branch with a step-up commit that bumps the version and updates the changelog if necessary. Merge it. - Create a pull request from the
dev
branch toward themain
branch and merge that. - Create an annotated tag on the
main
branch:git tag -am "Step up Seasonwatch to version X.Y.Z" vX.Y.Z
. - Push the tag:
git push --tags origin vX.Y.Z
. - Verify that the Release workflow is triggered and succeeds.