Skip to content

prefect421/mvidarr

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

MVidarr

A comprehensive music video management and discovery platform that helps you organize, discover, and stream your music video collection with intelligent artist management and advanced search capabilities.

Artist Screen

✨ Key Features

  • 🎯 Advanced Artist Management - Multi-criteria search and bulk operations
  • πŸ” Comprehensive Video Discovery - Dual-source integration (IMVDb + YouTube)
  • πŸ–ΌοΈ Advanced Thumbnail Management - Multi-source search and cropping
  • πŸ“ Intelligent Organization - Automatic folder creation and cleanup
  • πŸ”Ž Advanced Search System - Real-time suggestions and filtering
  • ⚑ Bulk Operations - Multi-select editing and batch processing
  • πŸ“Ί Video Streaming - Built-in player with transcoding support
  • πŸ’š System Health Monitoring - Comprehensive diagnostics
  • βš™οΈ Database-Driven Settings - Complete configuration management
  • πŸ“₯ Download Management - Queue visualization and progress tracking
  • 🎨 Modern UI - Left sidebar navigation with theme system
  • πŸ“Ί MvTV Continuous Player - Cinematic mode for uninterrupted viewing
  • 🎭 Genre Management - Automatic genre tagging and filtering
  • πŸ” User Authentication - Role-based access control with security features
  • 🎨 Advanced Theme System - 7 built-in themes with export/import functionality

πŸš€ LATEST: v0.11.0 - Scheduler V2 Release

⚠️ BETA STATUS: Active Development - Not Yet Production-Ready

Note: This is a beta release following SemVer 0.x conventions. The software is feature-complete but undergoing testing and validation before the official v1.0.0 production release.

Scheduler V2 - Database-Driven Scheduling βœ…

  • πŸ—„οΈ Database Configuration: All scheduler settings now stored in database
  • πŸŽ›οΈ Web UI Management: Configure schedules through Settings page
  • 🚫 No More Environment Variables: Removed MVIDARR_USE_ENHANCED_SCHEDULER and related env vars
  • πŸ“Š Job History Tracking: Complete history of all scheduled job executions
  • πŸ”„ Dynamic Updates: Changes apply immediately without container restart
  • πŸ₯ Health Monitoring: Built-in health checks and status endpoints
  • πŸ”Œ REST API Control: Full API for automation and integration

Code Cleanup & Optimization βœ…

  • ♻️ 10 Large Files Refactored - Transformed 15,133 lines into 58 modular files
  • πŸ“‰ 71.4% Average Size Reduction - Improved maintainability and testability
  • 🧹 607 Unused Imports Removed - Complete dead code elimination (100%)
  • πŸ“¦ Backward Compatibility - All functionality preserved and verified
  • πŸ—οΈ Enterprise Architecture - Modular design with clear separation of concerns

Security Hardening (30 Issues Fixed) βœ…

  • πŸ”’ SQL Injection Protection - Parameterized queries and input validation (6 fixes)
  • πŸ›‘οΈ Secure HTTP Requests - Timeout protection on all external calls (23 fixes)
  • πŸ” Pickle Integrity - HMAC-SHA256 signature verification (1 fix)
  • πŸ“ Safe Parsing - Eliminated unsafe eval() usage (2 fixes)
  • πŸ—‚οΈ Secure Temp Files - Proper temporary directory handling (3 fixes)
  • 🌐 XML Protection - XXE attack prevention with defusedxml (2 fixes)

Testing & Quality Assurance βœ…

  • πŸ§ͺ 222/230 E2E Tests Passing - 96.5% pass rate with Playwright
  • βœ… 100% Critical Tests - All smoke tests and core functionality verified
  • πŸ“Š Zero High-Severity Issues - Comprehensive security audit complete
  • πŸ“š Complete Documentation - API, scripts, and deployment guides updated

Docker Architecture Simplification βœ…

  • 🐳 3-Container Deployment - Reduced from 6 to 3 containers for home users
  • βš™οΈ Supervisord Integration - FastAPI + Celery worker in single container
  • πŸ“¦ Lower Resource Usage - Optimized for consumer-grade deployments
  • 🎯 Simplified Management - Easier troubleshooting and maintenance
  • ✨ Full Functionality - All background jobs and features preserved

🎯 Previous Releases

v0.9.8 - Subtitle System & User Testing Fixes

  • Complete subtitle implementation (WebVTT, SRT, ASS, SSA, SUB)
  • Smart YouTube language resolution
  • User testing fixes (8/8 critical issues resolved)
  • 100% Flask to FastAPI migration complete

πŸ†• Previous Updates (v0.9.4-0.9.7)

  • 🐳 Docker Optimization - Reduced build time from timeout failures to consistent 8-minute builds
  • πŸ“¦ Container Size Optimization - Efficient multi-stage builds with optimized caching (1.41GB optimized size)
  • πŸ” Build Monitoring - Comprehensive Docker build monitoring and validation infrastructure
  • ⚑ Build Reliability - 100% build success rate with automated size monitoring and performance tracking
  • πŸ› οΈ Infrastructure - Enhanced CI/CD workflows with automated Docker monitoring and health checks

πŸš€ Quick Start

Docker Deployment (Recommended)

Simple 3-Container Architecture:

  • mvidarr - FastAPI application + Celery worker (managed by supervisord)
  • mariadb - Database
  • redis - Cache and job queue

Installation Steps:

  1. Clone the repository:

    git clone https://github.com/prefect421/mvidarr.git
    cd mvidarr
  2. Create your environment file:

    cp .env.example .env
  3. Edit .env with your configuration:

    nano .env  # or use your preferred editor

    Required settings:

    • DB_PASSWORD - Set a secure database password
    • MYSQL_ROOT_PASSWORD - Set a secure root password
    • SECRET_KEY - Generate with: openssl rand -hex 32
    • MUSIC_VIDEOS_PATH - Path to your music video collection
  4. Start MVidarr:

    docker-compose up -d
  5. Access the application:

    • Open your browser to http://localhost:5000
    • Default login: admin / admin (change immediately)
    • Complete the first-run setup wizard

Docker Images:

  • Latest: ghcr.io/prefect421/mvidarr:latest
  • Specific version: ghcr.io/prefect421/mvidarr:v0.10.0-beta.1

What's Running:

  • All background jobs (Celery) run automatically inside the main container
  • Supervisord manages both FastAPI and Celery processes
  • Simple, efficient, and optimized for home users

Manual Installation

Prerequisites:

  • Python 3.12+
  • MariaDB 11.4+ (recommended)
  • FFmpeg (for video processing)

Installation:

# Clone and setup
git clone https://github.com/prefect421/mvidarr.git
cd mvidarr
python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate
pip install -r requirements.txt

# Start FastAPI application
python fastapi_app.py

Production Service:

# Install as systemd service (recommended)
sudo cp mvidarr.service /etc/systemd/system/
sudo systemctl daemon-reload
sudo systemctl enable mvidarr.service
sudo systemctl start mvidarr.service

# Check service status
sudo systemctl status mvidarr.service

Access: http://localhost:5000

πŸ“š Documentation

Getting Started

Advanced Topics

πŸ—οΈ Architecture

MVidarr is built with modern, high-performance architecture:

  • Backend: FastAPI (Python 3.12+) with async operations and advanced features
  • API Layer: Comprehensive FastAPI with versioning, request logging, and auto-generated clients
  • Template System: Async Jinja2 templates with performance optimization and caching
  • WebSocket Support: Native FastAPI WebSockets for real-time features
  • Background Jobs: Celery + Redis for reliable metadata enrichment and processing
  • Database: MariaDB 11.4+ with async connection pooling and optimization
  • Frontend: Modern HTML5/CSS3/JavaScript with ES6+ async patterns
  • Performance: Multi-layer caching (Memory + Redis), compression, and optimization
  • Testing: Enterprise-grade validation and load testing frameworks
  • Media Processing: FFmpeg, yt-dlp for video downloading and processing
  • Authentication: Secure user management with role-based access control
  • Security: bcrypt password hashing, session management, audit logging
  • Containerization: Optimized Docker Compose with multi-stage builds, automated monitoring, and 1.41GB production images

πŸ”§ Configuration

Configuration is managed through:

  • Database settings (preferred for production)
  • Environment variables
  • Docker Compose environment files

Key environment variables:

# Database
DB_HOST=mariadb
DB_PASSWORD=secure_password
SECRET_KEY=your-secret-key

# External APIs
IMVDB_API_KEY=your-imvdb-key
YOUTUBE_API_KEY=your-youtube-key

# Background Jobs (New!)
REDIS_URL=redis://redis:6379/0
CELERY_BROKER_URL=redis://redis:6379/0
BACKGROUND_JOBS_ENABLED=true

πŸ›‘οΈ Security

MVidarr includes comprehensive security features:

  • Multi-user authentication with role-based access (Admin, Manager, User, ReadOnly)
  • Secure password hashing with bcrypt
  • Session management with secure tokens and expiration
  • Account lockout protection against brute force attacks
  • Password reset functionality with secure tokens
  • Audit logging for user actions and system events
  • SQL injection prevention with parameterized queries and ORM
  • Docker security with non-root containers and isolated networking

🎯 Use Cases

  • Personal Music Video Collections - Organize and stream your collection
  • Music Discovery - Find new videos through integrated search
  • Media Center Integration - Works with Plex and other media servers
  • Home Entertainment - MvTV mode for continuous viewing
  • Music Research - Advanced search and filtering capabilities

🀝 Contributing

We welcome contributions! Please see our Contributing Guide for details.

Development Setup

  1. Fork the repository
  2. Create a virtual environment: python -m venv venv
  3. Activate it: source venv/bin/activate (Linux/macOS) or venv\Scripts\activate (Windows)
  4. Install dev dependencies: pip install -r requirements.txt
  5. Run tests: pytest

πŸ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

πŸ™ Acknowledgments

  • yt-dlp - Video download and processing
  • IMVDb - Music video metadata database
  • YouTube API - Video discovery and streaming
  • Flask - Web framework
  • MariaDB - Database engine

πŸ“ž Support

  • Documentation: Check the docs/ directory
  • Issues: Report bugs via GitHub Issues
  • Community: Join our discussions

MVidarr v0.10.0-beta.1 - Built with ❀️ for music video enthusiasts

About

MVidarr - The Music Video Management System

Resources

License

MIT, GPL-3.0 licenses found

Licenses found

MIT
LICENSE
GPL-3.0
LICENSE.md

Contributing

Stars

Watchers

Forks

Sponsor this project

Packages

 
 
 

Contributors 2

  •  
  •