1
1
Fork 0
mirror of https://github.com/cooperhammond/irs.git synced 2025-01-11 20:35:27 +00:00

Added custom hook text support

This commit is contained in:
Kepoor Hampond 2017-05-06 22:37:06 -07:00
parent 8ec388964d
commit 65be52ce48
2 changed files with 21 additions and 11 deletions

View file

@ -13,6 +13,9 @@ from .utils import YdlUtils, ObjManip, Config
from .metadata import Metadata
from .metadata import find_album_and_track, parse_genre
# Config File and Flags
from .config import CONFIG
# Parsing
from bs4 import BeautifulSoup
if sys.version_info[0] >= 3:
@ -29,6 +32,16 @@ else:
class Ripper:
def __init__(self, args={}):
self.args = args
if self.args.get("hook-text") is None:
self.args["hook-text"] = {
"youtube": "Finding Youtube link ...",
"list": '{0}: "{1}" by "{2}"',
"song": 'Downloading "{0}" by "{1}"',
"converting": "Converting to mp3 ...",
}
if self.args["hook-text"].get("converting") is not None:
CONFIG["converting"] = self.args["hook-text"]["converting"]
self.locations = []
self.type = None
try:
@ -42,7 +55,7 @@ class Ripper:
client_credentials_manager=client_credentials_manager)
self.authorized = True
except Exception as e:
except Exception:
self.spotify = spotipy.Spotify()
self.authorized = False
@ -111,8 +124,7 @@ class Ripper:
def find_yt_url(self, song=None, artist=None, additional_search=None):
if additional_search is None:
additional_search = Config.parse_search_terms(self)
else:
print("Finding Youtube link ...")
print(self.args["hook-text"].get("youtube"))
try:
if not song:
@ -123,8 +135,6 @@ class Ripper:
raise ValueError("Must specify song_title/artist in `args` with \
init, or in method arguments.")
print("Finding Youtube Link ...")
search_terms = song + " " + artist + " " + additional_search
query_string = urlencode({"search_query": (
search_terms.encode('utf-8'))})
@ -238,8 +248,9 @@ with init, or in method arguments.")
if the_list is not None:
YdlUtils.clear_line()
print(type.title() + ': "%s" by \
"%s"' % (the_list["name"], the_list["artists"][0]["name"]))
print(self.args["hook-text"].get("list")
.format(type.title(), the_list["name"],
the_list["artists"][0]["name"]))
compilation = ""
if type == "album":
@ -358,7 +369,7 @@ init, or in method arguments.")
video_url, video_title = self.find_yt_url(song, artist)
print('Downloading "%s" by "%s" ...' % (song, artist))
print(self.args["hook-text"].get("song").format(song, artist))
file_name = str(data["file_prefix"] + ObjManip.blank(song, False) +
".mp3")

View file

@ -49,7 +49,7 @@ class YdlUtils:
def my_hook(d):
if d['status'] == 'finished':
print("Converting to mp3 ...")
print(CONFIG["converting"])
# ================================
@ -271,8 +271,7 @@ def banner():
.format(BYELLOW, BRED, BYELLOW), COLS))
flush_puts(center_colors("{0}Made with 😈 by: {1}Kepoor Hampond \
({2}kepoorhampond{3})".format(BBLUE, BYELLOW,
BRED, BYELLOW) + END, COLS))
({2}kepoorhampond{3})".format(BBLUE, BYELLOW, BRED, BYELLOW) + END, COLS))
flush_puts(center_colors("{0}Version: {1}".format(BBLUE, BYELLOW) +
pkg_resources.get_distribution("irs").version, COLS))