Skip to content

MediaWolfOrg/MediaWolf

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

57 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

MediaWolf

🚧 Project Status: Early Development 🚧

This project is still in the early stages of development and is not yet ready for general use.


πŸ’‘ Getting Involved

Contributions are welcome from anyone who wants to help shape the project! Here’s how to jump in:

1. Start a discussion – Before diving in, use the repo's Discussions tab to share what you’re planning. This helps avoid overlap and keeps everyone on the same page.

2. Create a Fork – Fork the repository to create your own copy. Next, create a new branch within your fork for your changes. Push your branch so your progress is visible and when you're ready, submit a Pull Request (PR).

3. Recognition – Contributors who handle a significant part of the work will be added as maintainers of the project and the organisation to help guide the project forward.

Note: Be sure to check out TheWicklowWolf for reference and proof of concepts β€” it will serve as a guide for formats, docker builds, actions and overall structure/style.

Thanks for your interest! πŸš€

🌍 Proposed Project Features:

Books (Readarr & Anna’s Archive)

πŸ“š Missing List β†’ Read from Readarr, fetch missing books and auto-download via Anna’s Archive
πŸ” Manual Search β†’ Search Anna’s Archive and download books (user selection and defined file structure)
πŸ’‘ Recommendations β†’ Generate book suggestions based on Readarr library (using a background task to scrape from Goodreads) - with options to add or dismiss suggestions including filters and sorting

Movies (Radarr & TMDB)

πŸ“½ Recommendations β†’ Read Radarr library and suggest similar movies via TMDB (with options to add or dismiss suggestions including filters and sorting)
πŸ” Manual Search β†’ Search via TMDB with option to add to Radarr

TV Shows (Sonarr & TMDB)

πŸ“Ί Recommendations β†’ Read Sonarr library and suggest similar shows via TMDB (with options to add or dismiss suggestions including filters and sorting)
πŸ” Manual Search β†’ Search via TMDB with option to add to Sonarr

Music (Lidarr, LastFM, yt-dlp & Spotify)

🎢 Manual Search β†’ Search Spotify for music and download via spotDL (which uses yt-dlp)
🎀 Recommendations β†’ Generate artist recommendations from LastFM based on Lidarr library (with options to add or dismiss suggestions including filters and sorting)
πŸ’€ Missing List β†’ Read Lidarr library, fetch missing albums and download via yt-dlp

Audiobooks (Readarr, Spotify, AudioBookBay & LibriVox??)

🎧 Missing List β†’ Read from Readarr library, fetch missing audiobooks and auto-download
πŸ” Manual Search β†’ Search Spotify and download audiobooks (user selection and defined file structure)
πŸ“š Recommendations β†’ Generate audiobook suggestions based on Readarr library - with options to add or dismiss suggestions including filters and sorting

Downloads (via yt-dlp)

πŸ’½ Direct Download Page β†’ Input YouTube or Spotify link and download video/audio using spotDL or yt-dlp

Subscriptions (via spotdl and yt-dlp)

πŸ—“οΈ Schedule System β†’ Subscribe to YouTube Channels, Spotify or YouTube Playlists and download on a schedule

πŸ› οΈ Tech Stack Overview

Layer Technology
Frontend Bootstrap
Backend Python with Flask
Database SQLite (SQLAlchemy)
Scheduler APScheduler (for cron-based scheduling)
Downloader spotdl and yt-dlp
Containerization Docker + Docker Compose

πŸ“‚ Proposed Project Structure

MediaWolf/
β”œβ”€β”€ backend/
β”‚   β”œβ”€β”€ __init__.py
β”‚   β”œβ”€β”€ api/
β”‚   β”‚   β”œβ”€β”€ __init__.py
β”‚   β”‚   └── example_api.py  # e.g. API for various sections
β”‚   β”œβ”€β”€ db/
β”‚   β”‚   β”œβ”€β”€ __init__.py
β”‚   β”‚   └── example_db_handler.py  # e.g. DB handler
β”‚   β”œβ”€β”€ services/
β”‚   β”‚   β”œβ”€β”€ __init__.py
β”‚   β”‚   └── example_services.py  # e.g. services for various integrations
β”‚   β”œβ”€β”€ utils/
β”‚   β”‚   β”œβ”€β”€ __init__.py
β”‚   β”‚   └── string_cleaner.py
β”‚   β”œβ”€β”€ logger.py
β”‚   └── main.py
β”œβ”€β”€ docker/
β”‚   β”œβ”€β”€ .dockerignore
β”‚   β”œβ”€β”€ Dockerfile
β”‚   β”œβ”€β”€ gunicorn_config.py
β”‚   β”œβ”€β”€ init.sh
β”‚   └── requirements.txt
β”œβ”€β”€ frontend/
β”‚   β”œβ”€β”€ static/
β”‚   β”‚   β”œβ”€β”€ js/
β”‚   β”‚   β”‚   └── example_script.js  # e.g. script for various sections
β”‚   β”‚   β”œβ”€β”€ css/
β”‚   β”‚   β”‚   └── example_style.css  # e.g. styles
β”‚   β”‚   └── assets/
β”‚   └── templates/
β”‚       β”œβ”€β”€ base.html
β”‚       └── example_template.html  # e.g. template for various sections
β”œβ”€β”€ docs/
β”‚   └── screenshot.png
β”œβ”€β”€ tests/
β”‚   └── generate_recommendations_for_test.py
└── README.md

πŸ“Š Project Progress Tracker

Books (Readarr & Anna’s Archive)

Movies (Radarr & TMDB)

  • Recommendations based on Radarr Movie List -> Similar to RadaRec
  • Manual Search

TV Shows (Sonarr & TMDB)

  • Recommendations based on Sonarr Show List -> Similar to SonaShow
  • Manual Search

Music (Lidarr, LastFM, yt-dlp, Spotify)

  • Lidarr Missing List Scheduled Downloader -> Similar to LidaTube
  • Manual Search
  • Recommendations

Audiobooks (Spotify & LibriVox??)

Downloads

  • Download via SpotDL or yt-dlp directly -> Similar to SpotTube

Tasks

  • Task Manager System (Cron schedule, Manual Start, Stop, Enable and Disable)

Subscriptions

  • YouTube Channels (Audio, Video, Live) -> Similar to ChannelTube
  • YouTube and Spotify Playlists (Audio) -> Similar to Syncify
  • Playlist Generators (For Audio Files) -> Similar to PlaylistDir

Login Manager

  • Login and User Management

Settings Manager

  • Settings Loader & Saver

πŸ“¦ Local Development Setup

Docker Setup

To quickly get started with the project, you can use the Docker Compose file.

  • Make sure you have Docker and Docker Compose installed.
  • Clone the repository.
  • Run docker compose up -d.
  • Access the application at http://127.0.0.1:5000.

Manual Setup

  • Clone the repository.
  • Create a virtual environment and activate it (You can use pyenv to manage multiple Python versions easily).
  • Run pip install -r docker/requirements.txt.
  • Run export FLASK_APP=backend/main.py && flask run.
  • Access the application at http://127.0.0.1:5000.

Committing Changes

Ensure you have pre-commit hooks installed by running:

pre-commit install
- Run `git add .`
- Run `git commit -m "Commit Message"`
- Run `git push`

If pre-commit hooks flag any issues, follow the suggested fixes and commit again.

Example Development Setup

A recommended development setup includes:

  • VSCode with Black formatting (line length set to 200 characters).
  • isort configured for organising imports.
  • Default formatters for JavaScript, CSS and HTML.
  • Python 3.12.

Docker Compose - Preview Image with minimal Functionality

services:
  mediawolf:
    image: ghcr.io/mediawolforg/mediawolf:develop_latest
    container_name: mediawolf
    environment:
      - lidarr_address=http://localhost:8686
      - lidarr_api_key=yourapikey
      - readarr_address=http://localhost:8787
      - readarr_api_key=yourapikey
      - radarr_address=http://localhost:7878
      - radarr_api_key=yourapikey
      - sonarr_address=http://localhost:8989
      - sonarr_api_key=yourapikey
      - lastfm_api_key=yourapikey
      - lastfm_api_secret=yourapikey
      - tmdb_api_key=yourapikey
      - tvdb_api_key=yourapikey
      - spotify_client_id=yourclientid
      - spotify_client_secret=yourclientsecret
    volumes:
      - /path/to/config:/config
      - /path/to/downloads:/downloads
    ports:
      - 5000:5000
    restart: unless-stopped

Discord

https://discord.gg/hxXzH9Xkcx

About

Media Discovery and Download Hub

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors 4

  •  
  •  
  •  
  •