拍爱

views.py 6.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. # -*- coding: utf-8 -*-
  2. from django.conf import settings
  3. from django.http import JsonResponse
  4. from account.models import UserInfo
  5. from message.models import SystemMessageDeleteInfo, SystemMessageInfo, SystemMessageReadInfo, UserMessageInfo
  6. from utils.error.errno_utils import MessageStatusCode, UserStatusCode
  7. from utils.error.response_utils import response
  8. from utils.page_utils import pagination
  9. from utils.redis.rmessage import (get_system_message_delete_info, get_system_message_read_info,
  10. set_system_message_delete_info, set_system_message_read_info)
  11. def message_list_api(request):
  12. """
  13. 消息列表
  14. :param request:
  15. :return:
  16. """
  17. user_id = request.POST.get('user_id', '') or request.GET.get('user_id', '')
  18. messages = UserMessageInfo.MESSAGE_TYPE_INFO
  19. final_messages = []
  20. for message in messages:
  21. msg_type = message['msg_type']
  22. if msg_type == UserMessageInfo.SYSTEM:
  23. read_message_ids = get_system_message_read_info(user_id)
  24. deleted_message_ids = get_system_message_delete_info(user_id)
  25. type_unread_messages = SystemMessageInfo.objects.filter(
  26. status=True,
  27. ).exclude(
  28. pk__in=list(set(read_message_ids + deleted_message_ids)),
  29. )
  30. else:
  31. type_unread_messages = UserMessageInfo.objects.filter(
  32. to_uid=user_id,
  33. msg_type=msg_type,
  34. read=False,
  35. status=True,
  36. )
  37. message['msg_unread_num'] = type_unread_messages.count()
  38. final_messages.append(message)
  39. return JsonResponse({
  40. 'status': 200,
  41. 'message': u'获取消息列表成功',
  42. 'data': {
  43. 'messages': final_messages,
  44. },
  45. })
  46. def message_type_list_api(request, msg_type):
  47. """
  48. 分类消息列表
  49. :param request:
  50. :param msg_type:
  51. :return:
  52. """
  53. user_id = request.POST.get('user_id', '') or request.GET.get('user_id', '')
  54. page = int(request.POST.get('page', 0) or request.GET.get('page', 0) or 1)
  55. num = int(request.POST.get('num', 0) or request.GET.get('num', 0) or settings.MESSAGE_NUM_PER_PAGE)
  56. if msg_type == UserMessageInfo.SYSTEM:
  57. deleted_message_ids = get_system_message_delete_info(user_id)
  58. type_messages = SystemMessageInfo.objects.filter(
  59. status=True,
  60. ).exclude(
  61. pk__in=deleted_message_ids,
  62. )
  63. else:
  64. type_messages = UserMessageInfo.objects.filter(
  65. to_uid=user_id,
  66. msg_type=msg_type,
  67. status=True,
  68. )
  69. type_messages = type_messages.order_by(
  70. '-pk'
  71. )
  72. type_messages, left = pagination(type_messages, page, num)
  73. type_messages = [msg.msg_info(user_id) for msg in type_messages]
  74. return JsonResponse({
  75. 'status': 200,
  76. 'message': u'获取消息列表成功',
  77. 'data': {
  78. 'messages': type_messages,
  79. 'left': left,
  80. },
  81. })
  82. def message_type_read_api(request, msg_type=None):
  83. """
  84. 消息读取
  85. :param request:
  86. :return:
  87. """
  88. user_id = request.POST.get('user_id', '') or request.GET.get('user_id', '')
  89. pk = int(request.POST.get('pk', 0) or request.GET.get('pk', 0) or -1)
  90. _all = (request.POST.get('all', '') or request.GET.get('all', '')).lower()
  91. # 用户校验
  92. try:
  93. user = UserInfo.objects.get(user_id=user_id)
  94. except UserInfo.DoesNotExist:
  95. return response(UserStatusCode.USER_NOT_FOUND)
  96. # 消息读取
  97. if msg_type == UserMessageInfo.SYSTEM:
  98. if pk > 0: # 系统消息单个读取
  99. if not SystemMessageInfo.objects.filter(pk=pk).exists():
  100. return response(MessageStatusCode.MESSAGE_NOT_FOUND)
  101. SystemMessageReadInfo.objects.get_or_create(user_id=user_id, msg_id=pk)
  102. if _all == 'true': # 系统消息全部读取
  103. for msg in SystemMessageInfo.objects.filter(status=True):
  104. SystemMessageReadInfo.objects.get_or_create(user_id=user_id, msg_id=msg.pk)
  105. get_system_message_read_info(user_id)
  106. else:
  107. if pk > 0: # 用户(点赞/评论)消息单个读取
  108. UserMessageInfo.objects.filter(pk=pk, to_uid=user_id).update(read=True)
  109. if _all == 'true': # 用户消息(点赞/评论)全部读取
  110. UserMessageInfo.objects.filter(to_uid=user_id, msg_type=msg_type).update(read=True)
  111. return JsonResponse({
  112. 'status': 200,
  113. 'message': u'已读消息成功',
  114. })
  115. def message_type_delete_api(request, msg_type=None):
  116. """
  117. 消息删除
  118. :param request:
  119. :param msg_type:
  120. :return:
  121. """
  122. user_id = request.POST.get('user_id', '') or request.GET.get('user_id', '')
  123. pk = int(request.POST.get('pk', 0) or request.GET.get('pk', 0) or -1)
  124. _all = (request.POST.get('all', '') or request.GET.get('all', '')).lower()
  125. # 用户校验
  126. try:
  127. user = UserInfo.objects.get(user_id=user_id)
  128. except UserInfo.DoesNotExist:
  129. return response(UserStatusCode.USER_NOT_FOUND)
  130. # 消息删除
  131. if msg_type == UserMessageInfo.SYSTEM:
  132. if pk > 0: # 系统消息单个删除
  133. if not SystemMessageInfo.objects.filter(pk=pk).exists():
  134. return response(MessageStatusCode.MESSAGE_NOT_FOUND)
  135. SystemMessageDeleteInfo.objects.get_or_create(user_id=user_id, msg_id=pk)
  136. if _all == 'true': # 系统消息全部删除
  137. for msg in SystemMessageInfo.objects.filter(status=True):
  138. SystemMessageDeleteInfo.objects.get_or_create(user_id=user_id, msg_id=msg.pk)
  139. set_system_message_delete_info(user_id)
  140. else:
  141. if pk > 0: # 用户(点赞/评论)消息单个删除
  142. UserMessageInfo.objects.filter(pk=pk, to_uid=user_id).update(status=False)
  143. if _all == 'true': # 用户消息(点赞/评论)全部删除
  144. UserMessageInfo.objects.filter(to_uid=user_id, msg_type=msg_type).update(status=False)
  145. return JsonResponse({
  146. 'status': 200,
  147. 'message': u'消息删除成功',
  148. })