| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371 | 
							- import json
 
- import time
 
- import oss2
 
- from django.db import transaction
 
- from django.views.generic.base import View
 
- from Ansjer.config import ACCESS_KEY_ID, SECRET_ACCESS_KEY, REGION_NAME, PUSH_BUCKET, PUSH_INACCURATE_BUCKET
 
- from Ansjer.config import OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET
 
- from Model.models import FeedBackModel, StatResModel, PushInaccurateFeedback
 
- from Object.AWS.AmazonS3Util import AmazonS3Util
 
- from Object.ResponseObject import ResponseObject
 
- from Object.TokenObject import TokenObject
 
- from Service.CommonService import CommonService
 
- from Service.ModelService import ModelService
 
- class FeedBackView(View):
 
-     def get(self, request, *args, **kwargs):
 
-         request.encoding = 'utf-8'
 
-         operation = kwargs.get('operation', None)
 
-         return self.validation(request.GET, operation)
 
-     def post(self, request, *args, **kwargs):
 
-         request.encoding = 'utf-8'
 
-         operation = kwargs.get('operation', None)
 
-         return self.validation(request.POST, operation)
 
-     def validation(self, request_dict, operation):
 
-         response = ResponseObject()
 
-         token = request_dict.get('token', None)
 
-         tko = TokenObject(token)
 
-         if tko.code == 0:
 
-             userID = tko.userID
 
-             if operation == 'add':
 
-                 return self.do_add(userID, request_dict, response)
 
-             elif operation == 'getUploadUrl':
 
-                 return self.do_get_upload_url(request_dict, response)
 
-             elif operation == 'query':
 
-                 return self.do_query(userID, request_dict, response)
 
-             elif operation == 'delete':
 
-                 return self.do_delete(userID, request_dict, response)
 
-             elif operation == 'queryByAdmin':
 
-                 return self.do_query_by_admin(userID, request_dict, response)
 
-             elif operation == 'deleteByAdmin':
 
-                 return self.do_delete_by_admin(userID, request_dict, response)
 
-             elif operation == 'deleteImage':
 
-                 return self.do_delete_image(userID, request_dict, response)
 
-             elif operation == 'submitted':  # 查询是否已提交过推送图片反馈
 
-                 return self.submitted(userID, request_dict, response)
 
-             elif operation == 'pushInaccurate':  # 用户反馈推送不准确
 
-                 return self.push_inaccurate(userID, request_dict, response)
 
-             else:
 
-                 return response.json(414)
 
-         else:
 
-             return response.json(tko.code)
 
-     def do_query(self, userID, request_dict, response):
 
-         page = request_dict.get('page', None)
 
-         line = request_dict.get('line', None)
 
-         if page and line:
 
-             page = int(page)
 
-             line = int(line)
 
-         else:
 
-             return response.json(444, 'page,line')
 
-         fb_qs = FeedBackModel.objects.filter(userID_id=userID)[(page - 1) * line:page * line]. \
 
-             values('id', 'status', 'content', 'addTime', 'updTime', 'type')
 
-         sid_list = []
 
-         for fb in fb_qs:
 
-             sid_list.append(fb['id'])
 
-         sm_qs = StatResModel.objects.filter(feedbackmodel__id__in=sid_list).values('id', 'name', 'feedbackmodel__id')
 
-         # return response.json(0,list(sm_qs))
 
-         auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
 
-         bucket = oss2.Bucket(auth, 'oss-cn-hongkong.aliyuncs.com', 'statres')
 
-         res = []
 
-         for fb in fb_qs:
 
-             fb['img_url'] = []
 
-             for sm in sm_qs:
 
-                 if sm['feedbackmodel__id'] == fb['id']:
 
-                     obj = 'feedback/' + sm['name']
 
-                     img_url = bucket.sign_url('GET', obj, 3600)
 
-                     fb['img_url'].append(img_url)
 
-                     # fb['FS__name'] = sm['name']
 
-             res.append(fb)
 
-         return response.json(0, res)
 
-     def do_add(self, userID, request_dict, response):
 
-         nowTime = int(time.time())
 
-         content = request_dict.get('content', None)
 
-         type = request_dict.get('type', None)
 
-         res_1 = request_dict.get('res_1', None)
 
-         res_2 = request_dict.get('res_2', None)
 
-         res_3 = request_dict.get('res_3', None)
 
-         app = request_dict.get('app', None)
 
-         phone_model = request_dict.get('phone_model', None)
 
-         os_version = request_dict.get('os_version', None)
 
-         uid = request_dict.get('uid', None)
 
-         product_type = request_dict.get('product_type', None)
 
-         app_version = request_dict.get('app_version', None)
 
-         appBundleId = request_dict.get('appBundleId', None)
 
-         email = request_dict.get('email', None)
 
-         score = request_dict.get('score', None)
 
-         try:
 
-             with transaction.atomic():
 
-                 fb = FeedBackModel()
 
-                 fb.addTime = nowTime
 
-                 fb.updTime = nowTime
 
-                 fb.content = content
 
-                 if type:
 
-                     fb.type = type
 
-                 if app:
 
-                     fb.app = app
 
-                 if phone_model:
 
-                     fb.phone_model = phone_model
 
-                 if os_version:
 
-                     fb.os_version = os_version
 
-                 if uid:
 
-                     fb.uid = uid
 
-                 if product_type:
 
-                     fb.product_type = product_type
 
-                 if app_version:
 
-                     fb.app_version = app_version
 
-                 if appBundleId:
 
-                     fb.appBundleId = appBundleId
 
-                 if email:
 
-                     fb.email = email
 
-                 if score:
 
-                     fb.score = score
 
-                 fb.userID_id = userID
 
-                 fb.save()
 
-                 if res_1:
 
-                     fb.FS.add(StatResModel.objects.create(addTime=nowTime, name=res_1))
 
-                 if res_2:
 
-                     fb.FS.add(StatResModel.objects.create(addTime=nowTime, name=res_2))
 
-                 if res_3:
 
-                     fb.FS.add(StatResModel.objects.create(addTime=nowTime, name=res_3))
 
-         except Exception as e:
 
-             print(repr(e))
 
-             return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
 
-         else:
 
-             return response.json(0)
 
-     def do_get_upload_url(self, request_dict, response):
 
-         uploadType = request_dict.get('uploadType', None)
 
-         uploadType = json.loads(uploadType)
 
-         if len(uploadType):
 
-             res = []
 
-             auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
 
-             bucket = oss2.Bucket(auth, 'oss-cn-hongkong.aliyuncs.com', 'statres')
 
-             for upType in uploadType:
 
-                 name = CommonService.createOrderID()
 
-                 s_name = str(name) + '.' + upType
 
-                 obj = 'feedback/' + s_name
 
-                 url = bucket.sign_url('PUT', obj, 7200)
 
-                 res.append({'put_url': url, 'res_name': s_name})
 
-             return response.json(0, res)
 
-         else:
 
-             return response.json(444, 'uploadType')
 
-     def do_delete(self, userID, request_dict, response):
 
-         id = request_dict.get('id', None)
 
-         try:
 
-             fb_qs = FeedBackModel.objects.get(userID_id=userID, id=id)
 
-             sr_id_list = fb_qs.FS.values_list('id', flat=True)
 
-             StatResModel.objects.filter(id__in=sr_id_list).delete()
 
-             fb_qs.delete()
 
-             # is_delete = StatResModel.objects.filter(id__in=sr_id_list).delete()
 
-             # print(is_delete)
 
-             print('----------')
 
-         except Exception as e:
 
-             return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
 
-         else:
 
-             return response.json(0)
 
-     def do_query_by_admin(self, userID, request_dict, response):
 
-         own_perm = ModelService.check_perm(userID, 30)
 
-         if own_perm:
 
-             page = request_dict.get('page', None)
 
-             line = request_dict.get('line', None)
 
-             status = request_dict.get('status', None)
 
-             username = request_dict.get('username', None)
 
-             type = request_dict.get('type', None)
 
-             if page and line:
 
-                 page = int(page)
 
-                 line = int(line)
 
-                 filter_data = {}
 
-                 if status:
 
-                     filter_data = {'status': status}
 
-                 if username:
 
-                     filter_data = {'userID_id': ModelService.get_userID_byname(username)}
 
-                 if type:
 
-                     filter_data = {'type': type}
 
-                 try:
 
-                     fb_qs = FeedBackModel.objects.filter()
 
-                 except Exception as e:
 
-                     return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
 
-                 print('----------')
 
-                 if filter_data:
 
-                     fb_qs = fb_qs.filter(**filter_data)
 
-                 count = fb_qs.count()
 
-                 fb_qs = fb_qs[(page - 1) * line:page * line].values('id', 'type', 'status', 'content', 'addTime', 'app',
 
-                                                                     'uid', 'os_version', 'phone_model', 'product_type',
 
-                                                                     'updTime', 'userID__username', 'userID__phone',
 
-                                                                     'userID__userEmail', 'app_version', 'appBundleId',
 
-                                                                     'email', 'score'
 
-                                                                     )
 
-                 sid_list = []
 
-                 print(fb_qs)
 
-                 for fb in fb_qs:
 
-                     sid_list.append(fb['id'])
 
-                 sm_qs = StatResModel.objects.filter(feedbackmodel__id__in=sid_list).values('id', 'name',
 
-                                                                                            'feedbackmodel__id')
 
-                 auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
 
-                 bucket = oss2.Bucket(auth, 'oss-cn-hongkong.aliyuncs.com', 'statres')
 
-                 res = []
 
-                 print(sm_qs)
 
-                 for fb in fb_qs:
 
-                     fb['img_url'] = []
 
-                     for sm in sm_qs:
 
-                         if sm['feedbackmodel__id'] == fb['id']:
 
-                             obj = 'feedback/' + sm['name']
 
-                             img_url = bucket.sign_url('GET', obj, 3600)
 
-                             # img_url.replace('statres.oss-cn-hongkong.aliyuncs.com','static.zositech.xyz')
 
-                             fb['img_url'].append(img_url)
 
-                             # fb['FS__name'] = sm['name']
 
-                             if fb['userID__username'] == '':
 
-                                 fb['userID__username'] = fb['userID__userEmail']
 
-                             if fb['userID__username'] == '':
 
-                                 fb['userID__username'] = fb['userID__phone']
 
-                     res.append(fb)
 
-                 return response.json(0, {'datas': res, 'count': count})
 
-             else:
 
-                 return response.json(444, 'page,line')
 
-         else:
 
-             return response.json(404)
 
-     def do_delete_by_admin(self, userID, request_dict, response):
 
-         own_perm = ModelService.check_perm(userID, 10)
 
-         if own_perm:
 
-             id = request_dict.get('id', None)
 
-             try:
 
-                 fb_qs = FeedBackModel.objects.get(id=id)
 
-                 sr_id_list = fb_qs.FS.values_list('id', flat=True)
 
-                 StatResModel.objects.filter(id__in=sr_id_list).delete()
 
-                 fb_qs.delete()
 
-                 print('----------')
 
-             except Exception as e:
 
-                 return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
 
-             else:
 
-                 return response.json(0)
 
-         else:
 
-             return response.json(404)
 
-     def do_delete_image(self, userID, request_dict, response):
 
-         # own_perm = ModelService.check_perm(userID, 10)
 
-         # if not own_perm:
 
-         #     return response.json(404)
 
-         end_time = request_dict.get('end_time', None)
 
-         if end_time is None:
 
-             return response.json(444)
 
-         sys_ms_qs = FeedBackModel.objects.filter(addTime__lt=end_time).order_by('id').values('id')
 
-         ids = []
 
-         for sys_ms in sys_ms_qs:
 
-             ids.append(sys_ms['id'])
 
-         sm_qs = StatResModel.objects.filter(feedbackmodel__id__in=ids).values('id', 'name')
 
-         names = []
 
-         time_struct = time.localtime()
 
-         current_year = time_struct.tm_year
 
-         target_year = current_year - 1
 
-         str_prefix = str(target_year)
 
-         print(str_prefix)
 
-         for sm in sm_qs:
 
-             name = sm['name']
 
-             if name.find(str_prefix) == 0:
 
-                 names.append('feedback/' + name)
 
-         # auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
 
-         # bucket = oss2.Bucket(auth, 'oss-cn-hongkong.aliyuncs.com', 'statres')
 
-         # bucket.batch_delete_objects(names)
 
-         # FeedBackModel.objects.filter(id__in=ids).delete()
 
-         print(names)
 
-         print(len(names))
 
-         return response.json(0)
 
-     @staticmethod
 
-     def submitted(user_id, request_dict, response):
 
-         equipment_info_id = request_dict.get('equipment_info_id', None)
 
-         uid = request_dict.get('uid', None)
 
-         is_st = request_dict.get('is_st', None)
 
-         event_type = request_dict.get('event_type', None)
 
-         event_time = request_dict.get('event_time', None)
 
-         channel = request_dict.get('channel', None)
 
-         if not all([equipment_info_id, uid, is_st, event_type, event_time, channel]):
 
-             return response.json(444)
 
-         is_st, event_type, channel = int(is_st), int(event_type), int(channel)
 
-         # 查询数据是否存在
 
-         push_inaccurate_feedback_qs = PushInaccurateFeedback.objects.filter(equipment_info_id=equipment_info_id,
 
-                                                                             user_id=user_id, uid=uid, channel=channel,
 
-                                                                             event_type=event_type,
 
-                                                                             event_time=event_time,
 
-                                                                             is_st=is_st)
 
-         if push_inaccurate_feedback_qs.exists():
 
-             return response.json(174)
 
-         # 查询图片是否存在s3
 
-         if is_st == 3:
 
-             key = '{uid}/{channel}/{event_time}_0.jpeg'.format(uid=uid, channel=channel, event_time=event_time)
 
-         else:
 
-             key = '{uid}/{channel}/{event_time}.jpeg'.format(uid=uid, channel=channel, event_time=event_time)
 
-         try:
 
-             s3 = AmazonS3Util(
 
-                 aws_access_key_id=ACCESS_KEY_ID,
 
-                 secret_access_key=SECRET_ACCESS_KEY,
 
-                 region_name=REGION_NAME
 
-             )
 
-             have_object = s3.get_object(PUSH_BUCKET, key)
 
-             if have_object:
 
-                 return response.json(0)
 
-             else:
 
-                 return response.json(174)
 
-         except Exception as e:
 
-             return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
 
-     @staticmethod
 
-     def push_inaccurate(user_id, request_dict, response):
 
-         equipment_info_id = request_dict.get('equipment_info_id', None)
 
-         uid = request_dict.get('uid', None)
 
-         is_st = request_dict.get('is_st', None)
 
-         event_type = request_dict.get('event_type', None)
 
-         event_time = request_dict.get('event_time', None)
 
-         channel = request_dict.get('channel', None)
 
-         tag = request_dict.get('tag', '')
 
-         if not all([equipment_info_id, uid, is_st, event_type, event_time, channel]):
 
-             return response.json(444)
 
-         now_time = int(time.time())
 
-         is_st = int(is_st)
 
-         try:
 
-             s3 = AmazonS3Util(
 
-                 aws_access_key_id=ACCESS_KEY_ID,
 
-                 secret_access_key=SECRET_ACCESS_KEY,
 
-                 region_name=REGION_NAME
 
-             )
 
-             if is_st != 3:
 
-                 file_path = '{uid}/{channel}/{event_time}.jpeg'.format(uid=uid,
 
-                                                                        channel=channel,
 
-                                                                        event_time=event_time)
 
-                 s3.copy_obj(PUSH_BUCKET, PUSH_INACCURATE_BUCKET, file_path)
 
-             else:
 
-                 for index in range(3):
 
-                     file_path = '{uid}/{channel}/{event_time}_{index}.jpeg'.format(uid=uid,
 
-                                                                                    channel=channel,
 
-                                                                                    event_time=event_time,
 
-                                                                                    index=index)
 
-                     if s3.get_object(PUSH_BUCKET, file_path):
 
-                         s3.copy_obj(PUSH_BUCKET, PUSH_INACCURATE_BUCKET, file_path)
 
-             PushInaccurateFeedback.objects.create(equipment_info_id=equipment_info_id, user_id=user_id,
 
-                                                   event_type=event_type, uid=uid, channel=channel,
 
-                                                   add_time=now_time, tag=tag, is_st=is_st, event_time=event_time)
 
-             return response.json(0)
 
-         except Exception as e:
 
-             return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
 
 
  |