RoleController.py 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  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: 2021/07/06 11:17
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. """
  12. import json
  13. import time
  14. import urllib
  15. import uuid
  16. import boto3
  17. import threading
  18. import logging
  19. from boto3.session import Session
  20. from django.http import JsonResponse, HttpResponseRedirect, HttpResponse
  21. from django.views.generic.base import View
  22. from Model.models import Device_Info, Role, MenuModel
  23. from Object.ResponseObject import ResponseObject
  24. from Object.TokenObject import TokenObject
  25. from Object.UidTokenObject import UidTokenObject
  26. from Service.CommonService import CommonService
  27. from django.db.models import Q, F, Max
  28. from time import strftime
  29. class RoleView(View):
  30. def get(self, request, *args, **kwargs):
  31. request.encoding = 'utf-8'
  32. operation = kwargs.get('operation')
  33. return self.validation(request.GET, request, operation)
  34. def post(self, request, *args, **kwargs):
  35. request.encoding = 'utf-8'
  36. operation = kwargs.get('operation')
  37. return self.validation(request.POST, request, operation)
  38. def validation(self, request_dict, request, operation):
  39. language = request_dict.get('language', 'en')
  40. response = ResponseObject(language, 'pc')
  41. if operation == '??':
  42. return 0
  43. else:
  44. tko = TokenObject(request.META.get('HTTP_AUTHORIZATION'),returntpye='pc')
  45. if tko.code != 0:
  46. return response.json(tko.code)
  47. response.lang = tko.lang
  48. userID = tko.userID
  49. if operation == 'getList':
  50. return self.getList(userID, request_dict, response)
  51. elif operation == 'doEdit':
  52. return self.doEdit(userID, request_dict, response)
  53. elif operation == 'doDelete':
  54. return self.doDelete(userID, request_dict, response)
  55. elif operation == 'getPerms':
  56. return self.getPerms(userID, request_dict, response)
  57. elif operation == 'setPerms':
  58. return self.setPerms(userID, request_dict, response)
  59. else:
  60. return response.json(404)
  61. def getList(self, userID, request_dict, response):
  62. isSelect = request_dict.get('isSelect', None) # 获取全部数据作为角色选项
  63. if isSelect:
  64. role_qs = Role.objects.all().values('rid', 'roleName', 'Description')
  65. return response.json(0, {'list': CommonService.qs_to_list(role_qs)})
  66. roleName = request_dict.get('roleName', '').strip() # 移除字符串头尾的空格
  67. pageNo = request_dict.get('pageNo', None)
  68. pageSize = request_dict.get('pageSize', None)
  69. if not all([pageNo, pageSize]):
  70. return response.json(444)
  71. page = int(pageNo)
  72. line = int(pageSize)
  73. if roleName:
  74. role_qs = Role.objects.filter(roleName=roleName).values('rid', 'roleName', 'Description')
  75. else:
  76. role_qs = Role.objects.all().values('rid', 'roleName', 'Description')
  77. count = role_qs.count()
  78. role_qs = role_qs.order_by('rid')[(page - 1) * line:page * line]
  79. return response.json(0, {'list': CommonService.qs_to_list(role_qs), 'total': count})
  80. def doEdit(self, userID, request_dict, response):
  81. data_dict = request_dict.dict()
  82. # data_dict = json.loads(data_str)
  83. if 'rid' in data_dict:
  84. Role.objects.filter(rid=data_dict['rid']).update(**data_dict)
  85. else:
  86. id = Role.objects.all().aggregate(Max('rid'))['rid__max'] + 1
  87. data_dict['rid'] = id
  88. Role.objects.create(**data_dict)
  89. return response.json(0)
  90. def doDelete(self, userID, request_dict, response):
  91. rid = request_dict.get('rid', '')
  92. if not all([rid]):
  93. return response.json(444)
  94. Role.objects.filter(rid=rid).delete()
  95. return response.json(0)
  96. def getPerms(self, userID, request_dict, response):
  97. rid = request_dict.get('rid', '')
  98. if rid:
  99. role_qs = Role.objects.filter(rid=rid).values('menu__id')
  100. return response.json(0, CommonService.qs_to_list(role_qs))
  101. return response.json(0)
  102. def setPerms(self, userID, request_dict, response):
  103. rid = request_dict.get('rid', '')
  104. permsIds = request_dict.get('permsIds', '')
  105. if not all([rid]):
  106. return response.json(444)
  107. Role.objects.get(rid=rid).menu.clear()
  108. menu_obj = MenuModel.objects.filter(id__in=permsIds.split(','))
  109. Role.objects.filter(rid=rid)[0].menu.add(*menu_obj)
  110. return response.json(0)