Two streaming options

This commit is contained in:
BarsTiger
2022-12-13 16:09:52 +02:00
parent 9dae35a537
commit cd8c384e95
8 changed files with 72 additions and 20 deletions

View File

@@ -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