PctestController.py 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549
  1. import hashlib
  2. import logging
  3. import shutil
  4. import time
  5. import traceback
  6. import os
  7. from urllib import request, parse
  8. import requests
  9. from django.http import HttpResponse
  10. import jwt
  11. from django.views.generic.base import View
  12. from Model.models import PctestuserModel, PctestjobModel, PctestdeviceModel,\
  13. PctestfunctionModel, PctestjobdeviceModel, PctestModel, PctestlogModel
  14. from Object.ResponseObject import ResponseObject
  15. from Object.TokenObject import TokenObject
  16. from Service.CommonService import CommonService
  17. from Ansjer.config import OAUTH_ACCESS_TOKEN_SECRET
  18. class PcTest(View):
  19. def dispatch(self, requset, *args, **kwargs):
  20. return super(PcTest, self).dispatch(requset, *args, **kwargs)
  21. def get(self, request, *args, **kwargs):
  22. operation = kwargs.get('operation')
  23. request.encoding = 'utf-8'
  24. return self.validation(request.GET, request, operation)
  25. def post(self, request, *args, **kwargs):
  26. operation = kwargs.get('operation')
  27. request.encoding = 'utf-8'
  28. return self.validation(request.POST, request, operation)
  29. def validation(self, request_dict, request, operation):
  30. response = ResponseObject()
  31. if not operation:
  32. return response.json(444, 'operation')
  33. else:
  34. if operation == 'login':
  35. return self.login(request_dict, response)
  36. else:
  37. print(operation)
  38. token = request_dict.get('token', None)
  39. print('token:', token)
  40. # 解析token,验证是否有id
  41. tko = TokenObject1(token)
  42. response.lang = tko.lang
  43. if tko.code != 0:
  44. return response.json(tko.code)
  45. # 获取访问者的id和岗位
  46. userID = tko.id
  47. jobID = tko.job
  48. # if jobID == 1:
  49. # # 管理员可访问的接口
  50. if operation == 'job/add':
  51. return self.jobadd(request_dict, userID, response)
  52. elif operation == 'job/query':
  53. return self.jobquery(request_dict, userID, response)
  54. elif operation == 'job/delete':
  55. return self.jobdelete(request_dict, userID, response)
  56. elif operation == 'device/add':
  57. return self.deviceadd(request_dict, userID, response)
  58. elif operation == 'device/query':
  59. return self.devicequery(request_dict, userID, response)
  60. elif operation == 'device/delete':
  61. return self.devicedelete(request_dict, userID, response)
  62. elif operation == 'function/add':
  63. return self.functionadd(request_dict, userID, response)
  64. elif operation == 'function/query':
  65. return self.functionquery(request_dict, userID, response)
  66. elif operation == 'function/delete':
  67. return self.functiondelete(request_dict, userID, response)
  68. elif operation == 'job/device/add':
  69. return self.jobdeviceadd(request_dict, userID, response)
  70. elif operation == 'device/function/add':
  71. return self.devicefunctionadd(request_dict, userID, response)
  72. elif operation == 'staff/add':
  73. return self.staffadd(request_dict, userID, response)
  74. elif operation == 'staff/query':
  75. return self.staffquery(request_dict, userID, response)
  76. elif operation == 'staff/delete':
  77. return self.staffdelete(request_dict, userID, response)
  78. # 公共访问的接口
  79. if operation == 'job/device/query':
  80. return self.jobdevicequery(request_dict, jobID, response)
  81. elif operation == 'device/function/query':
  82. return self.devicefunctionquery(request_dict, jobID, response)
  83. elif operation == 'log/add':
  84. return self.logadd(request_dict, userID, response)
  85. elif operation == 'log/query':
  86. return self.logquery(request_dict, userID, response)
  87. elif operation == 'token/fullInfo':
  88. return self.fullInfo(request_dict, userID, response)
  89. elif operation == 'staff/initPass':
  90. return self.initPass(request_dict, userID, response)
  91. elif operation == 'staff/updatePass':
  92. return self.updatePass(request_dict, userID, response)
  93. else:
  94. return response.json(404)
  95. def login(self, request_dict, response):
  96. username = request_dict.get('username', None)
  97. password = request_dict.get('password', None)
  98. param_flag = CommonService.get_param_flag(
  99. data=[username, password])
  100. if param_flag is not True:
  101. return response.json(444)
  102. user_qs = PctestuserModel.objects.filter(username=username, password=password)
  103. if not user_qs.exists():
  104. if not PctestuserModel.objects.filter(username=username).exists():
  105. return response.json(104)
  106. return response.json(111)
  107. users = user_qs.values('id', 'username', 'password', 'job__id', 'job__jobcode')[0]
  108. tko = TokenObject()
  109. # 加密
  110. res = tko.generate(
  111. data={'id': users['id'], 'username': users['username'], 'password': users['password'], 'jobid': users['job__id'], 'job': users['job__jobcode']})
  112. res_qs = {
  113. 'res': res,
  114. 'id': users['id'],
  115. 'username': users['username'],
  116. 'job': users['job__jobcode'],
  117. 'jobid': users['job__id']
  118. }
  119. return response.json(0, res_qs)
  120. def jobadd(self, request_dict, userID, response):
  121. jobname = request_dict.get('jobname', None)
  122. jobcode = request_dict.get('jobcode', None)
  123. param_flag = CommonService.get_param_flag(
  124. data=[jobname])
  125. if param_flag is not True:
  126. return response.json(444)
  127. job_qs = PctestjobModel.objects.filter(jobname=jobname)
  128. if job_qs.exists():
  129. return response.json(174)
  130. else:
  131. PctestjobModel.objects.create(jobname=jobname,jobcode=jobcode)
  132. return response.json(0)
  133. def jobquery(self, request_dict, userID, response):
  134. # user_qs = PctestuserModel.objects.filter(id=userID).values('job')
  135. # job_qs = PctestjobModel.objects.filter(id=user_qs[0]['job'])
  136. #
  137. # if job_qs[0].id == 1:
  138. # job_qs = PctestjobModel.objects.filter()
  139. job_qs = PctestjobModel.objects.filter()
  140. device_qs = PctestjobdeviceModel.objects.filter(job__in=job_qs).values('device')
  141. data = CommonService.qs_to_list(job_qs.values('id', 'jobname', 'jobcode'))
  142. i = 0
  143. for jobs in job_qs:
  144. data[i]['devices'] = CommonService.qs_to_list(device_qs.filter(job__id=jobs.id).values('device__id', 'device__devicename'))
  145. i = i + 1
  146. count = device_qs.count()
  147. return response.json(0, {'datas': data, 'count': count})
  148. def jobdelete(self, request_dict, userID, response):
  149. id = request_dict.get('id', None)
  150. job_qs = PctestjobModel.objects.filter(id=id)
  151. if job_qs.exists:
  152. job_qs.delete()
  153. PctestjobdeviceModel.objects.filter(job__in=job_qs).delete()
  154. return response.json(0)
  155. def deviceadd(self, request_dict, userID, response):
  156. deviceid = request_dict.get('deviceid', None)
  157. devicename = request_dict.get('devicename', None)
  158. functions= request_dict.get('functions', None)
  159. param_flag = CommonService.get_param_flag(
  160. data=[devicename])
  161. if param_flag is not True:
  162. return response.json(444)
  163. if not deviceid:
  164. device_qs = PctestdeviceModel.objects.filter(devicename=devicename)
  165. if device_qs.exists():
  166. return response.json(174)
  167. PctestdeviceModel.objects.create(devicename=devicename)
  168. else:
  169. device_qs = PctestdeviceModel.objects.filter(id=deviceid)
  170. PctestdeviceModel.objects.filter(id=deviceid).update(devicename=devicename)
  171. function_list = PctestfunctionModel.objects.filter(id__in=functions.split(','))
  172. # 判断设备与此职能是否有关联,避免重复添加
  173. PctestModel.objects.filter(device_id=device_qs[0].id).delete()
  174. for fid in functions.split(','):
  175. for fun in function_list:
  176. if int(fid) ==fun.id:
  177. PctestModel.objects.create(device_id=device_qs[0].id, function_id=fun.id)
  178. return response.json(0)
  179. def devicequery(self, request_dict, userID, response):
  180. # user_qs = PctestuserModel.objects.filter(id=userID).values('job')
  181. # job_qs = PctestjobModel.objects.filter(id=user_qs[0]['job'])
  182. #
  183. # if job_qs[0].id == 1:
  184. # device_qs = PctestjobdeviceModel.objects.filter().values('device')
  185. # else:
  186. # device_qs = PctestjobdeviceModel.objects.filter(job__in=job_qs).values('device')
  187. device_qs = PctestdeviceModel.objects.filter()
  188. function_qs = PctestModel.objects.filter(device__in=device_qs)
  189. device_qs = device_qs.values('id', 'devicename')
  190. data = CommonService.qs_to_list(device_qs)
  191. i = 0
  192. for devices in device_qs:
  193. data[i]['functions'] = CommonService.qs_to_list(function_qs.filter(device__id=devices['id']).values('function__id','function__functionname','function__functioncode'))
  194. i = i + 1
  195. count = device_qs.count()
  196. return response.json(0, {'datas': data, 'count': count})
  197. def devicedelete(self, request_dict, userID, response):
  198. id = request_dict.get('id', None)
  199. device_qs = PctestdeviceModel.objects.filter(id=id)
  200. if device_qs.exists:
  201. PctestjobdeviceModel.objects.filter(device__in=device_qs).delete()
  202. PctestModel.objects.filter(device__in=device_qs).delete()
  203. device_qs.delete()
  204. return response.json(0)
  205. def functionadd(self, request_dict, userID, response):
  206. functionname = request_dict.get('functionname', None)
  207. functioncode = request_dict.get('functioncode', None)
  208. id = request_dict.get('id', None)
  209. param_flag = CommonService.get_param_flag(
  210. data=[functionname])
  211. if param_flag is not True:
  212. return response.json(444)
  213. if not id:
  214. job_qs = PctestfunctionModel.objects.filter(functionname=functionname)
  215. if job_qs.exists():
  216. return response.json(174)
  217. PctestfunctionModel.objects.create(functionname=functionname,functioncode=functioncode)
  218. else:
  219. PctestfunctionModel.objects.filter(id=id).update(functionname=functionname, functioncode=functioncode)
  220. return response.json(0)
  221. def functiondelete(self, request_dict, userID, response):
  222. id = request_dict.get('id', None)
  223. function_qs = PctestfunctionModel.objects.filter(id=id)
  224. if function_qs.exists:
  225. PctestModel.objects.filter(function__in=function_qs).delete()
  226. function_qs.delete()
  227. return response.json(0)
  228. def functionquery(self, request_dict, userID, response):
  229. function_list = PctestfunctionModel.objects.all()
  230. count = function_list.count()
  231. res = function_list
  232. send_json = CommonService.qs_to_dict(res)
  233. send_json['count'] = count
  234. return response.json(0, send_json)
  235. def jobdeviceadd(self, request_dict, userID, response):
  236. job_id = request_dict.get('job_id', None)
  237. device_id = request_dict.get('device_id', None)
  238. param_flag = CommonService.get_param_flag(
  239. data=[job_id, device_id])
  240. if param_flag is not True:
  241. return response.json(444)
  242. # 判断岗位与设备是否存在
  243. job_list = PctestjobModel.objects.filter(id=job_id)
  244. device_list = PctestdeviceModel.objects.filter(id=device_id)
  245. if not job_list.exists() or not device_list.exists():
  246. return response.json(173)
  247. # 判断岗位与此设备是否有关联,避免重复添加
  248. job_device_list = PctestjobdeviceModel.objects.filter(job_id=job_id, device_id=device_id)
  249. if job_device_list.exists():
  250. return response.json(174)
  251. else:
  252. PctestjobdeviceModel.objects.create(job_id=job_id, device_id=device_id)
  253. return response.json(0)
  254. def jobdevicequery(self, request_dict, jobID, response):
  255. if jobID == 1:
  256. job_device_list = PctestjobdeviceModel.objects.values('job__jobname', 'device__devicename')
  257. else:
  258. job_device_list = PctestjobdeviceModel.objects.filter(job_id=jobID).values('device_id','device__devicename')
  259. device_list = []
  260. for i in job_device_list:
  261. device_list.append(i)
  262. return response.json(0, device_list)
  263. def devicefunctionadd(self, request_dict, userID, response):
  264. device_id = request_dict.get('device_id', None)
  265. function_id = request_dict.get('function_id', None)
  266. param_flag = CommonService.get_param_flag(
  267. data=[function_id, device_id])
  268. if param_flag is not True:
  269. return response.json(444)
  270. # 判断设备与职能是否存在
  271. device_list = PctestdeviceModel.objects.filter(id=device_id)
  272. function_list = PctestfunctionModel.objects.filter(id=function_id)
  273. if not function_list.exists() or not device_list.exists():
  274. return response.json(173)
  275. # 判断设备与此职能是否有关联,避免重复添加
  276. device_function_list = PctestModel.objects.filter(device_id=device_id, function_id=function_id)
  277. if device_function_list.exists():
  278. return response.json(174)
  279. else:
  280. PctestModel.objects.create(device_id=device_id, function_id=function_id)
  281. return response.json(0)
  282. def devicefunctionquery(self, request_dict, jobID, response):
  283. if jobID == 1:
  284. device_function_list = PctestModel.objects.values('device__devicename', 'function__functionname')
  285. else:
  286. device_id = request_dict.get('device_id', None)
  287. param_flag = CommonService.get_param_flag(
  288. data=[device_id])
  289. if param_flag is not True:
  290. return response.json(444)
  291. # 判断岗位与此设备是否有关联,有关联则通过
  292. job_device_list = PctestjobdeviceModel.objects.filter(job_id=jobID, device_id=device_id)
  293. if not job_device_list.exists():
  294. return response.json(173)
  295. device_function_list = PctestModel.objects.filter(device_id=device_id).values('function_id', 'function__functionname')
  296. function_list = []
  297. for i in device_function_list:
  298. function_list.append(i)
  299. return response.json(0, function_list)
  300. def staffadd(self, request_dict, userID, response):
  301. username = request_dict.get('username', None)
  302. password = request_dict.get('password', None)
  303. id = request_dict.get('id', None)
  304. job_id = request_dict.get('job_id', None)
  305. param_flag = CommonService.get_param_flag(
  306. data=[username, job_id])
  307. if param_flag is not True:
  308. return response.json(444)
  309. # 判断员工与岗位是否存在,员工存在返回174
  310. user_list = PctestuserModel.objects.filter(username=username)
  311. job_list = PctestjobModel.objects.filter(id=job_id)
  312. if not job_list.exists():
  313. return response.json(174)
  314. if not id:
  315. if user_list.exists():
  316. return response.json(174)
  317. PctestuserModel.objects.create(username=username, password=password, job_id=job_id)
  318. else:
  319. PctestuserModel.objects.filter(id=id).update(username=username, job_id=job_id)
  320. return response.json(0)
  321. def initPass(self, request_dict, userID, response):
  322. id = request_dict.get('id', None)
  323. param_flag = CommonService.get_param_flag(
  324. data=[id])
  325. if param_flag is not True:
  326. return response.json(444)
  327. # 判断员工与岗位是否存在,员工存在返回174
  328. user_list = PctestuserModel.objects.filter(id=id)
  329. if user_list.exists():
  330. user_list.update(password='555')
  331. return response.json(0)
  332. def updatePass(self, request_dict, userID, response):
  333. id = request_dict.get('id', None)
  334. oldpass = request_dict.get('oldpass', None)
  335. newpass1 = request_dict.get('newpass1', None)
  336. newpass2 = request_dict.get('newpass2', None)
  337. param_flag = CommonService.get_param_flag(
  338. data=[id,oldpass,newpass1,newpass2])
  339. if param_flag is not True:
  340. return response.json(444)
  341. # 判断员工与岗位是否存在,员工存在返回174
  342. user_list = PctestuserModel.objects.filter(id=id, password=oldpass)
  343. if not user_list.exists():
  344. if not PctestuserModel.objects.filter(id=id).exists():
  345. return response.json(104)
  346. return response.json(111)
  347. if newpass1 != newpass2:
  348. return response.json(10,'两次密码不相同,请重新输入')
  349. user_list.update(password=newpass1)
  350. return response.json(0)
  351. # def updatePass(self, request_dict, userID, response):
  352. #
  353. # id = request_dict.get('id', None)
  354. # password = request_dict.get('password', None)
  355. # param_flag = CommonService.get_param_flag(
  356. # data=[id,password])
  357. # if param_flag is not True:
  358. # return response.json(444)
  359. #
  360. # # 判断员工与岗位是否存在,员工存在返回174
  361. # user_list = PctestuserModel.objects.filter(id=id)
  362. # if user_list.exists():
  363. # user_list.update(password=password)
  364. #
  365. # return response.json(0)
  366. def staffquery(self, request_dict, userID, response):
  367. user_list = PctestuserModel.objects.filter(id__gt=1).values('id', 'username', 'job__id', 'job__jobname', 'job__jobcode')
  368. users_list = []
  369. for i in user_list:
  370. users_list.append(i)
  371. return response.json(0, users_list)
  372. def staffdelete(self, request_dict, userID, response):
  373. id = request_dict.get('id', None)
  374. param_flag = CommonService.get_param_flag(data=[id])
  375. if param_flag is not True:
  376. return response.json(444)
  377. staff = PctestuserModel.objects.filter(id=id)
  378. if not staff.exists():
  379. return response.json(173)
  380. else:
  381. staff.delete()
  382. return response.json(0)
  383. def logadd(self, request_dict, userID, response):
  384. content = request_dict.get('content', None)
  385. param_flag = CommonService.get_param_flag(data=[content])
  386. if param_flag is not True:
  387. return response.json(444)
  388. addtime = time.time()
  389. PctestlogModel.objects.create(user_id=userID, content=content, addtime=addtime)
  390. return response.json(0)
  391. def logquery(self, request_dict, userID, response):
  392. startDateTime = request_dict.get('startDateTime', None)
  393. endDateTime = request_dict.get('endDateTime', None)
  394. userid = request_dict.get('userid', None)
  395. if userid :
  396. job_device_list = PctestlogModel.objects.filter(user_id=userID,addtime__range=(startDateTime, endDateTime)).values('id', 'user__id', 'user__username', 'content', 'addtime')
  397. else:
  398. job_device_list = PctestlogModel.objects.filter(addtime__range=(startDateTime, endDateTime)).values('id', 'user__id', 'user__username', 'content', 'addtime')
  399. device_list = []
  400. for i in job_device_list:
  401. device_list.append(i)
  402. return response.json(0, device_list)
  403. def fullInfo(self, request_dict, userID, response):
  404. user_qs = PctestuserModel.objects.filter(id=userID).values('job')
  405. fullinfo = []
  406. data = {}
  407. if user_qs.exists():
  408. job_qs = PctestjobModel.objects.filter(id=user_qs[0]['job'])
  409. user_qs = user_qs.values('id', 'username')
  410. # device_qs = PctestjobdeviceModel.objects.filter(job__in=job_qs).values('device')
  411. #
  412. # function_qs = PctestModel.objects.filter(device__in=device_qs)
  413. data = user_qs[0]
  414. data['jobs'] = CommonService.qs_to_list(job_qs.values('id', 'jobname', 'jobcode'))
  415. # i = 0
  416. # for jobs in data['jobs']:
  417. #
  418. # data['jobs'][i]['devices'] = CommonService.qs_to_list(device_qs.filter(job__id=jobs['id']).values('device__id', 'device__devicename'))
  419. #
  420. # j = 0
  421. # for devices in jobs['devices']:
  422. # data['jobs'][i]['devices'][j]['functions'] = CommonService.qs_to_list(function_qs.filter(device__id=devices['device__id']).values('function__id','function__functionname','function__functioncode'))
  423. # j = j+1
  424. #
  425. # i = i+1
  426. fullinfo.append(data)
  427. return response.json(0, fullinfo)
  428. class TokenObject1:
  429. def __init__(self, token=None):
  430. if token == 'local':
  431. token = 'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VySUQiOiIxNTg0MzUxODk2MjgyMTM4MDAxMzgwMDAiLCJsYW5nIjoiZW4iLCJ1c2VyIjoiMTM2ODAzMTc1OTYiLCJtX2NvZGUiOiIxMjM0MTMyNDMyMTQiLCJleHAiOjE1ODcyNzcwNjB9.c0LV_XyxwbzUlYqMJqx7vw9f19Jv-0kGnUHuu_go-mo'
  432. if token == 'test':
  433. token = 'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VyIjoiMTM4MDAxMzgwMDEiLCJleHAiOjE1Njk5OTg4OTYsInVzZXJJRCI6IjE1MTU2NDI2MjMzNzkzOTUxMzgwMDEzODAwMSIsImxhbmciOiJlbiIsIm1fY29kZSI6IjEyMzQxMzI0MzIxNCJ9.VAQtT9AbCCfXcrNj9DL5cvVasMDoI7AP8ptgU1GoMu8'
  434. self.token = token
  435. self.lang = None
  436. self.id = None
  437. self.job = None
  438. self.user = ''
  439. self.code = 0
  440. # 令牌校验
  441. self.valid()
  442. def valid(self):
  443. if self.token is None:
  444. self.code = 309
  445. return
  446. try:
  447. res = jwt.decode(self.token, OAUTH_ACCESS_TOKEN_SECRET, algorithms='HS256')
  448. print('res:', res)
  449. # print(res)
  450. self.id = res.get('id', None)
  451. self.lang = res.get('lang', None)
  452. self.job = res.get('job', None)
  453. self.user = res.get('user', '')
  454. except jwt.ExpiredSignatureError as e:
  455. print('过期')
  456. print(repr(e))
  457. self.code = 309
  458. return
  459. except Exception as e:
  460. self.code = 309
  461. return
  462. else:
  463. if not self.id:
  464. self.code = 309
  465. return
  466. else:
  467. if self.id:
  468. self.code = 0
  469. return res
  470. else:
  471. self.code = 309
  472. return