使用Django Rest Framework和django oauth2-toolkit无法迭代'type'对象

时间:2018-04-12 04:48:18

标签: django-rest-framework django-oauth

我正在尝试使用视图中的自定义身份验证类为登录用户创建新的访问令牌。

Serializer.py

class UserCreateSerializer(ModelSerializer):            

    def create(self, validated_data):
        user = User.objects.create_user(validated_data['username'], 
            validated_data['email'],
            validated_data['password'])
        return user

    class Meta:
        model = User
        fields = ('username', 'email' ,'password')

views.py

class User_Create_view(CreateAPIView):
    serializer_class = UserCreateSerializer
    queryset = User.objects.all()
    permission_classes = [AllowAny]
    authentication_classes = Has_Access_Token

    def create(self, request):
        serializers =self.serializer_class(data=request.data)
        if serializers.is_valid():
        # pdb.set_trace()
            serializers.save()   
            # Has_Access_Token.access_token(Has_Access_Token())         
            return Response(serializers.data)
        return Response(status=status.HTTP_202_ACCEPTED))

permission.py

class Has_Access_Token(BaseAuthentication):
    def access_token(self):
        app = Application.objects.get(name="testing")
        tok = generate_token()
        pdb.set_trace()
        acce_token=AccessToken.objects.get_or_create(
        user=User.objects.all().last(),
        application=app,
        expires=datetime.datetime.now() + datetime.timedelta(days=365),
        token=tok)
        return acce_token

    @method_decorator(access_token)
    def authenticate(self):
        return request

如果我使用装饰器

文件“/usr/lib/python2.7/functools.py”,第33行,在update_wrapper中     setattr(wrapper,attr,getattr(wrapped,attr)) AttributeError:'tuple'对象没有属性' module '

如果我不使用装饰器   在get_authenticators中输入文件“/home/allwin/Desktop/response/env/local/lib/python2.7/site-packages/rest_framework/views.py”,第262行     在self.authentication_classes中返回[auth()for auth]     TypeError:'type'对象不可迭代

我面临的问题是,当我在serializer.save()之后隐式使用Has_Access_Token功能时,管理员会针对用户生成访问令牌但这不是有效的方法,因此我需要覆盖视图中的自定义authentication_class。

有人可以提出一些方法来解决这个问题,或者让我知道上面代码中的装饰器修正。

提前致谢。

1 个答案:

答案 0 :(得分:0)

REST_FRAMEWORK.DEFAULT_AUTHENTICATION_CLASSES文件中设置settings.py时,customAuthencationClass必须如下所示:

REST_FRAMEWORK = {
    'DEFAULT_AUTHENTICATION_CLASSES': [ # need to be list not tuple
        'CustomAuthentication',
    ],
}