bongacams.py (2395B)
- # coding: utf-8
- from __future__ import unicode_literals
- import re
- from .common import InfoExtractor
- from ..compat import compat_str
- from ..utils import (
- int_or_none,
- try_get,
- urlencode_postdata,
- )
- class BongaCamsIE(InfoExtractor):
- _VALID_URL = r'https?://(?P<host>(?:[^/]+\.)?bongacams\d*\.(?:com|net))/(?P<id>[^/?&#]+)'
- _TESTS = [{
- 'url': 'https://de.bongacams.com/azumi-8',
- 'only_matching': True,
- }, {
- 'url': 'https://cn.bongacams.com/azumi-8',
- 'only_matching': True,
- }, {
- 'url': 'https://de.bongacams.net/claireashton',
- 'info_dict': {
- 'id': 'claireashton',
- 'ext': 'mp4',
- 'title': r're:ClaireAshton \d{4}-\d{2}-\d{2} \d{2}:\d{2}',
- 'age_limit': 18,
- 'uploader_id': 'ClaireAshton',
- 'uploader': 'ClaireAshton',
- 'like_count': int,
- 'is_live': True,
- },
- 'params': {
- 'skip_download': True,
- },
- }]
- def _real_extract(self, url):
- mobj = re.match(self._VALID_URL, url)
- host = mobj.group('host')
- channel_id = mobj.group('id')
- amf = self._download_json(
- 'https://%s/tools/amf.php' % host, channel_id,
- data=urlencode_postdata((
- ('method', 'getRoomData'),
- ('args[]', channel_id),
- ('args[]', 'false'),
- )), headers={'X-Requested-With': 'XMLHttpRequest'})
- server_url = amf['localData']['videoServerUrl']
- uploader_id = try_get(
- amf, lambda x: x['performerData']['username'], compat_str) or channel_id
- uploader = try_get(
- amf, lambda x: x['performerData']['displayName'], compat_str)
- like_count = int_or_none(try_get(
- amf, lambda x: x['performerData']['loversCount']))
- formats = self._extract_m3u8_formats(
- '%s/hls/stream_%s/playlist.m3u8' % (server_url, uploader_id),
- channel_id, 'mp4', m3u8_id='hls', live=True)
- self._sort_formats(formats)
- return {
- 'id': channel_id,
- 'title': self._live_title(uploader or uploader_id),
- 'uploader': uploader,
- 'uploader_id': uploader_id,
- 'like_count': like_count,
- 'age_limit': 18,
- 'is_live': True,
- 'formats': formats,
- }