Spaces:
Paused
Paused
from tmdbv3api import TMDb, Movie, TV | |
import requests | |
import logging | |
from bs4 import BeautifulSoup,SoupStrainer | |
from datetime import datetime | |
import dateparser | |
from convert import get_TMDb_id_from_IMDb_id | |
from info import get_info_tmdb, is_movie, get_info_imdb | |
import config | |
import re | |
import json | |
LC_DOMAIN = config.LC_DOMAIN | |
async def search(showname,date,season,episode,ismovie,client): | |
cookies = { | |
'csrftoken': '7lvc502CZe8Zbx7iSX1xkZOBA1NbDxJZ', | |
} | |
headers = { | |
'authority': f'lordchannel.{LC_DOMAIN}', | |
'accept': '*/*', | |
'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7', | |
# 'cookie': 'csrftoken=7lvc502CZe8Zbx7iSX1xkZOBA1NbDxJZ', | |
'referer': f'https://lordchannel.{LC_DOMAIN}/anime/anime-ita/', | |
'sec-ch-ua': '"Not-A.Brand";v="99", "Chromium";v="124"', | |
'sec-ch-ua-mobile': '?0', | |
'sec-ch-ua-platform': '"Android"', | |
'sec-fetch-dest': 'empty', | |
'sec-fetch-mode': 'cors', | |
'sec-fetch-site': 'same-origin', | |
'user-agent': 'Mozilla/5.0 (Linux; Android 10; K) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36', | |
'x-requested-with': 'XMLHttpRequest', | |
} | |
params = { | |
'media': showname, | |
'_': '1724421723999', | |
} | |
response = await client.get(f'https://lordchannel.{LC_DOMAIN}/live_search/', params=params, cookies=cookies, headers=headers, follow_redirects=True) | |
data = json.loads(response.text) | |
for entry in data['data']: | |
if entry is not None: # check if the a_tag exists | |
href = entry['url'] | |
quality = entry['qualit\u00e0_video'] | |
link = f'https://lordchannel.{LC_DOMAIN}{href}' | |
response = await client.get(link, follow_redirects=True) | |
soup2 = BeautifulSoup(response.text,'lxml') | |
li_tag = soup2.select_one("ul.card__meta li:nth-of-type(2)") | |
if li_tag is not None: # check if the li_tag exists | |
card_date = li_tag.text[-4:] | |
if card_date == date: | |
if ismovie == 1: | |
video_url = soup2.find('a', class_="btn-streaming streaming_btn") | |
video_url = video_url['href'] | |
return video_url,quality | |
elif ismovie == 0: | |
div = soup2.find('div', id=f'collapse{season}') | |
episode = episode -1 #Index start from 0 so I need to subtract 1 | |
episode = div.select('tr')[2] # index is 2 because we want the correct element | |
video_url = href = episode.find('a').get('href') | |
return video_url,quality | |
else: | |
print("Sadly date are not equals") | |
continue | |
async def get_m3u8(video_url,client): | |
response = await client.get(video_url, follow_redirects=True) | |
pattern = r'const videoData = \[(.*?)\];' | |
match = re.search(pattern, response.text) | |
if match: | |
video_data = match.group(1).strip().split(', ') | |
url = video_data[0] | |
return url | |
async def lordchannel(imdb,client): | |
try: | |
general = is_movie(imdb) | |
ismovie = general[0] | |
imdb_id = general[1] | |
type = "LordChannel" | |
if ismovie == 0: | |
season = int(general[2]) | |
episode = int(general[3]) | |
if "tt" in imdb: | |
tmdba = await get_TMDb_id_from_IMDb_id(imdb_id,client) | |
else: | |
tmdba = imdb_id | |
else: | |
season = None | |
episode = None | |
if "tt" in imdb: | |
tmdba = await get_TMDb_id_from_IMDb_id(imdb_id,client) | |
else: | |
tmdba = imdb_id | |
showname,date = get_info_tmdb(tmdba,ismovie,type) | |
video_url,quality = await search(showname,date,season,episode,ismovie,client) | |
url = await get_m3u8(video_url,client) | |
url = url.replace('"','') | |
print(url) | |
return url,quality | |
except: | |
print("Lordchannel Failed") | |
return None,None | |