UidappController.py 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. import time
  2. import traceback
  3. import simplejson as json
  4. from django.utils.decorators import method_decorator
  5. from django.views.decorators.csrf import csrf_exempt
  6. from django.views.generic.base import View
  7. from Model.models import UID_App
  8. from Object.ResponseObject import ResponseObject
  9. from Object.TokenObject import TokenObject
  10. from Service.CommonService import CommonService
  11. from Service.ModelService import ModelService
  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=JW3684H8BSHG9TTM111A&appBundleId=com.ansjer.accloud&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 == 'adminDelete':
  47. return self.do_admin_delete(request_dict, userID, response)
  48. elif operation == 'adminQuery':
  49. return self.do_admin_query(request_dict, userID, response)
  50. elif operation == 'adminAdd':
  51. return self.do_admin_add(request_dict, userID, response)
  52. elif operation == 'adminEdit':
  53. return self.do_admin_edit(request_dict, userID, response)
  54. else:
  55. return response.json(444, 'error path')
  56. # 管理员删除
  57. def do_admin_delete(self, request_dict, userID, response):
  58. own_perm = ModelService.check_perm(userID, 20)
  59. if own_perm is True:
  60. id = request_dict.get('id')
  61. try:
  62. list = UID_App.objects.filter(id=id)
  63. if list.exists():
  64. list.delete()
  65. return response.json(0)
  66. else:
  67. return response.json(173)
  68. except Exception as e:
  69. print(repr(e))
  70. return response.json(424, repr(e))
  71. else:
  72. return response.json(404)
  73. # 管理员查询接口
  74. def do_admin_query(self, request_dict, userID, response):
  75. own_perm = ModelService.check_perm(userID, 20)
  76. if own_perm is True:
  77. page = request_dict.get('page', None)
  78. line = request_dict.get('line', None)
  79. page = int(page)
  80. line = int(line)
  81. omqs = UID_App.objects.filter()
  82. if not omqs.exists():
  83. return response.json(0, [])
  84. count = omqs.count()
  85. order_ql = omqs[(page - 1) * line:page * line].values("id", "uid", "app_type","appBundleId","push_type", "token_val", "addTime", "updTime","status", "userID__username")
  86. order_list = list(order_ql)
  87. print (order_list)
  88. return response.json(0, {'data': order_list, 'count': count})
  89. else:
  90. return response.json(404)
  91. # 管理员的添加
  92. def do_admin_add(self, request_dict, userID, response):
  93. own_perm = ModelService.check_perm(userID=userID, permID=40)
  94. if own_perm is not True:
  95. return response.json(404)
  96. uid = request_dict.get('uid', None)
  97. appBundleId = request_dict.get('appBundleId', None)
  98. app_type = request_dict.get('app_type', None)
  99. token_val = request_dict.get('token_val', None)
  100. timestamp = int(time.time())
  101. param_flag = CommonService.get_param_flag(
  102. data=[uid, appBundleId, app_type, token_val])
  103. if param_flag is not True:
  104. return response.json(444)
  105. try:
  106. Uidapp = UID_App(
  107. uid=uid,
  108. appBundleId=appBundleId,
  109. app_type=app_type,
  110. token_val=token_val,
  111. addTime=timestamp,
  112. updTime=timestamp)
  113. Uidapp.save()
  114. return response.json(0)
  115. except Exception:
  116. errorInfo = traceback.format_exc()
  117. print(errorInfo)
  118. return response.json(500, {'details': errorInfo})
  119. # 管理员的编辑
  120. def do_admin_edit(self, request_dict, userID, response):
  121. own_perm = ModelService.check_perm(userID=userID, permID=50)
  122. if own_perm is not True:
  123. return response.json(404)
  124. deviceContent = request_dict.get('content', None)
  125. id = request_dict.get('id', None)
  126. if not deviceContent or not id:
  127. return response.json(444, 'content,id')
  128. try:
  129. timestamp = int(time.time())
  130. deviceData = json.loads(deviceContent)
  131. uid_app = UID_App.objects.filter(id=id)
  132. if uid_app.exists():
  133. uid_app.update(updTime=timestamp, **deviceData)
  134. return response.json(0)
  135. else:
  136. return response.json(173)
  137. except Exception:
  138. errorInfo = traceback.format_exc()
  139. print(errorInfo)
  140. return response.json(500, {'details': errorInfo})