[soundcloud] Allow login using oauth token (#469)

Authored by: blackjack4494
This commit is contained in:
Tom-Oliver Heidel 2021-07-07 00:51:13 +02:00 committed by GitHub
parent 30d569d2ac
commit be05d5cff1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -4,7 +4,7 @@
import itertools import itertools
import re import re
import json import json
import random # import random
from .common import ( from .common import (
InfoExtractor, InfoExtractor,
@ -164,23 +164,11 @@ class SoundcloudIE(InfoExtractor):
}, },
# downloadable song # downloadable song
{ {
'url': 'https://soundcloud.com/oddsamples/bus-brakes', 'url': 'https://soundcloud.com/the80m/the-following',
'md5': '7624f2351f8a3b2e7cd51522496e7631', 'md5': '9ffcddb08c87d74fb5808a3c183a1d04',
'info_dict': { 'info_dict': {
'id': '128590877', 'id': '343609555',
'ext': 'mp3', 'ext': 'wav',
'title': 'Bus Brakes',
'description': 'md5:0053ca6396e8d2fd7b7e1595ef12ab66',
'uploader': 'oddsamples',
'uploader_id': '73680509',
'timestamp': 1389232924,
'upload_date': '20140109',
'duration': 17.346,
'license': 'cc-by-sa',
'view_count': int,
'like_count': int,
'comment_count': int,
'repost_count': int,
}, },
}, },
# private link, downloadable format # private link, downloadable format
@ -317,12 +305,13 @@ def _download_json(self, *args, **kwargs):
raise raise
def _real_initialize(self): def _real_initialize(self):
self._CLIENT_ID = self._downloader.cache.load('soundcloud', 'client_id') or "T5R4kgWS2PRf6lzLyIravUMnKlbIxQag" # 'EXLwg5lHTO2dslU5EePe3xkw0m1h86Cd' # 'YUKXoArFcqrlQn9tfNHvvyfnDISj04zk' self._CLIENT_ID = self._downloader.cache.load('soundcloud', 'client_id') or 'fXuVKzsVXlc6tzniWWS31etd7VHWFUuN' # persistent `client_id`
self._login() self._login()
_USER_AGENT = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.105 Safari/537.36" _USER_AGENT = 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.105 Safari/537.36'
_API_AUTH_QUERY_TEMPLATE = '?client_id=%s' _API_AUTH_QUERY_TEMPLATE = '?client_id=%s'
_API_AUTH_URL_PW = 'https://api-auth.soundcloud.com/web-auth/sign-in/password%s' _API_AUTH_URL_PW = 'https://api-auth.soundcloud.com/web-auth/sign-in/password%s'
_API_VERIFY_AUTH_TOKEN = 'https://api-auth.soundcloud.com/connect/session%s'
_access_token = None _access_token = None
_HEADERS = {} _HEADERS = {}
_NETRC_MACHINE = 'soundcloud' _NETRC_MACHINE = 'soundcloud'
@ -332,6 +321,23 @@ def _login(self):
if username is None: if username is None:
return return
if username == 'oauth' and password is not None:
self._access_token = password
query = self._API_AUTH_QUERY_TEMPLATE % self._CLIENT_ID
payload = {'session': {'access_token': self._access_token}}
token_verification = sanitized_Request(self._API_VERIFY_AUTH_TOKEN % query, json.dumps(payload).encode('utf-8'))
response = self._download_json(token_verification, None, note='Verifying login token...', fatal=False)
if response is not False:
self._HEADERS = {'Authorization': 'OAuth ' + self._access_token}
self.report_login()
else:
self.report_warning('Provided authorization token seems to be invalid. Continue as guest')
elif username is not None:
self.report_warning(
'Login using username and password is not currently supported. '
'Use "--user oauth --password <oauth_token>" to login using an oauth token')
r'''
def genDevId(): def genDevId():
def genNumBlock(): def genNumBlock():
return ''.join([str(random.randrange(10)) for i in range(6)]) return ''.join([str(random.randrange(10)) for i in range(6)])
@ -358,6 +364,7 @@ def genNumBlock():
self.report_warning('Unable to get access token, login may has failed') self.report_warning('Unable to get access token, login may has failed')
else: else:
self._HEADERS = {'Authorization': 'OAuth ' + self._access_token} self._HEADERS = {'Authorization': 'OAuth ' + self._access_token}
'''
# signature generation # signature generation
def sign(self, user, pw, clid): def sign(self, user, pw, clid):
@ -370,9 +377,9 @@ def sign(self, user, pw, clid):
b = 37 b = 37
k = 37 k = 37
c = 5 c = 5
n = "0763ed7314c69015fd4a0dc16bbf4b90" # _KEY n = '0763ed7314c69015fd4a0dc16bbf4b90' # _KEY
y = "8" # _REV y = '8' # _REV
r = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.105 Safari/537.36" # _USER_AGENT r = 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.105 Safari/537.36' # _USER_AGENT
e = user # _USERNAME e = user # _USERNAME
t = clid # _CLIENT_ID t = clid # _CLIENT_ID