commit
b632fd089b
4 changed files with 60 additions and 0 deletions
|
@ -13,6 +13,7 @@ from bdfr.site_downloaders.fallback_downloaders.youtubedl_fallback import Youtub
|
||||||
from bdfr.site_downloaders.gallery import Gallery
|
from bdfr.site_downloaders.gallery import Gallery
|
||||||
from bdfr.site_downloaders.gfycat import Gfycat
|
from bdfr.site_downloaders.gfycat import Gfycat
|
||||||
from bdfr.site_downloaders.imgur import Imgur
|
from bdfr.site_downloaders.imgur import Imgur
|
||||||
|
from bdfr.site_downloaders.pornhub import PornHub
|
||||||
from bdfr.site_downloaders.redgifs import Redgifs
|
from bdfr.site_downloaders.redgifs import Redgifs
|
||||||
from bdfr.site_downloaders.self_post import SelfPost
|
from bdfr.site_downloaders.self_post import SelfPost
|
||||||
from bdfr.site_downloaders.youtube import Youtube
|
from bdfr.site_downloaders.youtube import Youtube
|
||||||
|
@ -43,6 +44,8 @@ class DownloadFactory:
|
||||||
return Youtube
|
return Youtube
|
||||||
elif re.match(r'i\.redd\.it.*', sanitised_url):
|
elif re.match(r'i\.redd\.it.*', sanitised_url):
|
||||||
return Direct
|
return Direct
|
||||||
|
elif re.match(r'pornhub\.com.*', sanitised_url):
|
||||||
|
return PornHub
|
||||||
elif YoutubeDlFallback.can_handle_link(sanitised_url):
|
elif YoutubeDlFallback.can_handle_link(sanitised_url):
|
||||||
return YoutubeDlFallback
|
return YoutubeDlFallback
|
||||||
else:
|
else:
|
||||||
|
|
30
bdfr/site_downloaders/pornhub.py
Normal file
30
bdfr/site_downloaders/pornhub.py
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
#!/usr/bin/env python3
|
||||||
|
# coding=utf-8
|
||||||
|
|
||||||
|
import logging
|
||||||
|
import tempfile
|
||||||
|
from pathlib import Path
|
||||||
|
from typing import Optional
|
||||||
|
|
||||||
|
import youtube_dl
|
||||||
|
from praw.models import Submission
|
||||||
|
|
||||||
|
from bdfr.exceptions import NotADownloadableLinkError, SiteDownloaderError
|
||||||
|
from bdfr.resource import Resource
|
||||||
|
from bdfr.site_authenticator import SiteAuthenticator
|
||||||
|
from bdfr.site_downloaders.youtube import Youtube
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
class PornHub(Youtube):
|
||||||
|
def __init__(self, post: Submission):
|
||||||
|
super().__init__(post)
|
||||||
|
|
||||||
|
def find_resources(self, authenticator: Optional[SiteAuthenticator] = None) -> list[Resource]:
|
||||||
|
ytdl_options = {
|
||||||
|
'format': 'best',
|
||||||
|
'nooverwrites': True,
|
||||||
|
}
|
||||||
|
out = self._download_video(ytdl_options)
|
||||||
|
return [out]
|
|
@ -13,6 +13,7 @@ from bdfr.site_downloaders.fallback_downloaders.youtubedl_fallback import Youtub
|
||||||
from bdfr.site_downloaders.gallery import Gallery
|
from bdfr.site_downloaders.gallery import Gallery
|
||||||
from bdfr.site_downloaders.gfycat import Gfycat
|
from bdfr.site_downloaders.gfycat import Gfycat
|
||||||
from bdfr.site_downloaders.imgur import Imgur
|
from bdfr.site_downloaders.imgur import Imgur
|
||||||
|
from bdfr.site_downloaders.pornhub import PornHub
|
||||||
from bdfr.site_downloaders.redgifs import Redgifs
|
from bdfr.site_downloaders.redgifs import Redgifs
|
||||||
from bdfr.site_downloaders.self_post import SelfPost
|
from bdfr.site_downloaders.self_post import SelfPost
|
||||||
from bdfr.site_downloaders.youtube import Youtube
|
from bdfr.site_downloaders.youtube import Youtube
|
||||||
|
@ -44,6 +45,7 @@ from bdfr.site_downloaders.youtube import Youtube
|
||||||
('https://streamable.com/dt46y', YoutubeDlFallback),
|
('https://streamable.com/dt46y', YoutubeDlFallback),
|
||||||
('https://vimeo.com/channels/31259/53576664', YoutubeDlFallback),
|
('https://vimeo.com/channels/31259/53576664', YoutubeDlFallback),
|
||||||
('http://video.pbs.org/viralplayer/2365173446/', YoutubeDlFallback),
|
('http://video.pbs.org/viralplayer/2365173446/', YoutubeDlFallback),
|
||||||
|
('https://www.pornhub.com/view_video.php?viewkey=ph5a2ee0461a8d0', PornHub),
|
||||||
))
|
))
|
||||||
def test_factory_lever_good(test_submission_url: str, expected_class: BaseDownloader, reddit_instance: praw.Reddit):
|
def test_factory_lever_good(test_submission_url: str, expected_class: BaseDownloader, reddit_instance: praw.Reddit):
|
||||||
result = DownloadFactory.pull_lever(test_submission_url)
|
result = DownloadFactory.pull_lever(test_submission_url)
|
||||||
|
|
25
tests/site_downloaders/test_pornhub.py
Normal file
25
tests/site_downloaders/test_pornhub.py
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
#!/usr/bin/env python3
|
||||||
|
# coding=utf-8
|
||||||
|
|
||||||
|
from unittest.mock import MagicMock
|
||||||
|
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
from bdfr.resource import Resource
|
||||||
|
from bdfr.site_downloaders.pornhub import PornHub
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.online
|
||||||
|
@pytest.mark.slow
|
||||||
|
@pytest.mark.parametrize(('test_url', 'expected_hash'), (
|
||||||
|
('https://www.pornhub.com/view_video.php?viewkey=ph5a2ee0461a8d0', '5f5294b9b97dbb7cb9cf8df278515621'),
|
||||||
|
))
|
||||||
|
def test_find_resources_good(test_url: str, expected_hash: str):
|
||||||
|
test_submission = MagicMock()
|
||||||
|
test_submission.url = test_url
|
||||||
|
downloader = PornHub(test_submission)
|
||||||
|
resources = downloader.find_resources()
|
||||||
|
assert len(resources) == 1
|
||||||
|
assert isinstance(resources[0], Resource)
|
||||||
|
resources[0].download(120)
|
||||||
|
assert resources[0].hash.hexdigest() == expected_hash
|
Loading…
Reference in a new issue