shareUserPermission.py 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381
  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, UserExModel, UidSetModel, UidPushModel, GatewayPush
  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. elif 'roleName' in fieldDict.keys():
  39. roleName = fieldDict.get('roleName', None)
  40. User = Device_User.objects.filter(role__roleName__contains=roleName).order_by('-data_joined')
  41. else:
  42. User = Device_User.objects.filter(**fieldDict).order_by('-data_joined')
  43. if User.exists():
  44. ddUser = User[0].device_info_set.all()
  45. sqlJSON = serializers.serialize('json', User)
  46. sqlList = json.loads(sqlJSON)
  47. if ddUser:
  48. sqlJSON1 = serializers.serialize('json', ddUser)
  49. sqlList1 = json.loads(sqlJSON1)
  50. device_Info_dict = {}
  51. device_Info_list = []
  52. for eachJson1 in sqlList1:
  53. device_Info_dict['primaryUserID'] = eachJson1['fields']['primaryUserID']
  54. device_Info_dict['Type'] = eachJson1['fields']['Type']
  55. device_Info_dict['UID'] = eachJson1['fields']['UID']
  56. device_Info_dict['pk'] = eachJson1['pk']
  57. device_Info_dict['NickName'] = eachJson1['fields']['NickName']
  58. device_Info_dict['View_Password'] = eachJson1['fields']['View_Password']
  59. device_Info_dict['View_Account'] = eachJson1['fields']['View_Account']
  60. device_Info_dict['Online'] = eachJson1['fields']['Online']
  61. device_Info_dict['EventNotification'] = eachJson1['fields']['EventNotification']
  62. device_Info_dict['ChannelIndex'] = eachJson1['fields']['ChannelIndex']
  63. device_Info_dict['EventNotification'] = eachJson1['fields']['EventNotification']
  64. device_Info_dict['NotificationMode'] = eachJson1['fields']['NotificationMode']
  65. device_Info_list.append(device_Info_dict)
  66. device_Info_dict = {}
  67. sqlList[0]['device_info'] = device_Info_list
  68. else:
  69. sqlList[0]['device_info'] = []
  70. if sqlList[0]['fields']['username'] is None:
  71. sqlList[0]['fields']['username'] = ''
  72. if sqlList[0]['fields']['userEmail'] is None:
  73. sqlList[0]['fields']['userEmail'] = ''
  74. sqlDict = dict(zip(["datas"], [sqlList]))
  75. return response.json(0, sqlDict)
  76. else:
  77. return response.json(104)
  78. def searchUserPCSQL(self, fieldDict, response):
  79. try:
  80. page = int(fieldDict['page'])
  81. line = int(fieldDict['line'])
  82. fieldDict.pop('page')
  83. fieldDict.pop('line')
  84. fieldDict.pop('type')
  85. if len(fieldDict) > 0:
  86. searchCondition = CommonService.get_kwargs(data=fieldDict)
  87. qs = Device_User.objects.filter(**searchCondition).order_by('-data_joined')
  88. else:
  89. qs = Device_User.objects.all().order_by('-data_joined')
  90. except Exception as e:
  91. errorInfo = traceback.format_exc()
  92. print('查询数据库错误: %s' % errorInfo)
  93. return response.json(500, {"details": repr(e)})
  94. else:
  95. if qs:
  96. device_user_count = qs.count()
  97. device_user_res = qs[(page - 1) * line:page * line]
  98. sqlDict = CommonService.qs_to_dict(device_user_res)
  99. redisObj = RedisObject()
  100. for k, v in enumerate(sqlDict["datas"]):
  101. for val in device_user_res:
  102. if v['pk'] == val.userID:
  103. dvqs = val.device_info_set.all()
  104. device_info_list = CommonService.qs_to_dict(dvqs)
  105. # device_user关联到device_info
  106. sqlDict["datas"][k]['device_info'] = device_info_list
  107. if len(v['fields']['role']) > 0:
  108. role_query_set = Role.objects.get(rid=v['fields']['role'][0])
  109. sqlDict["datas"][k]['fields']['role'].append(role_query_set.roleName)
  110. if redisObj.get_data(key=v['pk']):
  111. sqlDict["datas"][k]['fields']['online'] = True
  112. else:
  113. sqlDict["datas"][k]['fields']['online'] = False
  114. ue = UserExModel.objects.filter(userID=v['pk'])
  115. if ue.exists():
  116. sqlDict["datas"][k]['fields']['appBundleId'] = ue[0].appBundleId
  117. else:
  118. sqlDict["datas"][k]['fields']['appBundleId'] = ''
  119. sqlDict['count'] = device_user_count
  120. return response.json(0, sqlDict)
  121. else:
  122. return response.json(0, {"datas": ""})
  123. def validations(self, fieldDict, *args, **kwargs):
  124. token = fieldDict.get('token', None)
  125. response = ResponseObject()
  126. tko = TokenObject(token)
  127. response.lang = tko.lang
  128. if tko.code != 0:
  129. return response.json(tko.code)
  130. fieldDict = fieldDict.dict()
  131. fieldDict.pop('token')
  132. type = fieldDict.get('type', None)
  133. if type == 'PC':
  134. return self.searchUserPCSQL(fieldDict, response)
  135. else:
  136. return self.searchUserSQL(fieldDict, response, args, kwargs)
  137. class shareUserEquipmentView(View):
  138. @method_decorator(csrf_exempt)
  139. def dispatch(self, *args, **kwargs):
  140. return super(shareUserEquipmentView, self).dispatch(*args, **kwargs)
  141. def post(self, request, *args, **kwargs):
  142. request.encoding = 'utf-8'
  143. queryDict = request.POST
  144. return self.shareUser(queryDict, args, kwargs)
  145. def get(self, request, *args, **kwargs):
  146. request.encoding = 'gb2312'
  147. queryDict = request.GET
  148. return self.shareUser(queryDict, args, kwargs)
  149. def shareUser(self, queryDict, *args, **kwargs):
  150. token = queryDict.get('token', None)
  151. GuestID = queryDict.get('guestID', None)
  152. content = queryDict.get('content', None)
  153. sharedAll = queryDict.get('sharedAll', False)
  154. if sharedAll in ('1', '0'):
  155. sharedAll = bool(int(sharedAll))
  156. elif sharedAll in ('true', 'false'):
  157. if sharedAll == 'true':
  158. sharedAll = 1
  159. else:
  160. sharedAll = 0
  161. response = ResponseObject()
  162. if not GuestID:
  163. return response.json(444, 'GuestID')
  164. tko = TokenObject(token)
  165. response.lang = tko.lang
  166. if tko.code != 0:
  167. return response.json(tko.code)
  168. MasterID = tko.userID
  169. if sharedAll and MasterID != None:
  170. return self.shareUserSQL(MasterID, GuestID, True, response, args, kwargs)
  171. if content != None and MasterID != None:
  172. return self.shareUserSQL(MasterID, GuestID, False, response, args, content=content)
  173. else:
  174. return response.json(444, 'sharedAll or content')
  175. def shareUserSQL(self, MasterID, GuestID, sharedAll, response, *args, **kwargs):
  176. Guest = Device_User.objects.filter(userID=GuestID).order_by('-data_joined')
  177. Master = Device_Info.objects.filter(userID_id=MasterID).order_by('-data_joined')
  178. if not Master or not Guest:
  179. return response.json(104)
  180. querysetList = []
  181. uid_push_list = []
  182. now_time = int(time.time())
  183. dictLen = 0
  184. if sharedAll:
  185. for equipment in Master:
  186. eqDict = equipment.model_to_dict(exclude=['id', 'data_joined', 'primaryUserID'])
  187. shareEquipment = Device_Info.objects.filter(userID_id=GuestID, primaryUserID= \
  188. MasterID, UID=eqDict.get('UID', None)).order_by('-data_joined')
  189. if shareEquipment:
  190. dictLen += 1
  191. continue
  192. else:
  193. uid_push_list.append(eqDict.get('UID', None))
  194. puserId = eqDict.pop('userID')
  195. eqDict['primaryUserID'] = puserId
  196. eqDict['primaryMaster'] = ModelService.get_user_name(puserId)
  197. eqDict['isShare'] = True
  198. eqDict['userID_id'] = GuestID
  199. eqDict['id'] = CommonService.getUserID(getUser=False)
  200. querysetList.append(Device_Info(**eqDict))
  201. else:
  202. content = kwargs.get('content', None)
  203. if content != None:
  204. contentDict = json.loads(content)
  205. uidlist = UID = contentDict.get('UID', None)
  206. print(uidlist)
  207. for equipment in Master:
  208. eqDict = equipment.model_to_dict(exclude=['id', 'data_joined', 'primaryUserID'])
  209. if eqDict['UID'] in uidlist:
  210. UID.remove(eqDict['UID'])
  211. shareEquipment = Device_Info.objects.filter(userID_id=GuestID, primaryUserID= \
  212. MasterID, UID=eqDict.get('UID', None)).order_by('-data_joined')
  213. if shareEquipment:
  214. dictLen += 1
  215. else:
  216. uid_push_list.append(eqDict.get('UID', None))
  217. puserId = eqDict.pop('userID')
  218. eqDict['primaryUserID'] = puserId
  219. eqDict['primaryMaster'] = ModelService.get_user_name(puserId)
  220. eqDict['isShare'] = True
  221. eqDict['userID_id'] = GuestID
  222. eqDict['id'] = CommonService.getUserID(getUser=False)
  223. querysetList.append(Device_Info(**eqDict))
  224. else:
  225. continue
  226. if len(querysetList) == 0:
  227. return response.json(174, {'error_UID': UID})
  228. else:
  229. try:
  230. Device_Info.objects.bulk_create(querysetList)
  231. uid_set_qs = UidSetModel.objects.filter(uid__in=uid_push_list).values('id')
  232. for uid_set in uid_set_qs:
  233. uid_set_id = uid_set['id']
  234. now_time = int(time.time())
  235. uid_push_qs = UidPushModel.objects.filter(userID=GuestID).values_list('appBundleId', 'app_type',
  236. 'push_type', 'token_val',
  237. 'jg_token_val', 'm_code',
  238. 'lang', 'tz')
  239. if uid_push_qs.exists():
  240. for item in set(list(uid_push_qs)):
  241. UidPushModel.objects.create(userID_id=GuestID, appBundleId=item[0], app_type=item[1],
  242. push_type=item[2], token_val=item[3], jg_token_val=item[4],
  243. m_code=item[5], lang=item[6], tz=item[7], addTime=now_time,
  244. updTime=now_time, uid_set_id=uid_set_id)
  245. else:
  246. gateway_push_qs = GatewayPush.objects.filter(user_id=GuestID, logout=False).values(
  247. 'app_bundle_id', 'm_code', 'app_type', 'push_type', 'token_val', 'lang', 'jg_token_val',
  248. 'tz')
  249. for item in gateway_push_qs:
  250. UidPushModel.objects.create(userID_id=GuestID, appBundleId=item['app_bundle_id'],
  251. app_type=item['app_type'], addTime=now_time,
  252. push_type=item['push_type'], updTime=now_time,
  253. token_val=item['token_val'], uid_set_id=uid_set_id,
  254. jg_token_val=item['jg_token_val'], lang=item['lang'],
  255. m_code=item['m_code'], tz=item['tz'])
  256. except Exception as e:
  257. errorInfo = traceback.format_exc()
  258. print('添加数据库记录错误: %s' % errorInfo)
  259. return response.json(500, {"details": repr(e)})
  260. else:
  261. if dictLen > 0:
  262. res = {'Shared': dictLen, 'Sharing': len(querysetList), 'errormsg': 'some had share'}
  263. else:
  264. if sharedAll:
  265. res = {'Sharing': len(querysetList)}
  266. else:
  267. if len(UID) > 0:
  268. res = {'error_UID': UID, 'Sharing': len(querysetList)}
  269. else:
  270. res = {'Sharing': len(querysetList)}
  271. # redisObj = RedisObject(db=8)
  272. # redisObj.del_data(key='uid_qs_' + GuestID)
  273. return response.json(0, res)
  274. class unsharedUserEquipmentView(View):
  275. @method_decorator(csrf_exempt)
  276. def dispatch(self, *args, **kwargs):
  277. return super(unsharedUserEquipmentView, self).dispatch(*args, **kwargs)
  278. def post(self, request, *args, **kwargs):
  279. request.encoding = 'utf-8'
  280. queryset = request.POST
  281. return self.unsharedUserEquipment(queryset, args, kwargs)
  282. def get(self, request, *args, **kwargs):
  283. request.encoding = 'gb2312'
  284. queryset = request.GET
  285. return self.unsharedUserEquipment(queryset, args, kwargs)
  286. def unsharedUserEquipment(self, queryset, *args, **kwargs):
  287. token = queryset.get('token', None)
  288. GuestID = queryset.get('guestID', None)
  289. content = queryset.get('content', None)
  290. unsharedAll = queryset.get('unsharedAll', False)
  291. response = ResponseObject()
  292. if unsharedAll in ('1', '0'):
  293. unsharedAll = bool(int(unsharedAll))
  294. elif unsharedAll in ('true', 'false'):
  295. if unsharedAll == 'true':
  296. unsharedAll = 1
  297. else:
  298. unsharedAll = 0
  299. if token != None and GuestID != None and len(GuestID) > 0:
  300. tko = TokenObject(token)
  301. response.lang = tko.lang
  302. if tko.code == 0:
  303. MasterID = tko.userID
  304. if unsharedAll and MasterID != None:
  305. return self.unsharedUserEquipmentSQL(MasterID, GuestID, True, response, args, kwargs)
  306. else:
  307. if content != None and MasterID != None:
  308. return self.unsharedUserEquipmentSQL(MasterID, GuestID, False, response, args, content=content)
  309. else:
  310. return response.json(444, 'content or unsharedAll')
  311. else:
  312. return response.json(tko.code)
  313. else:
  314. return response.json(800)
  315. def unsharedUserEquipmentSQL(self, MasterID, GuestID, unsharedAll, response, *args, **kwargs):
  316. if unsharedAll:
  317. ec = Device_Info.objects.filter(userID_id=GuestID, primaryUserID=MasterID).delete()
  318. return response.json(0, {'removeCount': ec[0]})
  319. else:
  320. content = kwargs.get('content', None)
  321. if content != None:
  322. removeCount = 0
  323. errorRemove = []
  324. errorUID = []
  325. contentDict = json.loads(content)
  326. uidlist = contentDict.get('UID', None)
  327. for index in range(len(uidlist)):
  328. uid = uidlist[index]
  329. try:
  330. equipment = Device_Info.objects.filter(userID_id=GuestID, primaryUserID=MasterID, UID=uid)
  331. if equipment:
  332. equipmentCount = equipment.delete()
  333. else:
  334. errorUID.append(uid)
  335. continue
  336. except Exception as e:
  337. errorInfo = traceback.format_exc()
  338. print('查询数据库错误: %s' % errorInfo)
  339. errorRemove.append(uid)
  340. continue
  341. else:
  342. removeCount += equipmentCount[0]
  343. if len(errorRemove) > 0:
  344. return response.json(176, {'removeCount': removeCount, 'error_UID': errorRemove})
  345. else:
  346. if len(errorUID) > 0:
  347. return response.json(173, {'removeCount': removeCount, 'error_UID': errorUID})
  348. else:
  349. return response.json(0, {'removeCount': removeCount})