irs/README.md

98 lines
4 KiB
Markdown
Raw Normal View History

2017-03-14 05:46:44 +00:00
<div align="center"><img src ="http://i.imgur.com/VbsyTe7.png" /></div>
2017-03-16 03:13:47 +00:00
2017-06-06 02:30:23 +00:00
# Ironic Redistribution System
2017-03-14 05:37:26 +00:00
[![License: GNU](https://img.shields.io/badge/license-gnu-yellow.svg?style=flat-square)](http://www.gnu.org/licenses/gpl.html)
[![Stars](https://img.shields.io/github/stars/kepoorhampond/irs.svg?style=flat-square)](https://github.com/kepoorhampond/irs/stargazers)
[![Say Thanks](https://img.shields.io/badge/say-thanks-ff69b4.svg?style=flat-square)](https://saythanks.io/to/kepoorhampond)
[![PyPI](https://img.shields.io/badge/pypi-irs-blue.svg?style=flat-square)](https://pypi.python.org/pypi/irs)
2017-03-14 05:46:44 +00:00
<sup><sub>(Shields: Gotta Catch Em All)</sub></sup>
2017-03-06 21:46:00 +00:00
> A music downloader that understands your metadata needs.
2017-01-24 06:14:29 +00:00
A tool to download your music with metadata. It uses [Spotify](https://www.spotify.com/) for finding metadata and [Youtube](https://www.youtube.com/) for the actual audio source. You will need to have some Spotify tokens, the instructions to set them up are [here](https://github.com/kepoorhampond/irs#spotify-tokens).
2017-01-24 05:49:05 +00:00
2017-03-06 21:46:00 +00:00
Works with Python 2 and 3.
## Install and Setup
2017-06-11 02:05:06 +00:00
```
$ sudo pip install irs
$ irs --setup
2017-11-14 15:55:07 +00:00
$ pip install youtube_dl # Only if on windows
2017-06-11 02:05:06 +00:00
```
**You will need to have some Spotify tokens, the instructions to set them up are [here](https://github.com/kepoorhampond/irs#spotify-tokens).**
## Demo and Usages
2017-03-06 21:46:00 +00:00
This is a demo of the CLI displayling its features:
[![demo](https://asciinema.org/a/105993.png)](https://asciinema.org/a/105993?autoplay=1)
2017-01-24 05:49:05 +00:00
2017-03-06 21:46:00 +00:00
The usages can be found with the `-h` or `--help` flag:
2016-12-11 00:26:11 +00:00
```
2017-05-02 05:45:10 +00:00
usage: irs [-h] [-a ARTIST -s SONG] [-A ALBUM [-a ARTIST]]
[-u USERNAME -p PLAYLIST] [-l LOCATION] [-o] [-c]
2016-12-11 00:26:11 +00:00
2017-03-06 21:46:00 +00:00
optional arguments:
2016-12-11 00:26:11 +00:00
-h, --help show this help message and exit
2017-03-06 21:46:00 +00:00
-a ARTIST, --artist ARTIST
2017-05-02 05:44:14 +00:00
Specify artist name. Must be used with -s/--song or
-A/--album
2017-03-06 21:46:00 +00:00
-s SONG, --song SONG Specify song name. Must be used with -a/--artist
-A ALBUM, --album ALBUM
2017-03-06 21:46:00 +00:00
Specify album name
-u USERNAME, --username USERNAME
Specify username. Must be used with -p/--playlist
-p PLAYLIST, --playlist PLAYLIST
2017-03-06 21:46:00 +00:00
Specify playlist name. Must be used with -u/--username
-l LOCATION, --location LOCATION
Specify a directory to place files in.
-o, --organize Organize downloaded files.
-c, --config Display path to config file.
```
2017-05-02 05:44:14 +00:00
2017-03-06 21:46:00 +00:00
So all of these are valid commands:
```
2017-03-06 21:46:00 +00:00
$ irs -a "Brandon Flowers" -s "Lonely Town"
$ irs -u "spotify" -p "Brain Food"
$ irs -A "Suicide Squad: The Album"
```
2017-03-06 21:46:00 +00:00
But these are not:
```
2017-03-06 21:46:00 +00:00
$ irs -s "Bohemian Rhapsody"
$ irs -p "Best Nirvana"
```
2016-12-20 03:50:24 +00:00
## Spotify Tokens
2017-11-28 22:40:36 +00:00
To download metadata through spotify, you'll want to head to their Dev Apps page, [here](https://developer.spotify.com/my-applications/). After doing that you'll want to create a new app. Name it whatever you want and then once you've done that, find the `Client ID` and `Client Secret` keys. You'll want to take those keys and paste them into your system's environment variables as `SPOTIFY_CLIENT_ID` and `SPOTIFY_CLIENT_SECRET`, correspondingly. Voilà! You can now download metadata with IRS!
## Metadata
2017-03-06 21:46:00 +00:00
Currently, the program attaches the following metadata to the downloaded files:
- Title
- Artist
- Album
- Album Art
- Genre
- Track Number
- Disc Number
- Compilation (iTunes only)
## Philosophy
2017-03-06 21:46:00 +00:00
When I made this program I was pretty much broke and my music addiction wasn't really helping that problem. So, I did the obvious thing: make an uber-complicated program to ~~steal~~ download music for me! As for the name, its acronym spells IRS, which I found amusing, seeing as the IRS ~~takes~~ steals money while my program ~~gives~~ reimburses you with music.
2017-06-11 21:24:06 +00:00
The design/style inspiration of the CLI goes to [k4m4](https://github.com/k4m4).
2017-03-14 05:37:26 +00:00
## Wishlist
2017-01-24 06:14:29 +00:00
- [x] Full album downloading
- [x] Album art metadata correctly displayed
- [x] Spotify playlist downloading
2017-03-06 21:46:00 +00:00
- [ ] GUI/Console interactive version - *in progress*
- [ ] Lyric metadata
- [ ] 99% success rate for automatic song choosing