Handle Mediafire link when in Javascript
This commit is contained in:
parent
6ecb62431e
commit
0a0fb144c0
|
@ -286,34 +286,35 @@ def downloadFile(download_url, download_path, download_filename):
|
|||
def parseC3Universe(dl_link):
|
||||
try:
|
||||
p = requests.get(dl_link)
|
||||
if p.status_code != 200:
|
||||
raise HTTPError(dl_link, p.status_code, "", None, None)
|
||||
|
||||
parsed_html = BeautifulSoup(p.text, "html.parser")
|
||||
download_url = (
|
||||
download_element = (
|
||||
parsed_html.body.find("div", attrs={"class": "lock-head"})
|
||||
.find("a")
|
||||
.get("href")
|
||||
)
|
||||
download_url = download_element.get("href")
|
||||
return download_url
|
||||
except Exception as e:
|
||||
click.echo(f"Failed parsing or retrieving HTML link: {e}")
|
||||
return None
|
||||
|
||||
|
||||
def parseMediafire(dl_link):
|
||||
def parseMediafirePage(dl_link):
|
||||
try:
|
||||
p = requests.get(dl_link)
|
||||
if p.status_code != 200:
|
||||
raise HTTPError(dl_link, p.status_code, "", None, None)
|
||||
|
||||
parsed_html = BeautifulSoup(p.text, "html.parser")
|
||||
download_url = parsed_html.find(
|
||||
"a", attrs={"id": "downloadButton", "rel": "nofollow", "aria-label": "Download file"}
|
||||
).get("href")
|
||||
download_element = parsed_html.find(
|
||||
"a", attrs={"aria-label": "Download file"}
|
||||
)
|
||||
download_url = download_element.get("href")
|
||||
return download_url
|
||||
except Exception as e:
|
||||
return None
|
||||
|
||||
def parseMediafireJS(dl_link):
|
||||
try:
|
||||
p = requests.get(dl_link)
|
||||
download_url = re.find(r"'(http://download[0-9]+.mediafire.com/.*)';", p.text).group(1)
|
||||
return download_url
|
||||
except Exception as e:
|
||||
click.echo(f"Failed parsing or retrieving HTML link: {e}")
|
||||
return None
|
||||
|
||||
def downloadSong(destination, filename, entry, dlid, dldesc):
|
||||
|
@ -345,13 +346,16 @@ def downloadSong(destination, filename, entry, dlid, dldesc):
|
|||
if 'dl.c3universe.com' in dl_link['link']:
|
||||
download_url = parseC3Universe(dl_link["link"])
|
||||
elif 'www.mediafire.com' in dl_link["link"]:
|
||||
download_url = parseMediafire(dl_link["link"])
|
||||
download_url = parseMediafirePage(dl_link["link"])
|
||||
if download_url is None:
|
||||
download_url = parseMediafireJS(dl_link["link"])
|
||||
else:
|
||||
click.echo("Download URL is not valid for CLI download; skipping...")
|
||||
click.echo(f"URL: {dl_link['link']}")
|
||||
continue
|
||||
|
||||
if download_url is None:
|
||||
click.echo(f"Failed parsing or retrieving file URL from link {dl_link}, skipping...")
|
||||
continue
|
||||
|
||||
download_filename = filename.format(
|
||||
|
|
Loading…
Reference in New Issue