|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding:utf-8 -*-
|
|
|
|
# project: 5月
|
|
|
|
# author: NinEveN
|
|
|
|
# date: 2021/5/27
|
|
|
|
|
|
|
|
import logging
|
|
|
|
|
|
|
|
from celery import shared_task
|
|
|
|
from django.core.cache import cache
|
|
|
|
|
|
|
|
from api.models import Apps, DeveloperAppID
|
|
|
|
from api.utils.app.supersignutils import IosUtils, resign_by_app_id_and_developer
|
|
|
|
from api.utils.crontab.ctasks import sync_download_times, auto_clean_upload_tmp_file, auto_delete_ios_mobile_tmp_file, \
|
|
|
|
auto_check_ios_developer_active
|
|
|
|
from api.utils.crontab.iproxy import get_best_proxy_ips, clean_ip_proxy_infos
|
|
|
|
from api.utils.geetest.geetest_utils import check_bypass_status
|
|
|
|
from api.utils.mp.wechat import sync_wx_access_token
|
|
|
|
from api.utils.storage.storage import get_local_storage
|
|
|
|
from api.utils.sysconfig import Config, invalid_config_cache
|
|
|
|
from api.views.login import get_login_type
|
|
|
|
from common.cache.state import MigrateStorageState
|
|
|
|
from fir_ser.celery import app
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
@shared_task
|
|
|
|
def run_sign_task(format_udid_info, short, client_ip):
|
|
|
|
app_obj = Apps.objects.filter(short=short).first()
|
|
|
|
|
|
|
|
if MigrateStorageState(app_obj.user_id.uid).get_state():
|
|
|
|
msg = "数据迁移中,无法处理该操作"
|
|
|
|
return msg
|
|
|
|
|
|
|
|
ios_obj = IosUtils(format_udid_info, app_obj.user_id, app_obj)
|
|
|
|
status, msg = ios_obj.sign_ipa(client_ip)
|
|
|
|
if not status:
|
|
|
|
code = msg.get("code", -1)
|
|
|
|
if code == 0:
|
|
|
|
msg = ""
|
|
|
|
elif code == 1005:
|
|
|
|
msg = "签名余额不足"
|
|
|
|
elif code == 1002:
|
|
|
|
msg = "维护中"
|
|
|
|
elif code == 1003:
|
|
|
|
msg = "应用余额不足"
|
|
|
|
elif code in [1004, 1001, 1009]:
|
|
|
|
msg = msg.get('msg', '未知错误')
|
|
|
|
else:
|
|
|
|
msg = '系统内部错误,请稍后再试或联系管理员'
|
|
|
|
else:
|
|
|
|
msg = ""
|
|
|
|
return msg
|
|
|
|
|
|
|
|
|
|
|
|
def run_resign_task(app_id, need_download_profile=True, force=True):
|
|
|
|
app_obj = Apps.objects.filter(pk=app_id).first()
|
|
|
|
if app_obj.issupersign and app_obj.user_id.supersign_active:
|
|
|
|
with cache.lock("%s_%s" % ('task_resign', app_obj.app_id), timeout=60 * 60):
|
|
|
|
task_list = []
|
|
|
|
for developer_app_id_obj in DeveloperAppID.objects.filter(app_id=app_obj).all():
|
|
|
|
c_task = run_resign_task_do.apply_async((app_id, developer_app_id_obj.developerid.pk,
|
|
|
|
developer_app_id_obj.aid, need_download_profile, force))
|
|
|
|
task_list.append(c_task)
|
|
|
|
for c_task in task_list:
|
|
|
|
msg = c_task.get(propagate=False)
|
|
|
|
logger.info(f"app {app_obj} run_resign_task msg:{msg}")
|
|
|
|
if c_task.successful():
|
|
|
|
c_task.forget()
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
|
|
|
@shared_task
|
|
|
|
def run_resign_task_do(app_id, developer_id, developer_app_id, need_download_profile=True, force=True):
|
|
|
|
return resign_by_app_id_and_developer(app_id, developer_id, developer_app_id, need_download_profile, force)
|
|
|
|
|
|
|
|
|
|
|
|
@app.task
|
|
|
|
def start_api_sever_do_clean():
|
|
|
|
# 启动服务的时候,同时执行下面操作,主要是修改配置存储的时候,需要执行清理,否则会出问题,如果不修改,则无需执行
|
|
|
|
logger.info("clean local storage cache")
|
|
|
|
get_local_storage(clean_cache=True)
|
|
|
|
check_bypass_status()
|
|
|
|
clean_ip_proxy_infos()
|
|
|
|
invalid_config_cache()
|
|
|
|
|
|
|
|
|
|
|
|
def clean_config_cache(key):
|
|
|
|
invalid_config_cache(key)
|
|
|
|
|
|
|
|
|
|
|
|
@app.task
|
|
|
|
def sync_download_times_job():
|
|
|
|
sync_download_times()
|
|
|
|
|
|
|
|
|
|
|
|
@app.task
|
|
|
|
def check_bypass_status_job():
|
|
|
|
if Config.LOGIN.get("geetest") or Config.CHANGER.get('geetest') or Config.REGISTER.get(
|
|
|
|
'geetest') or Config.REPORT.get('geetest'):
|
|
|
|
check_bypass_status()
|
|
|
|
|
|
|
|
|
|
|
|
@app.task
|
|
|
|
def auto_clean_upload_tmp_file_job():
|
|
|
|
auto_clean_upload_tmp_file()
|
|
|
|
|
|
|
|
|
|
|
|
@app.task
|
|
|
|
def auto_delete_tmp_file_job():
|
|
|
|
auto_delete_ios_mobile_tmp_file()
|
|
|
|
|
|
|
|
|
|
|
|
@app.task
|
|
|
|
def auto_check_ios_developer_active_job():
|
|
|
|
auto_check_ios_developer_active()
|
|
|
|
|
|
|
|
|
|
|
|
@app.task
|
|
|
|
def sync_wx_access_token_job():
|
|
|
|
if get_login_type().get('third', '').get('wxp'):
|
|
|
|
sync_wx_access_token()
|
|
|
|
|
|
|
|
|
|
|
|
@app.task
|
|
|
|
def get_best_proxy_ips_job():
|
|
|
|
get_best_proxy_ips()
|