strava auth seems to work
This commit is contained in:
@@ -44,7 +44,8 @@ class RowerInline(admin.StackedInline):
|
|||||||
'polartoken','polartokenexpirydate',
|
'polartoken','polartokenexpirydate',
|
||||||
'polarrefreshtoken','polaruserid',
|
'polarrefreshtoken','polaruserid',
|
||||||
'polar_auto_import',
|
'polar_auto_import',
|
||||||
'stravatoken','stravaexportas','strava_auto_export',
|
'stravatoken','stravatokenexpirydate','stravarefreshtoken',
|
||||||
|
'stravaexportas','strava_auto_export',
|
||||||
'strava_auto_import',
|
'strava_auto_import',
|
||||||
'runkeepertoken','runkeeper_auto_export',)}),
|
'runkeepertoken','runkeeper_auto_export',)}),
|
||||||
('Team',
|
('Team',
|
||||||
|
|||||||
@@ -94,7 +94,7 @@ def imports_open(user,oauth_data):
|
|||||||
tokenname = oauth_data['tokenname']
|
tokenname = oauth_data['tokenname']
|
||||||
refreshtokenname = oauth_data['refreshtokenname']
|
refreshtokenname = oauth_data['refreshtokenname']
|
||||||
expirydatename = oauth_data['expirydatename']
|
expirydatename = oauth_data['expirydatename']
|
||||||
if tokenexpirydate and timezone.now()>tokenexpirydate:
|
if tokenexpirydate and timezone.now()+timedelta(seconds=3599)>tokenexpirydate:
|
||||||
token = imports_token_refresh(
|
token = imports_token_refresh(
|
||||||
user,
|
user,
|
||||||
tokenname,
|
tokenname,
|
||||||
@@ -102,6 +102,15 @@ def imports_open(user,oauth_data):
|
|||||||
expirydatename,
|
expirydatename,
|
||||||
oauth_data,
|
oauth_data,
|
||||||
)
|
)
|
||||||
|
elif tokenexpirydate is None and 'strava' in expirydatename:
|
||||||
|
token = imports_token_refresh(
|
||||||
|
user,
|
||||||
|
tokenname,
|
||||||
|
refreshtokenname,
|
||||||
|
expirydatename,
|
||||||
|
oauth_data,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
return token
|
return token
|
||||||
|
|
||||||
@@ -156,7 +165,11 @@ def imports_do_refresh_token(refreshtoken,oauth_data,access_token=''):
|
|||||||
try:
|
try:
|
||||||
expires_in = token_json['expires_in']
|
expires_in = token_json['expires_in']
|
||||||
except KeyError:
|
except KeyError:
|
||||||
expires_in = 0
|
try:
|
||||||
|
expires_at = arrow.get(token_json['expires_at']).timestamp
|
||||||
|
expires_in = expires_at - arrow.now().timestamp
|
||||||
|
except KeyError:
|
||||||
|
expires_in = 0
|
||||||
try:
|
try:
|
||||||
refresh_token = token_json['refresh_token']
|
refresh_token = token_json['refresh_token']
|
||||||
except KeyError:
|
except KeyError:
|
||||||
@@ -266,6 +279,11 @@ def imports_token_refresh(user,tokenname,refreshtokenname,expirydatename,oauth_d
|
|||||||
r = Rower.objects.get(user=user)
|
r = Rower.objects.get(user=user)
|
||||||
|
|
||||||
refreshtoken = getattr(r,refreshtokenname)
|
refreshtoken = getattr(r,refreshtokenname)
|
||||||
|
|
||||||
|
# for Strava transition
|
||||||
|
if not refreshtoken:
|
||||||
|
refreshtoken = getattr(r,tokenname)
|
||||||
|
|
||||||
|
|
||||||
res = imports_do_refresh_token(refreshtoken,oauth_data)
|
res = imports_do_refresh_token(refreshtoken,oauth_data)
|
||||||
access_token = res[0]
|
access_token = res[0]
|
||||||
|
|||||||
@@ -653,6 +653,9 @@ class Rower(models.Model):
|
|||||||
polar_auto_import = models.BooleanField(default=False)
|
polar_auto_import = models.BooleanField(default=False)
|
||||||
|
|
||||||
stravatoken = models.CharField(default='',max_length=200,blank=True,null=True)
|
stravatoken = models.CharField(default='',max_length=200,blank=True,null=True)
|
||||||
|
stravatokenexpirydate = models.DateTimeField(blank=True,null=True)
|
||||||
|
stravarefreshtoken = models.CharField(default='',max_length=1000,
|
||||||
|
blank=True,null=True)
|
||||||
stravaexportas = models.CharField(default="Rowing",
|
stravaexportas = models.CharField(default="Rowing",
|
||||||
max_length=30,
|
max_length=30,
|
||||||
choices=stravatypes,
|
choices=stravatypes,
|
||||||
|
|||||||
@@ -40,11 +40,11 @@ oauth_data = {
|
|||||||
'autorization_uri': "https://www.strava.com/oauth/authorize",
|
'autorization_uri': "https://www.strava.com/oauth/authorize",
|
||||||
'content_type': 'application/json',
|
'content_type': 'application/json',
|
||||||
'tokenname': 'stravatoken',
|
'tokenname': 'stravatoken',
|
||||||
'refreshtokenname': '',
|
'refreshtokenname': 'stravarefreshtoken',
|
||||||
'expirydatename': '',
|
'expirydatename': 'stravatokenexpirydate',
|
||||||
'bearer_auth': True,
|
'bearer_auth': True,
|
||||||
'base_url': "https://www.strava.com/oauth/token",
|
'base_url': "https://www.strava.com/oauth/token",
|
||||||
'grant_type': None,
|
'grant_type': 'refresh_token',
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -52,6 +52,27 @@ oauth_data = {
|
|||||||
def get_token(code):
|
def get_token(code):
|
||||||
return imports_get_token(code, oauth_data)
|
return imports_get_token(code, oauth_data)
|
||||||
|
|
||||||
|
def strava_open(user):
|
||||||
|
return imports_open(user, oauth_data)
|
||||||
|
|
||||||
|
def do_refresh_token(refreshtoken):
|
||||||
|
return imports_do_refresh_token(refreshtoken, oauth_data)
|
||||||
|
|
||||||
|
def rower_strava_token_refresh(user):
|
||||||
|
r = Rower.objects.get(user=user)
|
||||||
|
res = do_refresh_token(r.stravarefreshtoken)
|
||||||
|
access_token = res[0]
|
||||||
|
expires_in = res[1]
|
||||||
|
refresh_token = res[2]
|
||||||
|
expirydatetime = timezone.now()+timedelta(seconds=expires_in)
|
||||||
|
|
||||||
|
r.stravatoken = access_token
|
||||||
|
r.stravatokenexpirydate = expirydatetime
|
||||||
|
r.stravarefreshtoken = refresh_token
|
||||||
|
r.save()
|
||||||
|
|
||||||
|
return r.stravatoken
|
||||||
|
|
||||||
# Make authorization URL including random string
|
# Make authorization URL including random string
|
||||||
def make_authorization_url(request):
|
def make_authorization_url(request):
|
||||||
return imports_make_authorization_url(oauth_data)
|
return imports_make_authorization_url(oauth_data)
|
||||||
@@ -62,6 +83,9 @@ def get_strava_workout_list(user,limit_n=0):
|
|||||||
if (r.stravatoken == '') or (r.stravatoken is None):
|
if (r.stravatoken == '') or (r.stravatoken is None):
|
||||||
s = "Token doesn't exist. Need to authorize"
|
s = "Token doesn't exist. Need to authorize"
|
||||||
return custom_exception_handler(401,s)
|
return custom_exception_handler(401,s)
|
||||||
|
elif (r.stravatokenexpirydate is None or timezone.now()+timedelta(seconds=3599)>r.stravatokenexpirydate):
|
||||||
|
s = "Token expired. Needs to refresh."
|
||||||
|
return custom_exception_handler(401,s)
|
||||||
else:
|
else:
|
||||||
# ready to fetch. Hurray
|
# ready to fetch. Hurray
|
||||||
authorizationstring = str('Bearer ' + r.stravatoken)
|
authorizationstring = str('Bearer ' + r.stravatoken)
|
||||||
@@ -86,10 +110,13 @@ def get_strava_workouts(rower):
|
|||||||
|
|
||||||
if not isprorower(rower):
|
if not isprorower(rower):
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
res = get_strava_workout_list(rower.user,limit_n=10)
|
|
||||||
|
|
||||||
print res.status_code
|
try:
|
||||||
|
thetoken = strava_open(rower.user)
|
||||||
|
except NoTokenError:
|
||||||
|
return 0
|
||||||
|
|
||||||
|
res = get_strava_workout_list(rower.user,limit_n=10)
|
||||||
|
|
||||||
if (res.status_code != 200):
|
if (res.status_code != 200):
|
||||||
return 0
|
return 0
|
||||||
@@ -227,6 +254,9 @@ def get_workout(user,stravaid):
|
|||||||
if (r.stravatoken == '') or (r.stravatoken is None):
|
if (r.stravatoken == '') or (r.stravatoken is None):
|
||||||
s = "Token doesn't exist. Need to authorize"
|
s = "Token doesn't exist. Need to authorize"
|
||||||
return custom_exception_handler(401,s)
|
return custom_exception_handler(401,s)
|
||||||
|
elif (r.stravatokenexpirydate is not None and timezone.now()>r.stravatokenexpirydate):
|
||||||
|
s = "Token expired. Needs to refresh."
|
||||||
|
return custom_exception_handler(401,s)
|
||||||
else:
|
else:
|
||||||
# ready to fetch. Hurray
|
# ready to fetch. Hurray
|
||||||
fetchresolution = 'high'
|
fetchresolution = 'high'
|
||||||
|
|||||||
@@ -116,6 +116,7 @@ from sporttracksstuff import sporttracks_open
|
|||||||
from tpstuff import tp_open
|
from tpstuff import tp_open
|
||||||
from iso8601 import ParseError
|
from iso8601 import ParseError
|
||||||
import stravastuff
|
import stravastuff
|
||||||
|
from stravastuff import strava_open
|
||||||
import polarstuff
|
import polarstuff
|
||||||
import sporttracksstuff
|
import sporttracksstuff
|
||||||
import underarmourstuff
|
import underarmourstuff
|
||||||
@@ -2421,15 +2422,22 @@ def rower_process_stravacallback(request):
|
|||||||
|
|
||||||
if res[0]:
|
if res[0]:
|
||||||
access_token = res[0]
|
access_token = res[0]
|
||||||
|
expires_in = res[1]
|
||||||
|
refresh_token = res[2]
|
||||||
|
|
||||||
|
expirydatetime = timezone.now()+datetime.timedelta(seconds=expires_in)
|
||||||
|
|
||||||
r = getrower(request.user)
|
r = getrower(request.user)
|
||||||
r.stravatoken = access_token
|
r.stravatoken = access_token
|
||||||
|
r.stravatokenexpirydate = expirydatetime
|
||||||
|
r.stravarefreshtoken = refresh_token
|
||||||
|
|
||||||
r.save()
|
r.save()
|
||||||
|
|
||||||
successmessage = "Tokens stored. Good to go"
|
successmessage = "Tokens stored. Good to go"
|
||||||
messages.info(request,successmessage)
|
messages.info(request,successmessage)
|
||||||
return imports_view(request)
|
url = reverse(workouts_view)
|
||||||
|
return HttpResponseRedirect(url)
|
||||||
else:
|
else:
|
||||||
message = "Something went wrong with the Strava authorization"
|
message = "Something went wrong with the Strava authorization"
|
||||||
messages.error(request,message)
|
messages.error(request,message)
|
||||||
@@ -10272,6 +10280,11 @@ def workout_stravaimport_view(request,message="",userid=0):
|
|||||||
|
|
||||||
r = getrequestrower(request,userid=userid)
|
r = getrequestrower(request,userid=userid)
|
||||||
|
|
||||||
|
try:
|
||||||
|
thetoken = strava_open(request.user)
|
||||||
|
except NoTokenError:
|
||||||
|
return HttpResponseRedirect("/rowers/me/stravaauthorize/")
|
||||||
|
|
||||||
if r.user != request.user:
|
if r.user != request.user:
|
||||||
messages.info(request,"You cannot import other people's workouts from Concept2")
|
messages.info(request,"You cannot import other people's workouts from Concept2")
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user