2021-09-16 12:09:00 +08:00
|
|
|
import os
|
|
|
|
import re
|
2020-04-16 14:05:37 +08:00
|
|
|
import time
|
2021-09-16 12:09:00 +08:00
|
|
|
from datetime import datetime
|
2020-04-16 14:05:37 +08:00
|
|
|
|
2021-09-14 17:32:23 +08:00
|
|
|
import inflection
|
|
|
|
from cached_property import cached_property
|
|
|
|
|
2021-09-27 22:39:59 +08:00
|
|
|
import module.config.server as server
|
2021-09-14 17:32:23 +08:00
|
|
|
from module.config.config import AzurLaneConfig, TaskEnd
|
2021-09-25 23:29:10 +08:00
|
|
|
from module.config.config_updater import ConfigUpdater
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.config.utils import deep_get
|
2020-08-01 17:53:00 +08:00
|
|
|
from module.exception import *
|
2021-09-16 12:09:00 +08:00
|
|
|
from module.logger import logger, log_file
|
2021-09-27 22:39:59 +08:00
|
|
|
|
2020-06-22 07:23:16 +08:00
|
|
|
|
2020-06-22 05:14:16 +08:00
|
|
|
class AzurLaneAutoScript:
|
2021-09-14 17:32:23 +08:00
|
|
|
def __init__(self, config_name='alas'):
|
|
|
|
self.config_name = config_name
|
2021-09-25 23:29:10 +08:00
|
|
|
ConfigUpdater().update_config(config_name)
|
2021-09-14 17:32:23 +08:00
|
|
|
|
|
|
|
@cached_property
|
|
|
|
def config(self):
|
|
|
|
config = AzurLaneConfig(config_name=self.config_name)
|
2021-09-27 22:39:59 +08:00
|
|
|
# Set server before loading any buttons.
|
|
|
|
server.server = deep_get(config.data, keys='Alas.Emulator.Server', default='cn')
|
2021-09-14 17:32:23 +08:00
|
|
|
return config
|
|
|
|
|
|
|
|
@cached_property
|
|
|
|
def device(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.device.device import Device
|
2021-09-14 17:32:23 +08:00
|
|
|
device = Device(config=self.config)
|
|
|
|
return device
|
2020-03-29 01:22:46 +08:00
|
|
|
|
2020-04-16 14:05:37 +08:00
|
|
|
def run(self, command):
|
2021-09-16 12:09:00 +08:00
|
|
|
try:
|
|
|
|
self.__getattribute__(command)()
|
|
|
|
return True
|
|
|
|
except TaskEnd:
|
|
|
|
return True
|
|
|
|
except GameNotRunningError as e:
|
|
|
|
logger.warning(e)
|
|
|
|
self.config.task_call('Restart')
|
|
|
|
return True
|
|
|
|
except (GameStuckError, GameTooManyClickError) as e:
|
|
|
|
logger.warning(e)
|
|
|
|
self.save_error_log()
|
|
|
|
logger.warning(f'Game stuck, {self.config.Emulator_PackageName} will be restarted in 10 seconds')
|
|
|
|
logger.warning('If you are playing by hand, please stop Alas')
|
|
|
|
self.config.task_call('Restart')
|
|
|
|
self.device.sleep(10)
|
|
|
|
return False
|
|
|
|
except LogisticsRefreshBugHandler as e:
|
|
|
|
logger.warning(e)
|
|
|
|
self.save_error_log()
|
|
|
|
self.config.task_call('Restart')
|
|
|
|
self.device.sleep(10)
|
|
|
|
return False
|
|
|
|
except ScriptError as e:
|
|
|
|
logger.critical(e)
|
|
|
|
logger.critical('This is likely to be a mistake of developers, but sometimes just random issues')
|
|
|
|
exit(1)
|
|
|
|
except RequestHumanTakeover:
|
|
|
|
logger.critical('Request human takeover')
|
|
|
|
exit(1)
|
|
|
|
except Exception as e:
|
|
|
|
logger.exception(e)
|
|
|
|
self.save_error_log()
|
2021-09-22 00:13:32 +08:00
|
|
|
exit(1)
|
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
|
|
|
|
"""
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.handler.sensitive_info import handle_sensitive_image, handle_sensitive_logs
|
2021-09-16 12:09:00 +08:00
|
|
|
if self.config.Error_SaveError:
|
|
|
|
folder = f'./log/error/{int(time.time() * 1000)}'
|
|
|
|
logger.warning(f'Saving error: {folder}')
|
|
|
|
os.mkdir(folder)
|
|
|
|
for data in self.device.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')
|
|
|
|
with open(log_file, 'r', encoding='utf-8') as f:
|
|
|
|
lines = f.readlines()
|
|
|
|
start = 0
|
|
|
|
for index, line in enumerate(lines):
|
|
|
|
if re.search('\+-{15,}\+', line):
|
|
|
|
start = index
|
|
|
|
lines = lines[start - 2:]
|
|
|
|
lines = handle_sensitive_logs(lines)
|
|
|
|
with open(f'{folder}/log.txt', 'w', encoding='utf-8') as f:
|
|
|
|
f.writelines(lines)
|
|
|
|
|
|
|
|
def restart(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.handler.login import LoginHandler
|
2021-09-16 12:09:00 +08:00
|
|
|
LoginHandler(self.config, device=self.device).app_restart()
|
2020-04-01 22:40:21 +08:00
|
|
|
|
2021-09-14 17:32:23 +08:00
|
|
|
def research(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.research.research import RewardResearch
|
2021-09-14 17:32:23 +08:00
|
|
|
RewardResearch(config=self.config, device=self.device).run()
|
2020-04-01 22:40:21 +08:00
|
|
|
|
2021-09-14 17:32:23 +08:00
|
|
|
def commission(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.commission.commission import RewardCommission
|
2021-09-14 17:32:23 +08:00
|
|
|
RewardCommission(config=self.config, device=self.device).run()
|
2020-04-01 02:53:28 +08:00
|
|
|
|
2021-09-14 17:32:23 +08:00
|
|
|
def tactical(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.tactical.tactical_class import RewardTacticalClass
|
2021-09-14 17:32:23 +08:00
|
|
|
RewardTacticalClass(config=self.config, device=self.device).run()
|
2020-04-01 02:53:28 +08:00
|
|
|
|
2021-09-20 22:39:06 +08:00
|
|
|
def dorm(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.dorm.dorm import RewardDorm
|
2021-09-20 22:39:06 +08:00
|
|
|
RewardDorm(config=self.config, device=self.device).run()
|
|
|
|
|
2021-09-23 22:04:03 +08:00
|
|
|
def meowfficer(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.meowfficer.meowfficer import RewardMeowfficer
|
2021-09-23 22:04:03 +08:00
|
|
|
RewardMeowfficer(config=self.config, device=self.device).run()
|
|
|
|
|
2021-09-21 12:46:41 +08:00
|
|
|
def guild(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.guild.guild_reward import RewardGuild
|
2021-09-21 12:46:41 +08:00
|
|
|
RewardGuild(config=self.config, device=self.device).run()
|
|
|
|
|
2021-09-20 20:35:10 +08:00
|
|
|
def reward(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.reward.reward import Reward
|
2021-09-20 20:35:10 +08:00
|
|
|
Reward(config=self.config, device=self.device).run()
|
|
|
|
|
2021-09-23 22:04:03 +08:00
|
|
|
def shop(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.shop.shop_reward import RewardShop
|
2021-09-23 22:04:03 +08:00
|
|
|
RewardShop(config=self.config, device=self.device).run()
|
2021-09-21 00:56:33 +08:00
|
|
|
|
2021-09-22 21:49:36 +08:00
|
|
|
def daily(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.daily.daily import Daily
|
2021-09-22 21:49:36 +08:00
|
|
|
Daily(config=self.config, device=self.device).run()
|
|
|
|
|
2021-09-23 01:03:39 +08:00
|
|
|
def hard(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.hard.hard import CampaignHard
|
2021-09-23 01:03:39 +08:00
|
|
|
CampaignHard(config=self.config, device=self.device).run()
|
|
|
|
|
2021-09-23 02:31:08 +08:00
|
|
|
def exercise(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.exercise.exercise import Exercise
|
2021-09-23 02:31:08 +08:00
|
|
|
Exercise(config=self.config, device=self.device).run()
|
|
|
|
|
2021-09-24 21:30:19 +08:00
|
|
|
def sos(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.sos.sos import CampaignSos
|
2021-09-24 21:30:19 +08:00
|
|
|
CampaignSos(config=self.config, device=self.device).run()
|
|
|
|
|
2021-09-26 07:44:26 +08:00
|
|
|
def opsi_ash_assist(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.os_ash.ash import AshBeaconAssist
|
2021-09-25 00:38:53 +08:00
|
|
|
AshBeaconAssist(config=self.config, device=self.device).run()
|
|
|
|
|
2021-09-26 07:44:26 +08:00
|
|
|
def opsi_explore(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.campaign.os_run import OSCampaignRun
|
2021-09-26 07:44:26 +08:00
|
|
|
OSCampaignRun(config=self.config, device=self.device).opsi_explore()
|
|
|
|
|
|
|
|
def opsi_daily(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.campaign.os_run import OSCampaignRun
|
2021-09-26 07:44:26 +08:00
|
|
|
OSCampaignRun(config=self.config, device=self.device).opsi_daily()
|
|
|
|
|
|
|
|
def opsi_obscure(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.campaign.os_run import OSCampaignRun
|
2021-09-26 07:44:26 +08:00
|
|
|
OSCampaignRun(config=self.config, device=self.device).opsi_obscure()
|
|
|
|
|
|
|
|
def opsi_meowfficer_farming(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.campaign.os_run import OSCampaignRun
|
2021-09-26 07:44:26 +08:00
|
|
|
OSCampaignRun(config=self.config, device=self.device).opsi_meowfficer_farming()
|
|
|
|
|
2021-09-15 21:33:11 +08:00
|
|
|
def main(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.campaign.run import CampaignRun
|
|
|
|
CampaignRun(config=self.config, device=self.device).run(
|
|
|
|
name=self.config.Campaign_Name, folder=self.config.Campaign_Event, mode=self.config.Campaign_Mode)
|
|
|
|
|
|
|
|
def event(self):
|
|
|
|
from module.campaign.run import CampaignRun
|
|
|
|
CampaignRun(config=self.config, device=self.device).run(
|
|
|
|
name=self.config.Campaign_Name, folder=self.config.Campaign_Event, mode=self.config.Campaign_Mode)
|
|
|
|
|
|
|
|
def raid(self):
|
|
|
|
from module.raid.run import RaidRun
|
|
|
|
RaidRun(config=self.config, device=self.device).run()
|
|
|
|
|
|
|
|
def c11_affinity_farming(self):
|
|
|
|
from module.campaign.run import CampaignRun
|
2021-09-15 21:33:11 +08:00
|
|
|
CampaignRun(config=self.config, device=self.device).run(
|
2021-09-27 22:39:59 +08:00
|
|
|
name=self.config.Campaign_Name, folder=self.config.Campaign_Event, mode=self.config.Campaign_Mode)
|
2021-09-16 00:43:05 +08:00
|
|
|
|
2021-09-25 12:14:33 +08:00
|
|
|
def c72_mystery_farming(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.campaign.run import CampaignRun
|
|
|
|
CampaignRun(config=self.config, device=self.device).run(
|
|
|
|
name=self.config.Campaign_Name, folder=self.config.Campaign_Event, mode=self.config.Campaign_Mode)
|
|
|
|
|
|
|
|
def c122_medium_leveling(self):
|
|
|
|
from module.campaign.run import CampaignRun
|
|
|
|
CampaignRun(config=self.config, device=self.device).run(
|
|
|
|
name=self.config.Campaign_Name, folder=self.config.Campaign_Event, mode=self.config.Campaign_Mode)
|
|
|
|
|
|
|
|
def c124_large_leveling(self):
|
|
|
|
from module.campaign.run import CampaignRun
|
2021-09-25 12:14:33 +08:00
|
|
|
CampaignRun(config=self.config, device=self.device).run(
|
2021-09-27 22:39:59 +08:00
|
|
|
name=self.config.Campaign_Name, folder=self.config.Campaign_Event, mode=self.config.Campaign_Mode)
|
2021-09-25 12:14:33 +08:00
|
|
|
|
2021-09-16 00:43:05 +08:00
|
|
|
def gems_farming(self):
|
2021-09-27 22:39:59 +08:00
|
|
|
from module.campaign.gems_farming import GemsFarming
|
2021-09-16 00:43:05 +08:00
|
|
|
GemsFarming(config=self.config, device=self.device).run(
|
2021-09-27 22:39:59 +08:00
|
|
|
name=self.config.Campaign_Name, folder=self.config.Campaign_Event, mode=self.config.Campaign_Mode)
|
2021-09-15 21:33:11 +08:00
|
|
|
|
2021-09-14 17:32:23 +08:00
|
|
|
def loop(self):
|
2021-09-25 00:51:51 +08:00
|
|
|
is_first = True
|
2021-09-14 17:32:23 +08:00
|
|
|
while 1:
|
2021-09-25 00:51:51 +08:00
|
|
|
if is_first and self.config.task == 'Restart':
|
|
|
|
logger.info('Skip task `Restart` at scheduler start')
|
|
|
|
self.config.task_delay(server_update=True)
|
|
|
|
del self.__dict__['config']
|
|
|
|
|
2021-09-14 17:32:23 +08:00
|
|
|
logger.info(f'Scheduler: Start task `{self.config.task}`')
|
2021-09-16 12:09:00 +08:00
|
|
|
logger.hr(self.config.task, level=0)
|
2021-09-14 17:32:23 +08:00
|
|
|
success = self.run(inflection.underscore(self.config.task))
|
2020-12-23 18:48:41 +08:00
|
|
|
|
2021-09-14 17:32:23 +08:00
|
|
|
logger.info(f'Scheduler: End task `{self.config.task}`')
|
2021-09-24 22:24:04 +08:00
|
|
|
del self.__dict__['config']
|
2021-09-25 00:51:51 +08:00
|
|
|
is_first = False
|
2020-12-23 18:48:41 +08:00
|
|
|
|
2021-09-16 12:09:00 +08:00
|
|
|
if success:
|
|
|
|
continue
|
|
|
|
elif self.config.Error_HandleError:
|
|
|
|
# self.config.task_delay(success=False)
|
|
|
|
continue
|
|
|
|
else:
|
2021-09-14 17:32:23 +08:00
|
|
|
break
|
2021-05-15 04:19:55 +08:00
|
|
|
|
2021-04-17 22:20:21 +08:00
|
|
|
|
2021-09-14 17:32:23 +08:00
|
|
|
if __name__ == '__main__':
|
|
|
|
alas = AzurLaneAutoScript()
|
|
|
|
alas.loop()
|