SysMsg.py 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. @Copyright (C) ansjer cop Video Technology Co.,Ltd.All rights reserved.
  5. @AUTHOR: ASJRD018
  6. @NAME: AnsjerFormal
  7. @software: PyCharm
  8. @DATE: 2019/5/18 10:45
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: SysMsg.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. import time
  15. import re
  16. from django.views.generic.base import View
  17. from Model.models import SysMsgModel, FeedBackModel, SysMassModel, UserExModel, UidSetModel
  18. from Object.ResponseObject import ResponseObject
  19. from Object.TokenObject import TokenObject
  20. from Service.CommonService import CommonService
  21. from Service.ModelService import ModelService
  22. class SysMsgView(View):
  23. def get(self, request, *args, **kwargs):
  24. request.encoding = 'utf-8'
  25. operation = kwargs.get('operation', None)
  26. return self.validation(request.GET, operation)
  27. def post(self, request, *args, **kwargs):
  28. request.encoding = 'utf-8'
  29. operation = kwargs.get('operation', None)
  30. return self.validation(request.POST, operation)
  31. def validation(self, request_dict, operation):
  32. response = ResponseObject()
  33. token = request_dict.get('token', None)
  34. tko = TokenObject(token)
  35. if tko.code == 0:
  36. userID = tko.userID
  37. if operation == 'pushFeedBack':
  38. return self.do_push_msg_feed_back(userID, request_dict, response)
  39. elif operation == 'query':
  40. return self.do_query(userID, request_dict, response)
  41. elif operation == 'queryByAdmin':
  42. return self.do_query_by_admin(userID, request_dict, response)
  43. elif operation == 'update':
  44. return self.do_update(userID, request_dict, response)
  45. elif operation == 'delete':
  46. return self.do_delete(userID, request_dict, response)
  47. elif operation == 'deleteByAdmin':
  48. return self.do_delete_by_admin(userID, request_dict, response)
  49. elif operation == 'massPush':
  50. return self.do_mass_push(userID, request_dict, response)
  51. elif operation == 'queryMassPush':
  52. return self.do_query_mass_push(userID, request_dict, response)
  53. else:
  54. return response.json(414)
  55. else:
  56. return response.json(tko.code)
  57. def do_query_mass_push(self, userID, request_dict, response):
  58. own_perm = ModelService.check_perm(userID, 30)
  59. sender = request_dict.get('sender', None)
  60. page = int(request_dict.get('page', None))
  61. line = int(request_dict.get('line', None))
  62. if own_perm:
  63. smss_qs = SysMassModel.objects.filter()
  64. if sender:
  65. smss_qs.filter(sender__username=sender)
  66. count = smss_qs.count()
  67. smss_qs = smss_qs.values('id', 'sender__username', 'addTime', 'updTime', 'lang', 'recever', 'msg',
  68. 'platform')
  69. smss_qs = smss_qs[(page - 1) * line:page * line]
  70. return response.json(0, {'count': count, 'datas': list(smss_qs)})
  71. else:
  72. return response.json(404)
  73. def do_mass_push(self, userID, request_dict, response):
  74. own_perm = ModelService.check_perm(userID, 10)
  75. if own_perm:
  76. app_str = request_dict.get('app_list', None)
  77. msg = request_dict.get('msg', None)
  78. region_str = request_dict.get('region', None)
  79. platform = request_dict.get('platform', None)
  80. app_list = app_str.split(',')
  81. region = region_str.split(',')
  82. nowTime = int(time.time())
  83. ue_filter = UserExModel.objects.filter()
  84. if app_list:
  85. ue_filter = ue_filter.filter(appBundleId__in=app_list)
  86. if region:
  87. ue_filter = ue_filter.filter(region__in=region)
  88. ue_count = ue_filter.count()
  89. # range_count = math.ceil(ue_count / 5000)
  90. SysMassModel.objects.create(
  91. sender_id=userID,
  92. lang=region_str,
  93. recever=app_str,
  94. msg=msg,
  95. addTime=nowTime,
  96. updTime=nowTime,
  97. platform=platform
  98. )
  99. querysetlist = []
  100. userID_list = ue_filter.values_list('userID_id', flat=True)
  101. for urd in userID_list:
  102. querysetlist.append(SysMsgModel(userID_id=urd, msg=msg, addTime=nowTime, updTime=nowTime))
  103. if len(querysetlist) > 5000:
  104. is_y = SysMsgModel.objects.bulk_create(querysetlist)
  105. print(is_y)
  106. querysetlist = []
  107. SysMsgModel.objects.bulk_create(querysetlist)
  108. return response.json(0)
  109. else:
  110. return response.json(404)
  111. def do_push_msg_feed_back(self, userID, request_dict, response):
  112. own_perm = ModelService.check_perm(userID, 10)
  113. if own_perm:
  114. fid = request_dict.get('fid', None)
  115. msg = request_dict.get('msg', None)
  116. if all([fid, msg]):
  117. nowTime = int(time.time())
  118. fb_qs = FeedBackModel.objects.filter(id=fid)
  119. fb_list = fb_qs.values('userID_id')
  120. if fb_qs.exists():
  121. create_data = {'userID_id': fb_list[0]['userID_id'], 'msg': msg, 'addTime': nowTime,
  122. 'updTime': nowTime}
  123. try:
  124. SysMsgModel.objects.create(**create_data)
  125. fb_qs.update(status=1)
  126. except Exception as e:
  127. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  128. else:
  129. return response.json(0, {'status': 1, 'updTime': nowTime})
  130. else:
  131. return response.json(173)
  132. else:
  133. return response.json(444, 'fid,msg')
  134. else:
  135. return response.json(404)
  136. def do_query(self, userID, request_dict, response):
  137. page = request_dict.get('page', None)
  138. line = request_dict.get('line', None)
  139. if not all([page, line]):
  140. return response.json(444, 'page,line')
  141. page = int(page)
  142. line = int(line)
  143. sm_qs = SysMsgModel.objects.filter(userID_id=userID)
  144. try:
  145. # 如果没有系统消息,周视ios用户暂时生成消息并返回
  146. if not sm_qs.exists():
  147. user_ex_qs = UserExModel.objects.filter(userID_id=userID, appBundleId='com.ansjer.zccloud').values(
  148. 'region')
  149. if not user_ex_qs.exists():
  150. return response.json(0, [])
  151. now_time = int(time.time())
  152. region = user_ex_qs[0]['region']
  153. if region == 'en':
  154. msg = "Note: If you have upgraded iPhone system version to iOS 16 or above, there will be a situation where you cannot return to the portrait orientation after turning the live and playback page to landscape. We are sorry for the inconvenience caused. The following is the solution: you can swipe down from the top right corner of your screen to open control center, turn on the portrait orientation lock to prevent the system from automatically switching between landscape and portrait. We will solve the issue in the next version. Wish you a happy life."
  155. elif region == 'fr':
  156. msg = "Remarque : Si vous avez mis à jour votre iPhone vers iOS 16 ou une version supérieur, il arrive que l'écran de lecture en direct ne revienne pas à l'écran vertical après être passé à l'écran horizontal.\nNous nous excusons pour le dérangement.\nLa solution est celle-ci :\nLorsque le téléphone est en mode portrait, faites glisser le coin supérieur droit de l'écran pour ouvrir le centre de contrôle et activez l'icône de verrouillage de l'écran pour empêcher le système de modifier automatiquement l'orientation de l'écran.\nSoyez assuré que nous corrigerons ce problème dans la prochaine version.\nTous mes vœux! "
  157. elif region == 'ru':
  158. msg = "Напоминание: если вы обновите версию системы iPhone до iOS 16 или выше, вы не сможете вернуться к вертикальному экрану после переключения на горизонтальный экран интерфейса воспроизведения в реальном времени. Приносим свои извинения за неудобства. Вот решение: вы можете провести пальцем вниз в правом верхнем углу экрана, чтобы вызвать центр управления, подсветить значок блокировки портретной ориентации и запретить системе автоматическое переключение между альбомной и портретной ориентацией. Мы полностью решим эту проблему в следующей версии, желаем вам счастливой жизни!"
  159. elif region == 'es':
  160. msg = "Nota: Si la versión de tu iPhone es iOS 16 o superior, habrá un problema cuando vuelva a la orientación vertical después de cambiar la interfaz en vivo y reproducción a horizontal.\n Disculpe mucho los inconvenientes, aquí está la solución: puede deslizar hacia abajo desde la esquina superior derecha de la pantalla para abrir el centro de control, activa el bloqueo de orientación vertical para evitar que el sistema cambie automáticamente entre horizontal y vertical. Resolveremos este problema en la próxima versión. ¡Qué tenga un buen día!"
  161. elif region == 'ja':
  162. msg = "ご注意: iPhoneのバージョンを iOS16以上に更新すると、ライブ再生インターフェイスの横画面に切り替えた後、横画面から縦画面に切り替えができません、ご不便をおかけして申し訳ありません。                                次の手順にって調整ください:画面の右上隅を下にスワイプしてコントロールセンターに表示され、画面縦向きのロックアイコンをクリックして、ロックアイコンがオンにすればシステムが横画面と縦画面を切り替えません。次のバージョンいごにこの問題を解決しますのでご迷惑をおかけして申し訳ありません、よろしくお願いします。"
  163. elif region == 'de':
  164. msg = "Hinweis: Wenn Sie Ihr iPhone auf iOS 16 oder höher aktualisiert haben, könnte das Problem bestehen, dass der Live-Wiedergabebildschirm nach dem Umschalten auf den horizontalen Bildschirm nicht zum vertikalen Bildschirm zurückkehrt.\nWir entschuldigen uns für die Unannehmlichkeiten.\nDie Lösung ist folgende:\nWenn das Telefon im Hochformat ist, schieben Sie bitte die obere rechte Ecke des Bildschirms nach unten, um das Kontrollzentrum aufzurufen, und aktivieren Sie das Symbol für die Bildschirmsperre, um zu verhindern, dass das System automatisch die Bildschirmausrichtung ändert.\nBitte seien Sie versichert, dass wir dieses Problem in der nächsten Version lösen werden.\nAlles gute!"
  165. elif region == 'cn':
  166. msg = "温馨提示:若您将iPhone系统版本升级为iOS 16及以上,会出现切换直播回放界面横屏后无法回到竖屏。我们很抱歉,给您带来不便。以下是解决方案:您可以在屏幕右上角下滑,调出控制中心,点亮竖屏锁定图标,禁止系统自动切换横竖屏。我们将在下一个版本彻底解决这个问题,祝您生活愉快!"
  167. else:
  168. msg = "Note: If you have upgraded iPhone system version to iOS 16 or above, there will be a situation where you cannot return to the portrait orientation after turning the live and playback page to landscape. We are sorry for the inconvenience caused. The following is the solution: you can swipe down from the top right corner of your screen to open control center, turn on the portrait orientation lock to prevent the system from automatically switching between landscape and portrait. We will solve the issue in the next version. Wish you a happy life."
  169. SysMsgModel.objects.create(userID_id=userID, msg=msg, addTime=now_time, updTime=now_time)
  170. sys_msg_qs = SysMsgModel.objects.filter(userID_id=userID).values()
  171. return response.json(0, {'data': CommonService.qs_to_list(sys_msg_qs), 'count': 1})
  172. count = sm_qs.count()
  173. sm_qs = sm_qs[(page - 1) * line:page * line]. \
  174. values('status', 'id', 'msg', 'addTime', 'updTime', 'uid', 'eventType', 'title', 'jumpLink', 'channel')
  175. data_res = []
  176. uid_list = []
  177. for sm_q in sm_qs:
  178. if sm_q['eventType'] > 0:
  179. uid_list.append(sm_q['uid'])
  180. if sm_q['eventType'] == 2:
  181. msg = sm_q['msg']
  182. number_list = re.findall('\d+', msg)
  183. for number in number_list:
  184. if len(number) == 6:
  185. sm_q['code'] = number
  186. data_res.append(sm_q)
  187. if uid_list:
  188. uid_set_qs = UidSetModel.objects.filter(uid__in=uid_list).values('uid', 'nickname', 'device_type')
  189. data_res = []
  190. for sm_q in sm_qs:
  191. for uid_set_q in uid_set_qs:
  192. if uid_set_q['uid'] == sm_q['uid']:
  193. sm_q['devNickName'] = uid_set_q['nickname']
  194. sm_q['devType'] = int(uid_set_q['device_type'])
  195. data_res.append(sm_q)
  196. return response.json(0, {'data': data_res, 'count': count})
  197. except Exception as e:
  198. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  199. def do_query_by_admin(self, userID, request_dict, response):
  200. own_perm = ModelService.check_perm(userID, 30)
  201. if own_perm:
  202. page = request_dict.get('page', None)
  203. line = request_dict.get('line', None)
  204. username = request_dict.get('username', None)
  205. if page and line:
  206. page = int(page)
  207. line = int(line)
  208. sm_qs = SysMsgModel.objects.filter()
  209. if username:
  210. userID_list = ModelService.get_user_list_by_username(username)
  211. sm_qs = sm_qs.filter(userID_id__in=userID_list)
  212. count = sm_qs.count()
  213. sm_qs = sm_qs[(page - 1) * line:page * line]. \
  214. values('status', 'id', 'msg', 'addTime', 'updTime', 'userID__username', 'userID__userEmail',
  215. 'userID__phone')
  216. for k, v in enumerate(sm_qs):
  217. if sm_qs[k]['userID__username'] == '':
  218. sm_qs[k]['userID__username'] = sm_qs[k]['userID__userEmail']
  219. if sm_qs[k]['userID__username'] == '':
  220. sm_qs[k]['userID__username'] = sm_qs[k]['userID__phone']
  221. sm_qs[k].pop('userID__userEmail')
  222. sm_qs[k].pop('userID__phone')
  223. return response.json(0, {'datas': list(sm_qs), 'count': count})
  224. else:
  225. return response.json(444, 'page,line')
  226. else:
  227. return response.json(404)
  228. def do_update(self, userID, request_dict, response):
  229. sid = request_dict.get('sid', None)
  230. if sid:
  231. sm_qs = SysMsgModel.objects.filter(userID_id=userID, id=sid)
  232. if sm_qs.exists():
  233. sm_qs.update(status=1)
  234. return response.json(0)
  235. else:
  236. return response.json(173)
  237. else:
  238. sm_qs = SysMsgModel.objects.filter(userID_id=userID).update(status=1)
  239. return response.json(0)
  240. def do_delete(self, userID, request_dict, response):
  241. sid = request_dict.get('sid', None)
  242. sid_list = sid.split(',')
  243. if sid:
  244. sm_qs = SysMsgModel.objects.filter(userID_id=userID, id__in=sid_list)
  245. if sm_qs.exists():
  246. sm_qs.delete()
  247. return response.json(0)
  248. else:
  249. return response.json(173)
  250. else:
  251. sm_qs = SysMsgModel.objects.filter(userID_id=userID)
  252. if sm_qs.exists():
  253. sm_qs.delete()
  254. return response.json(0)
  255. else:
  256. return response.json(173)
  257. def do_delete_by_admin(self, userID, request_dict, response):
  258. own_perm = ModelService.check_perm(userID, 10)
  259. if not own_perm:
  260. return response.json(404)
  261. sid = request_dict.get('sid', None)
  262. if sid:
  263. sm_qs = SysMsgModel.objects.filter(id=sid)
  264. if sm_qs.exists():
  265. sm_qs.delete()
  266. return response.json(0)
  267. else:
  268. return response.json(173)
  269. else:
  270. return response.json(444, 'sid')
  271. # 回复记录