{"id":31985703,"url":"https://github.com/fuzzygrim/yamtrack","last_synced_at":"2025-12-28T02:30:52.883Z","repository":{"id":64918379,"uuid":"576455465","full_name":"FuzzyGrim/Yamtrack","owner":"FuzzyGrim","description":"A self hosted media tracker.","archived":false,"fork":false,"pushed_at":"2025-10-14T21:44:01.000Z","size":6373,"stargazers_count":1374,"open_issues_count":195,"forks_count":66,"subscribers_count":7,"default_branch":"dev","last_synced_at":"2025-10-14T23:58:37.853Z","etag":null,"topics":["django","docker","docker-compose","media-tracker","postgresql","self-hosted","sqlite","tailwindcss"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"agpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/FuzzyGrim.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2022-12-09T22:58:21.000Z","updated_at":"2025-10-14T21:44:05.000Z","dependencies_parsed_at":"2023-09-27T02:03:43.703Z","dependency_job_id":"62a399b2-93f8-416e-b9ad-62f3c65d3296","html_url":"https://github.com/FuzzyGrim/Yamtrack","commit_stats":null,"previous_names":[],"tags_count":72,"template":false,"template_full_name":null,"purl":"pkg:github/FuzzyGrim/Yamtrack","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/FuzzyGrim%2FYamtrack","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/FuzzyGrim%2FYamtrack/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/FuzzyGrim%2FYamtrack/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/FuzzyGrim%2FYamtrack/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/FuzzyGrim","download_url":"https://codeload.github.com/FuzzyGrim/Yamtrack/tar.gz/refs/heads/dev","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/FuzzyGrim%2FYamtrack/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":279034316,"owners_count":26089467,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-10-15T02:00:07.814Z","response_time":56,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["django","docker","docker-compose","media-tracker","postgresql","self-hosted","sqlite","tailwindcss"],"created_at":"2025-10-15T06:33:12.981Z","updated_at":"2025-12-28T02:30:52.874Z","avatar_url":"https://github.com/FuzzyGrim.png","language":"Python","readme":"# Yamtrack\n\n![App Tests](https://github.com/FuzzyGrim/Yamtrack/actions/workflows/app-tests.yml/badge.svg)\n![Docker Image](https://github.com/FuzzyGrim/Yamtrack/actions/workflows/docker-image.yml/badge.svg)\n![CodeFactor](https://www.codefactor.io/repository/github/fuzzygrim/yamtrack/badge)\n![Codecov](https://codecov.io/github/FuzzyGrim/Yamtrack/branch/dev/graph/badge.svg?token=PWUG660120)\n![GitHub](https://img.shields.io/badge/license-AGPL--3.0-blue)\n\nYamtrack is a self hosted media tracker for movies, tv shows, anime, manga, video games and books.\n\n## 🚀 Demo\n\nYou can try the app at [yamtrack.fuzzygrim.com](https://yamtrack.fuzzygrim.com) using the username `demo` and password `demo`.\n\n## ✨ Features\n\n- 🎬 Track movies, tv shows, anime, manga, games, books and comics.\n- 📺 Track each season of a tv show individually and episodes watched.\n- ⭐ Save score, status, progress, repeats (rewatches, rereads...), start and end dates, or write a note.\n- 📈 Keep a tracking history with each action with a media, such as when you added it, when you started it, when you started watching it again, etc.\n- ✏️ Create custom media entries, for niche media that cannot be found by the supported APIs.\n- 📂 Create personal lists to organize your media for any purpose, add other members to collaborate on your lists.\n- 📅 Keep up with your upcoming media with a calendar, which can be subscribed to in external applications using a iCalendar (.ics) URL.\n- 🔔 Receive notifications of upcoming releases via Apprise (supports Discord, Telegram, ntfy, Slack, email, and many more).\n- 🐳 Easy deployment with Docker via docker-compose with SQLite or PostgreSQL.\n- 👥 Multi-users functionality allowing individual accounts with personalized tracking.\n- 🔑 Flexible authentication options including OIDC and 100+ social providers (Google, GitHub, Discord, etc.) via django-allauth.\n- 🦀 Integration with [Jellyfin](https://jellyfin.org/), [Plex](https://plex.tv/) and [Emby](https://emby.media/) to automatically track new media watched.\n- 📥 Import from [Trakt](https://trakt.tv/), [Simkl](https://simkl.com/), [MyAnimeList](https://myanimelist.net/), [AniList](https://anilist.co/) and [Kitsu](https://kitsu.app/) with support for periodic automatic imports.\n- 📊 Export all your tracked media to a CSV file and import it back.\n\n## 📱 Screenshots\n\n| Homepage                                                                                       | Calendar                                                                                    |\n| ---------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------- |\n| \u003cimg src=\"https://cdn.fuzzygrim.com/file/fuzzygrim/yamtrack/homepage.png?v2\" alt=\"Homepage\" /\u003e | \u003cimg src=\"https://cdn.fuzzygrim.com/file/fuzzygrim/yamtrack/calendar.png\" alt=\"calendar\" /\u003e |\n\n| Media List Grid                                                                                    | Media List Table                                                                                     |\n| -------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------- |\n| \u003cimg src=\"https://cdn.fuzzygrim.com/file/fuzzygrim/yamtrack/medialist_grid.png\" alt=\"List Grid\" /\u003e | \u003cimg src=\"https://cdn.fuzzygrim.com/file/fuzzygrim/yamtrack/medialist_table.png\" alt=\"List Table\" /\u003e |\n\n| Media Details                                                                                         | Tracking                                                                                    |\n| ----------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------- |\n| \u003cimg src=\"https://cdn.fuzzygrim.com/file/fuzzygrim/yamtrack/media_details.png\" alt=\"Media Details\" /\u003e | \u003cimg src=\"https://cdn.fuzzygrim.com/file/fuzzygrim/yamtrack/tracking.png\" alt=\"Tracking\" /\u003e |\n\n| Season Details                                                                                          | Tracking Episodes                                                                                            |\n| ------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------ |\n| \u003cimg src=\"https://cdn.fuzzygrim.com/file/fuzzygrim/yamtrack/season_details.png\" alt=\"Season Details\" /\u003e | \u003cimg src=\"https://cdn.fuzzygrim.com/file/fuzzygrim/yamtrack/tracking_episode.png\" alt=\"Tracking Episodes\" /\u003e |\n\n| Lists                                                                                 | Statistics                                                                                      |\n| ------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------- |\n| \u003cimg src=\"https://cdn.fuzzygrim.com/file/fuzzygrim/yamtrack/lists.png\" alt=\"Lists\" /\u003e | \u003cimg src=\"https://cdn.fuzzygrim.com/file/fuzzygrim/yamtrack/statistics.png\" alt=\"Statistics\" /\u003e |\n\n| Create Manual Entries                                                                                         | Import Data                                                                                       |\n| ------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------- |\n| \u003cimg src=\"https://cdn.fuzzygrim.com/file/fuzzygrim/yamtrack/create_custom.png\" alt=\"Create Manual Entries\" /\u003e | \u003cimg src=\"https://cdn.fuzzygrim.com/file/fuzzygrim/yamtrack/import_data.png\" alt=\"Import Data\" /\u003e |\n\n## 🐳 Installing with Docker\n\nCopy the default `docker-compose.yml` file from the repository and set the environment variables. This would use a SQlite database, which is enough for most use cases.\n\nTo start the containers run:\n\n```bash\ndocker-compose up -d\n```\n\nAlternatively, if you need a PostgreSQL database, you can use the `docker-compose.postgres.yml` file.\n\n### 🌊 Reverse Proxy Setup\n\nWhen using a reverse proxy, if you see a `403 - Forbidden` error, you need to set the `URLS` environment variable to the URL you are using for the app.\n\n```bash\nservices:\n  yamtrack:\n    ...\n    environment:\n      - URLS=https://yamtrack.mydomain.com\n    ...\n```\n\nNote that the setting must include the correct protocol (`https` or `http`), and must not include the application `/` context path. Multiple origins can be specified by separating them with a comma (`,`).\n\n### ⚙️ Environment variables\n\nFor detailed information on environment variables, please refer to the [Environment Variables wiki page](https://github.com/FuzzyGrim/Yamtrack/wiki/Environment-Variables).\n\n## 💻 Local development\n\nClone the repository and change directory to it.\n\n```bash\ngit clone https://github.com/FuzzyGrim/Yamtrack.git\ncd Yamtrack\n```\n\nInstall Redis or spin up a bare redis container:\n\n```bash\ndocker run -d --name redis -p 6379:6379 --restart unless-stopped redis:8-alpine\n```\n\nCreate a `.env` file in the root directory and add the following variables.\n\n```bash\nTMDB_API=API_KEY\nMAL_API=API_KEY\nIGDB_ID=IGDB_ID\nIGDB_SECRET=IGDB_SECRET\nSTEAM_API_KEY=STEAM_API_SECRET\nSECRET=SECRET\nDEBUG=True\n```\n\nThen run the following commands.\n\n```bash\npython -m pip install -U -r requirements-dev.txt\ncd src\npython manage.py migrate\npython manage.py runserver \u0026 celery -A config worker --beat --scheduler django --loglevel DEBUG \u0026 tailwindcss -i ./static/css/input.css -o ./static/css/tailwind.css --watch\n```\n\nGo to: http://localhost:8000\n\n## 💪 Support the Project\n\nThere are many ways you can support Yamtrack's development:\n\n### ⭐ Star the Project\n\nThe simplest way to show your support is to star the repository on GitHub. It helps increase visibility and shows appreciation for the work.\n\n### 🐛 Bug Reports\n\nFound a bug? Open an [issue](https://github.com/FuzzyGrim/Yamtrack/issues) on GitHub with detailed steps to reproduce it. Quality bug reports are incredibly valuable for improving stability.\n\n### 💡 Feature Suggestions\n\nHave ideas for new features? Share them through [GitHub issues](https://github.com/FuzzyGrim/Yamtrack/issues). Your feedback helps shape the future of Yamtrack.\n\n### 🧪 Contributing\n\nPull requests are welcome! Whether it's fixing typos, improving documentation, or adding new features, your contributions help make Yamtrack better for everyone.\n\n### ☕ Donate\n\nIf you'd like to support the project financially:\n\n[![ko-fi](https://ko-fi.com/img/githubbutton_sm.svg)](https://ko-fi.com/fuzzygrim)\n","funding_links":["https://ko-fi.com/fuzzygrim"],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ffuzzygrim%2Fyamtrack","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Ffuzzygrim%2Fyamtrack","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ffuzzygrim%2Fyamtrack/lists"}