Migrating external apps
parent
4864b9f957
commit
d7a979d23c
|
@ -17,6 +17,7 @@
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
from . import serializers
|
from . import serializers
|
||||||
|
from . import validators
|
||||||
from . import models
|
from . import models
|
||||||
from . import permissions
|
from . import permissions
|
||||||
from . import services
|
from . import services
|
||||||
|
@ -27,12 +28,12 @@ from taiga.base.api import ModelCrudViewSet, ModelRetrieveViewSet
|
||||||
from taiga.base.api.utils import get_object_or_404
|
from taiga.base.api.utils import get_object_or_404
|
||||||
from taiga.base.decorators import list_route, detail_route
|
from taiga.base.decorators import list_route, detail_route
|
||||||
|
|
||||||
from django.db import transaction
|
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
|
||||||
|
|
||||||
class Application(ModelRetrieveViewSet):
|
class Application(ModelRetrieveViewSet):
|
||||||
serializer_class = serializers.ApplicationSerializer
|
serializer_class = serializers.ApplicationSerializer
|
||||||
|
validator_class = validators.ApplicationValidator
|
||||||
permission_classes = (permissions.ApplicationPermission,)
|
permission_classes = (permissions.ApplicationPermission,)
|
||||||
model = models.Application
|
model = models.Application
|
||||||
|
|
||||||
|
@ -61,6 +62,7 @@ class Application(ModelRetrieveViewSet):
|
||||||
|
|
||||||
class ApplicationToken(ModelCrudViewSet):
|
class ApplicationToken(ModelCrudViewSet):
|
||||||
serializer_class = serializers.ApplicationTokenSerializer
|
serializer_class = serializers.ApplicationTokenSerializer
|
||||||
|
validator_class = validators.ApplicationTokenValidator
|
||||||
permission_classes = (permissions.ApplicationTokenPermission,)
|
permission_classes = (permissions.ApplicationTokenPermission,)
|
||||||
|
|
||||||
def get_queryset(self):
|
def get_queryset(self):
|
||||||
|
@ -87,9 +89,9 @@ class ApplicationToken(ModelCrudViewSet):
|
||||||
auth_code = request.DATA.get("auth_code", None)
|
auth_code = request.DATA.get("auth_code", None)
|
||||||
state = request.DATA.get("state", None)
|
state = request.DATA.get("state", None)
|
||||||
application_token = get_object_or_404(models.ApplicationToken,
|
application_token = get_object_or_404(models.ApplicationToken,
|
||||||
application__id=application_id,
|
application__id=application_id,
|
||||||
auth_code=auth_code,
|
auth_code=auth_code,
|
||||||
state=state)
|
state=state)
|
||||||
|
|
||||||
application_token.generate_token()
|
application_token.generate_token()
|
||||||
application_token.save()
|
application_token.save()
|
||||||
|
|
|
@ -16,9 +16,8 @@
|
||||||
# You should have received a copy of the GNU Affero General Public License
|
# You should have received a copy of the GNU Affero General Public License
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
import json
|
|
||||||
|
|
||||||
from taiga.base.api import serializers
|
from taiga.base.api import serializers
|
||||||
|
from taiga.base.fields import Field
|
||||||
|
|
||||||
from . import models
|
from . import models
|
||||||
from . import services
|
from . import services
|
||||||
|
@ -26,33 +25,27 @@ from . import services
|
||||||
from django.utils.translation import ugettext as _
|
from django.utils.translation import ugettext as _
|
||||||
|
|
||||||
|
|
||||||
class ApplicationSerializer(serializers.ModelSerializer):
|
class ApplicationSerializer(serializers.LightSerializer):
|
||||||
class Meta:
|
id = Field()
|
||||||
model = models.Application
|
name = Field()
|
||||||
fields = ("id", "name", "web", "description", "icon_url")
|
web = Field()
|
||||||
|
description = Field()
|
||||||
|
icon_url = Field()
|
||||||
|
|
||||||
|
|
||||||
class ApplicationTokenSerializer(serializers.ModelSerializer):
|
class ApplicationTokenSerializer(serializers.LightSerializer):
|
||||||
cyphered_token = serializers.CharField(source="cyphered_token", read_only=True)
|
id = Field()
|
||||||
next_url = serializers.CharField(source="next_url", read_only=True)
|
user = Field(attr="user_id")
|
||||||
application = ApplicationSerializer(read_only=True)
|
application = ApplicationSerializer()
|
||||||
|
auth_code = Field()
|
||||||
class Meta:
|
next_url = Field()
|
||||||
model = models.ApplicationToken
|
|
||||||
fields = ("user", "id", "application", "auth_code", "next_url")
|
|
||||||
|
|
||||||
|
|
||||||
class AuthorizationCodeSerializer(serializers.ModelSerializer):
|
class AuthorizationCodeSerializer(serializers.LightSerializer):
|
||||||
next_url = serializers.CharField(source="next_url", read_only=True)
|
state = Field()
|
||||||
class Meta:
|
auth_code = Field()
|
||||||
model = models.ApplicationToken
|
next_url = Field()
|
||||||
fields = ("auth_code", "state", "next_url")
|
|
||||||
|
|
||||||
|
|
||||||
class AccessTokenSerializer(serializers.ModelSerializer):
|
class AccessTokenSerializer(serializers.LightSerializer):
|
||||||
cyphered_token = serializers.CharField(source="cyphered_token", read_only=True)
|
cyphered_token = Field()
|
||||||
next_url = serializers.CharField(source="next_url", read_only=True)
|
|
||||||
|
|
||||||
class Meta:
|
|
||||||
model = models.ApplicationToken
|
|
||||||
fields = ("cyphered_token", )
|
|
||||||
|
|
|
@ -0,0 +1,54 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# Copyright (C) 2014-2016 Andrey Antukh <niwi@niwi.nz>
|
||||||
|
# Copyright (C) 2014-2016 Jesús Espino <jespinog@gmail.com>
|
||||||
|
# Copyright (C) 2014-2016 David Barragán <bameda@dbarragan.com>
|
||||||
|
# Copyright (C) 2014-2016 Alejandro Alonso <alejandro.alonso@kaleidos.net>
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU Affero General Public License as
|
||||||
|
# published by the Free Software Foundation, either version 3 of the
|
||||||
|
# License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU Affero General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU Affero General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
from taiga.base.api import serializers
|
||||||
|
|
||||||
|
from . import models
|
||||||
|
from taiga.base.api import validators
|
||||||
|
|
||||||
|
|
||||||
|
class ApplicationValidator(validators.ModelValidator):
|
||||||
|
class Meta:
|
||||||
|
model = models.Application
|
||||||
|
fields = ("id", "name", "web", "description", "icon_url")
|
||||||
|
|
||||||
|
|
||||||
|
class ApplicationTokenValidator(validators.ModelValidator):
|
||||||
|
cyphered_token = serializers.CharField(source="cyphered_token", read_only=True)
|
||||||
|
next_url = serializers.CharField(source="next_url", read_only=True)
|
||||||
|
application = ApplicationValidator(read_only=True)
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = models.ApplicationToken
|
||||||
|
fields = ("user", "id", "application", "auth_code", "next_url")
|
||||||
|
|
||||||
|
|
||||||
|
class AuthorizationCodeValidator(validators.ModelValidator):
|
||||||
|
next_url = serializers.CharField(source="next_url", read_only=True)
|
||||||
|
class Meta:
|
||||||
|
model = models.ApplicationToken
|
||||||
|
fields = ("auth_code", "state", "next_url")
|
||||||
|
|
||||||
|
|
||||||
|
class AccessTokenValidator(validators.ModelValidator):
|
||||||
|
cyphered_token = serializers.CharField(source="cyphered_token", read_only=True)
|
||||||
|
next_url = serializers.CharField(source="next_url", read_only=True)
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = models.ApplicationToken
|
||||||
|
fields = ("cyphered_token", )
|
Loading…
Reference in New Issue