You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
257 lines
9.5 KiB
257 lines
9.5 KiB
#!/usr/bin/env python
|
|
# -*- coding:utf-8 -*-
|
|
# project: 3月
|
|
# author: liuyu
|
|
# date: 2020/3/6
|
|
|
|
from api.utils.app.apputils import get_random_short,SaveAppInfos
|
|
from api.utils.storage.storage import Storage
|
|
from api.utils.storage.caches import del_cache_response_by_short
|
|
from api.models import Apps,AppReleaseInfo
|
|
from api.utils.app.randomstrings import make_app_uuid
|
|
from rest_framework.views import APIView
|
|
from api.utils.response import BaseResponse
|
|
from api.utils.auth import ExpiringTokenAuthentication
|
|
from api.utils.app.randomstrings import make_from_user_uuid
|
|
from rest_framework.response import Response
|
|
from fir_ser import settings
|
|
from api.utils.TokenManager import DownloadToken
|
|
import os,json
|
|
|
|
class AppAnalyseView(APIView):
|
|
|
|
authentication_classes = [ExpiringTokenAuthentication, ]
|
|
|
|
def post(self, request):
|
|
res = BaseResponse()
|
|
# 1.接收 bundelid ,返回随机应用名称和短连接
|
|
bundleid = request.data.get("bundleid", None)
|
|
app_type = request.data.get("type", None)
|
|
|
|
if bundleid and app_type:
|
|
ap = 'apk'
|
|
if app_type == 'iOS':
|
|
ap='ipa'
|
|
app_uuid = make_app_uuid(request.user, bundleid + ap)
|
|
release_id = make_from_user_uuid(request.user)
|
|
png_id = make_from_user_uuid(request.user)
|
|
app_obj = Apps.objects.filter(app_id=app_uuid).first()
|
|
if app_obj:
|
|
short = app_obj.short
|
|
else:
|
|
short = get_random_short()
|
|
if app_type == 'iOS':
|
|
upload_key = release_id+'.ipa'
|
|
else:
|
|
upload_key = release_id+'.apk'
|
|
png_key = png_id+'.png'
|
|
storage = Storage(request.user)
|
|
storage_type =storage.get_storage_type()
|
|
|
|
if storage_type == 1:
|
|
upload_token = storage.get_upload_token(upload_key)
|
|
png_token = storage.get_upload_token(png_key)
|
|
elif storage_type == 2:
|
|
png_token=upload_token = storage.get_upload_token(upload_key)
|
|
else:
|
|
upload_token = storage.get_upload_token(upload_key)
|
|
png_token = storage.get_upload_token(png_key)
|
|
|
|
res.data = {"app_uuid": app_uuid, "short": short,
|
|
"domain_name": request.user.domain_name,
|
|
"upload_token":upload_token,
|
|
"upload_key":upload_key,
|
|
"png_token":png_token,
|
|
"png_key":png_key,
|
|
"storage":storage_type}
|
|
else:
|
|
res.code = 1003
|
|
|
|
return Response(res.dict)
|
|
|
|
def put(self,request):
|
|
res = BaseResponse()
|
|
data=request.data
|
|
appinfo={
|
|
"labelname":data.get("appname"),
|
|
"version":data.get("buildversion"),
|
|
"versioncode":data.get("version"),
|
|
"release_type":data.get("release_type"),
|
|
"miniOSversion":data.get("miniosversion"),
|
|
"changelog":data.get("changelog",'')
|
|
}
|
|
|
|
try:
|
|
SaveAppInfos(data.get("upload_key"), request.user, appinfo,
|
|
data.get("bundleid"), data.get("png_key"), data.get("short"), data.get('filesize'))
|
|
except Exception as e:
|
|
print(e)
|
|
res.code = 10003
|
|
return Response(res.dict)
|
|
|
|
|
|
class UploadView(APIView):
|
|
'''
|
|
上传文件接口
|
|
'''
|
|
authentication_classes = [ExpiringTokenAuthentication, ]
|
|
|
|
def get(self,request):
|
|
res = BaseResponse()
|
|
storage = Storage(request.user)
|
|
request_upload_key=request.query_params.get("upload_key",None)
|
|
app_id=request.query_params.get("app_id",None)
|
|
ftype = request.query_params.get("ftype",None)
|
|
if ftype and app_id and request_upload_key :
|
|
if ftype =='app':
|
|
app_obj = Apps.objects.filter(app_id=app_id, user_id=request.user).first()
|
|
|
|
elif ftype and ftype == 'head':
|
|
if request.user.uid != app_id:
|
|
res.code = 1007
|
|
res.msg = '该用户不存在'
|
|
return Response(res.dict)
|
|
else:
|
|
app_obj=True
|
|
else:
|
|
app_obj=False
|
|
|
|
if app_obj:
|
|
app_type = request_upload_key.split(".")[-1]
|
|
if app_type not in ["apk", "ipa", 'png', 'jpeg', 'jpg']:
|
|
res.code = 1006
|
|
res.msg='类型不允许'
|
|
else:
|
|
upload_key = make_from_user_uuid(request.user)+'.'+app_type
|
|
upload_token = storage.get_upload_token(upload_key)
|
|
storage_type = storage.get_storage_type()
|
|
res.data = {"domain_name": request.user.domain_name,
|
|
"upload_token": upload_token,
|
|
"upload_key": upload_key,
|
|
"storage": storage_type,
|
|
"app_id":app_id,
|
|
"ftype":ftype}
|
|
else:
|
|
res.code = 1006
|
|
res.msg = '该应用不存在'
|
|
else:
|
|
res.code = 1006
|
|
return Response(res.dict)
|
|
|
|
|
|
|
|
def post(self, request):
|
|
res = BaseResponse()
|
|
|
|
# 获取多个file
|
|
files = request.FILES.getlist('file', None)
|
|
certinfo = request.data.get('certinfo', None)
|
|
|
|
try:
|
|
certinfo = json.loads(certinfo)
|
|
if not certinfo:
|
|
res.msg = "token 校验失败"
|
|
res.code = 1006
|
|
return Response(res.dict)
|
|
except Exception as e:
|
|
print(e)
|
|
res.msg = "token 校验失败"
|
|
res.code = 1006
|
|
return Response(res.dict)
|
|
|
|
token_obj = DownloadToken()
|
|
if token_obj.verify_token(token=certinfo.get("upload_token",None),release_id=certinfo.get("upload_key",None)):
|
|
|
|
app_id = certinfo.get("app_id", None)
|
|
ftype = certinfo.get("ftype",None)
|
|
if ftype and ftype == 'app':
|
|
pass
|
|
# app_obj = Apps.objects.filter(app_id=app_id, user_id=request.user).first()
|
|
# if not app_obj:
|
|
# res.code = 1006
|
|
# res.msg = '该应用不存在'
|
|
# return Response(res.dict)
|
|
elif ftype and ftype == 'head':
|
|
if request.user.uid != app_id:
|
|
res.code = 1007
|
|
res.msg = '该用户不存在'
|
|
return Response(res.dict)
|
|
else:
|
|
res.code = 1008
|
|
res.msg = '该请求不存在'
|
|
return Response(res.dict)
|
|
if not files:
|
|
res.msg="文件不存在"
|
|
for file_obj in files:
|
|
try:
|
|
app_type = file_obj.name.split(".")[-1]
|
|
if app_type not in ["apk","ipa",'png','jpeg','jpg']:
|
|
raise TypeError
|
|
except Exception as e:
|
|
print(e)
|
|
res.code = 1003
|
|
res.msg = "错误的类型"
|
|
return Response(res.dict)
|
|
|
|
random_file_name = make_from_user_uuid(request.user)
|
|
local_file = os.path.join(settings.MEDIA_ROOT,certinfo.get("upload_key",random_file_name))
|
|
# 读取传入的文件
|
|
try:
|
|
destination = open(local_file, 'wb+')
|
|
for chunk in file_obj.chunks():
|
|
destination.write(chunk)
|
|
destination.close()
|
|
|
|
except Exception as e:
|
|
res.code = 1003
|
|
res.msg = "数据写入失败"
|
|
try:
|
|
os.remove(local_file)
|
|
except Exception as e:
|
|
print(e)
|
|
return Response(res.dict)
|
|
else:
|
|
res.msg = "token 校验失败"
|
|
res.code = 1006
|
|
|
|
return Response(res.dict)
|
|
|
|
def put(self,request):
|
|
res = BaseResponse()
|
|
certinfo = request.data.get('certinfo',None)
|
|
if certinfo:
|
|
app_id = certinfo.get("app_id", None)
|
|
|
|
ftype = certinfo.get('ftype',None)
|
|
storage = Storage(request.user)
|
|
if ftype and ftype == 'app':
|
|
app_obj = Apps.objects.filter(app_id=app_id, user_id=request.user).first()
|
|
if app_obj:
|
|
release_obj = AppReleaseInfo.objects.filter(app_id=app_obj,is_master=True).first()
|
|
if release_obj:
|
|
old_file_key = release_obj.icon_url
|
|
release_obj.icon_url = certinfo.get("upload_key")
|
|
release_obj.save()
|
|
del_cache_response_by_short(app_obj.short,app_id)
|
|
storage.delete_file(old_file_key)
|
|
return Response(res.dict)
|
|
elif ftype and ftype == 'head':
|
|
if request.user.uid != app_id:
|
|
res.code = 1007
|
|
res.msg = '该用户不存在'
|
|
return Response(res.dict)
|
|
old_file_key = request.user.head_img
|
|
request.user.head_img = certinfo.get("upload_key")
|
|
request.user.save()
|
|
if old_file_key != "" or old_file_key != 'head_img.jpeg':
|
|
storage.delete_file(old_file_key)
|
|
|
|
return Response(res.dict)
|
|
else:
|
|
pass
|
|
res.code = 1008
|
|
return Response(res.dict)
|
|
|
|
|
|
|
|
|
|
|