LangArea.py 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. @Copyright (C) ansjer cop Video Technology Co.,Ltd.All rights reserved.
  5. @AUTHOR: ASJRD018
  6. @NAME: langer
  7. @software: PyCharm
  8. @DATE: 2019/6/4 11:44
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: LangArea.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. import json
  15. from django.http import HttpResponse
  16. from django.views.generic import TemplateView
  17. from django.views.decorators.csrf import csrf_exempt
  18. from django.utils.decorators import method_decorator
  19. from object.ResponseObject import ResponseObject
  20. from django.contrib.auth.hashers import make_password, check_password
  21. from model.models import UserModel, LangSetModel, LangAreaModel, LangValModel, LangKeyModel, LangKeyClassModel, \
  22. SearchToolBlock, SearchToolKeyModel, LangLocationModel
  23. import time
  24. from object.TokenObject import TokenObject
  25. from django.http import StreamingHttpResponse
  26. class LangAreaView(TemplateView):
  27. def post(self, request, *args, **kwargs):
  28. request.encoding = 'utf-8'
  29. operation = kwargs.get('operation', None)
  30. request_dict = json.loads(request.body.decode('utf-8'))
  31. return self.validate(request_dict, operation)
  32. def get(self, request, *args, **kwargs):
  33. request.encoding = 'utf-8'
  34. request_dict = request.GET
  35. operation = kwargs.get('operation', None)
  36. return self.validate(request_dict, operation)
  37. def validate(self, request_dict, operation):
  38. response = ResponseObject()
  39. token = request_dict.get('token', None)
  40. tko = TokenObject(token)
  41. if tko.code == 0:
  42. userID = tko.userID
  43. user_qs = UserModel.objects.filter(id=userID, username='admin')
  44. if not user_qs.exists():
  45. return response.json(403)
  46. if operation == 'add':
  47. return self.do_add(request_dict, response)
  48. elif operation == 'update':
  49. return self.do_update(request_dict, response)
  50. elif operation == 'delete':
  51. return self.do_delete(request_dict, response)
  52. elif operation == 'query':
  53. return self.do_query(request_dict, response, userID)
  54. elif operation == 'export':
  55. return self.do_export(request_dict, response, userID)
  56. else:
  57. return response.json(414)
  58. else:
  59. return response.json(tko.code)
  60. def do_add(self, request_dict, response):
  61. lang = request_dict.get('lang', None)
  62. if lang:
  63. nowTime = int(time.time())
  64. create_dict = {
  65. 'lang': lang,
  66. 'addTime': nowTime,
  67. 'updTime': nowTime
  68. }
  69. try:
  70. LangAreaModel.objects.create(**create_dict)
  71. except Exception as e:
  72. return response.json(404, repr(e))
  73. else:
  74. return response.json(0)
  75. else:
  76. return response.json(414)
  77. def do_update(self, request_dict, response):
  78. lang = request_dict.get('lang', None)
  79. id = request_dict.get('id', None)
  80. nowTime = int(time.time())
  81. update_dict = {
  82. 'lang': lang,
  83. 'updTime': nowTime
  84. }
  85. try:
  86. LangAreaModel.objects.filter(id=id).update(**update_dict)
  87. except Exception as e:
  88. return response.json(404, repr(e))
  89. else:
  90. return response.json(0)
  91. def do_delete(self, request_dict, response):
  92. id = request_dict.get('id', None)
  93. try:
  94. LangAreaModel.objects.filter(id=id).delete()
  95. except Exception as e:
  96. return response.json(404, repr(e))
  97. else:
  98. return response.json(0)
  99. def do_query(self, request_dict, response, userID):
  100. user_qs = UserModel.objects.filter(id=userID, username='admin')
  101. if not user_qs.exists():
  102. return response.json(403)
  103. la_qs = LangAreaModel.objects.filter().values('lang', 'id')
  104. return response.json(0, list(la_qs))
  105. def do_export(self, request_dict, response, userID):
  106. print("进来了")
  107. id = request_dict.get('id', None)
  108. type = request_dict.get('type', None)
  109. # key_list = LangKeyModel.objects.filter().values_list('word_key', flat=True)
  110. print('id = ' + id)
  111. langType = (1, 3, 5, 7)
  112. if type == 'avss':
  113. langType = (2, 3, 6, 7)
  114. elif type == 'link_ios' or type == 'link_android':
  115. langType = (4, 5, 6, 7)
  116. en_qs = LangKeyModel.objects.filter(langvalmodel__la__id=20, type__in=langType).values('word_key',
  117. 'langvalmodel__word_val')
  118. en_kv = {}
  119. for e in en_qs:
  120. en_kv[e['word_key']] = e['langvalmodel__word_val']
  121. content = ''
  122. if type == 'ios' or type == 'link_ios' or type == 'flutter':
  123. res_qs = LangKeyModel.objects.filter(langvalmodel__la__id=id, type__in=langType). \
  124. values('word_key', 'langvalmodel__word_val')
  125. res = {}
  126. for r in res_qs:
  127. print(r['langvalmodel__word_val'])
  128. if r['langvalmodel__word_val']:
  129. res[r['word_key']] = r['langvalmodel__word_val']
  130. elif en_kv[r['word_key']]:
  131. res[r['word_key']] = en_kv[r['word_key']]
  132. for l in res:
  133. content_val = res[l].replace('"', '\'')
  134. if type == 'ios' or type == 'link_ios':
  135. content = content + '"' + l + '"="' + content_val + '";\n'
  136. else:
  137. content = content + '{"' + l + '":"' + content_val + '"},\n'
  138. elif type == 'android' or type == 'link_android':
  139. res_qs = LangKeyModel.objects.filter(langvalmodel__la__id=id, type__in=langType). \
  140. values('word_key', 'langvalmodel__word_val').order_by('addTime')
  141. res = {}
  142. for r in res_qs:
  143. print(r['langvalmodel__word_val'])
  144. if r['langvalmodel__word_val']:
  145. res[r['word_key']] = r['langvalmodel__word_val']
  146. elif en_kv[r['word_key']]:
  147. res[r['word_key']] = en_kv[r['word_key']]
  148. for l in res:
  149. lk = l
  150. lk = lk.replace('.', '_')
  151. lk = lk.replace('\\n', '_')
  152. lk = lk.replace('“', '_')
  153. lk = lk.replace('”', '_')
  154. lk = lk.replace(' ', '_')
  155. lk = lk.replace('\\\'', '_')
  156. lk = lk.replace('\'', '_')
  157. lk = lk.replace('\\', '_')
  158. lk = lk.replace('!', '_')
  159. lk = lk.replace('’', '_')
  160. lk = lk.replace('...', '_')
  161. lk = lk.replace('…', '_')
  162. lk = lk.replace(':', '_')
  163. lk = lk.replace(':', '_')
  164. lk = lk.replace('(', '_')
  165. lk = lk.replace(')', '_')
  166. lk = lk.replace('?', '_')
  167. lk = lk.replace(',', '_')
  168. lk = lk.replace('-', '_')
  169. lk = lk.replace('%', '_')
  170. lk = lk.replace(';', '_')
  171. lk = lk.replace('‘', '_')
  172. lk = lk.replace('&', '&')
  173. # 正则表达式
  174. # re.sub("[a-z]+", "$", "123abc78ab9cdeg00t8")
  175. content_val = res[l].replace("'", "\\'")
  176. content_val = content_val.replace('"', '\\"')
  177. content_val = content_val.replace('&', '&')
  178. content = content + '<string name="' + lk + '">' + content_val + '</string>\n'
  179. elif type == 'avss':
  180. content = self.do_download_avss(id)
  181. elif type == 'new_searchTool':
  182. content = self.do_download_SearchTool(id, 0)
  183. elif type == 'old_searchTool':
  184. content = self.do_download_SearchTool(id, 1)
  185. response = StreamingHttpResponse(content)
  186. response['Content-Type'] = 'application/octet-stream'
  187. response['Content-Disposition'] = 'attachment;filename="lang.txt"'
  188. return response
  189. def do_download_avss(self, id):
  190. content = ''
  191. en_result = self.get_area_language(20)
  192. target_result = self.get_area_language(id)
  193. if target_result:
  194. content += '<TS version=\"2.1\" language=\"' + self.get_avss_language(int(id)) + '\">\n'
  195. # keys = result.keys()
  196. keys = en_result.keys()
  197. for key in keys:
  198. content += '<context>\n<name>'
  199. content += key
  200. content += '</name>\n'
  201. messages = None
  202. if target_result.__contains__(key):
  203. messages = target_result[key]
  204. else:
  205. messages = en_result[key]
  206. messageKeys = en_result[key].keys()
  207. for messageKey in messageKeys:
  208. message = None
  209. if messages.__contains__(messageKey):
  210. message = messages[messageKey]
  211. else:
  212. message = en_result[key][messageKey]
  213. # message = messages[messageKey]
  214. content += '<message>\n'
  215. content += '<source>'
  216. content += message['source']
  217. content += '</source>\n'
  218. content += '<translation>'
  219. translation = message['translation']
  220. # if translation is None or translation == '':
  221. # content += '23333'
  222. # else:
  223. content += translation
  224. content += '</translation>\n'
  225. locations = message['locations']
  226. print(message)
  227. for location in locations:
  228. if location['filename'] != '':
  229. content += '<location filename=\"' + location['filename'] + '\" line=\"' + str(
  230. location['line']) + '\"/>\n'
  231. content += '</message>\n'
  232. content += '</context>\n'
  233. content += '</TS>'
  234. return content
  235. else:
  236. print('none')
  237. return content
  238. def get_area_language(self, id):
  239. result = {}
  240. lkc_qs = LangKeyModel.objects.filter(langvalmodel__la__id=id, type__in=(2, 3, 6, 7)).values('word_key',
  241. 'langkeyclassmodel__clazz__name',
  242. 'langvalmodel__word_val',
  243. 'langlocationmodel__filename',
  244. 'langlocationmodel__line')
  245. for lkc in lkc_qs:
  246. # print(lkc)
  247. name = lkc['langkeyclassmodel__clazz__name']
  248. hasClass = result.__contains__(name)
  249. if hasClass is False:
  250. result[name] = {}
  251. source = lkc['word_key']
  252. if not result[name].__contains__(source):
  253. result[name][source] = {}
  254. message = result[name][source]
  255. message['source'] = source
  256. message['translation'] = lkc['langvalmodel__word_val']
  257. # location
  258. locations = []
  259. locations.append({'filename': lkc['langlocationmodel__filename'], 'line': lkc['langlocationmodel__line']})
  260. message['locations'] = locations
  261. print(result)
  262. return result
  263. def get_area_language_search(self, id):
  264. result = {}
  265. lkc_qs = LangKeyModel.objects.filter(langvalmodel__la__id=id, project__id=4).values('word_key',
  266. 'searchtoolkeymodel__bk__name',
  267. 'langvalmodel__word_val',
  268. 'langlocationmodel__filename',
  269. 'langlocationmodel__line')
  270. for lkc in lkc_qs:
  271. # print(lkc)
  272. name = lkc['searchtoolkeymodel__bk__name']
  273. hasClass = result.__contains__(name)
  274. if hasClass is False:
  275. result[name] = {}
  276. source = lkc['word_key']
  277. if not result[name].__contains__(source):
  278. result[name][source] = {}
  279. message = result[name][source]
  280. message['source'] = source[(len(name) + 1):]
  281. message['translation'] = lkc['langvalmodel__word_val']
  282. # location
  283. locations = []
  284. locations.append({'filename': lkc['langlocationmodel__filename'], 'line': lkc['langlocationmodel__line']})
  285. message['locations'] = locations
  286. print(result)
  287. return result
  288. def get_avss_language(self, id):
  289. if id == 18: # 简体中文
  290. return 'zh_CN'
  291. elif id == 19: # 繁体中文
  292. return 'zh_HK'
  293. elif id == 20: # 英文
  294. return 'en_US'
  295. elif id == 21: # 俄语
  296. return 'ru'
  297. elif id == 22: # 德语
  298. return 'de'
  299. elif id == 23: # 波兰语
  300. return 'pl'
  301. elif id == 24: # 法语
  302. return 'fr'
  303. elif id == 25: # 西班牙语
  304. return 'es'
  305. elif id == 26: # 日语
  306. return 'ja'
  307. elif id == 27: # 阿拉伯语
  308. return 'ar'
  309. elif id == 29: # 意大利语
  310. return 'it'
  311. elif id == 30: # 葡萄牙语
  312. return 'pt'
  313. elif id == 31: # 荷兰语
  314. return 'nl'
  315. elif id == 32: # 越南语
  316. return 'vi'
  317. else:
  318. return 'en'
  319. def do_download_SearchTool(self, id, searchtype):
  320. content = ''
  321. en_result = self.get_area_language_search(20)
  322. print(en_result)
  323. target_result = self.get_area_language_search(id)
  324. if target_result:
  325. content += '<TS version=\"2.1\" language=\"' + self.get_avss_language(int(id)) + '\">\n'
  326. # keys = result.keys()
  327. keys = en_result.keys()
  328. for key in keys:
  329. content += '<context>\n<name>'
  330. content += key
  331. content += '</name>\n'
  332. messages = None
  333. if target_result.__contains__(key):
  334. messages = target_result[key]
  335. else:
  336. messages = en_result[key]
  337. messageKeys = en_result[key].keys()
  338. for messageKey in messageKeys:
  339. message = None
  340. if messages.__contains__(messageKey):
  341. message = messages[messageKey]
  342. else:
  343. message = en_result[key][messageKey]
  344. # message = messages[messageKey]
  345. content += '<message>\n'
  346. content += '<source>'
  347. content += message['source']
  348. content += '</source>\n'
  349. content += '<translation>'
  350. translation = message['translation']
  351. # if translation is None or translation == '':
  352. # content += '23333'
  353. # else:
  354. content += translation
  355. content += '</translation>\n'
  356. locations = message['locations']
  357. print(message)
  358. for location in locations:
  359. if location['filename'] != '':
  360. content += '<location filename=\"' + location['filename'] + '\" line=\"' + str(
  361. location['line']) + '\"/>\n'
  362. content += '</message>\n'
  363. content += '</context>\n'
  364. content += '</TS>'
  365. return content
  366. else:
  367. print('none')
  368. return content
  369. class exportLangView(TemplateView):
  370. def post(self, request, *args, **kwargs):
  371. request.encoding = 'utf-8'
  372. request_dict = json.loads(request.body.decode('utf-8'))
  373. return self.validate(request_dict)
  374. def get(self, request, *args, **kwargs):
  375. request.encoding = 'utf-8'
  376. request_dict = request.GET
  377. return self.validate(request_dict)
  378. def validate(self, request_dict):
  379. # 得到即将下载文件的路径和名称
  380. response = StreamingHttpResponse('123l4kjlkfjlksadjlfksdajlf')
  381. response['Content-Type'] = 'application/octet-stream'
  382. response['Content-Disposition'] = 'attachment;filename="lang.txt"'
  383. return response