123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238 |
- # Create your views here.
- import hashlib
- import time
- import uuid
- import logging
- import requests
- from rest_framework.views import APIView
- from rest_framework.viewsets import ModelViewSet
- from background.Object import AmazonS3Util, RedisObject, TokenObject
- from background.author import MyAuthentication
- from background.serializers import ProductInfoSerializer, VideoInSerializer, QuickStartInfoSerializer, \
- UpgradeFirmwareInfoSerializer
- from background.models import ProductInfo, VideoInfo, QuickStartInfo, UpgradeFirmwareInfo, WechatUserInfo
- from rest_framework.response import Response
- s3_obj = AmazonS3Util()
- bucket = 'ansjerfilemanager'
- LOGGER = logging.getLogger('django')
- class ProductInfoSet(ModelViewSet):
- queryset = ProductInfo.objects.all()
- serializer_class = ProductInfoSerializer
- authentication_classes = [MyAuthentication, ]
- class VideoInfoSet(ModelViewSet):
- authentication_classes = [MyAuthentication, ]
- queryset = VideoInfo.objects.all()
- serializer_class = VideoInSerializer
- filterset_fields = ['id', 'product_info_id', 'title']
- class QuickStartInfoSet(ModelViewSet):
- authentication_classes = [MyAuthentication, ]
- queryset = QuickStartInfo.objects.all()
- serializer_class = QuickStartInfoSerializer
- filterset_fields = ['id', 'product_info_id', 'title']
- def create(self, request, *args, **kwargs):
- request_dict = request.data
- link = request_dict.get('link')
- file_key = 'vsees/quick_start_file/{}'.format(link)
- s3_obj.upload_file_obj(bucket, file_key, link, extra_args={'ACL': 'public-read'})
- request_dict['link'] = 'https://ansjerfilemanager.s3.amazonaws.com/vsees/quick_start_file/{}'.format(link)
- serializer = self.get_serializer(data=request_dict)
- serializer.is_valid(raise_exception=True)
- self.perform_create(serializer)
- return Response(serializer.data)
- def update(self, request, *args, **kwargs):
- request_dict = request.data
- link = request_dict.get('link', None)
- if link:
- file_key = 'vsees/quick_start_file/{}'.format(link)
- s3_obj.upload_file_obj(bucket, file_key, link, extra_args={'ACL': 'public-read'})
- request_dict['link'] = 'https://ansjerfilemanager.s3.amazonaws.com/vsees/quick_start_file/{}'.format(link)
- serializer = self.get_serializer(data=request_dict, instance=self.get_object(), partial=True)
- serializer.is_valid(raise_exception=True)
- self.perform_update(serializer)
- return Response(serializer.data)
- class UpgradeFirmwareInfoSet(ModelViewSet):
- queryset = UpgradeFirmwareInfo.objects.all()
- serializer_class = UpgradeFirmwareInfoSerializer
- filterset_fields = ['id', 'product_info_id', 'title']
- authentication_classes = [MyAuthentication, ]
- def create(self, request, *args, **kwargs):
- request_dict = request.data
- link = request_dict.get('link')
- file_key = 'vsees/upgrade_firmware_file/{}'.format(link)
- s3_obj.upload_file_obj(bucket, file_key, link, extra_args={'ACL': 'public-read'})
- request_dict['link'] = 'https://ansjerfilemanager.s3.amazonaws.com/vsees/upgrade_firmware_file/{}'.format(link)
- serializer = self.get_serializer(data=request_dict)
- serializer.is_valid(raise_exception=True)
- self.perform_create(serializer)
- return Response(serializer.data)
- def update(self, request, *args, **kwargs):
- link = request.data.get('link', None)
- if link:
- file_key = 'vsees/upgrade_firmware_file/{}'.format(link)
- s3_obj.upload_file_obj(bucket, file_key, link, extra_args={'ACL': 'public-read'})
- request.data['link'] = 'https://ansjerfilemanager.s3.amazonaws.com/vsees/upgrade_firmware_file/{}'.format(
- link)
- serializer = self.get_serializer(data=request.data, instance=self.get_object(), partial=True)
- serializer.is_valid(raise_exception=True)
- self.perform_update(serializer)
- return Response(serializer.data)
- class WechatLoginView(APIView):
- def get(self, request, *args, **kwargs):
- request.encoding = 'utf-8'
- operation = kwargs.get('operation')
- return self.validation(request.GET, operation, request)
- def post(self, request, *args, **kwargs):
- request.encoding = 'utf-8'
- operation = kwargs.get('operation')
- return self.validation(request.POST, operation, request)
- def validation(self, request_dict, operation, request):
- if operation == 'get-state': # 获取state值
- return self.get_state()
- elif operation == 'get-user': # 获取用户
- return self.get_user(request_dict)
- else:
- return Response({'code': 414, 'result': {'error_msg': '请求路径有误'}})
- @staticmethod
- def get_state():
- """
- 获取state
- @return: response
- """
- nwo_time = int(time.time())
- redis_obj = RedisObject()
- try:
- state = hashlib.md5((str(uuid.uuid1()) + str(nwo_time)).encode('utf-8')).hexdigest()
- state_statue = redis_obj.set_ex_data(state, 0, 300) # redis记录state
- if state_statue:
- return Response({'code': 0, 'result': {'state': state}})
- else:
- return Response({'code': 120, 'result': {'error_msg': '获取status失败'}})
- except Exception as e:
- return Response(
- {'code': 500, 'result': {'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e))}})
- @classmethod
- def get_user(cls, request_dict):
- """
- 获取用户信息
- @request_dict code:唯一标识
- @request_dict state:唯一标识
- return:
- """
- code = request_dict.get('code', None)
- state = request_dict.get('state', None)
- if not all([code, state]):
- return Response({'code': 444, 'result': {'error_msg': '缺少参数'}})
- # 验证state,获取token
- access_token = cls.get_access_token(state)
- if not access_token:
- return Response({'code': 120, 'result': {'error_msg': '获取token失败'}})
- data = {
- 'access_token': access_token,
- 'code': code
- }
- try:
- # 获取用户id
- get_userid_url = 'https://qyapi.weixin.qq.com/cgi-bin/auth/getuserinfo'
- response = requests.get(get_userid_url, params=data)
- data = response.json()
- user_id = data.get("userid")
- if user_id:
- user_name = cls.add_or_update_user_info(access_token, user_id)
- if not user_name:
- return Response({'code': 120, 'result': {'error_msg': '登录失败'}})
- token_obj = TokenObject()
- token = token_obj.generate(data={'userID': user_id, 'user': user_name})
- return Response({'code': 0, 'result': {'token': token}})
- else:
- errcode = data.get('errcode')
- errmsg = data.get('errmsg')
- return Response({'code': errcode, 'result': {'error_msg': errmsg}})
- except Exception as e:
- return Response(
- {'code': 500, 'result': {'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e))}})
- @classmethod
- def get_access_token(cls, state):
- redis_client = RedisObject()
- state_val = redis_client.get_data(state)
- # 验证state
- if state_val:
- redis_client.del_data(state)
- else:
- LOGGER.info('企业微信扫码登录,state:{}获取失败'.format(state))
- return False
- access_token = redis_client.get_data(key='enterprise_wechat_access_token')
- if access_token:
- return access_token
- data = {
- 'corpid': 'ww467ec1685e8262e6',
- 'corpsecret': 'IeUoaQ-0hEhEduCQq1zyfVXjfeZpMsThK1nklszRzUY'
- }
- # 获取access_token,redis中不存在该值时重新请求获取access_token(有效时长两小时)
- token_url = 'https://qyapi.weixin.qq.com/cgi-bin/gettoken'
- token_response = requests.get(token_url, params=data)
- data = token_response.json()
- if data.get('errcode') == 0:
- access_token = data['access_token']
- expires_in = data['expires_in']
- flag = redis_client.set_ex_data('enterprise_wechat_access_token', access_token, expires_in)
- if flag:
- return access_token
- else:
- LOGGER.info('企业微信扫码登录,access_token:{}储存失败'.format(access_token))
- return False
- else:
- LOGGER.info('企业微信扫码登录,access_token获取失败')
- return False
- @classmethod
- def add_or_update_user_info(cls, access_token, user_id):
- now_time = int(time.time())
- data = {
- 'access_token': access_token,
- 'userid': user_id
- }
- # 获取用户信息
- token_url = 'https://qyapi.weixin.qq.com/cgi-bin/user/get'
- response = requests.get(token_url, params=data)
- data = response.json()
- wechat_user_qs = WechatUserInfo.objects.filter(user_id=user_id)
- if data.get('errcode') == 0:
- url_data = {
- 'name': data.get('name'),
- 'position': data.get('position'),
- 'status': data.get('status'),
- 'add_time': now_time,
- 'upd_time': now_time
- }
- if not wechat_user_qs.exists():
- url_data['user_id'] = user_id
- WechatUserInfo.objects.create(**url_data)
- else:
- wechat_user_qs.update(**url_data)
- if data.get('status') == 1:
- return data.get('name')
- else:
- return False
- else:
- return False
|