- mkvmerge (optional, mkv output required)
! Minyami requires Node 10.22.0+
Make sure you had put the binary files into your system PATH
.
npm install minyami -g
Please also install the following extension to work with Minyami
- Install Chrome extension (recommended): https://chrome.google.com/webstore/detail/minyami/cgejkofhdaffiifhcohjdbbheldkiaed (which is also open-sourced here)
Help:
Commands Description Alias
--help <command> Show help documentation --h
<command> Show help of a specified comma
--version Show version
--download <input_path> Download video --d
<input_path> m3u8 file path
--threads <limit> Threads limit
<limit> (Optional) Limit of threads, defaults to 5
--retries <limit> Retry limit
<limit> (Optional) Limit of retry times
--output, o <path> Output path
<path> (Optional) Output file path, defaults to ./output.mkv
--key <key> Set key manually (Internal use)
<key> (Optional) Key for decrypt video.
--cookies <cookies> Cookies to download
<cookies>
--headers <headers> HTTP Headers used to download
<headers> Multiple headers should be splited with \n. eg. --headers "Cookie: a=1\nUser-Agent: X-UA". Don't forget to escape. This option will override --cookies.
--live Download live
--format <format_name> (Optional) Set output format. default: ts
<format_name> Format name. ts or mkv.
--proxy <socks-proxy> Download via Socks proxy
<socks-proxy> Set Socks Proxy in [<host>:<port>] format. eg. --proxy "127.0.0.1:1080".
--slice <range> Download specified part of the stream
<range> Set time range in [<hh:mm:ss>-<hh:mm:ss> format]. eg. --slice "45:00-53:00"
--nomerge Do not merge m3u8 chunks.
--resume <input_path> Resume a download. (Archive) --r
<input_path> m3u8 file path
--clean Clean cache files
Options:
Options Description
--verbose, debug Debug output
Q: Should I keep the browser open when downloading?
A: It's not necessary.
import { ArchiveDownloader } from 'minyami';
import { LiveDownloader } from 'minyami';
currentChunkInfo
<object>
The information of the chunk which is just downloaded.
The 'chunk-downloaded'
event is emitted when every media chunk is downloaded.
error: Error
The 'chunk-error'
event is emitted when failed to download or decrypt media chunks.
The 'downloaded'
event is emitted after all chunks are downloaded but before starting merge.
The 'finished'
event is emitted after all the works are done. CLI program exits after this event is emitted.
error: Error
The merge-error
event is emitted when a merge progress is failed.
error: Error
The critical-error
is emitted when a error that Minyami can't handle happens.
Minyami is developed with TypeScript. You need to install TypeScript Compiler before you start coding.
Install development dependencies
npm install -g typescript
git clone https://github.com/Last-Order/Minyami
cd Minyami
npm install
To build the project, just run tsc
.
Open-sourced under GPLv3. © 2018-2021, Eridanus Sora, member of MeowSound Idols.