Merge pull request #149 from mbirtwell/python3_with_six

Use six to simplify python 2/3 compatibilty code where possible
This commit is contained in:
Paul Lamere 2017-01-07 10:55:43 -05:00 committed by GitHub
commit f638b0c59b
5 changed files with 22 additions and 31 deletions

View File

@ -1 +1,2 @@
requests==2.3.0 requests==2.3.0
six==1.10.0

View File

@ -7,6 +7,9 @@ setup(
author="@plamere", author="@plamere",
author_email="paul@echonest.com", author_email="paul@echonest.com",
url='http://spotipy.readthedocs.org/', url='http://spotipy.readthedocs.org/',
install_requires=['requests>=1.0'], install_requires=[
'requests>=1.0',
'six>=1.10.0',
],
license='LICENSE.txt', license='LICENSE.txt',
packages=['spotipy']) packages=['spotipy'])

View File

@ -7,6 +7,8 @@ import requests
import json import json
import time import time
import six
''' A simple and thin Python library for the Spotify Web API ''' A simple and thin Python library for the Spotify Web API
''' '''
@ -418,12 +420,7 @@ class Spotify(object):
- collaborative - optional is the playlist collaborative - collaborative - optional is the playlist collaborative
''' '''
data = {} data = {}
# Add Python2 and Python3 compatibility checking string types if isinstance(name, six.string_types):
try:
basestring
except NameError:
basestring = str
if isinstance(name, basestring):
data['name'] = name data['name'] = name
if isinstance(public, bool): if isinstance(public, bool):
data['public'] = public data['public'] = public

View File

@ -8,18 +8,19 @@ import time
import sys import sys
# Workaround to support both python 2 & 3 # Workaround to support both python 2 & 3
try: import six
import urllib.request, urllib.error import six.moves.urllib.parse as urllibparse
import urllib.parse as urllibparse
except ImportError:
import urllib as urllibparse
class SpotifyOauthError(Exception): class SpotifyOauthError(Exception):
pass pass
def _make_authorization_headers(client_id, client_secret):
auth_header = base64.b64encode(six.text_type(client_id + ':' + client_secret).encode('ascii'))
return {'Authorization': 'Basic %s' % auth_header.decode('ascii')}
class SpotifyClientCredentials(object): class SpotifyClientCredentials(object):
OAUTH_TOKEN_URL = 'https://accounts.spotify.com/api/token' OAUTH_TOKEN_URL = 'https://accounts.spotify.com/api/token'
@ -63,12 +64,7 @@ class SpotifyClientCredentials(object):
"""Gets client credentials access token """ """Gets client credentials access token """
payload = { 'grant_type': 'client_credentials'} payload = { 'grant_type': 'client_credentials'}
if sys.version_info[0] >= 3: # Python 3 headers = _make_authorization_headers(self.client_id, self.client_secret)
auth_header = base64.b64encode(str(self.client_id + ':' + self.client_secret).encode())
headers = {'Authorization': 'Basic %s' % auth_header.decode()}
else: # Python 2
auth_header = base64.b64encode(self.client_id + ':' + self.client_secret)
headers = {'Authorization': 'Basic %s' % auth_header}
response = requests.post(self.OAUTH_TOKEN_URL, data=payload, response = requests.post(self.OAUTH_TOKEN_URL, data=payload,
headers=headers, verify=True, proxies=self.proxies) headers=headers, verify=True, proxies=self.proxies)
@ -191,6 +187,9 @@ class SpotifyOAuth(object):
except IndexError: except IndexError:
return None return None
def _make_authorization_headers(self):
return _make_authorization_headers(self.client_id, self.client_secret)
def get_access_token(self, code): def get_access_token(self, code):
""" Gets the access token for the app given the code """ Gets the access token for the app given the code
@ -206,12 +205,7 @@ class SpotifyOAuth(object):
if self.state: if self.state:
payload['state'] = self.state payload['state'] = self.state
if sys.version_info[0] >= 3: # Python 3 headers = self._make_authorization_headers()
auth_header = base64.b64encode(str(self.client_id + ':' + self.client_secret).encode())
headers = {'Authorization': 'Basic %s' % auth_header.decode()}
else: # Python 2
auth_header = base64.b64encode(self.client_id + ':' + self.client_secret)
headers = {'Authorization': 'Basic %s' % auth_header}
response = requests.post(self.OAUTH_TOKEN_URL, data=payload, response = requests.post(self.OAUTH_TOKEN_URL, data=payload,
headers=headers, verify=True, proxies=self.proxies) headers=headers, verify=True, proxies=self.proxies)
@ -234,12 +228,7 @@ class SpotifyOAuth(object):
payload = { 'refresh_token': refresh_token, payload = { 'refresh_token': refresh_token,
'grant_type': 'refresh_token'} 'grant_type': 'refresh_token'}
if sys.version_info[0] >= 3: # Python 3 headers = self._make_authorization_headers()
auth_header = base64.b64encode(str(self.client_id + ':' + self.client_secret).encode())
headers = {'Authorization': 'Basic %s' % auth_header.decode()}
else: # Python 2
auth_header = base64.b64encode(self.client_id + ':' + self.client_secret)
headers = {'Authorization': 'Basic %s' % auth_header}
response = requests.post(self.OAUTH_TOKEN_URL, data=payload, response = requests.post(self.OAUTH_TOKEN_URL, data=payload,
headers=headers, proxies=self.proxies) headers=headers, proxies=self.proxies)

View File

@ -3,5 +3,6 @@ envlist = py27,py34
[testenv] [testenv]
deps= deps=
requests requests
six
py27: mock py27: mock
commands=python -m unittest discover tests commands=python -m unittest discover tests