AdminManage.py 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303
  1. # -*- coding: utf-8 -*-
  2. from django.views.decorators.csrf import csrf_exempt
  3. from django.views.generic import TemplateView
  4. from django.utils.decorators import method_decorator
  5. from django.contrib.auth.hashers import make_password # 对密码加密模块
  6. from Model.models import Device_Info,Role
  7. from Service.ModelService import ModelService
  8. from django.utils import timezone
  9. from Model.models import Access_Log,Device_User
  10. from django.views.decorators.http import require_http_methods
  11. from Object.ResponseObject import ResponseObject
  12. from Object.TokenObject import TokenObject
  13. from Ansjer.config import OFF_LINE_TIME_DELTA
  14. import datetime,simplejson as json
  15. from Service.CommonService import CommonService
  16. '''
  17. http://192.168.136.40:8077/adminManage/manage?operation=getAllDeviceArea&token=debug
  18. http://192.168.136.40:8077/adminManage/manage?operation=getAllUserName&token=debug
  19. http://192.168.136.40:8077/adminManage/manage?operation=getAllUID&token=debug
  20. http://127.0.0.1:8000/adminManage/manage?operation=getAllOnLine&token=stest
  21. http://127.0.0.1:8000/adminManage/manage?operation=getOnLine&token=stest
  22. '''
  23. class AdminManage(TemplateView):
  24. @method_decorator(csrf_exempt)
  25. def dispatch(self, *args, **kwargs):
  26. return super(AdminManage, self).dispatch(*args, **kwargs)
  27. def get(self, request, *args, **kwargs):
  28. request.encoding = 'utf-8'
  29. return self.validation(request_dict=request.GET)
  30. def post(self, request, *args, **kwargs):
  31. request.encoding = 'utf-8'
  32. return self.validation(request_dict=request.POST)
  33. def validation(self, request_dict, *args, **kwargs):
  34. response = ResponseObject()
  35. token = request_dict.get('token', None)
  36. if token is not None:
  37. tko = TokenObject(token)
  38. tko.valid()
  39. response.lang = tko.lang
  40. if tko.code == 0:
  41. userID = tko.userID()
  42. operation = request_dict.get('operation', None)
  43. if userID is not None and operation is not None:
  44. if operation == 'resetUserPwd':
  45. return self.resetUserPwd(request_dict=request_dict, userID=userID)
  46. if operation == 'getAllOnLine':
  47. return self.getAllOnLine(userID,response)
  48. if operation == 'getOnLine':
  49. return self.getOnLine(userID,response)
  50. if operation == 'getAllUserName':
  51. return self.getAllUserName(userID,response)
  52. if operation == 'getStatisAccess':
  53. return self.getStatisAccess(userID,request_dict,response)
  54. if operation == 'getAllUID':
  55. return self.getAllUID(userID,response)
  56. if operation == 'getAllDeviceArea':
  57. return self.getAllDeviceArea(userID,response)
  58. else:
  59. return response.json(444,'operation')
  60. else:
  61. return response.json(tko.code)
  62. else:
  63. return response.json(311)
  64. def resetUserPwd(self, request_dict, userID,response):
  65. own_permission = ModelService.check_permission(userID=userID, permID=50)
  66. if own_permission:
  67. duserID = request_dict.get('duserID', None)
  68. userPwd = request_dict.get('userPwd', None)
  69. if duserID:
  70. UserValid = Device_User.objects.filter(userID=duserID)
  71. if UserValid:
  72. if userPwd is None:
  73. userPwd = '123456'
  74. is_update = UserValid.update(password=make_password(userPwd))
  75. if is_update:
  76. return response.json(0)
  77. else:
  78. return response.json(106)
  79. else:
  80. return response.json(444,'duserID')
  81. else:
  82. return response.json(404)
  83. def getAllUserName(self, userID,response):
  84. # 权限固定为30
  85. own_permission = ModelService.check_permission(userID=userID, permID=30)
  86. if own_permission is True:
  87. username_list = Device_User.objects.all().values_list('username', flat=True)
  88. if username_list:
  89. return response.json(0,{'username_list': list(username_list)})
  90. else:
  91. return response.json(0)
  92. else:
  93. return response.json(404)
  94. # 获取全部用户的在线个数
  95. def getAllOnLine(self, userID,response):
  96. # 权限固定为30
  97. own_permission = ModelService.check_permission(userID=userID, permID=30)
  98. if own_permission is True:
  99. allonline = Device_User.objects.all().values('online')
  100. # 两个变量,分别是在线,离线
  101. onlinenum = 0
  102. noonlinenum=0
  103. for q in allonline:
  104. if q['online'] ==True:
  105. onlinenum+=1
  106. else:
  107. noonlinenum+=1
  108. print("在线人数:")
  109. print(onlinenum)
  110. return response.json(0, {"onlinenum": onlinenum, "no_onlinenum": noonlinenum})
  111. else:
  112. return response.json(404)
  113. # 获取全部用户的在线人数
  114. def getOnLine(self, userID,response):
  115. # 权限固定为30
  116. own_permission = ModelService.check_permission(userID=userID, permID=30)
  117. if own_permission is True:
  118. online_list = Device_User.objects.all().values('online', 'last_login')
  119. # 两个变量,分别是在线,离线
  120. onlinenum=0
  121. noonlinenum=0
  122. for q in online_list:
  123. # print(q['last_login'] )
  124. # 最后访问时间加5分种
  125. dl_time = q['last_login'] + datetime.timedelta(minutes=OFF_LINE_TIME_DELTA)
  126. # print(dl_time)
  127. # 当前时间
  128. now_time = timezone.localtime(timezone.now())
  129. # print(now_time)
  130. # 如果当前时间大于最后访问的时间
  131. if now_time < dl_time:
  132. onlinenum += 1
  133. else:
  134. noonlinenum += 1
  135. print("在线人")
  136. print(onlinenum)
  137. return response.json(0, {"onlinenum": onlinenum,"no_onlinenum": noonlinenum})
  138. else:
  139. return response.json(404)
  140. # 获取所有设备地区
  141. def getAllDeviceArea(self, userID,response):
  142. own_permission = ModelService.check_permission(userID=userID, permID=30)
  143. if own_permission is True:
  144. qs = Device_Info.objects.all().values('area','UID')
  145. uid_area_dict = {}
  146. for q in qs:
  147. if q['UID'] and q['area']:
  148. uid_area_dict[q['UID']]=q['area']
  149. if len(uid_area_dict):
  150. area_dict = {}
  151. for k,v in uid_area_dict.items():
  152. if v in area_dict:
  153. area_dict[v] += 1
  154. else:
  155. area_dict[v] = 1
  156. return response.json(0,{'area':area_dict})
  157. else:
  158. return response.json(0)
  159. else:
  160. return response.json(404)
  161. '''
  162. 统计一天访问量
  163. http://192.168.136.45:8077/adminManage/manage?token=test&operation=getStatisAccess&timestamp=1528773308
  164. '''
  165. def getStatisAccess(self,userID,request_dict,response):
  166. own_permission = ModelService.check_permission(userID=userID, permID=30)
  167. if own_permission is True:
  168. time_stamp = int(request_dict.get('timestamp', None))
  169. times = datetime.datetime.fromtimestamp(time_stamp)
  170. time_dict = CommonService.getTimeDict(times)
  171. res = {}
  172. for k, v in time_dict.items():
  173. start_date = time_dict[k]
  174. end_date = time_dict[k] + datetime.timedelta(hours=1)
  175. count = Access_Log.objects.filter(time__range=(start_date, end_date)).count()
  176. if count:
  177. res[k] = count
  178. else:
  179. res[k] = 0
  180. return response.json(0, {'count': res})
  181. else:
  182. return response.json(404)
  183. def getAllUID(self,userID,response):
  184. own_permission = ModelService.check_permission(userID=userID, permID=30)
  185. if own_permission is True:
  186. uid_list = Device_Info.objects.all().values_list('UID', flat=True)
  187. if uid_list:
  188. return response.json(0, {'count': len(uid_list),'uid_list':list(uid_list)})
  189. else:
  190. return response.json(404)
  191. @require_http_methods(["GET"])
  192. def getUserIds(request):
  193. token = request.GET.get('token', None)
  194. response = ResponseObject()
  195. if token is not None:
  196. tko = TokenObject(token)
  197. tko.valid()
  198. response.lang = tko.lang
  199. if tko.code == 0:
  200. userID = tko.userID()
  201. own_perm = ModelService.check_permission(userID,30)
  202. if own_perm is True:
  203. # userID_list = Device_User.objects.all().values_list('userID', flat=True)
  204. dn = Device_User.objects.all().values('userID', 'username')
  205. return response.json(0,{"datas":list(dn)})
  206. else:
  207. return response.json(404)
  208. else:
  209. return response.json(tko.code)
  210. else:
  211. return response.json(311)
  212. @csrf_exempt
  213. def search_user_by_content(request):
  214. if request.method == 'GET':
  215. request_dict = request.GET
  216. if request.method == 'POST':
  217. request_dict = request.POST
  218. token = request_dict.get('token', None)
  219. page = request_dict.get('page', None)
  220. line = request_dict.get('line', None)
  221. content = request_dict.get('content', None)
  222. rstime = request_dict.get('rstime', None)
  223. retime = request_dict.get('retime', None)
  224. response = ResponseObject()
  225. if page is not None and line is not None:
  226. page = int(page)
  227. line = int(line)
  228. else:
  229. return response.json(10,'page,line is none')
  230. if token is not None:
  231. tko = TokenObject(token)
  232. tko.valid()
  233. response.lang = tko.lang
  234. if tko.code == 0:
  235. userID = tko.userID()
  236. own_perm = ModelService.check_permission(userID,30)
  237. if own_perm is True:
  238. check_perm = ModelService.check_permission(userID=userID, permID=20)
  239. if check_perm is True:
  240. try:
  241. content = json.loads(content)
  242. search_kwargs = CommonService.get_kwargs(data=content)
  243. queryset = Device_User.objects.filter(**search_kwargs)
  244. except Exception as e:
  245. return response.json(444,repr(e))
  246. if rstime is not None and rstime != '' and retime is not None and retime != '':
  247. startt = datetime.datetime.fromtimestamp(int(rstime))
  248. rstime = startt.strftime("%Y-%m-%d %H:%M:%S.%f")
  249. endt = datetime.datetime.fromtimestamp(int(retime))
  250. retime = endt.strftime("%Y-%m-%d %H:%M:%S.%f")
  251. queryset = queryset.filter(data_joined__range=(rstime, retime))
  252. elif rstime is not None and rstime != '':
  253. startt = datetime.datetime.fromtimestamp(int(rstime))
  254. rstime = startt.strftime("%Y-%m-%d %H:%M:%S.%f")
  255. queryset = queryset.filter(data_joined__gte=rstime)
  256. elif retime is not None and retime != '':
  257. endt = datetime.datetime.fromtimestamp(int(retime))
  258. retime = endt.strftime("%Y-%m-%d %H:%M:%S.%f")
  259. queryset = queryset.filter(data_joined__lte=retime)
  260. if queryset.exists():
  261. count = queryset.count()
  262. res = queryset[(page - 1) * line:page * line]
  263. sqlDict = CommonService.qs_to_dict(res)
  264. for k, v in enumerate(sqlDict["datas"]):
  265. if len(v['fields']['role']) > 0:
  266. role_query_set = Role.objects.get(rid=v['fields']['role'][0])
  267. sqlDict["datas"][k]['fields']['role'].append(role_query_set.roleName)
  268. for val in res:
  269. if v['pk'] == val.userID:
  270. if sqlDict["datas"][k]['fields']['online'] is True:
  271. dl_time = val.last_login + datetime.timedelta(minutes=5)
  272. now_time = timezone.localtime(timezone.now())
  273. if now_time > dl_time:
  274. sqlDict["datas"][k]['fields']['online'] = False
  275. sqlDict['count'] = count
  276. return response.json(0, sqlDict)
  277. return response.json(0, {'datas': [], 'count': 0})
  278. else:
  279. return response.json(404)
  280. else:
  281. return response.json(404)
  282. else:
  283. return response.json(tko.code)
  284. else:
  285. return response.json(311)