A Python Bunkr downloader using Playwright for browser automation to fetch images and videos from URLs, falling back to Playwright only if the main download fails. It supports both Bunkr albums and individual file URLs, logs issues, and enables concurrent downloads for efficiency.
- Downloads multiple files from an album concurrently.
- Supports batch downloading via a list of URLs.
- Progress indication during downloads.
- Automatically creates a directory structure for organized storage.
- Logs URLs that encounter errors for troubleshooting.
- Python 3
playwright
- for browser automation and downloading content.BeautifulSoup
(bs4) - for HTML parsingrequests
- for HTTP requestsrich
- for progress display in the terminal.
project-root/
├── helpers/
│ ├── crawlers/
│ │ ├── crawler_utils.py # Utilities for extracting media download links from item pages
│ │ └── playwright_crawler.py # Module that utilizes Playwright to automate downloads from Bunkr
│ ├── managers/
│ │ ├── live_manager.py # Manages a real-time live display
│ │ ├── log_manager.py # Manages real-time log updates
│ │ └── progress_manager.py # Manages progress bars
│ ├── bunkr_utils.py # Utilities for checking Bunkr status and URL validation
│ ├── download_utils.py # Utilities for managing the download process
│ ├── file_utils.py # Utilities for managing file operations
│ ├── general_utils.py # Miscellaneous utility functions
│ └── url_utils.py # Utilities for Bunkr URLs
├── downloader.py # Module for initiating downloads from specified Bunkr URLs
├── main.py # Main script to run the downloader
├── URLs.txt # Text file listing album URLs to be downloaded
└── session_log.txt # Log file for recording session details
- Clone the repository:
git clone https://github.com/Lysagxra/BunkrDownloader.git
- Navigate to the project directory:
cd BunkrDownloader
- Install the required dependencies:
pip install -r requirements.txt
- Ensure you have Playwright installed and set up installing Firefox:
playwright install firefox
To download a single media from an URL, you can use downloader.py
, running the script with a valid album or media URL.
python3 downloader.py <bunkr_url>
python3 downloader.py https://bunkr.si/a/PUK068QE
To batch download from multiple URLs, you can use the main.py
script. This script reads URLs from a file named URLs.txt
and downloads each one using the media downloader.
- Create a file named
URLs.txt
in the root of your project, listing each URL on a new line.
- Example of
URLs.txt
:
https://bunkr.si/a/PUK068QE
https://bunkr.fi/v/gBrv5f8tAGlGW
https://bunkr.fi/a/kVYLh49Q
- Ensure that each URL is on its own line without any extra spaces.
- You can add as many URLs as you need, following the same format.
- Run the batch download script:
python3 main.py
- The downloaded files will be saved in the
Downloads
directory.
The application logs any issues encountered during the download process in a file named session_log.txt
. Check this file for any URLs that may have been blocked or had errors.