From 1a52dfdcbcd99e10a5f4ef28869b8b3f893ac51e Mon Sep 17 00:00:00 2001 From: Serene-Arc Date: Fri, 25 Jun 2021 17:47:49 +1000 Subject: [PATCH] Add PornHub module --- bdfr/site_downloaders/download_factory.py | 3 ++ bdfr/site_downloaders/pornhub.py | 30 +++++++++++++++++++ .../site_downloaders/test_download_factory.py | 2 ++ tests/site_downloaders/test_pornhub.py | 25 ++++++++++++++++ 4 files changed, 60 insertions(+) create mode 100644 bdfr/site_downloaders/pornhub.py create mode 100644 tests/site_downloaders/test_pornhub.py diff --git a/bdfr/site_downloaders/download_factory.py b/bdfr/site_downloaders/download_factory.py index 41813f9..911e8fb 100644 --- a/bdfr/site_downloaders/download_factory.py +++ b/bdfr/site_downloaders/download_factory.py @@ -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.gfycat import Gfycat 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.self_post import SelfPost from bdfr.site_downloaders.youtube import Youtube @@ -43,6 +44,8 @@ class DownloadFactory: return Youtube elif re.match(r'i\.redd\.it.*', sanitised_url): return Direct + elif re.match(r'pornhub\.com.*', sanitised_url): + return PornHub elif YoutubeDlFallback.can_handle_link(sanitised_url): return YoutubeDlFallback else: diff --git a/bdfr/site_downloaders/pornhub.py b/bdfr/site_downloaders/pornhub.py new file mode 100644 index 0000000..924a6b8 --- /dev/null +++ b/bdfr/site_downloaders/pornhub.py @@ -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] diff --git a/tests/site_downloaders/test_download_factory.py b/tests/site_downloaders/test_download_factory.py index 4b5356c..95b522d 100644 --- a/tests/site_downloaders/test_download_factory.py +++ b/tests/site_downloaders/test_download_factory.py @@ -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.gfycat import Gfycat 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.self_post import SelfPost from bdfr.site_downloaders.youtube import Youtube @@ -44,6 +45,7 @@ from bdfr.site_downloaders.youtube import Youtube ('https://streamable.com/dt46y', YoutubeDlFallback), ('https://vimeo.com/channels/31259/53576664', 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): result = DownloadFactory.pull_lever(test_submission_url) diff --git a/tests/site_downloaders/test_pornhub.py b/tests/site_downloaders/test_pornhub.py new file mode 100644 index 0000000..12144dd --- /dev/null +++ b/tests/site_downloaders/test_pornhub.py @@ -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