mirror of
https://github.com/spaam/svtplay-dl.git
synced 2024-11-30 15:14:14 +01:00
33 lines
1.4 KiB
Python
33 lines
1.4 KiB
Python
import copy
|
|
import json
|
|
import re
|
|
from urllib.parse import unquote_plus
|
|
|
|
from svtplay_dl.error import ServiceError
|
|
from svtplay_dl.fetcher.http import HTTP
|
|
from svtplay_dl.service import OpenGraphThumbMixin
|
|
from svtplay_dl.service import Service
|
|
|
|
|
|
class Facebook(Service, OpenGraphThumbMixin):
|
|
supported_domains_re = ["www.facebook.com"]
|
|
|
|
def get(self):
|
|
data = self.get_urldata()
|
|
|
|
match = re.search('params","([^"]+)"', data)
|
|
if not match:
|
|
yield ServiceError("Cant find params info. video need to be public.")
|
|
return
|
|
data2 = json.loads(f'["{match.group(1)}"]')
|
|
data2 = json.loads(unquote_plus(data2[0]))
|
|
if "sd_src_no_ratelimit" in data2["video_data"]["progressive"][0]:
|
|
yield HTTP(copy.copy(self.config), data2["video_data"]["progressive"][0]["sd_src_no_ratelimit"], "240", output=self.output)
|
|
else:
|
|
yield HTTP(copy.copy(self.config), data2["video_data"]["progressive"][0]["sd_src"], "240")
|
|
if "hd_src_no_ratelimit" in data2["video_data"]["progressive"][0]:
|
|
yield HTTP(copy.copy(self.config), data2["video_data"]["progressive"][0]["hd_src_no_ratelimit"], "720", output=self.output)
|
|
else:
|
|
if data2["video_data"]["progressive"][0]["hd_src"]:
|
|
yield HTTP(copy.copy(self.config), data2["video_data"]["progressive"][0]["hd_src"], "720", output=self.output)
|