CloudStorageController.py 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. #!/usr/bin/python3.6
  2. # -*- coding: utf-8 -*-
  3. #
  4. # Copyright (C) 2022 #
  5. # @Time : 2022/3/24 20:09
  6. # @Author : ming
  7. # @Email : zhangdongming@asj6.wecom.work
  8. # @File : CloudStorageController.py
  9. # @Software: PyCharm
  10. import logging
  11. import time
  12. from django.db import transaction
  13. from django.utils.decorators import method_decorator
  14. from django.views.decorators.csrf import csrf_exempt
  15. from django.views.generic.base import View
  16. from Model.models import Surveys, SurveysTitle, Order_Model, CloudVodSurveysAnswer, SurveysUserLog, \
  17. CloudVodSurveysOperateLog
  18. from Object.utils import LocalDateTimeUtil
  19. from Object.ResponseObject import ResponseObject
  20. from Object.TokenObject import TokenObject
  21. from Service.CommonService import CommonService
  22. class CloudStorageView(View):
  23. @method_decorator(csrf_exempt)
  24. def dispatch(self, *args, **kwargs):
  25. return super(CloudStorageView, self).dispatch(*args, **kwargs)
  26. def get(self, request, *args, **kwargs):
  27. request.encoding = 'utf-8'
  28. operation = kwargs.get('operation')
  29. return self.validation(request.GET, request, operation)
  30. def post(self, request, *args, **kwargs):
  31. request.encoding = 'utf-8'
  32. operation = kwargs.get('operation')
  33. return self.validation(request.POST, request, operation)
  34. def validation(self, request_dict, request, operation):
  35. logger = logging.getLogger('info')
  36. token = TokenObject(request.META.get('HTTP_AUTHORIZATION'))
  37. response = ResponseObject(token.lang) if token.lang else ResponseObject()
  38. if token.code != 0:
  39. return response.json(token.code)
  40. userID = token.userID
  41. ''' API '''
  42. logger.info('---- this user id:{},dict{}'.format(userID, request_dict))
  43. if operation == 'get/info':
  44. return self.check_stock_user(userID, request_dict, response)
  45. if operation == 'cloud/answer/save':
  46. ip = CommonService.get_ip_address(request)
  47. return self.answer_save(userID, ip, request_dict, response)
  48. if operation == "cloud/storage/icon/close":
  49. self.cloud_vob_operate_log_save(status=2, userId=userID)
  50. if operation == "entrance/cloud/storage/icon":
  51. return self.entrance_cloud_storage_icon(userID, request_dict, response)
  52. return response.json(0)
  53. def check_stock_user(self, user_id, request_dict, response):
  54. order = Order_Model.objects.filter(userID=user_id, status=1, order_type=0)
  55. if not order.exists() and order.count() == 0:
  56. return response.json(10030)
  57. try:
  58. lang = request_dict.get('lang', 'en')
  59. no = '01'
  60. surveys = Surveys.objects.filter(no=no, user_type=1)
  61. if not surveys.exists():
  62. return response.json(173)
  63. result = surveys[0]
  64. surveys_title = SurveysTitle.objects.filter(surveys_id=result.id).order_by('-created_time')
  65. submit = 0
  66. if surveys_title.exists():
  67. surveys_title = surveys_title[0]
  68. cloud_vod = CloudVodSurveysAnswer.objects.filter(title_id=surveys_title.id, user_id=user_id)
  69. if cloud_vod.exists():
  70. submit = 1
  71. close = self.check_user_is_icon_close(userId=user_id)
  72. data = {
  73. 'no': result.no,
  74. 'title': 'Zosi Cloud Storage',
  75. 'imageUrl': 'https://d2cjxvw3tr9apc.cloudfront.net/app/images/ansjer-cloud-surveys.png',
  76. 'userType': result.user_type,
  77. 'startTime': result.start_time,
  78. 'endTime': result.end_time,
  79. 'isShow': 0 if close else result.is_show,
  80. 'isSubmit': submit,
  81. 'page': '/surveys?lang=' + lang + '&token=' if result.is_show == 1 else ''
  82. }
  83. localTime = int(time.time())
  84. if result.start_time <= localTime <= result.end_time:
  85. status = True if submit == 1 else False
  86. self.surveys_user_log_save(status, user_id)
  87. if not submit == 1:
  88. self.cloud_vob_operate_log_save(2 if close else submit, userId=user_id)
  89. return response.json(0, data)
  90. except Exception as e:
  91. print(e)
  92. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  93. @classmethod
  94. def surveys_user_log_save(cls, status=False, userId='', survey_type=1):
  95. if userId:
  96. user_log = SurveysUserLog.objects.filter(user_id=userId, type=survey_type)
  97. if user_log.exists():
  98. if status and user_log[0].is_filled == 0:
  99. user_log.update(is_filled=1)
  100. else:
  101. createdTime = int(time.time())
  102. user_log = SurveysUserLog(user_id=userId, type=1, created_time=createdTime)
  103. user_log.save()
  104. @classmethod
  105. def check_user_is_icon_close(cls, userId):
  106. if userId:
  107. start_time, end_time = LocalDateTimeUtil.get_today_date(True)
  108. user_operate_log_list = CloudVodSurveysOperateLog.objects.filter(user_id=userId, status=2,
  109. created_time__gte=start_time,
  110. created_time__lte=end_time)
  111. if user_operate_log_list.exists():
  112. return True
  113. return False
  114. @classmethod
  115. def cloud_vob_operate_log_save(cls, status=0, userId=''):
  116. """ 保存用户操作记录 """
  117. try:
  118. with transaction.atomic():
  119. if userId:
  120. start_time, end_time = LocalDateTimeUtil.get_today_date(True)
  121. user_operate_qs = CloudVodSurveysOperateLog.objects.filter(user_id=userId,
  122. created_time__gte=start_time,
  123. created_time__lte=end_time)
  124. local_time = int(time.time())
  125. if user_operate_qs.exists():
  126. operate_log = user_operate_qs.first()
  127. if not operate_log.status == status:
  128. operate_log.status = status
  129. operate_log.updated_time = local_time
  130. operate_log.save()
  131. else:
  132. operate_log = CloudVodSurveysOperateLog(user_id=userId, status=status, updated_time=local_time,
  133. created_time=local_time)
  134. operate_log.save()
  135. except Exception as e:
  136. print(e)
  137. @classmethod
  138. def answer_save(cls, userId, ip, request_dict, response):
  139. logger = logging.getLogger('info')
  140. try:
  141. ipInfo = CommonService.getIpIpInfo(ip, "CN")
  142. country_name = ipInfo['country_name']
  143. no = request_dict.get('no', None)
  144. if not no:
  145. return response.json(10, 'no is null')
  146. survey = Surveys.objects.filter(no=no)
  147. if survey.exists():
  148. survey = survey[0]
  149. survey_title = SurveysTitle.objects.filter(surveys=survey.id)
  150. if survey_title.exists():
  151. survey_title = survey_title[0]
  152. cloud_vod = CloudVodSurveysAnswer.objects.filter(title_id=survey_title.id, user_id=userId)
  153. if cloud_vod.exists():
  154. return response.json(10, "Do not submit twice")
  155. score = request_dict.get('score', None)
  156. topicA = request_dict.get('topicA', None)
  157. topicB = request_dict.get('topicB', None)
  158. topicC = request_dict.get('topicC', None)
  159. topicD = request_dict.get('topicD', None)
  160. topicF = request_dict.get('topicF', None)
  161. createdTime = int(time.time())
  162. answer = CloudVodSurveysAnswer(title_id=survey_title.id, user_id=userId, ip=ip, answer1=int(score),
  163. answer2=topicA,
  164. answer3=topicB, answer4=topicC, answer5=topicD, answer6=topicF,
  165. created_time=createdTime, country_name=country_name)
  166. answer.save()
  167. SurveysUserLog.objects.filter(user_id=userId, type=1).update(is_filled=1)
  168. cls.cloud_vob_operate_log_save(status=1, userId=userId)
  169. return response.json(0)
  170. except Exception as e:
  171. logger.info('异常详情,errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  172. return response.json(200, repr(e))
  173. @classmethod
  174. def entrance_cloud_storage_icon(cls, userID, request_dict, response):
  175. status = request_dict.get('status', None)
  176. if not status:
  177. return response.json(444, 'status')
  178. status = int(status)
  179. start_time, end_time = LocalDateTimeUtil.get_today_date(True)
  180. local_time = int(time.time())
  181. try:
  182. if status == 3: #
  183. cloud_vod_surveys_Operate_qs = CloudVodSurveysOperateLog.objects.filter(user_id=userID, status=status,
  184. created_time__gte=start_time,
  185. created_time__lte=end_time)
  186. if not cloud_vod_surveys_Operate_qs.exists(): # 判断用户当天是否查阅问卷
  187. cls.cloud_vob_operate_log_save(status=status, userId=userID)
  188. else:
  189. user_record_qs = cloud_vod_surveys_Operate_qs.first()
  190. user_record_qs.updated_time = local_time
  191. user_record_qs.save()
  192. return response.json(0)
  193. except Exception as e:
  194. print(e)