Revoke button
This commit is contained in:
@@ -9,7 +9,7 @@
|
|||||||
</p>
|
</p>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<div class="grid_6 alpha">
|
<div class="grid_6 alpha">
|
||||||
<h1>Heart Rate Bands</h1>
|
<h2>Heart Rate Bands</h2>
|
||||||
|
|
||||||
<form enctype="multipart/form-data" action="" method="post">
|
<form enctype="multipart/form-data" action="" method="post">
|
||||||
<table>
|
<table>
|
||||||
@@ -22,8 +22,8 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="grid_6 omega">
|
<div class="grid_6 omega">
|
||||||
<h1>Functional Threshold Power</h1>
|
|
||||||
<p>
|
<p>
|
||||||
|
<h2>Functional Threshold Power</h2>
|
||||||
<form enctype="multipart/form-data" action="" method="post">
|
<form enctype="multipart/form-data" action="" method="post">
|
||||||
<table>
|
<table>
|
||||||
{{ powerform.as_table }}
|
{{ powerform.as_table }}
|
||||||
@@ -34,6 +34,31 @@
|
|||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</p>
|
</p>
|
||||||
|
{% if grants %}
|
||||||
|
<p>
|
||||||
|
<h2>Applications</h2>
|
||||||
|
<table width="100%">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th>Application</th>
|
||||||
|
<th>Scope</th>
|
||||||
|
<th>Revoke</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
{% for grant in grants %}
|
||||||
|
<tr>
|
||||||
|
<td>{{ grant.application }}</td>
|
||||||
|
<td>{{ grant.scope }}</td>
|
||||||
|
<td>
|
||||||
|
<a class="button red small" href="/rowers/me/revokeapp/{{ grant.application.id }}">Revoke</a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</p>
|
||||||
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -22,6 +22,15 @@ from rowers.serializers import (
|
|||||||
FavoriteChartSerializer,
|
FavoriteChartSerializer,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
from oauth2_provider.views import (
|
||||||
|
AuthorizedTokensListView,
|
||||||
|
AuthorizedTokenDeleteView,
|
||||||
|
)
|
||||||
|
|
||||||
|
from oauth2_provider.views.base import (
|
||||||
|
RevokeTokenView
|
||||||
|
)
|
||||||
|
|
||||||
class WorkoutViewSet(viewsets.ModelViewSet):
|
class WorkoutViewSet(viewsets.ModelViewSet):
|
||||||
model = Workout
|
model = Workout
|
||||||
#queryset = Workout.objects.all().order_by("-date", "-starttime")
|
#queryset = Workout.objects.all().order_by("-date", "-starttime")
|
||||||
@@ -180,6 +189,7 @@ urlpatterns = [
|
|||||||
url(r'^me/edit/$',views.rower_edit_view),
|
url(r'^me/edit/$',views.rower_edit_view),
|
||||||
url(r'^me/edit/(.+.*)/$',views.rower_edit_view),
|
url(r'^me/edit/(.+.*)/$',views.rower_edit_view),
|
||||||
url(r'^me/c2authorize/$',views.rower_c2_authorize),
|
url(r'^me/c2authorize/$',views.rower_c2_authorize),
|
||||||
|
url(r'^me/revokeapp/(\d+)$',views.rower_revokeapp_view),
|
||||||
url(r'^me/stravaauthorize/$',views.rower_strava_authorize),
|
url(r'^me/stravaauthorize/$',views.rower_strava_authorize),
|
||||||
url(r'^me/sporttracksauthorize/$',views.rower_sporttracks_authorize),
|
url(r'^me/sporttracksauthorize/$',views.rower_sporttracks_authorize),
|
||||||
url(r'^me/sporttracksrefresh/$',views.rower_sporttracks_token_refresh),
|
url(r'^me/sporttracksrefresh/$',views.rower_sporttracks_token_refresh),
|
||||||
|
|||||||
@@ -75,6 +75,8 @@ import stravalib
|
|||||||
from stravalib.exc import ActivityUploadFailed,TimeoutExceeded
|
from stravalib.exc import ActivityUploadFailed,TimeoutExceeded
|
||||||
from weather import get_wind_data
|
from weather import get_wind_data
|
||||||
|
|
||||||
|
from oauth2_provider.models import Application,Grant,AccessToken
|
||||||
|
|
||||||
import django_rq
|
import django_rq
|
||||||
queue = django_rq.get_queue('default')
|
queue = django_rq.get_queue('default')
|
||||||
queuelow = django_rq.get_queue('low')
|
queuelow = django_rq.get_queue('low')
|
||||||
@@ -4780,14 +4782,38 @@ def rower_edit_view(request,message=""):
|
|||||||
r = Rower.objects.get(user=request.user)
|
r = Rower.objects.get(user=request.user)
|
||||||
form = RowerForm(instance=r)
|
form = RowerForm(instance=r)
|
||||||
powerform = RowerPowerForm(instance=r)
|
powerform = RowerPowerForm(instance=r)
|
||||||
|
grants = AccessToken.objects.filter(user=request.user)
|
||||||
return render(request, 'rower_form.html',
|
return render(request, 'rower_form.html',
|
||||||
{
|
{
|
||||||
'form':form,
|
'form':form,
|
||||||
'powerform':powerform,
|
'powerform':powerform,
|
||||||
|
'grants':grants,
|
||||||
})
|
})
|
||||||
except Rower.DoesNotExist:
|
except Rower.DoesNotExist:
|
||||||
return HttpResponse("This user doesn't exist")
|
return HttpResponse("This user doesn't exist")
|
||||||
|
|
||||||
|
@login_required()
|
||||||
|
def rower_revokeapp_view(request,id=0):
|
||||||
|
tokens = AccessToken.objects.filter(user=request.user,application=id)
|
||||||
|
refreshtokens = AccessToken.objects.filter(user=request.user,application=id)
|
||||||
|
for token in tokens:
|
||||||
|
token.revoke()
|
||||||
|
for token in refreshtokens:
|
||||||
|
token.revoke()
|
||||||
|
|
||||||
|
r = Rower.objects.get(user=request.user)
|
||||||
|
form = RowerForm(instance=r)
|
||||||
|
powerform = RowerPowerForm(instance=r)
|
||||||
|
grants = AccessToken.objects.filter(user=request.user)
|
||||||
|
return render(request, 'rower_form.html',
|
||||||
|
{
|
||||||
|
'form':form,
|
||||||
|
'powerform':powerform,
|
||||||
|
'grants':grants,
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class JSONResponse(HttpResponse):
|
class JSONResponse(HttpResponse):
|
||||||
def __init__(self, data, **kwargs):
|
def __init__(self, data, **kwargs):
|
||||||
content = JSONRenderer().render(data)
|
content = JSONRenderer().render(data)
|
||||||
|
|||||||
Reference in New Issue
Block a user