|
|
@ -384,27 +384,24 @@ class SoundcloudUserIE(SoundcloudIE): |
|
|
|
resource = mobj.group('rsrc') or 'all' |
|
|
|
base_url = self._BASE_URL_MAP[resource] % user['id'] |
|
|
|
|
|
|
|
next_href = None |
|
|
|
COMMON_QUERY = { |
|
|
|
'limit': 50, |
|
|
|
'client_id': self._CLIENT_ID, |
|
|
|
'linked_partitioning': '1', |
|
|
|
} |
|
|
|
|
|
|
|
query = COMMON_QUERY.copy() |
|
|
|
query['offset'] = 0 |
|
|
|
|
|
|
|
next_href = base_url + '?' + compat_urllib_parse.urlencode(query) |
|
|
|
|
|
|
|
entries = [] |
|
|
|
for i in itertools.count(): |
|
|
|
if not next_href: |
|
|
|
data = compat_urllib_parse.urlencode({ |
|
|
|
'offset': i * 50, |
|
|
|
'limit': 50, |
|
|
|
'client_id': self._CLIENT_ID, |
|
|
|
'linked_partitioning': '1', |
|
|
|
'representation': 'speedy', |
|
|
|
}) |
|
|
|
next_href = base_url + '?' + data |
|
|
|
|
|
|
|
response = self._download_json( |
|
|
|
next_href, uploader, 'Downloading track page %s' % (i + 1)) |
|
|
|
|
|
|
|
collection = response['collection'] |
|
|
|
|
|
|
|
if not collection: |
|
|
|
self.to_screen('%s: End page received' % uploader) |
|
|
|
break |
|
|
|
|
|
|
|
def resolve_permalink_url(candidates): |
|
|
@ -419,12 +416,15 @@ class SoundcloudUserIE(SoundcloudIE): |
|
|
|
if permalink_url: |
|
|
|
entries.append(self.url_result(permalink_url)) |
|
|
|
|
|
|
|
if 'next_href' in response: |
|
|
|
next_href = response['next_href'] |
|
|
|
if not next_href: |
|
|
|
break |
|
|
|
else: |
|
|
|
next_href = None |
|
|
|
next_href = response.get('next_href') |
|
|
|
if not next_href: |
|
|
|
break |
|
|
|
|
|
|
|
parsed_next_href = compat_urlparse.urlparse(response['next_href']) |
|
|
|
qs = compat_urlparse.parse_qs(parsed_next_href.query) |
|
|
|
qs.update(COMMON_QUERY) |
|
|
|
next_href = compat_urlparse.urlunparse( |
|
|
|
parsed_next_href._replace(query=compat_urllib_parse.urlencode(qs, True))) |
|
|
|
|
|
|
|
return { |
|
|
|
'_type': 'playlist', |
|
|
|