123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- # coding=utf-8
- from django.db import transaction
- from django.conf import settings
- from rest_framework.views import APIView
- from rest_framework import generics
- from rest_framework_jwt.views import ObtainJSONWebToken,VerifyJSONWebToken,RefreshJSONWebToken
- from rest_framework.serializers import ValidationError
- from utils import response_ok, response_error
- from utils.exceptions import CustomError
- from utils.permission import IsCustomerUser, IsAdministratorUser
- from utils.wx.WXBizDataCrypt import WXBizDataCrypt
- from apps.customer.serializers import WechatLoginSerializer, WechatBindSerializer, StatementSerializer, CustomerSerializer
- from apps.customer.models import Customer
- from apps.customer.filters import CustomerFilter
- from apps.wechat.models import Wechat
- class CustomerRefreshTokenView(RefreshJSONWebToken):
- def post(self, request, *args, **kwargs):
- try:
- ser = self.serializer_class(data=request.data)
- if ser.is_valid(raise_exception=True):
- return response_ok({'token': ser.validated_data['token']})
- except ValidationError as e:
- return response_error(u'登录状态失效,请重新登录[' + e.detail['error'][0] + ']')
- class CustomerVerifyTokenView(VerifyJSONWebToken):
- def post(self, request, *args, **kwargs):
- try:
- ser = self.serializer_class(data=request.data)
- if ser.is_valid(raise_exception=True):
- return response_ok({'token': ser.validated_data['token']})
- except ValidationError as e:
- return response_error(u'登录状态失效,请重新登录[' + e.detail['error'][0] + ']')
- class WxLoginView(APIView):
- serializer_class = WechatLoginSerializer
- def post(self, request, *args, **kwargs):
- ser = self.serializer_class(data=request.data)
- if ser.is_valid():
- return response_ok(ser.validated_data)
- else:
- return response_error('参数错误')
- class WxBindView(APIView):
- serializer_class = WechatBindSerializer
- def post(self, request, *args, **kwargs):
- ser = self.serializer_class(data=request.data)
- if ser.is_valid():
- return response_ok(ser.validated_data)
- else:
- return response_error('参数错误')
- class SetUserInfoView(APIView):
- permission_classes = [IsCustomerUser, ]
- def post(self, request, *args, **kwargs):
- appid = request.POST.get('appid')
- openid = request.POST.get('openid')
- encryptedData = request.POST.get('encryptedData')
- iv = request.POST.get('iv')
- customer = Customer.objects.filter(openid=openid, app__appid=appid).first()
- if not customer:
- raise CustomError(u'未找到相应的微信客户!')
- user = request.user
- if customer.user and customer.user.id != user.id:
- raise CustomError(u'该微信已同步其他客户!')
- if not customer.user:
- customer.user = user
- customer.save()
- pc = WXBizDataCrypt(appid, customer.session_key)
- result = pc.decrypt(encryptedData, iv)
- with transaction.atomic():
- if result['gender'] == 1:
- user.gender = settings.MALE
- elif result['gender'] == 2:
- user.gender = settings.FEMALE
- else:
- user.gender = settings.UNKNOW
- user.name = result['nickName']
- user.face = result['avatarUrl']
- user.save()
- return response_ok({'face': user.face,'name': user.name})
- class CsutomerListViewSet(generics.ListAPIView):
- permission_classes = [IsAdministratorUser, ]
- queryset = Customer.objects.filter()
- serializer_class = CustomerSerializer
- def filter_queryset(self, queryset):
- queryset = queryset.filter()
- f = CustomerFilter(self.request.GET, queryset=queryset)
- return f.qs
- class StatementViewSet(generics.RetrieveAPIView):
- '''查看隐私声明'''
- serializer_class = StatementSerializer
- def retrieve(self, request, *args, **kwargs):
- instance = Wechat.objects.filter().first()
- if not instance:
- raise CustomError(u'未添加小程序!')
- serializer = self.get_serializer(instance)
- return response_ok(serializer.data)
|