5 from .common
import InfoExtractor
15 class ChingariBaseIE(InfoExtractor
):
16 def _get_post(self
, id, post_data
):
17 media_data
= post_data
['mediaLocation']
18 base_url
= media_data
['base']
19 author_data
= post_data
.get('authorData', {})
20 song_data
= post_data
.get('song', {}) # revist this in future for differentiating b/w 'art' and 'author'
24 'width': str_to_int(frmt
[1:]),
25 'url': base_url
+ frmt_path
,
26 } for frmt
, frmt_path
in media_data
.get('transcoded', {}).items()]
28 if media_data
.get('path'):
30 'format_id': 'original',
31 'format_note': 'Direct video.',
32 'url': base_url
+ '/apipublic' + media_data
['path'],
35 self
._sort
_formats
(formats
)
36 timestamp
= str_to_int(post_data
.get('created_at'))
38 timestamp
= int_or_none(timestamp
, 1000)
40 thumbnail
, uploader_url
= None, None
41 if media_data
.get('thumbnail'):
42 thumbnail
= base_url
+ media_data
.get('thumbnail')
43 if author_data
.get('username'):
44 uploader_url
= 'https://chingari.io/' + author_data
.get('username')
48 'extractor_key': ChingariIE
.ie_key(),
49 'extractor': 'Chingari',
50 'title': urllib
.parse
.unquote_plus(clean_html(post_data
.get('caption'))),
51 'description': urllib
.parse
.unquote_plus(clean_html(post_data
.get('caption'))),
52 'duration': media_data
.get('duration'),
53 'thumbnail': url_or_none(thumbnail
),
54 'like_count': post_data
.get('likeCount'),
55 'view_count': post_data
.get('viewsCount'),
56 'comment_count': post_data
.get('commentCount'),
57 'repost_count': post_data
.get('shareCount'),
58 'timestamp': timestamp
,
59 'uploader_id': post_data
.get('userId') or author_data
.get('_id'),
60 'uploader': author_data
.get('name'),
61 'uploader_url': url_or_none(uploader_url
),
62 'track': song_data
.get('title'),
63 'artist': song_data
.get('author'),
68 class ChingariIE(ChingariBaseIE
):
69 _VALID_URL
= r
'https?://(?:www\.)?chingari\.io/share/post\?id=(?P<id>[^&/#?]+)'
71 'url': 'https://chingari.io/share/post?id=612f8f4ce1dc57090e8a7beb',
73 'id': '612f8f4ce1dc57090e8a7beb',
75 'title': 'Happy birthday Srila Prabhupada',
76 'description': 'md5:c7080ebfdfeb06016e638c286d6bc3fa',
78 'thumbnail': 'https://media.chingari.io/uploads/c41d30e2-06b6-4e3b-9b4b-edbb929cec06-1630506826911/thumbnail/198f993f-ce87-4623-82c6-cd071bd6d4f4-1630506828016.jpg',
83 'timestamp': 1630506828,
84 'upload_date': '20210901',
85 'uploader_id': '5f0403982c8bd344f4813f8c',
86 'uploader': 'ISKCON,Inc.',
87 'uploader_url': 'https://chingari.io/iskcon,inc',
91 'params': {'skip_download': True}
94 def _real_extract(self
, url
):
95 id = self
._match
_id
(url
)
96 post_json
= self
._download
_json
(f
'https://api.chingari.io/post/post_details/{id}', id)
97 if post_json
['code'] != 200:
98 raise ExtractorError(post_json
['message'], expected
=True)
99 post_data
= post_json
['data']
100 return self
._get
_post
(id, post_data
)
103 class ChingariUserIE(ChingariBaseIE
):
104 _VALID_URL
= r
'https?://(?:www\.)?chingari\.io/(?!share/post)(?P<id>[^/?]+)'
106 'url': 'https://chingari.io/dada1023',
110 'params': {'playlistend': 3}
,
112 'url': 'https://chingari.io/share/post?id=614781f3ade60b3a0bfff42a',
114 'id': '614781f3ade60b3a0bfff42a',
116 'title': '#chingaribappa ',
117 'description': 'md5:d1df21d84088770468fa63afe3b17857',
119 'thumbnail': 'https://media.chingari.io/uploads/346d86d4-abb2-474e-a164-ffccf2bbcb72-1632076273717/thumbnail/b0b3aac2-2b86-4dd1-909d-9ed6e57cf77c-1632076275552.jpg',
122 'comment_count': int,
124 'timestamp': 1632076275,
125 'upload_date': '20210919',
126 'uploader_id': '5efc4b12cca35c3d1794c2d3',
127 'uploader': 'dada (girish) dhawale',
128 'uploader_url': 'https://chingari.io/dada1023',
132 'params': {'skip_download': True}
134 'url': 'https://chingari.io/share/post?id=6146b132bcbf860959e12cba',
136 'id': '6146b132bcbf860959e12cba',
138 'title': 'Tactor harvesting',
139 'description': 'md5:8403f12dce68828b77ecee7eb7e887b7',
141 'thumbnail': 'https://media.chingari.io/uploads/b353ca70-7a87-400d-93a6-fa561afaec86-1632022814584/thumbnail/c09302e3-2043-41b1-a2fe-77d97e5bd676-1632022834260.jpg',
144 'comment_count': int,
146 'timestamp': 1632022834,
147 'upload_date': '20210919',
148 'uploader_id': '5efc4b12cca35c3d1794c2d3',
149 'uploader': 'dada (girish) dhawale',
150 'uploader_url': 'https://chingari.io/dada1023',
154 'params': {'skip_download': True}
156 'url': 'https://chingari.io/share/post?id=6145651b74cb030a64c40b82',
158 'id': '6145651b74cb030a64c40b82',
160 'title': '#odiabhajan ',
161 'description': 'md5:687ea36835b9276cf2af90f25e7654cb',
163 'thumbnail': 'https://media.chingari.io/uploads/6cbf216b-babc-4cce-87fe-ceaac8d706ac-1631937782708/thumbnail/8855754f-6669-48ce-b269-8cc0699ed6da-1631937819522.jpg',
166 'comment_count': int,
168 'timestamp': 1631937819,
169 'upload_date': '20210918',
170 'uploader_id': '5efc4b12cca35c3d1794c2d3',
171 'uploader': 'dada (girish) dhawale',
172 'uploader_url': 'https://chingari.io/dada1023',
176 'params': {'skip_download': True}
179 'url': 'https://chingari.io/iskcon%2Cinc',
180 'playlist_mincount': 1025,
182 'id': 'iskcon%2Cinc',
186 def _entries(self
, id):
189 for page
in itertools
.count():
190 posts
= self
._download
_json
('https://api.chingari.io/users/getPosts', id,
191 data
=json
.dumps({'userId': id, 'ownerId': id, 'skip': skip, 'limit': 20}
).encode(),
192 headers
={'content-type': 'application/json;charset=UTF-8'}
,
193 note
='Downloading page %s' % page
)
194 for post
in posts
.get('data', []):
195 post_data
= post
['post']
196 yield self
._get
_post
(post_data
['_id'], post_data
)
198 has_more
= posts
['hasMoreData']
202 def _real_extract(self
, url
):
203 alt_id
= self
._match
_id
(url
)
204 post_json
= self
._download
_json
(f
'https://api.chingari.io/user/{alt_id}', alt_id
)
205 if post_json
['code'] != 200:
206 raise ExtractorError(post_json
['message'], expected
=True)
207 id = post_json
['data']['_id']
208 return self
.playlist_result(self
._entries
(id), playlist_id
=alt_id
)