Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ccgauche/ytermusic
An in terminal youtube music client with focus on privacy, simplicity and performance
https://github.com/ccgauche/ytermusic
music-player rust terminal tui youtube youtube-player
Last synced: 3 months ago
JSON representation
An in terminal youtube music client with focus on privacy, simplicity and performance
- Host: GitHub
- URL: https://github.com/ccgauche/ytermusic
- Owner: ccgauche
- License: apache-2.0
- Created: 2022-04-18T19:45:08.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2024-07-26T10:25:28.000Z (6 months ago)
- Last Synced: 2024-08-01T13:17:05.641Z (6 months ago)
- Topics: music-player, rust, terminal, tui, youtube, youtube-player
- Language: Rust
- Homepage:
- Size: 5.96 MB
- Stars: 344
- Watchers: 6
- Forks: 19
- Open Issues: 32
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-rust-tools - ytermusic
README
# YTerMusic
![YTeRMUSiC](./assets/banner/YTeRMUSiC.png "YTeRMUSiC")
YTerMusic is a TUI based Youtube Music Player that aims to be as fast and simple as possible.
## Screenshots
## Features and upcoming features
- Play your Youtube Music Playlist and Supermix.
- Memory efficient (Around 20MB of RAM while fully loaded)
- Cache all downloads and store them
- Work even without connection (If musics were already downloaded)
- Automatic background download manager
### Check List
- [x] Playlist selector
- [x] Error message display in the TUI
- [x] Enable connection less music playing
- [ ] Cache limit to not exceed some given disk space
- [x] A download limit to stop downloading after the queue is full
- [x] Mouse support
- [x] Search
- [x] Custom theming (You can use hex! #05313d = ![05313d](./assets/hex/05313d.png "#05313d") )## Install
> [!TIP]
> 3rd party AUR packages are available [here](https://aur.archlinux.org/packages?O=0&K=ytermusic).- Download the latest version from [releases](https://github.com/ccgauche/ytermusic/releases/latest).
### Linux
Install the following libraries:
```sh
sudo apt install alsa-tools libasound2-dev libdbus-1-dev pkg-config
```
- Use `cargo` to install the latest version
```sh
cargo install ytermusic --git https://github.com/ccgauche/ytermusic
```
## Setup
> [!IMPORTANT]
> If you're using Firefox enable the "Raw" switch so the cookie isn't mangled.
> ![Firefox Raw Switch](./assets/screenshots/Firefox-Raw-Switch.png "Firefox Raw Switch")- Give `ytermusic` authentication to your account, by copying out the headers
1. Open the https://music.youtube.com website in your browser
2. Open the developer tools (F12 or Fn + F12)
3. Go to the Network tab
4. Find the request to the `music.youtube.com` document `/` page
5. Copy the `Cookie` header from the associated response request
6. Create a `headers.txt` file in one of the checked [paths](https://docs.rs/directories/latest/directories/struct.ProjectDirs.html#method.config_dir).
7. Create an entry like this :
```
Cookie:
User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/110.0.0.0 Safari/537.36
```
- Then you can start `ytermusic`## Building from source
- Clone the repository
- Install rust `https://rustup.rs` nightly
- Run `cargo build --release`
- The executable is in `target/release/ytermusic.exe` or `target/release/ytermusic`## Usage
- Use your mouse to click in lists if your terminal has mouse support
- Press Space to play/pause
- Press Enter to select a playlist or a music
- Press f to search
- Press s to shuffle
- Press Arrow Right or \> to skip 5 seconds
- Press Arrow Left or \< to go back 5 seconds
- Press CTRL + Arrow Right or CTRL + \> to go to the next song
- Press CTRL + Arrow Left or CTRL + \< to go to the previous song
- Press + for volume up
- Press - for volume down
- Press Arrow down to scroll down
- Press Arrow up to scroll up
- Press ESC to exit the current menu
- Press CTRL + C or CTRL + D to exit## How to fix common issues
If you have any issues start by running:
```sh
ytermusic --fix-db
```
This will try to fix any issues with the cache database.If you still have issues, you can clear the cache by running:
```sh
ytermusic --clear-cache
```If you need to report an issue or find the files related to ytermusic:
```sh
ytermusic --files
```## Changelog
```
Beta b0.1.1
- Added `hide_channels_on_homepage` with a default value of `true` to the config file
- Added `hide_albums_on_homepage` with a default value of `false` to the config file
- Fixed default style to support transparency
- Added more color configuration optionsBeta b0.1.0
- Fixed keyboard handling on windows
- Improved error handling
- Fixed youtube downloads
- Made volume bar optional in config
- Improved performance and updated dependenciesAlpha a0.0.11
- Added scrollable music view
- Added shuffle functionality
- Fixed some crashes while resizing the app
- Added error messages for invalid headers or cookies
- Added error messages for expired cookiesAlpha a0.0.10
- Speed up the download process
- Fix the download limit
- Fix music artists getting smashed together
- Fix the download manager not downloading all musics
- Improved stability
- Improved logs and added timings to better debugAlpha a0.0.9:
- Progress info for downloads
- Mouse support on time bar
- Vertical volume bar
- Vertical volume bar supports mouse click
- Scroll to change volume and skip in timeline
- Improved the scrolling action
- Fixed the bug where the time bar would not update
- Debouncing the search input
- Changed the location of the cache folder to follow the XDG Base Directory Specification (By @FerrahWolfeh #20)
- More configuration options (By @ccgauche and @FerrahWolfeh)Alpha a0.0.8
- Fixed scrolling
- Fixed audio-glitches
- Removed nightly flag useAlpha a0.0.7
- Major changes in the API
- Fixed log file bloat issueAlpha a0.0.6
- Fix: Fix a bug where the app would crash when trying to play a song that was not downloaded
- Fix: Improve the logger to not print the same error twice
- Improved startup time
- Fixed linux build
- Changed how task are distributed to the thread poolAlpha a0.0.5
- Added local database cache to improve IO accesses
- Added searching for musics in the local library
- Greatly improved render performance and RAM usage
- Error management and error display in specific screenAlpha a0.0.4
- Added menu navigation
- Added searching for musics
- Added new terminal backendAlpha a0.0.3
- Mouse support to select playlist and music
- Download limiter
- Connection less music playingAlpha a0.0.2
- Playlist selector
- Improved error management
- Improved TUI
- Performance upgrade
- Switch to Rustls instead of openSSL
```