UidappController.py 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. import time
  2. import simplejson as json
  3. from django.utils.decorators import method_decorator
  4. from django.views.decorators.csrf import csrf_exempt
  5. from django.views.generic.base import View
  6. from Object.ResponseObject import ResponseObject
  7. from Object.TokenObject import TokenObject
  8. from Model.models import UID_App
  9. from Service.CommonService import CommonService
  10. from Service.ModelService import ModelService
  11. import traceback
  12. '''
  13. # 管理员获取信息
  14. http://192.168.136.39:8000/uidApp/adminQuery?token=local&page=1&line=10
  15. 管理员删除信息
  16. http://192.168.136.39:8000/uidApp/adminDelete?token=local&id=2
  17. 管理员添加信息
  18. http://192.168.136.39:8000/uidApp/adminAdd?token=local&uid=321&app_id=1&app_type=2&token_val=ertewtwetrewrt
  19. 管理员编辑信息
  20. http://192.168.136.39:8000/uidApp/adminEdit?token=local&id=6&content={"token_val":"9999"}
  21. '''
  22. # 设备信息添加
  23. class UidappView(View):
  24. @method_decorator(csrf_exempt)
  25. def dispatch(self, *args, **kwargs):
  26. return super(UidappView, self).dispatch(*args, **kwargs)
  27. def get(self, request, *args, **kwargs):
  28. request.encoding = 'utf-8'
  29. operation = kwargs.get('operation')
  30. return self.validation(request.GET, request, operation)
  31. def post(self, request, *args, **kwargs):
  32. request.encoding = 'utf-8'
  33. operation = kwargs.get('operation')
  34. return self.validation(request.POST, request, operation)
  35. def validation(self, request_dict, request, operation):
  36. response = ResponseObject()
  37. if operation is None:
  38. return response.json(444, 'error path')
  39. token = request_dict.get('token', None)
  40. # 设备主键uid
  41. tko = TokenObject(token)
  42. response.lang = tko.lang
  43. if tko.code != 0:
  44. return response.json(tko.code)
  45. userID = tko.userID
  46. if operation == 'querylist':
  47. return self.do_querylist(request_dict, userID, response)
  48. elif operation == 'adminDelete':
  49. return self.do_admin_delete(request_dict, userID, response)
  50. elif operation == 'adminQuery':
  51. return self.do_admin_query(request_dict, userID, response)
  52. elif operation == 'adminAdd':
  53. return self.do_admin_add(request_dict, userID, response)
  54. elif operation == 'adminEdit':
  55. return self.do_admin_edit(request_dict, userID, response)
  56. else:
  57. return response.json(444, 'error path')
  58. # 管理员删除
  59. def do_admin_delete(self, request_dict, userID, response):
  60. own_perm = ModelService.check_perm(userID, 20)
  61. if own_perm is True:
  62. id = request_dict.get('id')
  63. try:
  64. list = UID_App.objects.filter(id=id)
  65. if list.exists():
  66. list.delete()
  67. return response.json(0)
  68. else:
  69. return response.json(173)
  70. except Exception as e:
  71. print(errorInfo)
  72. return response.json(424, errorInfo)
  73. else:
  74. return response.json(404)
  75. # 管理员查询接口
  76. def do_admin_query(self, request_dict, userID, response):
  77. own_perm = ModelService.check_perm(userID, 20)
  78. if own_perm is True:
  79. page = request_dict.get('page', None)
  80. line = request_dict.get('line', None)
  81. page = int(page)
  82. line = int(line)
  83. omqs = UID_App.objects.filter()
  84. if not omqs.exists():
  85. return response.json(0, [])
  86. count = omqs.count()
  87. order_ql = omqs[(page - 1) * line:page * line].values("id","uid","app_type","token_val","addTime","updTime",
  88. "endTime","app__id","app__appName")
  89. order_list = list(order_ql)
  90. return response.json(0, {'data': order_list, 'count': count})
  91. else:
  92. return response.json(404)
  93. # 管理员的添加
  94. def do_admin_add(self, request_dict, userID, response):
  95. own_perm = ModelService.check_perm(userID=userID, permID=40)
  96. if own_perm is not True:
  97. return response.json(404)
  98. uid = request_dict.get('uid', None)
  99. app_id = request_dict.get('app_id', None)
  100. app_type = request_dict.get('app_type', None)
  101. token_val = request_dict.get('token_val', None)
  102. timestamp = int(time.time())
  103. param_flag = CommonService.get_param_flag(
  104. data=[uid, app_id, app_type, token_val])
  105. if param_flag is not True:
  106. return response.json(444)
  107. try:
  108. Uidapp = UID_App(
  109. uid=uid,
  110. app_id=app_id,
  111. app_type=app_type,
  112. token_val=token_val,
  113. addTime=timestamp,
  114. updTime=timestamp,
  115. endTime=timestamp)
  116. Uidapp.save()
  117. return response.json(0)
  118. except Exception:
  119. errorInfo = traceback.format_exc()
  120. print(errorInfo)
  121. return response.json(500, {'details': errorInfo})
  122. # 管理员的编辑
  123. def do_admin_edit(self, request_dict, userID, response):
  124. own_perm = ModelService.check_perm(userID=userID, permID=50)
  125. if own_perm is not True:
  126. return response.json(404)
  127. deviceContent = request_dict.get('content', None)
  128. id = request_dict.get('id', None)
  129. if not deviceContent or not id:
  130. return response.json(444, 'content,id')
  131. try:
  132. timestamp = int(time.time())
  133. deviceData = json.loads(deviceContent)
  134. uid_app = UID_App.objects.filter(id=id)
  135. if uid_app.exists():
  136. uid_app.update(updTime=timestamp, **deviceData)
  137. return response.json(0)
  138. else:
  139. return response.json(173)
  140. except Exception:
  141. errorInfo = traceback.format_exc()
  142. print(errorInfo)
  143. return response.json(500, {'details': errorInfo})