FAQController.py 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. import json
  4. import os
  5. import shutil
  6. import time
  7. import traceback
  8. from django.core import serializers
  9. from django.http import HttpResponse
  10. from django.utils.decorators import method_decorator
  11. from django.views.decorators.csrf import csrf_exempt
  12. from django.views.generic.base import View
  13. import Ansjer
  14. from Ansjer.config import BASE_DIR, SERVER_TYPE
  15. from Ansjer.config_formal import SERVER_DOMAIN
  16. from Model.models import FAQModel
  17. from Object.RedisObject import RedisObject
  18. from Object.ResponseObject import ResponseObject
  19. from Object.TokenObject import TokenObject
  20. from var_dump import var_dump
  21. from Service.CommonService import CommonService
  22. from Service.ModelService import ModelService, ZositechHelpModel
  23. class FAQUploadView(View):
  24. @method_decorator(csrf_exempt)
  25. def dispatch(self, request, *args, **kwargs):
  26. return super(FAQUploadView, self).dispatch(request, *args, **kwargs)
  27. def get(self, request, *args, **kwargs):
  28. request.encoding = 'utf-8'
  29. request_dict = request.GET
  30. fileName = request.FILES.get('fileName', None)
  31. return self.validate(fileName, request_dict)
  32. def post(self, request, *args, **kwargs):
  33. request.encoding = 'utf-8'
  34. request_dict = request.POST
  35. fileName = request.FILES.get('fileName', None)
  36. return self.validate(fileName, request_dict)
  37. def validate(self, fileName, request_dict):
  38. token = TokenObject(request_dict.get('token', None))
  39. response = ResponseObject()
  40. if token.code != 0:
  41. return response.json(token.code)
  42. own_permission = ModelService.check_perm(userID=token.userID, permID=120)
  43. if own_permission is not True:
  44. return response.json(404)
  45. try:
  46. redisObject = RedisObject()
  47. path = '/'.join((BASE_DIR, 'static/FAQImages/tmp')).replace('\\', '/') + '/'
  48. # path = '/'.join((BASE_DIR, 'static/{user}/FAQImages'.format(user=token.userID))).replace('\\', '/') + '/'
  49. if not os.path.exists(path):
  50. os.makedirs(path)
  51. # 先从redis中取出token对应的图片信息
  52. images = redisObject.get_data(key=token.token)
  53. if images is not False:
  54. images = json.loads(images)
  55. # 判断此次编辑是否已经存在对应的图片
  56. if images.__contains__(str(fileName)):
  57. file_name = images[str(fileName)]
  58. index = file_name.find('static/')
  59. filePath = file_name[index:]
  60. if SERVER_TYPE == "Ansjer.formal_settings":
  61. filePath = 'http://www.dvema.com/faq/image/' + filePath
  62. else:
  63. filePath = 'http://test.www.dvema.com/faq/image/' + filePath
  64. # filePath = "http://192.168.136.35:8000/" + 'faq/image/' + filePath
  65. return response.json(0, {'filePath': filePath})
  66. # redis中没有对应的图片信息
  67. tmp_name = str(fileName)
  68. suffix = tmp_name[tmp_name.find('.'):]
  69. tmp_file_name = int(time.time())
  70. tmp_file_name = '{file_name}{suffix}'.format(file_name=tmp_file_name, suffix=suffix)
  71. file_name = path + str(tmp_file_name)
  72. if os.path.exists(file_name):
  73. os.remove(file_name)
  74. destination = open(file_name, 'wb+')
  75. for chunk in fileName.chunks():
  76. destination.write(chunk)
  77. destination.close()
  78. # 把图片信息保存到redis中
  79. images = redisObject.get_data(token.token)
  80. if images is False:
  81. images = json.dumps({})
  82. images = json.loads(images)
  83. images[tmp_name] = file_name
  84. redisObject.set_data(key=token.token, val=json.dumps(images), expire=3600)
  85. except Exception as e:
  86. errorInfo = traceback.format_exc()
  87. print('上传文件错误: %s' % errorInfo)
  88. return response.json(700, {'details': repr(e)})
  89. else:
  90. index = file_name.find('static/')
  91. filePath = file_name[index:]
  92. if SERVER_TYPE == "Ansjer.formal_settings":
  93. filePath = 'http://www.dvema.com/faq/image/' + filePath
  94. else:
  95. filePath = 'http://test.www.dvema.com/faq/image/' + filePath
  96. # filePath = "http://192.168.136.35:8000/" + 'faq/image/' + filePath
  97. return response.json(0, {'filePath': filePath})
  98. class getFAQImage(View):
  99. def post(self, request, *args, **kwargs):
  100. request.encoding = 'utf-8'
  101. filePath = kwargs.get('filePath', None)
  102. filePath.encode(encoding='utf-8', errors='strict')
  103. response = ResponseObject()
  104. return self.getFile(filePath, response)
  105. def get(self, request, *args, **kwargs):
  106. request.encoding = 'gb2312'
  107. filePath = kwargs.get('filePath', None)
  108. response = ResponseObject()
  109. filePath.encode(encoding='gb2312', errors='strict')
  110. return self.getFile(filePath, response)
  111. def getFile(self, filePath, response):
  112. if filePath:
  113. pass
  114. else:
  115. return response.json(800)
  116. fullPath = os.path.join(BASE_DIR, filePath).replace('\\', '/')
  117. var_dump(fullPath)
  118. if os.path.isfile(fullPath):
  119. try:
  120. Imagedata = open(fullPath, 'rb').read()
  121. except Exception as e:
  122. return response.json(906, repr(e))
  123. else:
  124. return HttpResponse(Imagedata, content_type="image/jpeg")
  125. else:
  126. return response.json(907)
  127. class FAQView(View):
  128. @method_decorator(csrf_exempt)
  129. def dispatch(self, *args, **kwargs):
  130. return super(FAQView, self).dispatch(*args, **kwargs)
  131. def post(self, request, *args, **kwargs):
  132. request.encoding = 'utf-8'
  133. request_dict = request.POST
  134. operation = kwargs.get('operation', None)
  135. return self.validate(request_dict, operation)
  136. def get(self, request, *args, **kwargs):
  137. request.encoding = 'utf-8'
  138. request_dict = request.GET
  139. operation = kwargs.get('operation', None)
  140. return self.validate(request_dict, operation)
  141. def validate(self, request_dict, operation):
  142. token = TokenObject(request_dict.get('token', None))
  143. response = ResponseObject()
  144. if operation != 'zositechHelp':
  145. if token.code != 0:
  146. return response.json(token.code)
  147. if operation == 'add':
  148. return self.do_add(token, request_dict, response)
  149. elif operation == 'query':
  150. return self.do_query(token.userID, request_dict, response)
  151. elif operation == 'update':
  152. return self.do_update(token, request_dict, response)
  153. elif operation == 'delete':
  154. return self.do_delete(token.userID, request_dict, response)
  155. elif operation == 'zositechHelp':
  156. return self.do_zositechHelp(request_dict, response)
  157. elif operation == 'synZositechHelp':
  158. return self.do_synZositechHelp(request_dict, response)
  159. else:
  160. return response.json(404)
  161. def do_add(self, token, request_dict, response):
  162. own_permission = ModelService.check_perm(userID=token.userID, permID=120)
  163. if own_permission is not True:
  164. return response.json(404)
  165. title = request_dict.get('title', None)
  166. content = request_dict.get('content', None)
  167. if title and content:
  168. try:
  169. # 对content中的图片路径进行修改
  170. content = str(content)
  171. content = content.replace('faq/image/static/FAQImages/tmp', 'faq/image/static/FAQImages')
  172. # 取出redis中保存的此次上传的图片信息
  173. redisObject = RedisObject()
  174. images = redisObject.get_data(key=token.token)
  175. if images is not False:
  176. images = json.loads(images)
  177. # 把图片从临时文件移动到FAQ资源文件夹下
  178. for k, v in images.items():
  179. start_index1 = v.find('tmp/')
  180. start_index2 = start_index1 + 4
  181. new_path = v[0:start_index1] + v[start_index2:]
  182. shutil.move(v, new_path)
  183. now_time = int(time.time())
  184. FAQModel.objects.create(**{
  185. 'title': title,
  186. 'content': content,
  187. 'add_time': now_time,
  188. 'update_time': now_time
  189. })
  190. # 删除redis中token对应的信息
  191. redisObject.del_data(key=token.token)
  192. except Exception as e:
  193. print(e)
  194. return response.json(174)
  195. return response.json(0)
  196. else:
  197. return response.json(444)
  198. def do_query(self, userID, request_dict, response):
  199. page = request_dict.get('page', None)
  200. line = request_dict.get('line', None)
  201. search_key = request_dict.get('search_key', None)
  202. if page and line:
  203. if search_key:
  204. own_permission = ModelService.check_perm(userID=userID, permID=110)
  205. if own_permission is not True:
  206. return response.json(404)
  207. faq_qs = FAQModel.objects.filter(title__contains=search_key).order_by('-add_time')
  208. else:
  209. own_permission = ModelService.check_perm(userID=userID, permID=100)
  210. if own_permission is not True:
  211. return response.json(404)
  212. faq_qs = FAQModel.objects.filter().order_by('-add_time')
  213. if not faq_qs.exists():
  214. return response.json(0, {'count': 0, 'data': []})
  215. count = faq_qs.count()
  216. page = int(page)
  217. line = int(line)
  218. start = (page - 1) * line
  219. end = start + line
  220. faq_qs = faq_qs.values()[start:end]
  221. return response.json(0, {'count': count, 'data': list(faq_qs)})
  222. else:
  223. return response.json(444)
  224. def do_update(self, token, request_dict, response):
  225. own_permission = ModelService.check_perm(userID=token.userID, permID=130)
  226. if own_permission is not True:
  227. return response.json(404)
  228. id = request_dict.get('id', None)
  229. title = request_dict.get('title', None)
  230. content = request_dict.get('content', None)
  231. if id:
  232. now_time = int(time.time())
  233. data = {
  234. 'update_time': now_time
  235. }
  236. if title:
  237. data['title'] = title
  238. if content:
  239. content = str(content)
  240. content = content.replace('faq/image/static/FAQImages/tmp', 'faq/image/static/FAQImages')
  241. # 取出redis中保存的此次上传的图片信息
  242. redisObject = RedisObject()
  243. images = redisObject.get_data(key=token.token)
  244. if images is not False:
  245. images = json.loads(images)
  246. # 把图片从临时文件移动到FAQ资源文件夹下
  247. for k, v in images.items():
  248. start_index1 = v.find('tmp/')
  249. start_index2 = start_index1 + 4
  250. new_path = v[0:start_index1] + v[start_index2:]
  251. shutil.move(v, new_path)
  252. # 删除redis中token对应的信息
  253. redisObject.del_data(key=token.token)
  254. data['content'] = content
  255. FAQModel.objects.filter(id=id).update(**data)
  256. return response.json(0)
  257. else:
  258. return response.json(444)
  259. def do_delete(self, userID, request_dict, response):
  260. own_permission = ModelService.check_perm(userID=userID, permID=140)
  261. if own_permission is not True:
  262. return response.json(404)
  263. id = request_dict.get('id', None)
  264. if id:
  265. try:
  266. faq_qs = FAQModel.objects.filter(id=id)
  267. faq_qs.delete()
  268. except Exception as e:
  269. print(e)
  270. return response.json(173)
  271. else:
  272. return response.json(0)
  273. else:
  274. return response.json(444)
  275. def do_zositechHelp(self, request_dict, response):
  276. locale = request_dict.get('locale', None)
  277. label_names = request_dict.get('label_names', None)
  278. origin = request_dict.get('origin', None)
  279. help_qs = None
  280. if label_names:
  281. help = ZositechHelpModel.objects.filter(locale=locale, label_names__contains=label_names,
  282. origin=origin).values()
  283. else:
  284. help = ZositechHelpModel.objects.filter(locale=locale, origin=origin).values()
  285. if help.exists():
  286. # send_dict = CommonService.qs_to_dict(help)
  287. send_dict = list(help)
  288. return response.json(0, send_dict)
  289. else:
  290. return response.json(444)
  291. def do_synZositechHelp(self, request_dict, response):
  292. zhresults = request_dict.get('zhresults', None).replace("\'", "XX??????XX")
  293. #.replace("\"", "XX??????XX").replace("\'", "\"").replace("XX??????XX", "\'")
  294. zhresults = json.loads(zhresults)
  295. enresults = request_dict.get('enresults', None).replace("\'", "XX??????XX")
  296. enresults = json.loads(enresults)
  297. ZositechHelpModel.objects.all().delete()
  298. for data in zhresults['results']:
  299. labname = ""
  300. if data['label_names']:
  301. for lab in data['label_names']:
  302. if lab:
  303. labname += ","
  304. labname = lab
  305. if not labname:
  306. labname = None
  307. ZositechHelpModel.objects.create(**{
  308. 'locale': data['locale'],
  309. 'label_names': labname,
  310. 'origin': 'web_widget',
  311. 'content': json.dumps(data).replace("\'", "\"").replace("XX??????XX", "\'")
  312. })
  313. for data in enresults['results']:
  314. labname = ""
  315. if data['label_names']:
  316. for lab in data['label_names']:
  317. if lab:
  318. labname += ","
  319. labname = lab
  320. if not labname:
  321. labname = None
  322. ZositechHelpModel.objects.create(**{
  323. 'locale': data['locale'],
  324. 'label_names': labname,
  325. 'origin': 'web_widget',
  326. 'content': json.dumps(data).replace("\'", "\"").replace("XX??????XX", "\'")
  327. })
  328. return response.json(0)