taslim19
MusicV2
a8e9b84
import re
from typing import Union
import aiohttp
from bs4 import BeautifulSoup
from youtubesearchpython.__future__ import VideosSearch
class AppleAPI:
def __init__(self):
self.regex = r"^(https:\/\/music.apple.com\/)(.*)$"
self.base = "https://music.apple.com/in/playlist/"
async def valid(self, link: str):
if re.search(self.regex, link):
return True
else:
return False
async def track(self, url, playid: Union[bool, str] = None):
if playid:
url = self.base + url
async with aiohttp.ClientSession() as session:
async with session.get(url) as response:
if response.status != 200:
return False
html = await response.text()
soup = BeautifulSoup(html, "html.parser")
search = None
for tag in soup.find_all("meta"):
if tag.get("property", None) == "og:title":
search = tag.get("content", None)
if search is None:
return False
results = VideosSearch(search, limit=1)
for result in (await results.next())["result"]:
title = result["title"]
ytlink = result["link"]
vidid = result["id"]
duration_min = result["duration"]
thumbnail = result["thumbnails"][0]["url"].split("?")[0]
track_details = {
"title": title,
"link": ytlink,
"vidid": vidid,
"duration_min": duration_min,
"thumb": thumbnail,
}
return track_details, vidid
async def playlist(self, url, playid: Union[bool, str] = None):
if playid:
url = self.base + url
playlist_id = url.split("playlist/")[1]
async with aiohttp.ClientSession() as session:
async with session.get(url) as response:
if response.status != 200:
return False
html = await response.text()
soup = BeautifulSoup(html, "html.parser")
applelinks = soup.find_all("meta", attrs={"property": "music:song"})
results = []
for item in applelinks:
try:
xx = (((item["content"]).split("album/")[1]).split("/")[0]).replace(
"-", " "
)
except:
xx = ((item["content"]).split("album/")[1]).split("/")[0]
results.append(xx)
return results, playlist_id