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.
flyapps/fir_ser/api/utils/crontab/iproxy.py

87 lines
3.2 KiB

3 years ago
#!/usr/bin/env python
# -*- coding:utf-8 -*-
# project: 12月
# author: NinEveN
# date: 2021/12/10
import logging
import random
import time
from concurrent.futures import ThreadPoolExecutor
import requests
from django.core.cache import cache
from fir_ser.settings import CACHE_KEY_TEMPLATE, APPLE_DEVELOPER_API_PROXY_LIST, APPLE_DEVELOPER_API_PROXY
logger = logging.getLogger(__name__)
def get_best_proxy_ips(url='https://api.appstoreconnect.apple.com/agreement'):
active_proxy_ips = [proxy_info['proxy'] for proxy_info in APPLE_DEVELOPER_API_PROXY_LIST if
proxy_info.get('active')]
access_ip_info = []
if not active_proxy_ips:
return
def task(proxies):
start_time = time.time()
try:
r = requests.get(url, proxies={'http': proxies, 'https': proxies}, timeout=30)
access_ip_info.append({'ip': proxies, 'time': time.time() - start_time})
logger.info(f"ip:{proxies} code:{r.status_code} time: {time.time() - start_time}")
except Exception as e:
logger.warning(f"ip {proxies} check failed Exception:{e}")
pools = ThreadPoolExecutor(50)
for proxy_ip in active_proxy_ips:
pools.submit(task, proxy_ip)
pools.shutdown()
best_sorted_ips = sorted(access_ip_info, key=lambda x: x.get('time'))[:8]
ip_proxy_store_key = CACHE_KEY_TEMPLATE.get("ip_proxy_store_list_key")
best_sorted_ips = [ip_proxy['ip'] for ip_proxy in best_sorted_ips]
cache.set(ip_proxy_store_key, best_sorted_ips, 24 * 60 * 60)
return best_sorted_ips
def get_proxy_ip_from_cache(change_ip=False):
ip_proxy_store_key = CACHE_KEY_TEMPLATE.get("ip_proxy_store_list_key")
ip_proxy_store_active_key = CACHE_KEY_TEMPLATE.get("ip_proxy_store_active_key")
active_ip_proxy = cache.get(ip_proxy_store_active_key)
if not change_ip and active_ip_proxy:
logger.info(f"get ip proxy cache {active_ip_proxy}")
return active_ip_proxy
ip_proxy_result = cache.get(ip_proxy_store_key)
if not ip_proxy_result:
ip_proxy_result = get_best_proxy_ips()
3 years ago
if change_ip and ip_proxy_result:
3 years ago
try:
ip_proxy_result.remove(active_ip_proxy)
except Exception as e:
logger.warning(f'remove bad ip proxy failed {e}')
logger.error(f"remove bad ip proxy {active_ip_proxy}")
cache.delete(ip_proxy_store_active_key)
cache.set(ip_proxy_store_key, ip_proxy_result, 24 * 60 * 60)
3 years ago
if ip_proxy_result and len(ip_proxy_result) > 0:
3 years ago
proxy_ip = ip_proxy_result[random.randint(0, 2 if len(ip_proxy_result) > 2 else len(ip_proxy_result) - 1)]
proxy_info = {
'http': proxy_ip,
'https': proxy_ip
}
else:
proxy_info = APPLE_DEVELOPER_API_PROXY
logger.info(f"make ip proxy cache {proxy_info}")
cache.set(ip_proxy_store_active_key, proxy_info, 24 * 60 * 60)
return proxy_info
3 years ago
def clean_ip_proxy_infos():
logger.info("clean ip proxy infos")
ip_proxy_store_key = CACHE_KEY_TEMPLATE.get("ip_proxy_store_list_key")
ip_proxy_store_active_key = CACHE_KEY_TEMPLATE.get("ip_proxy_store_active_key")
cache.delete(ip_proxy_store_key)
cache.delete(ip_proxy_store_active_key)