2020-04-16 14:05:37 +08:00
|
|
|
import os
|
|
|
|
import re
|
|
|
|
import time
|
2020-04-17 23:35:20 +08:00
|
|
|
from datetime import datetime
|
2020-04-16 14:05:37 +08:00
|
|
|
|
2020-03-29 01:22:46 +08:00
|
|
|
from module.config.config import AzurLaneConfig
|
2020-06-22 07:23:16 +08:00
|
|
|
from module.device.device import Device
|
2020-08-01 17:53:00 +08:00
|
|
|
from module.exception import *
|
|
|
|
from module.handler.login import LoginHandler
|
2020-07-01 02:56:10 +08:00
|
|
|
from module.handler.sensitive_info import handle_sensitive_image, handle_sensitive_logs
|
2020-08-01 17:53:00 +08:00
|
|
|
from module.logger import logger, pyw_name, log_file
|
2020-06-17 00:36:05 +08:00
|
|
|
|
2020-06-22 07:23:16 +08:00
|
|
|
|
2020-06-22 05:14:16 +08:00
|
|
|
class AzurLaneAutoScript:
|
2020-04-08 00:50:39 +08:00
|
|
|
def __init__(self, ini_name=''):
|
|
|
|
if not ini_name:
|
|
|
|
ini_name = pyw_name
|
|
|
|
ini_name = ini_name.lower()
|
|
|
|
self.config = AzurLaneConfig(ini_name)
|
2020-06-16 08:14:47 +08:00
|
|
|
self.device = None
|
2020-03-29 01:22:46 +08:00
|
|
|
|
2020-04-16 14:05:37 +08:00
|
|
|
def run(self, command):
|
2020-11-23 21:47:36 +08:00
|
|
|
logger.attr('Command', command)
|
2020-06-06 21:53:31 +08:00
|
|
|
self.config.start_time = datetime.now()
|
2020-08-01 17:53:00 +08:00
|
|
|
self.device = Device(config=self.config)
|
|
|
|
while 1:
|
|
|
|
try:
|
|
|
|
self.__getattribute__(command.lower())()
|
|
|
|
break
|
|
|
|
except GameNotRunningError as e:
|
|
|
|
logger.warning(e)
|
|
|
|
az = LoginHandler(self.config, device=self.device)
|
|
|
|
az.app_restart()
|
2020-11-26 09:49:35 +08:00
|
|
|
az.ensure_no_unfinished_campaign()
|
|
|
|
continue
|
|
|
|
except GameTooManyClickError as e:
|
|
|
|
logger.warning(e)
|
2020-12-30 20:57:01 +08:00
|
|
|
self.save_error_log()
|
2020-11-26 09:49:35 +08:00
|
|
|
az = LoginHandler(self.config, device=self.device)
|
2020-12-30 20:57:01 +08:00
|
|
|
az.handle_game_stuck()
|
2020-08-01 17:53:00 +08:00
|
|
|
continue
|
|
|
|
except GameStuckError as e:
|
|
|
|
logger.warning(e)
|
|
|
|
self.save_error_log()
|
|
|
|
az = LoginHandler(self.config, device=self.device)
|
|
|
|
az.handle_game_stuck()
|
|
|
|
continue
|
2021-02-20 07:09:11 +08:00
|
|
|
except LogisticsRefreshBugHandler as e:
|
|
|
|
logger.warning(e)
|
|
|
|
self.save_error_log()
|
|
|
|
az = LoginHandler(self.config, device=self.device)
|
|
|
|
az.device.app_stop()
|
|
|
|
time.sleep(600)
|
|
|
|
az.app_ensure_start()
|
|
|
|
continue
|
2020-08-01 17:53:00 +08:00
|
|
|
except Exception as e:
|
|
|
|
logger.exception(e)
|
|
|
|
self.save_error_log()
|
|
|
|
break
|
2020-04-16 14:05:37 +08:00
|
|
|
|
2020-08-01 17:53:00 +08:00
|
|
|
def save_error_log(self):
|
|
|
|
"""
|
|
|
|
Save last 60 screenshots in ./log/error/<timestamp>
|
|
|
|
Save logs to ./log/error/<timestamp>/log.txt
|
|
|
|
"""
|
|
|
|
if self.config.ENABLE_ERROR_LOG_AND_SCREENSHOT_SAVE:
|
|
|
|
folder = f'./log/error/{int(time.time() * 1000)}'
|
|
|
|
logger.info(f'Saving error: {folder}')
|
|
|
|
os.mkdir(folder)
|
|
|
|
for data in logger.screenshot_deque:
|
|
|
|
image_time = datetime.strftime(data['time'], '%Y-%m-%d_%H-%M-%S-%f')
|
|
|
|
image = handle_sensitive_image(data['image'])
|
|
|
|
image.save(f'{folder}/{image_time}.png')
|
2020-09-16 12:37:18 +08:00
|
|
|
with open(log_file, 'r', encoding='utf-8') as f:
|
2020-08-01 17:53:00 +08:00
|
|
|
start = 0
|
|
|
|
for index, line in enumerate(f.readlines()):
|
|
|
|
if re.search('\+-{15,}\+', line):
|
|
|
|
start = index
|
2020-09-16 12:37:18 +08:00
|
|
|
with open(log_file, 'r', encoding='utf-8') as f:
|
2020-08-01 17:53:00 +08:00
|
|
|
text = f.readlines()[start - 2:]
|
|
|
|
text = handle_sensitive_logs(text)
|
2020-09-16 12:37:18 +08:00
|
|
|
with open(f'{folder}/log.txt', 'w', encoding='utf-8') as f:
|
2020-08-01 17:53:00 +08:00
|
|
|
f.writelines(text)
|
2020-04-16 14:05:37 +08:00
|
|
|
|
2020-06-05 10:54:29 +08:00
|
|
|
def reward_when_finished(self):
|
|
|
|
from module.reward.reward import Reward
|
2020-06-16 08:14:47 +08:00
|
|
|
az = Reward(self.config, device=self.device)
|
2020-06-05 10:54:29 +08:00
|
|
|
az.reward_loop()
|
2020-06-22 05:29:26 +08:00
|
|
|
self.update_check()
|
2020-06-05 10:54:29 +08:00
|
|
|
|
2020-03-29 01:22:46 +08:00
|
|
|
def setting(self):
|
|
|
|
for key, value in self.config.config['Setting'].items():
|
|
|
|
print(f'{key} = {value}')
|
|
|
|
|
|
|
|
logger.hr('Settings saved')
|
2020-06-22 05:14:16 +08:00
|
|
|
self.update_check()
|
2020-06-03 02:39:03 +08:00
|
|
|
self.config.config_check()
|
2020-03-29 01:22:46 +08:00
|
|
|
|
2020-06-22 05:14:16 +08:00
|
|
|
def update_check(self):
|
|
|
|
from module.update import Update
|
|
|
|
ad = Update(self.config)
|
|
|
|
if self.config.UPDATE_CHECK:
|
|
|
|
ad.get_local_commit()
|
2020-06-16 11:30:50 +08:00
|
|
|
|
2020-04-01 22:40:21 +08:00
|
|
|
def reward(self):
|
|
|
|
for key, value in self.config.config['Reward'].items():
|
|
|
|
print(f'{key} = {value}')
|
|
|
|
|
|
|
|
logger.hr('Reward Settings saved')
|
2020-06-22 05:14:16 +08:00
|
|
|
self.update_check()
|
2020-12-02 13:59:38 +08:00
|
|
|
self.reward_when_finished()
|
2020-04-01 22:40:21 +08:00
|
|
|
|
2020-04-01 02:53:28 +08:00
|
|
|
def emulator(self):
|
|
|
|
for key, value in self.config.config['Emulator'].items():
|
2020-06-30 02:05:29 +08:00
|
|
|
if key == 'github_token':
|
|
|
|
print(f'{key} = {"<sensitive_infomation>"}')
|
|
|
|
else:
|
|
|
|
print(f'{key} = {value}')
|
2020-04-01 02:53:28 +08:00
|
|
|
|
|
|
|
logger.hr('Emulator saved')
|
2020-06-22 05:14:16 +08:00
|
|
|
self.update_check()
|
2020-04-10 14:18:10 +08:00
|
|
|
from module.handler.login import LoginHandler
|
2020-06-16 08:14:47 +08:00
|
|
|
az = LoginHandler(self.config, device=self.device)
|
2020-05-06 23:53:25 +08:00
|
|
|
if az.app_ensure_start():
|
|
|
|
from module.reward.reward import Reward
|
2020-06-16 08:14:47 +08:00
|
|
|
az = Reward(self.config, device=self.device)
|
2020-05-06 23:53:25 +08:00
|
|
|
az.reward()
|
2020-07-07 20:45:45 +08:00
|
|
|
else:
|
|
|
|
az.device.screenshot()
|
2020-04-01 02:53:28 +08:00
|
|
|
|
2020-03-29 01:22:46 +08:00
|
|
|
def main(self):
|
|
|
|
"""
|
|
|
|
Method to run main chapter.
|
|
|
|
"""
|
2020-12-02 13:59:38 +08:00
|
|
|
from module.campaign.run import CampaignRun
|
|
|
|
az = CampaignRun(self.config, device=self.device)
|
|
|
|
az.run(self.config.CAMPAIGN_NAME)
|
|
|
|
self.reward_when_finished()
|
2020-03-29 01:22:46 +08:00
|
|
|
|
|
|
|
def daily(self):
|
|
|
|
"""
|
|
|
|
Method to run daily missions.
|
|
|
|
"""
|
2020-12-02 13:59:38 +08:00
|
|
|
from module.reward.reward import Reward
|
|
|
|
az = Reward(self.config, device=self.device)
|
|
|
|
az.daily_wrapper_run()
|
2020-06-24 17:10:57 +08:00
|
|
|
|
2020-12-02 13:59:38 +08:00
|
|
|
self.reward_when_finished()
|
2020-04-10 15:19:02 +08:00
|
|
|
|
2020-03-29 01:22:46 +08:00
|
|
|
def event(self):
|
|
|
|
"""
|
|
|
|
Method to run event.
|
|
|
|
"""
|
2020-12-02 13:59:38 +08:00
|
|
|
from module.campaign.run import CampaignRun
|
|
|
|
az = CampaignRun(self.config, device=self.device)
|
|
|
|
az.run(self.config.EVENT_STAGE, folder=self.config.EVENT_NAME)
|
|
|
|
self.reward_when_finished()
|
2020-03-29 01:22:46 +08:00
|
|
|
|
2020-10-24 22:50:55 +08:00
|
|
|
def sos(self):
|
|
|
|
"""
|
|
|
|
Method to SOS maps.
|
|
|
|
"""
|
2020-12-02 13:59:38 +08:00
|
|
|
from module.sos.sos import CampaignSos
|
|
|
|
az = CampaignSos(self.config, device=self.device)
|
|
|
|
az.run()
|
|
|
|
self.reward_when_finished()
|
2020-10-24 22:50:55 +08:00
|
|
|
|
2020-11-08 02:45:30 +08:00
|
|
|
def war_archives(self):
|
|
|
|
"""
|
|
|
|
Method to War Archives maps.
|
|
|
|
"""
|
2020-12-02 13:59:38 +08:00
|
|
|
from module.war_archives.war_archives import CampaignWarArchives
|
|
|
|
az = CampaignWarArchives(self.config, device=self.device)
|
|
|
|
az.run(self.config.WAR_ARCHIVES_STAGE, folder=self.config.WAR_ARCHIVES_NAME)
|
|
|
|
self.reward_when_finished()
|
2020-11-08 02:45:30 +08:00
|
|
|
|
2020-06-24 17:10:57 +08:00
|
|
|
def raid(self):
|
2020-12-02 13:59:38 +08:00
|
|
|
from module.raid.run import RaidRun
|
|
|
|
az = RaidRun(self.config, device=self.device)
|
|
|
|
az.run()
|
|
|
|
self.reward_when_finished()
|
2020-06-24 17:10:57 +08:00
|
|
|
|
2020-03-29 01:22:46 +08:00
|
|
|
def event_daily_ab(self):
|
2020-12-02 13:59:38 +08:00
|
|
|
from module.event.campaign_ab import CampaignAB
|
|
|
|
az = CampaignAB(self.config, device=self.device)
|
|
|
|
az.run_event_daily()
|
|
|
|
self.reward_when_finished()
|
2020-03-29 01:22:46 +08:00
|
|
|
|
|
|
|
def semi_auto(self):
|
|
|
|
from module.daemon.daemon import AzurLaneDaemon
|
2020-06-16 08:14:47 +08:00
|
|
|
az = AzurLaneDaemon(self.config, device=self.device)
|
2020-03-29 01:22:46 +08:00
|
|
|
az.daemon()
|
|
|
|
|
2020-08-14 08:05:26 +08:00
|
|
|
def c11_affinity_farming(self):
|
2020-12-02 13:59:38 +08:00
|
|
|
from module.campaign.run import CampaignRun
|
|
|
|
az = CampaignRun(self.config, device=self.device)
|
|
|
|
az.run('campaign_1_1_affinity_farming')
|
|
|
|
self.reward_when_finished()
|
2020-08-14 08:05:26 +08:00
|
|
|
|
2020-03-29 01:22:46 +08:00
|
|
|
def c72_mystery_farming(self):
|
2020-12-02 13:59:38 +08:00
|
|
|
from module.campaign.run import CampaignRun
|
|
|
|
az = CampaignRun(self.config, device=self.device)
|
|
|
|
az.run('campaign_7_2_mystery_farming')
|
|
|
|
self.reward_when_finished()
|
2020-03-29 01:22:46 +08:00
|
|
|
|
|
|
|
def c124_leveling(self):
|
2020-12-02 13:59:38 +08:00
|
|
|
from module.campaign.run import CampaignRun
|
|
|
|
az = CampaignRun(self.config, device=self.device)
|
|
|
|
az.run('campaign_12_4_leveling')
|
|
|
|
self.reward_when_finished()
|
2020-03-29 01:22:46 +08:00
|
|
|
|
2020-05-04 21:48:52 +08:00
|
|
|
def c122_leveling(self):
|
2020-12-02 13:59:38 +08:00
|
|
|
from module.campaign.run import CampaignRun
|
|
|
|
az = CampaignRun(self.config, device=self.device)
|
|
|
|
az.run('campaign_12_2_leveling')
|
|
|
|
self.reward_when_finished()
|
2020-05-04 21:48:52 +08:00
|
|
|
|
2020-03-29 01:22:46 +08:00
|
|
|
def retire(self):
|
|
|
|
from module.retire.retirement import Retirement
|
2020-06-16 08:14:47 +08:00
|
|
|
az = Retirement(self.config, device=self.device)
|
|
|
|
az.device.screenshot()
|
2020-03-29 01:22:46 +08:00
|
|
|
az.retire_ships(amount=2000)
|
|
|
|
|
2020-12-23 18:48:41 +08:00
|
|
|
def os_semi_auto(self):
|
|
|
|
from module.daemon.os_daemon import AzurLaneDaemon
|
|
|
|
az = AzurLaneDaemon(self.config, device=self.device)
|
|
|
|
az.daemon()
|
|
|
|
|
2021-01-26 17:40:14 +08:00
|
|
|
def os_clear_map(self):
|
|
|
|
from module.campaign.os_run import OSCampaignRun
|
|
|
|
az = OSCampaignRun(self.config, device=self.device)
|
|
|
|
az.run()
|
2020-12-23 18:48:41 +08:00
|
|
|
|
2020-03-31 14:21:55 +08:00
|
|
|
# alas = AzurLaneAutoScript()
|
|
|
|
# alas.reward()
|