logo

oasis-root

Compiled tree of Oasis Linux based on own branch at <https://hacktivis.me/git/oasis/> git clone https://anongit.hacktivis.me/git/oasis-root.git

noodlemagazine.py (3021B)


  1. from .common import InfoExtractor
  2. from ..utils import (
  3. int_or_none,
  4. parse_count,
  5. parse_duration,
  6. unified_strdate,
  7. urljoin,
  8. )
  9. from ..utils.traversal import traverse_obj
  10. class NoodleMagazineIE(InfoExtractor):
  11. _VALID_URL = r'https?://(?:www|adult\.)?noodlemagazine\.com/watch/(?P<id>[0-9-_]+)'
  12. _TEST = {
  13. 'url': 'https://adult.noodlemagazine.com/watch/-67421364_456239604',
  14. 'md5': '9e02aa763612929d0b4b850591a9248b',
  15. 'info_dict': {
  16. 'id': '-67421364_456239604',
  17. 'title': 'Aria alexander manojob',
  18. 'thumbnail': r're:^https://.*\.jpg',
  19. 'ext': 'mp4',
  20. 'duration': 903,
  21. 'view_count': int,
  22. 'like_count': int,
  23. 'description': 'Aria alexander manojob',
  24. 'tags': ['aria', 'alexander', 'manojob'],
  25. 'upload_date': '20190218',
  26. 'age_limit': 18,
  27. },
  28. }
  29. def _real_extract(self, url):
  30. video_id = self._match_id(url)
  31. webpage = self._download_webpage(url, video_id)
  32. title = self._og_search_title(webpage)
  33. duration = parse_duration(self._html_search_meta('video:duration', webpage, 'duration', default=None))
  34. description = self._og_search_property('description', webpage, default='').replace(' watch online hight quality video', '')
  35. tags = self._html_search_meta('video:tag', webpage, default='').split(', ')
  36. view_count = parse_count(self._html_search_meta('ya:ovs:views_total', webpage, default=None))
  37. like_count = parse_count(self._html_search_meta('ya:ovs:likes', webpage, default=None))
  38. upload_date = unified_strdate(self._html_search_meta('ya:ovs:upload_date', webpage, default=''))
  39. def build_url(url_or_path):
  40. return urljoin('https://adult.noodlemagazine.com', url_or_path)
  41. playlist_info = self._search_json(
  42. r'window\.playlist\s*=', webpage, video_id, 'playlist info')
  43. formats = []
  44. for source in traverse_obj(playlist_info, ('sources', lambda _, v: v['file'])):
  45. if source.get('type') == 'hls':
  46. formats.extend(self._extract_m3u8_formats(
  47. build_url(source['file']), video_id, 'mp4', fatal=False, m3u8_id='hls'))
  48. else:
  49. formats.append(traverse_obj(source, {
  50. 'url': ('file', {build_url}),
  51. 'format_id': 'label',
  52. 'height': ('label', {int_or_none}),
  53. 'ext': 'type',
  54. }))
  55. return {
  56. 'id': video_id,
  57. 'formats': formats,
  58. 'title': title,
  59. 'thumbnail': self._og_search_property('image', webpage, default=None) or playlist_info.get('image'),
  60. 'duration': duration,
  61. 'description': description,
  62. 'tags': tags,
  63. 'view_count': view_count,
  64. 'like_count': like_count,
  65. 'upload_date': upload_date,
  66. 'age_limit': 18,
  67. }