From b090d7f896da111ea49c26f067c3b42e9e17762f Mon Sep 17 00:00:00 2001 From: Manuel Cortez Date: Tue, 18 Jun 2019 16:16:29 -0500 Subject: [PATCH] Add options for all extractors to be enabled or disabled --- src/extractors/__init__.py | 6 +----- src/extractors/{baseFile.py => base.py} | 2 +- src/extractors/tidal.py | 6 ++++-- src/extractors/youtube.py | 21 +++++++++++++++++---- src/extractors/zaycev.py | 6 +++--- 5 files changed, 26 insertions(+), 15 deletions(-) rename src/extractors/{baseFile.py => base.py} (95%) diff --git a/src/extractors/__init__.py b/src/extractors/__init__.py index bd82a82..96981fe 100644 --- a/src/extractors/__init__.py +++ b/src/extractors/__init__.py @@ -1,7 +1,3 @@ #!/usr/bin/env python # -*- coding: UTF-8 -*- -import config -from . import youtube, zaycev -# conditional imports -if config.app != None and config.app["services"]["tidal"]["username"] != "" and config.app["services"]["tidal"]["password"] != "": - from . import tidal +from . import youtube, zaycev, tidal \ No newline at end of file diff --git a/src/extractors/baseFile.py b/src/extractors/base.py similarity index 95% rename from src/extractors/baseFile.py rename to src/extractors/base.py index 9c8f0a7..d72bcfd 100644 --- a/src/extractors/baseFile.py +++ b/src/extractors/base.py @@ -1,6 +1,6 @@ #!/usr/bin/env python # -*- coding: UTF-8 -*- -from __future__ import unicode_literals # at top of module +""" Base components useful for all other extractors. """ import logging import wx import config diff --git a/src/extractors/tidal.py b/src/extractors/tidal.py index fd5cdba..0bbc766 100644 --- a/src/extractors/tidal.py +++ b/src/extractors/tidal.py @@ -2,12 +2,14 @@ import logging import tidalapi import config -from .import baseFile from update.utils import seconds_to_string +from .import base + log = logging.getLogger("extractors.tidal.com") class interface(object): name = "tidal" + enabled = config.app["services"]["tidal"].get("enabled") def __init__(self): self.results = [] @@ -62,7 +64,7 @@ class interface(object): for track in tracks: data.append(track) for search_result in data: - s = baseFile.song(self) + s = base.song(self) s.title = search_result.name s.artist = search_result.artist.name s.duration = seconds_to_string(search_result.duration) diff --git a/src/extractors/youtube.py b/src/extractors/youtube.py index b6ad06e..ae7ddae 100644 --- a/src/extractors/youtube.py +++ b/src/extractors/youtube.py @@ -1,13 +1,13 @@ # -*- coding: utf-8 -*- -from __future__ import unicode_literals # at top of module import isodate import youtube_dl import logging import wx +import config from googleapiclient.discovery import build from googleapiclient.errors import HttpError from update.utils import seconds_to_string -from .import baseFile +from .import base DEVELOPER_KEY = "AIzaSyCU_hvZJEjLlAGAnlscquKEkE8l0lVOfn0" YOUTUBE_API_SERVICE_NAME = "youtube" @@ -17,6 +17,7 @@ log = logging.getLogger("extractors.youtube.com") class interface(object): name = "YouTube" + enabled = config.app["services"]["youtube"].get("enabled") def __init__(self): self.results = [] @@ -38,7 +39,7 @@ class interface(object): ids = [] for search_result in search_response.get("items", []): if search_result["id"]["kind"] == "youtube#video": - s = baseFile.song(self) + s = base.song(self) s.title = search_result["snippet"]["title"] ids.append(search_result["id"]["videoId"]) s.url = "https://www.youtube.com/watch?v="+search_result["id"]["videoId"] @@ -104,14 +105,26 @@ class interface(object): def format_track(self, item): return "{0} {1}".format(item.title, item.duration) -class settings(baseFile.baseSettings): +class settings(base.baseSettings): name = _("Youtube Settings") config_section = "youtube" def __init__(self, parent): super(settings, self).__init__(parent=parent) sizer = wx.BoxSizer(wx.VERTICAL) + self.enabled = wx.CheckBox(self, wx.NewId(), _("Enable this service")) + self.enabled.Bind(wx.EVT_CHECKBOX, self.on_enabled) + self.map.append(("enabled", self.enabled)) + sizer.Add(self.enabled, 0, wx.ALL, 5) self.transcode = wx.CheckBox(self, wx.NewId(), _("Enable transcode when downloading")) self.map.append(("transcode", self.transcode)) sizer.Add(self.transcode, 0, wx.ALL, 5) self.SetSizer(sizer) + + def on_enabled(self, *args, **kwargs): + for i in self.map: + if i[1] != self.enabled: + if self.enabled.GetValue() == True: + i[1].Enable(True) + else: + i[1].Enable(False) \ No newline at end of file diff --git a/src/extractors/zaycev.py b/src/extractors/zaycev.py index 2d2da3f..fc899de 100644 --- a/src/extractors/zaycev.py +++ b/src/extractors/zaycev.py @@ -1,12 +1,12 @@ #!/usr/bin/env python # -*- coding: UTF-8 -*- -from __future__ import unicode_literals # at top of module import re import json import requests import logging +import config from bs4 import BeautifulSoup -from . import baseFile +from . import base log = logging.getLogger("extractors.zaycev.net") @@ -32,7 +32,7 @@ class interface(object): # The easiest method to get artist and song names is to fetch links. There are only two links per result here. data = i.find_all("a") # from here, data[0] contains artist info and data[1] contains info of the retrieved song. - s = baseFile.song(self) + s = base.song(self) s.title = data[1].text s.artist = data[0].text s.url = "http://zaycev.net%s" % (data[1].attrs["href"])