class MotherlessPaginatedIE(InfoExtractor):
+ _EXTRA_QUERY = {}
_PAGE_SIZE = 60
def _correct_path(self, url, item_id):
def get_page(idx):
page = idx + 1
current_page = webpage if not idx else self._download_webpage(
- real_url, item_id, note=f'Downloading page {page}', query={'page': page})
+ real_url, item_id, note=f'Downloading page {page}', query={'page': page, **self._EXTRA_QUERY})
yield from self._extract_entries(current_page, real_url)
return self.playlist_result(
'url': 'http://motherless.com/gv/movie_scenes',
'info_dict': {
'id': 'movie_scenes',
- 'title': 'Movie Scenes',
+ 'title': 'Movie Scenes - Videos - Hot and sexy scenes from "regular" movies... Beautiful actresses fully',
},
'playlist_mincount': 540,
}, {
'id': '338999F',
'title': 'Random',
},
- 'playlist_mincount': 190,
+ 'playlist_mincount': 171,
}, {
'url': 'https://motherless.com/GVABD6213',
'info_dict': {
def _correct_path(self, url, item_id):
return urllib.parse.urljoin(url, f'/GV{item_id}')
+
+
+class MotherlessUploaderIE(MotherlessPaginatedIE):
+ _VALID_URL = r'https?://(?:www\.)?motherless\.com/u/(?P<id>\w+)/?(?:$|[?#])'
+ _TESTS = [{
+ 'url': 'https://motherless.com/u/Mrgo4hrs2023',
+ 'info_dict': {
+ 'id': 'Mrgo4hrs2023',
+ 'title': "Mrgo4hrs2023's Uploads - Videos",
+ },
+ 'playlist_mincount': 32,
+ }, {
+ 'url': 'https://motherless.com/u/Happy_couple?t=v',
+ 'info_dict': {
+ 'id': 'Happy_couple',
+ 'title': "Happy_couple's Uploads - Videos",
+ },
+ 'playlist_mincount': 8,
+ }]
+
+ _EXTRA_QUERY = {'t': 'v'}
+
+ def _correct_path(self, url, item_id):
+ return urllib.parse.urljoin(url, f'/u/{item_id}?t=v')