1
0
Fork 0
mirror of synced 2024-06-29 03:21:19 +12:00
bulk-downloader-for-reddit/bulkredditdownloader/site_downloaders/download_factory.py

32 lines
1.2 KiB
Python
Raw Normal View History

2021-02-11 12:09:37 +13:00
#!/usr/bin/env python3
# coding=utf-8
import re
from typing import Type
from bulkredditdownloader.errors import NotADownloadableLinkError
from bulkredditdownloader.site_downloaders.base_downloader import BaseDownloader
from bulkredditdownloader.site_downloaders.direct import Direct
from bulkredditdownloader.site_downloaders.erome import Erome
from bulkredditdownloader.site_downloaders.gfycat import Gfycat
from bulkredditdownloader.site_downloaders.imgur import Imgur
from bulkredditdownloader.site_downloaders.redgifs import Redgifs
class DownloadFactory:
@staticmethod
def pull_lever(url: str) -> Type[BaseDownloader]:
url_beginning = r'\s*(https?://(www.)?)'
if re.match(url_beginning + r'gfycat.com.*', url):
return Gfycat
elif re.match(url_beginning + r'erome.com.*', url):
return Erome
elif re.match(url_beginning + r'imgur.*', url):
return Imgur
elif re.match(url_beginning + r'redgifs.com', url):
return Redgifs
elif re.match(url_beginning + r'[vi].redd\.it.*', url):
return Direct
else:
raise NotADownloadableLinkError('No downloader module exists for url {}'.format(url))