firedm / Firedm
Programming Languages
Projects that are alternatives of or similar to Firedm
FireDM is a python open source (Internet Download Manager)
with multi-connections, high speed engine,
it downloads general files and videos from youtube and tons of other streaming websites .
Developed in Python, based on "LibCurl", and "youtube_dl".
Features:
- High download speeds "based on LibCurl" - See Speed test of: aria2 vs FireDM
- Multi-connection downloading "Multithreading"
- Automatic file segmentation.
- Automatic refresh for dead links.
- Resume uncompleted downloads.
- Support for Youtube, and a lot of stream websites "using youtube-dl to fetch info and libcurl to download media".
- download entire video playlist or selected videos.
- download fragmented video streams, and encrypted/nonencrypted HLS media streams.
- watch videos while downloading* "some videos will have no audio until finish downloading".
- download video subtitles.
- write video metadata to downloaded files.
- check for application updates.
- Scheduling downloads
- Re-using existing connection to remote server.
- Clipboard Monitor.
- proxy support (http, https, socks4, and socks5).
- user/pass authentication, referee link, use cookies, video thumbnail, subtitles.
- MD5 and SHA256 checksums.
- user can control a lot of options:
- select and edit themes.
- set proxy.
- Speed limit.
- Max. Concurrent downloads.
- Max. connections per download.
How to use FireDM:
Refer to user guide at https://github.com/firedm/FireDM/blob/master/docs/user_guide.md
Portable FireDM versions:
Run FireDM without any installation (recommended)
-
Windows portable version (Download!):
available in .zip format.
unzip, and run from FireDM.exe, no installation required. -
Linux portable version (Download!):
available in .AppImage format.
download file, then mark it as executable, and run it, no installation required, tested on ubuntu, mint, and manjaro.
note: ffmpeg is not included and must be installed separately if not existmark file as executable by right clicking the file> Properties> Permissions> Allow executing file as a program, or from terminal by
chmod +x FireDM_xxx.AppImage
To check for ffmpeg use this command:
which ffmpeg # expected output if installed /usr/bin/ffmpeg
if ffmpeg is missing you can install it by
sudo apt install ffmpeg
on debian based orsudo pacman -S ffmpeg
on Arch based distros.
Manually installing FireDM:
-
Linux:
-
UBUNTU:
1- verify you have minimum python version 3.6+
python3
2- install pip:
sudo apt-install python3-pip
3- install dependencies:
sudo apt install ffmpeg libcurl4-openssl-dev libssl-dev python3-pip python3-pil python3-pil.imagetk python3-tk python3-dbus
4- install fonts
sudo apt install fonts-symbola fonts-linuxlibertine fonts-inconsolata fonts-emojione
5- install firedm
python3 -m pip install firedm --user --upgrade --no-cache or if you run into a problem sudo python3 -m pip install firedm --upgrade --no-cache
-
-
PyPi:
on windows replace "python3" with "python" in below commandspython3 -m pip install firedm --user --upgrade --no-cache
orsudo python3 -m pip install firedm --upgrade --no-cache
then you can run application from Terminal by:
python3 -m firedm
or just
firedm
an executable "i.e. firedm.exe on windows" will be located at "python/scripts", if it doesn't work append "python/scripts" folder to PATH. -
run from github source code:
FireDM is a python app. so, it can run on any platform that can run python, To run from source, you have to have a python installed, "supported python versions is 3.6, 3.7, and 3.8", then download or clone this repository, and run FireDM.py (it will install the other required python packages automatically if missing) if FireDM failed to install required packages, you should install it manually, refer to "Dependencies" section below. -
Build FireDM yourself:
-
get the source code from github: (recommended for latest updated version, also shallow clone is preferred)
git clone --depth 1 https://github.com/firedm/FireDM.git
-
or get the source code from PyPi:
navigate to https://pypi.org/project/firedm/#files and download a tar ball, example file name "FireDM-2020.3.22.tar.gz", then extract it -
open your terminal or command prompt and navigate to firedm folder then type below command
python3 setup.py install --user
-
run FireDM from Terminal by typing:
python3 -m firedm
or justfiredm
-
Known Issues:
-
Linux X-server will raise an error if some fonts are missing especially emoji fonts, for more info refer to issue #200.
-
Mac - Tkinter, as mentioned in "python.org" the Apple-supplied Tcl/Tk 8.5 has serious bugs that can cause application crashes. If you wish to use Tkinter, do not use the Apple-supplied Pythons. Instead, install and use a newer version of Python from python.org or a third-party distributor that supplies or links with a newer version of Tcl/Tk.
refer to issue #113
Dependencies:
below are the requirements to run from source:
-
Python 3.6+: tested with python 3.6 on windows, and 3.7, 3.8 on linux
-
tkinter
-
ffmpeg : for merging audio with youtube DASH videos "it will be installed automatically on windows"
-
Fonts: (Linux X-server will raise an error if some fonts are missing especially emoji fonts, below are the recommended fonts to be installed, for more info refer to issue #200.)
ttf-linux-libertine ttf-inconsolata ttf-emojione ttf-symbola noto-fonts
Required python packages:
- pycurl: is a Python interface to libcurl / curl as our download engine,
- youtube_dl: famous youtube downloader, limited use for meta information extraction only but videos are downloaded using pycurl
- yt_dlp: a fork of youtube-dlc which is inturn a fork of youtube-dl
- certifi: required by 'pycurl' for validating the trustworthiness of SSL certificates,
- plyer: for systray area notification.
- awesometkinter: for application gui.
- pillow: imaging library for python
- pystray: for systray icon
Note: FireDM will do its best to install missing packages automatically using pip3 once you run it.
you can install required packages manually using:
pip install -r requirements.txt
more screenshots
what is the benefit of open source, compared to closed-source/Proprietary software if both are free?
As said, "if the product is free, then you are the product", most free closed-source software collect data about you, some of them are toxic and plant trojans and spy-wares in your system, with open source, nothing hidden, and source code exposed to thousands of programmers, no one can play dirty games.
Need to mention, this project is never made to compete with other download managers, it is just a "hopefully useful" addition.
for windows users:
normal pip install i.e python -m pip install pycurl
might fail on windows because you need to build libcurl on your system first which is a headache.
your best choice if pip fail is to download exe file for pycurl from its official download link, find the file that match your windows system and python version installed on your system, last checked on 12-06-2020, found available files for almost all Python versions upto version 3.8
example: if you have python 3.6 installed on windows 32bit, you should download "pycurl-7.43.0.2.win32-py3.6.exe" file and install it, another example: if you have python 3.7 running on windows 64 bit, you should choose and download "pycurl-7.43.0.3.win-amd64-py3.7.exe" file
other download options include a wheel, zip file, or even a windows installer
for linux users:
there is no issues, since most linux distros have curl preinstalled, so pycurl will link with libcurl library to get built with no issues, checked with python versions 3.6, 3.7, and 3.8 working with no problems.
Youtube-dl:
note for youtube website changes frequently, if this application failed to retrieve video/playlist data you should update youtube-dl module thru FireDM setting tab or manually by
python -m pip install youtube_dl --upgrade
Versions change log:
ChangeLog.txt is included in source code.
How to contribute to this project:
1- by testing the application and opening
new issue for bug
reporting, feature request, or suggestions.
2- check
developer guidelines.
3- check
todo list.
4- check open issues, see if you can help.
5- fork this repo and pull request
Some recent articles/reviews on this project*:
-
*help edit this list by writing a comment in this issue
contributors:
Please check contributors.md for a list of contributors
Feedback:
your feedback is most welcomed by filling a
new issue
or email to: [email protected]
Author:
Mahmoud Elshahat
2019-2021