]>
jfr.im git - yt-dlp.git/blob - yt_dlp/extractor/vine.py
2 from __future__
import unicode_literals
5 from .common
import InfoExtractor
6 from ..compat
import compat_str
15 class VineIE(InfoExtractor
):
16 _VALID_URL
= r
'https?://(?:www\.)?vine\.co/(?:v|oembed)/(?P<id>\w+)'
18 'url': 'https://vine.co/v/b9KOOWX7HUx',
19 'md5': '2f36fed6235b16da96ce9b4dc890940d',
24 'alt_title': 'Vine by Jack',
25 'timestamp': 1368997951,
26 'upload_date': '20130519',
35 'url': 'https://vine.co/v/e192BnZnZ9V',
39 'title': 'ยิ้ม~ เขิน~ อาย~ น่าร้ากอ้ะ >//< @n_whitewo @orlameena #lovesicktheseries #lovesickseason2',
40 'alt_title': 'Vine by Pimry_zaa',
41 'timestamp': 1436057405,
42 'upload_date': '20150705',
43 'uploader': 'Pimry_zaa',
44 'uploader_id': '1135760698325307392',
51 'skip_download': True,
54 'url': 'https://vine.co/v/MYxVapFvz2z',
55 'only_matching': True,
57 'url': 'https://vine.co/v/bxVjBbZlPUH',
58 'only_matching': True,
60 'url': 'https://vine.co/oembed/MYxVapFvz2z.json',
61 'only_matching': True,
64 def _real_extract(self
, url
):
65 video_id
= self
._match
_id
(url
)
67 data
= self
._download
_json
(
68 'https://archive.vine.co/posts/%s.json' % video_id
, video_id
)
71 for url_suffix
in ('Url', 'URL'):
72 format_url
= data
.get('video%s%s' % (kind
, url_suffix
))
77 for quality
, format_id
in enumerate(('low', '', 'dash')):
78 format_url
= video_url(format_id
.capitalize())
81 # DASH link returns plain mp4
82 if format_id
== 'dash' and determine_ext(format_url
) == 'mpd':
83 formats
.extend(self
._extract
_mpd
_formats
(
84 format_url
, video_id
, mpd_id
='dash', fatal
=False))
88 'format_id': format_id
or 'standard',
91 self
._check
_formats
(formats
, video_id
)
92 self
._sort
_formats
(formats
)
94 username
= data
.get('username')
96 alt_title
= format_field(username
, template
='Vine by %s')
100 'title': data
.get('description') or alt_title
or 'Vine video',
101 'alt_title': alt_title
,
102 'thumbnail': data
.get('thumbnailUrl'),
103 'timestamp': unified_timestamp(data
.get('created')),
104 'uploader': username
,
105 'uploader_id': data
.get('userIdStr'),
106 'view_count': int_or_none(data
.get('loops')),
107 'like_count': int_or_none(data
.get('likes')),
108 'comment_count': int_or_none(data
.get('comments')),
109 'repost_count': int_or_none(data
.get('reposts')),
114 class VineUserIE(InfoExtractor
):
115 IE_NAME
= 'vine:user'
116 _VALID_URL
= r
'https?://vine\.co/(?P<u>u/)?(?P<user>[^/]+)'
117 _VINE_BASE_URL
= 'https://vine.co/'
119 'url': 'https://vine.co/itsruthb',
123 'description': '| Instagram/Twitter: itsruthb | still a lost boy from neverland',
125 'playlist_mincount': 611,
127 'url': 'https://vine.co/u/942914934646415360',
128 'only_matching': True,
132 def suitable(cls
, url
):
133 return False if VineIE
.suitable(url
) else super(VineUserIE
, cls
).suitable(url
)
135 def _real_extract(self
, url
):
136 mobj
= self
._match
_valid
_url
(url
)
137 user
= mobj
.group('user')
140 profile_url
= '%sapi/users/profiles/%s%s' % (
141 self
._VINE
_BASE
_URL
, 'vanity/' if not u
else '', user
)
142 profile_data
= self
._download
_json
(
143 profile_url
, user
, note
='Downloading user profile data')
145 data
= profile_data
['data']
146 user_id
= data
.get('userId') or data
['userIdStr']
147 profile
= self
._download
_json
(
148 'https://archive.vine.co/profiles/%s.json' % user_id
, user_id
)
151 'https://vine.co/v/%s' % post_id
, ie
='Vine', video_id
=post_id
)
152 for post_id
in profile
['posts']
153 if post_id
and isinstance(post_id
, compat_str
)]
154 return self
.playlist_result(
155 entries
, user
, profile
.get('username'), profile
.get('description'))