Two streaming options
This commit is contained in:
@@ -1,12 +1,11 @@
|
||||
import pydub
|
||||
import validators
|
||||
from io import BytesIO
|
||||
from modules.config import Config
|
||||
from rich import print
|
||||
import pafy
|
||||
import hashlib
|
||||
import os
|
||||
from modules.spotify.spotify_dl import Spotify
|
||||
from gui.modules.core.popup import popup
|
||||
import requests
|
||||
|
||||
|
||||
@@ -15,28 +14,40 @@ def get_raw_link(url):
|
||||
if 'spotify' in url:
|
||||
url = Spotify().get_youtube_url(url)
|
||||
if 'youtu' in url:
|
||||
url = pafy.new(url).audiostreams[0].url
|
||||
else:
|
||||
url = None
|
||||
url = pafy.new(url).getbestaudio().url
|
||||
|
||||
return url
|
||||
|
||||
|
||||
def get_silenced_media(original: str) -> str | None:
|
||||
def get_ready_media(original: str) -> str | None:
|
||||
if not os.path.isdir('temp'):
|
||||
os.mkdir('temp')
|
||||
|
||||
try:
|
||||
namehash = 'temp\\' + hashlib.md5(original.encode('utf-8')).hexdigest()
|
||||
if os.path.isfile(namehash):
|
||||
return namehash
|
||||
|
||||
if not os.path.isfile(original):
|
||||
if validators.url(original):
|
||||
original = BytesIO(requests.get(get_raw_link(original)).content)
|
||||
if not Config.get().direct_stream:
|
||||
with open('tempsound', 'wb') as f:
|
||||
f.write(requests.get(get_raw_link(original)).content)
|
||||
original = 'tempsound'
|
||||
else:
|
||||
original = get_raw_link(original)
|
||||
|
||||
if Config.get().direct_stream:
|
||||
return original
|
||||
|
||||
(pydub.AudioSegment.from_file(original) + pydub.AudioSegment.silent(1500))\
|
||||
.export(namehash, format='mp3')
|
||||
|
||||
if os.path.isfile('tempsound'):
|
||||
os.remove('tempsound')
|
||||
|
||||
return namehash
|
||||
|
||||
except Exception as e:
|
||||
raise e
|
||||
print(e)
|
||||
return None
|
||||
|
||||
Reference in New Issue
Block a user