FAQController.py 14 KB

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