AppInfo.py 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323
  1. import time
  2. import traceback
  3. import os
  4. from django.shortcuts import render_to_response
  5. from django.utils.decorators import method_decorator
  6. from django.views.decorators.csrf import csrf_exempt
  7. from django.views.generic.base import View
  8. from Model.models import App_Info, App_Colophon
  9. from Object.ResponseObject import ResponseObject
  10. from Object.TokenObject import TokenObject
  11. from Service.CommonService import CommonService
  12. from Service.ModelService import ModelService
  13. from Ansjer.config import BASE_DIR, SERVER_DOMAIN
  14. '''
  15. http://192.168.136.45:8077/appInfo?operation=add&token=test&appBundleId=123456&appName=%E8%AF%BA%E5%9F%BA%E4%BA%9A1%E5%8F%B7&systemLanguage=US&content=dladfjklsjfdsajkdfasjkljlk&app_type=2&newAppversion=1234&bundleVersion=1234
  16. http://192.168.136.45:8077/appInfo?operation=update&token=test&appBundleId=1234&appName=%E8%AF%BA%E5%9F%BA%E4%BA%9A3%E5%8F%B7&systemLanguage=US&content=dladfjklsjfdsajkdfasjkljlk&app_type=2&newAppversion=555&id=6
  17. http://127.0.0.1:8000/appInfo?operation=query&token=stest&page=1&line=10
  18. http://192.168.136.45:8077/appInfo?operation=delete&token=test&id=1&id=2&id=3&id=4&id=5
  19. http://192.168.136.39:8000/appVer/views?lang=cn&appBundleId=com.ansjer.accloud&app_type=1
  20. '''
  21. class AppInfo(View):
  22. @method_decorator(csrf_exempt)
  23. def dispatch(self, *args, **kwargs):
  24. return super(AppInfo, self).dispatch(*args, **kwargs)
  25. def get(self, request, *args, **kwargs):
  26. request.encoding = 'utf-8'
  27. self.request = request
  28. return self.validation(request_dict=request.GET)
  29. def post(self, request, *args, **kwargs):
  30. request.encoding = 'utf-8'
  31. self.request = request
  32. return self.validation(request_dict=request.POST)
  33. def validation(self, request_dict, *args, **kwargs):
  34. operation = request_dict.get('operation', None)
  35. response = ResponseObject()
  36. if not operation:
  37. return response.json(444, 'operation')
  38. if operation == 'getAppNewVersion':
  39. return self.getAppNewVersion(request_dict, response)
  40. else:
  41. token = request_dict.get('token', None)
  42. tko = TokenObject(token)
  43. response.lang = tko.lang
  44. if tko.code != 0:
  45. return response.json(tko.code)
  46. userID = tko.userID
  47. if not userID:
  48. return response.json(104)
  49. if operation == 'query':
  50. return self.query(request_dict, userID, response)
  51. elif operation == 'add':
  52. return self.add(request_dict, userID, response)
  53. elif operation == 'update':
  54. return self.update(request_dict, userID, response)
  55. elif operation == 'delete':
  56. return self.delete(request_dict, userID, response)
  57. else:
  58. return response.json(414)
  59. def getAppNewVersion(self, request_dict, response):
  60. appBundleId = request_dict.get('appBundleId', None)
  61. app_type = request_dict.get('app_type', None)
  62. if appBundleId is not None and app_type is not None:
  63. try:
  64. app_info = App_Info.objects.get(appBundleId=appBundleId, app_type=app_type)
  65. except Exception:
  66. errorInfo = traceback.format_exc()
  67. return response.json(424, {'details': errorInfo})
  68. else:
  69. return response.json(0, {'appBundleId': app_info.appBundleId,
  70. 'appName': app_info.appName,
  71. 'newAppversion': app_info.newAppversion,
  72. 'systemLanguage': app_info.systemLanguage,
  73. 'content': app_info.content,
  74. 'app_type': app_info.app_type,
  75. 'downloadLink': app_info.downloadLink,
  76. 'id': app_info.id,
  77. 'bundleVersion': app_info.bundleVersion,
  78. 'minAppversion': app_info.minAppversion
  79. })
  80. else:
  81. return response.json(444, 'app_type,appBundleId')
  82. def add(self, request_dict, userID, response):
  83. own_perm = ModelService.check_perm(userID=userID, permID=40)
  84. if own_perm is not True:
  85. return response.json(404)
  86. appBundleId = request_dict.get('appBundleId', None)
  87. appName = request_dict.get('appName', None)
  88. systemLanguage = request_dict.get('systemLanguage', None)
  89. newAppversion = request_dict.get('newAppversion', None)
  90. content = request_dict.get('content', None)
  91. app_type = request_dict.get('app_type', None)
  92. bundleVersion = request_dict.get('bundleVersion', None)
  93. downloadLink = request_dict.get('downloadLink', None)
  94. minAppversion = request_dict.get('minAppversion', None)
  95. f = self.request.FILES.get('file', None)
  96. param_flag = CommonService.get_param_flag(
  97. data=[appBundleId, appName, systemLanguage, minAppversion, newAppversion, content, app_type, bundleVersion])
  98. if param_flag is not True:
  99. return response.json(444)
  100. has_app_info = App_Info.objects.filter(appBundleId=appBundleId)
  101. if has_app_info.exists():
  102. return response.json(174)
  103. else:
  104. try:
  105. create_dict = {
  106. 'appBundleId': appBundleId,
  107. 'appName': appName,
  108. 'newAppversion': newAppversion,
  109. 'systemLanguage': systemLanguage,
  110. 'content': content,
  111. 'app_type': app_type,
  112. 'bundleVersion': bundleVersion,
  113. 'minAppversion': minAppversion,
  114. 'downloadLink': downloadLink
  115. }
  116. # 产品图片
  117. if f:
  118. try:
  119. rv_path = 'static/app/image/' + appBundleId + '.png'
  120. as_path = os.path.join(BASE_DIR, rv_path)
  121. if os.path.exists(as_path):
  122. os.remove(as_path)
  123. with open(as_path, 'wb+') as destination:
  124. for chunk in f.chunks():
  125. destination.write(chunk)
  126. create_dict['img'] = rv_path
  127. except Exception as e:
  128. print(repr(e))
  129. pass
  130. app_Info = App_Info(**create_dict)
  131. app_Info.save()
  132. except Exception:
  133. errorInfo = traceback.format_exc()
  134. print(errorInfo)
  135. return response.json(500, {'details': errorInfo})
  136. else:
  137. if app_Info.id:
  138. res = {'appBundleId': app_Info.appBundleId,
  139. 'appName': app_Info.appName,
  140. 'newAppversion': app_Info.newAppversion,
  141. 'systemLanguage': app_Info.systemLanguage,
  142. 'content': app_Info.content,
  143. 'app_type': app_Info.app_type,
  144. 'id': app_Info.id,
  145. 'downloadLink': downloadLink,
  146. 'minAppversion': app_Info.minAppversion,
  147. 'bundleVersion': app_Info.bundleVersion}
  148. return response.json(0, res)
  149. else:
  150. return response.json(500)
  151. def query(self, request_dict, userID, response):
  152. own_perm = ModelService.check_perm(userID=userID, permID=30)
  153. if own_perm is not True:
  154. return response.json(404)
  155. page = int(request_dict.get('page', None))
  156. line = int(request_dict.get('line', None))
  157. app_type = request_dict.get('app_type', None)
  158. if not page or not line or not app_type:
  159. return response.json(444, 'page,line,app_type')
  160. queryset = App_Info.objects.filter(app_type=app_type)
  161. if queryset.exists():
  162. count = queryset.count()
  163. res = queryset[(page - 1) * line:page * line]
  164. send_json = CommonService.qs_to_dict(res)
  165. for k, v in enumerate(send_json["datas"]):
  166. if send_json['datas'][k]['fields']['img']:
  167. img = SERVER_DOMAIN + 'sysfile/' + send_json['datas'][k]['fields']['img']
  168. send_json["datas"][k]['fields']['img'] = img
  169. send_json['count'] = count
  170. return response.json(0, send_json)
  171. return response.json(0)
  172. def update(self, request_dict, userID, response):
  173. own_perm = ModelService.check_perm(userID=userID, permID=30)
  174. if own_perm is not True:
  175. return response.json(404)
  176. id = request_dict.get('id', None)
  177. appBundleId = request_dict.get('appBundleId', None)
  178. appName = request_dict.get('appName', None)
  179. systemLanguage = request_dict.get('systemLanguage', None)
  180. newAppversion = request_dict.get('newAppversion', None)
  181. content = request_dict.get('content', None)
  182. app_type = request_dict.get('app_type', None)
  183. bundleVersion = request_dict.get('bundleVersion', None)
  184. minAppversion = request_dict.get('minAppversion', None)
  185. downloadLink = request_dict.get('downloadLink', None)
  186. f = self.request.FILES.get('file', None)
  187. try:
  188. res = {}
  189. app_info = App_Info.objects.get(id=id)
  190. if appBundleId:
  191. app_info.appBundleId = appBundleId
  192. if appName:
  193. app_info.appName = appName
  194. if systemLanguage:
  195. app_info.systemLanguage = systemLanguage
  196. if newAppversion:
  197. app_info.newAppversion = newAppversion
  198. if content:
  199. app_info.content = content
  200. if app_type:
  201. app_info.app_type = app_type
  202. if minAppversion:
  203. app_info.minAppversion = minAppversion
  204. if bundleVersion:
  205. app_info.bundleVersion = bundleVersion
  206. if downloadLink:
  207. app_info.downloadLink = downloadLink
  208. if f:
  209. try:
  210. rv_path = 'static/app/image/' + appBundleId + '.png'
  211. as_path = os.path.join(BASE_DIR, rv_path)
  212. print(as_path)
  213. if os.path.exists(as_path):
  214. os.remove(as_path)
  215. with open(as_path, 'wb+') as destination:
  216. for chunk in f.chunks():
  217. destination.write(chunk)
  218. except Exception as e:
  219. print(repr(e))
  220. pass
  221. else:
  222. app_info.img = rv_path
  223. res['img'] = SERVER_DOMAIN + 'sysfile/' + rv_path
  224. app_info.save()
  225. except Exception as e:
  226. return response.json(404, repr(e))
  227. else:
  228. res['update_id'] = app_info.id
  229. res['update_time'] = str(app_info.update_time)
  230. return response.json(0, res)
  231. def delete(self, request_dict, userID, response):
  232. own_perm = ModelService.check_perm(userID=userID, permID=10)
  233. if own_perm is not True:
  234. return response.json(404)
  235. id_list = request_dict.getlist('id', None)
  236. if not id_list:
  237. return response.json(444, 'id must list')
  238. try:
  239. for id in id_list:
  240. App_Info.objects.filter(id=id).delete()
  241. except Exception as e:
  242. errorInfo = traceback.format_exc()
  243. print(errorInfo)
  244. return response.json(424, {'details': repr(e)})
  245. else:
  246. return response.json(0)
  247. class AppVersionView(View):
  248. def get(self, request, *args, **kwargs):
  249. request.encoding = 'utf-8'
  250. return self.validation(request_dict=request.GET)
  251. def post(self, request, *args, **kwargs):
  252. request.encoding = 'utf-8'
  253. return self.validation(request_dict=request.POST)
  254. def validation(self, request_dict, *args, **kwargs):
  255. appBundleId = request_dict.get('appBundleId', None)
  256. app_type = request_dict.get('app_type', None)
  257. lang = request_dict.get('lang', None)
  258. # print (appBundleId)
  259. # if lang == 'cn':
  260. # return render_to_response('appVersionLists_cn.html')
  261. # else:
  262. # return render_to_response('appVersionLists_en.html')
  263. queryset = App_Colophon.objects.filter(lang=lang, app_id__appBundleId=appBundleId,
  264. app_id__app_type=app_type).order_by('-version_time', '-newApp_version')
  265. queryset_dict = CommonService.qs_to_dict(queryset).get('datas')
  266. print(queryset_dict)
  267. # 修改数据逻辑改装数据返回值
  268. for k, v in enumerate(queryset_dict):
  269. content = v['fields']['content']
  270. content = content.split('\n') # 分割字符串
  271. v['fields']['content'] = content
  272. # 时间戳转日期
  273. version_time = v['fields']['version_time']
  274. version_time = time.strftime("%Y-%m-%d", time.localtime(version_time))
  275. v['fields']['version_time'] = version_time
  276. return render_to_response('appVerList.html', locals())
  277. class AppIdDataView(View):
  278. def get(self, request):
  279. request.encoding = 'utf-8'
  280. return self.validation(request_dict=request.GET)
  281. def post(self, request):
  282. request.encoding = 'utf-8'
  283. return self.validation(request_dict=request.POST)
  284. def validation(self, request_dict):
  285. response = ResponseObject()
  286. token = request_dict.get('token', None)
  287. tko = TokenObject(token)
  288. if tko.code == 0:
  289. # 获取appbulidID
  290. res = {'ios': [], 'android': []}
  291. qs = App_Info.objects.filter().values('appBundleId', 'appName', 'app_type')
  292. print(qs)
  293. for q in qs:
  294. if q['app_type'] == 1:
  295. res['ios'].append({'appBundleId': q['appBundleId'], 'appName': q['appName']})
  296. if q['app_type'] == 2:
  297. res['android'].append({'appBundleId': q['appBundleId'], 'appName': q['appName']})
  298. return response.json(0, res)
  299. else:
  300. return response.json(tko.code)