shareUserPermission.py 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342
  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. from django.core import serializers
  4. import traceback, simplejson as json
  5. from django.views.generic.base import View
  6. from django.views.decorators.csrf import csrf_exempt
  7. from django.utils.decorators import method_decorator
  8. from Model.models import Device_User, Device_Info, Role
  9. from Service.CommonService import CommonService
  10. from Object.ResponseObject import ResponseObject
  11. from Object.TokenObject import TokenObject
  12. from django.db.models import Q
  13. from Service.ModelService import ModelService
  14. from Object.RedisObject import RedisObject
  15. class searchUserView(View):
  16. @method_decorator(csrf_exempt)
  17. def dispatch(self, *args, **kwargs):
  18. return super(searchUserView, self).dispatch(*args, **kwargs)
  19. def post(self, request, *args, **kwargs):
  20. request.encoding = 'utf-8'
  21. fieldDict = request.POST
  22. return self.validations(fieldDict, args, kwargs)
  23. def get(self, request, *args, **kwargs):
  24. request.encoding = 'utf-8'
  25. fieldDict = request.GET
  26. return self.validations(fieldDict, args, kwargs)
  27. def searchUserSQL(self, fieldDict, response, *args, **kwargs):
  28. if 'username' in fieldDict.keys():
  29. username = fieldDict.get('username', None)
  30. User = Device_User.objects.filter(
  31. Q(username=username) | Q(phone=username) | Q(userEmail=username)).order_by('-data_joined')
  32. elif 'userEmail' in fieldDict.keys():
  33. email = fieldDict.get('userEmail', None)
  34. User = Device_User.objects.filter(Q(userEmail=email) | Q(username=email)).order_by('-data_joined')
  35. elif 'userID' in fieldDict.keys():
  36. userID = fieldDict.get('userID', None)
  37. User = Device_User.objects.filter(userID=userID).order_by('-data_joined')
  38. else:
  39. User = Device_User.objects.filter(**fieldDict).order_by('-data_joined')
  40. if User.exists():
  41. ddUser = User[0].device_info_set.all()
  42. sqlJSON = serializers.serialize('json', User)
  43. sqlList = json.loads(sqlJSON)
  44. if ddUser:
  45. sqlJSON1 = serializers.serialize('json', ddUser)
  46. sqlList1 = json.loads(sqlJSON1)
  47. device_Info_dict = {}
  48. device_Info_list = []
  49. for eachJson1 in sqlList1:
  50. device_Info_dict['primaryUserID'] = eachJson1['fields']['primaryUserID']
  51. device_Info_dict['Type'] = eachJson1['fields']['Type']
  52. device_Info_dict['UID'] = eachJson1['fields']['UID']
  53. device_Info_dict['pk'] = eachJson1['pk']
  54. device_Info_dict['NickName'] = eachJson1['fields']['NickName']
  55. device_Info_dict['View_Password'] = eachJson1['fields']['View_Password']
  56. device_Info_dict['View_Account'] = eachJson1['fields']['View_Account']
  57. device_Info_dict['Online'] = eachJson1['fields']['Online']
  58. device_Info_dict['EventNotification'] = eachJson1['fields']['EventNotification']
  59. device_Info_dict['ChannelIndex'] = eachJson1['fields']['ChannelIndex']
  60. device_Info_dict['EventNotification'] = eachJson1['fields']['EventNotification']
  61. device_Info_dict['NotificationMode'] = eachJson1['fields']['NotificationMode']
  62. device_Info_list.append(device_Info_dict)
  63. device_Info_dict = {}
  64. sqlList[0]['device_info'] = device_Info_list
  65. else:
  66. sqlList[0]['device_info'] = []
  67. if sqlList[0]['fields']['username'] is None:
  68. sqlList[0]['fields']['username'] = ''
  69. if sqlList[0]['fields']['userEmail'] is None:
  70. sqlList[0]['fields']['userEmail'] = ''
  71. sqlDict = dict(zip(["datas"], [sqlList]))
  72. return response.json(0, sqlDict)
  73. else:
  74. return response.json(102)
  75. def searchUserPCSQL(self, fieldDict, response):
  76. try:
  77. page = int(fieldDict['page'])
  78. line = int(fieldDict['line'])
  79. fieldDict.pop('page')
  80. fieldDict.pop('line')
  81. fieldDict.pop('type')
  82. if len(fieldDict) > 0:
  83. searchCondition = CommonService.get_kwargs(data=fieldDict)
  84. qs = Device_User.objects.filter(**searchCondition).order_by('-data_joined')
  85. else:
  86. qs = Device_User.objects.all().order_by('-data_joined')
  87. except Exception as e:
  88. errorInfo = traceback.format_exc()
  89. print('查询数据库错误: %s' % errorInfo)
  90. return response.json(500, {"details": repr(e)})
  91. else:
  92. if qs:
  93. device_user_count = qs.count()
  94. device_user_res = qs[(page - 1) * line:page * line]
  95. sqlDict = CommonService.qs_to_dict(device_user_res)
  96. redisObj = RedisObject(db=3)
  97. for k, v in enumerate(sqlDict["datas"]):
  98. for val in device_user_res:
  99. if v['pk'] == val.userID:
  100. dvqs = val.device_info_set.all()
  101. device_info_list = CommonService.qs_to_dict(dvqs)
  102. # device_user关联到device_info
  103. sqlDict["datas"][k]['device_info'] = device_info_list
  104. if len(v['fields']['role']) > 0:
  105. role_query_set = Role.objects.get(rid=v['fields']['role'][0])
  106. sqlDict["datas"][k]['fields']['role'].append(role_query_set.roleName)
  107. if redisObj.get_data(key=v['pk']):
  108. sqlDict["datas"][k]['fields']['online'] = True
  109. else:
  110. sqlDict["datas"][k]['fields']['online'] = False
  111. sqlDict['count'] = device_user_count
  112. return response.json(0, sqlDict)
  113. else:
  114. return response.json(0, {"datas": ""})
  115. def validations(self, fieldDict, *args, **kwargs):
  116. token = fieldDict.get('token', None)
  117. response = ResponseObject()
  118. tko = TokenObject(token)
  119. response.lang = tko.lang
  120. if tko.code != 0:
  121. return response.json(tko.code)
  122. fieldDict = fieldDict.dict()
  123. fieldDict.pop('token')
  124. type = fieldDict.get('type', None)
  125. if type == 'PC':
  126. return self.searchUserPCSQL(fieldDict, response)
  127. else:
  128. return self.searchUserSQL(fieldDict, response, args, kwargs)
  129. class shareUserEquipmentView(View):
  130. @method_decorator(csrf_exempt)
  131. def dispatch(self, *args, **kwargs):
  132. return super(shareUserEquipmentView, self).dispatch(*args, **kwargs)
  133. def post(self, request, *args, **kwargs):
  134. request.encoding = 'utf-8'
  135. queryDict = request.POST
  136. return self.shareUser(queryDict, args, kwargs)
  137. def get(self, request, *args, **kwargs):
  138. request.encoding = 'gb2312'
  139. queryDict = request.GET
  140. return self.shareUser(queryDict, args, kwargs)
  141. def shareUser(self, queryDict, *args, **kwargs):
  142. token = queryDict.get('token', None)
  143. GuestID = queryDict.get('guestID', None)
  144. content = queryDict.get('content', None)
  145. sharedAll = queryDict.get('sharedAll', False)
  146. if sharedAll in ('1', '0'):
  147. sharedAll = bool(int(sharedAll))
  148. elif sharedAll in ('true', 'false'):
  149. if sharedAll == 'true':
  150. sharedAll = 1
  151. else:
  152. sharedAll = 0
  153. response = ResponseObject()
  154. if not GuestID:
  155. return response.json(444, 'GuestID')
  156. tko = TokenObject(token)
  157. response.lang = tko.lang
  158. if tko.code != 0:
  159. return response.json(tko.code)
  160. MasterID = tko.userID
  161. if sharedAll and MasterID != None:
  162. return self.shareUserSQL(MasterID, GuestID, True, response, args, kwargs)
  163. if content != None and MasterID != None:
  164. return self.shareUserSQL(MasterID, GuestID, False, response, args, content=content)
  165. else:
  166. return response.json(444, 'sharedAll or content')
  167. def shareUserSQL(self, MasterID, GuestID, sharedAll, response, *args, **kwargs):
  168. Guest = Device_User.objects.filter(userID=GuestID).order_by('-data_joined')
  169. Master = Device_Info.objects.filter(userID_id=MasterID).order_by('-data_joined')
  170. if not Master or not Guest:
  171. return response.json(104)
  172. querysetList = []
  173. dictLen = 0
  174. if sharedAll:
  175. for equipment in Master:
  176. eqDict = equipment.model_to_dict(exclude=['id', 'data_joined', 'primaryUserID'])
  177. shareEquipment = Device_Info.objects.filter(userID_id=GuestID, primaryUserID= \
  178. MasterID, UID=eqDict.get('UID', None)).order_by('-data_joined')
  179. if shareEquipment:
  180. dictLen += 1
  181. continue
  182. else:
  183. puserId = eqDict.pop('userID')
  184. eqDict['primaryUserID'] = puserId
  185. eqDict['primaryMaster'] = ModelService.get_user_name(puserId)
  186. eqDict['isShare'] = True
  187. eqDict['userID_id'] = GuestID
  188. eqDict['id'] = CommonService.getUserID(getUser=False)
  189. querysetList.append(Device_Info(**eqDict))
  190. else:
  191. content = kwargs.get('content', None)
  192. if content != None:
  193. contentDict = json.loads(content)
  194. uidlist = UID = contentDict.get('UID', None)
  195. print(uidlist)
  196. for equipment in Master:
  197. eqDict = equipment.model_to_dict(exclude=['id', 'data_joined', 'primaryUserID'])
  198. if eqDict['UID'] in uidlist:
  199. UID.remove(eqDict['UID'])
  200. shareEquipment = Device_Info.objects.filter(userID_id=GuestID, primaryUserID= \
  201. MasterID, UID=eqDict.get('UID', None)).order_by('-data_joined')
  202. if shareEquipment:
  203. dictLen += 1
  204. else:
  205. puserId = eqDict.pop('userID')
  206. eqDict['primaryUserID'] = puserId
  207. eqDict['primaryMaster'] = ModelService.get_user_name(puserId)
  208. eqDict['isShare'] = True
  209. eqDict['userID_id'] = GuestID
  210. eqDict['id'] = CommonService.getUserID(getUser=False)
  211. querysetList.append(Device_Info(**eqDict))
  212. else:
  213. continue
  214. if len(querysetList) == 0:
  215. return response.json(174, {'error_UID': UID})
  216. else:
  217. try:
  218. Device_Info.objects.bulk_create(querysetList)
  219. except Exception as e:
  220. errorInfo = traceback.format_exc()
  221. print('添加数据库记录错误: %s' % errorInfo)
  222. return response.json(500, {"details": repr(e)})
  223. else:
  224. if dictLen > 0:
  225. res = {'Shared': dictLen,'Sharing': len(querysetList),'errormsg': 'some had share'}
  226. else:
  227. if sharedAll:
  228. res = {'Sharing': len(querysetList)}
  229. else:
  230. if len(UID) > 0:
  231. res = {'error_UID': UID,'Sharing': len(querysetList)}
  232. else:
  233. res = {'Sharing': len(querysetList)}
  234. return response.json(0, res)
  235. class unsharedUserEquipmentView(View):
  236. @method_decorator(csrf_exempt)
  237. def dispatch(self, *args, **kwargs):
  238. return super(unsharedUserEquipmentView, self).dispatch(*args, **kwargs)
  239. def post(self, request, *args, **kwargs):
  240. request.encoding = 'utf-8'
  241. queryset = request.POST
  242. return self.unsharedUserEquipment(queryset, args, kwargs)
  243. def get(self, request, *args, **kwargs):
  244. request.encoding = 'gb2312'
  245. queryset = request.GET
  246. return self.unsharedUserEquipment(queryset, args, kwargs)
  247. def unsharedUserEquipment(self, queryset, *args, **kwargs):
  248. token = queryset.get('token', None)
  249. GuestID = queryset.get('guestID', None)
  250. content = queryset.get('content', None)
  251. unsharedAll = queryset.get('unsharedAll', False)
  252. response = ResponseObject()
  253. if unsharedAll in ('1', '0'):
  254. unsharedAll = bool(int(unsharedAll))
  255. elif unsharedAll in ('true', 'false'):
  256. if unsharedAll == 'true':
  257. unsharedAll = 1
  258. else:
  259. unsharedAll = 0
  260. if token != None and GuestID != None and len(GuestID) > 0:
  261. tko = TokenObject(token)
  262. response.lang = tko.lang
  263. if tko.code == 0:
  264. MasterID = tko.userID
  265. if unsharedAll and MasterID != None:
  266. return self.unsharedUserEquipmentSQL(MasterID, GuestID, True, response, args, kwargs)
  267. else:
  268. if content != None and MasterID != None:
  269. return self.unsharedUserEquipmentSQL(MasterID, GuestID, False, response, args, content=content)
  270. else:
  271. return response.json(444,'content or unsharedAll')
  272. else:
  273. return response.json(tko.code)
  274. else:
  275. return response.json(800)
  276. def unsharedUserEquipmentSQL(self, MasterID, GuestID, unsharedAll, response, *args, **kwargs):
  277. if unsharedAll:
  278. ec = Device_Info.objects.filter(userID_id=GuestID, primaryUserID=MasterID).delete()
  279. return response.json(0, {'removeCount': ec[0]})
  280. else:
  281. content = kwargs.get('content', None)
  282. if content != None:
  283. removeCount = 0
  284. errorRemove = []
  285. errorUID = []
  286. contentDict = json.loads(content)
  287. uidlist = contentDict.get('UID', None)
  288. for index in range(len(uidlist)):
  289. uid = uidlist[index]
  290. try:
  291. equipment = Device_Info.objects.filter(userID_id=GuestID, primaryUserID=MasterID, UID=uid)
  292. if equipment:
  293. equipmentCount = equipment.delete()
  294. else:
  295. errorUID.append(uid)
  296. continue
  297. except Exception as e:
  298. errorInfo = traceback.format_exc()
  299. print('查询数据库错误: %s' % errorInfo)
  300. errorRemove.append(uid)
  301. continue
  302. else:
  303. removeCount += equipmentCount[0]
  304. if len(errorRemove) > 0:
  305. return response.json(176, {'removeCount': removeCount, 'error_UID': errorRemove})
  306. else:
  307. if len(errorUID) > 0:
  308. return response.json(173, {'removeCount': removeCount, 'error_UID': errorUID})
  309. else:
  310. return response.json(0, {'removeCount': removeCount})