1
0
mirror of https://gitee.com/sui-feng-cb/AzurLaneAutoScript1 synced 2026-03-09 17:29:04 +08:00
AzurLaneAutoScript/module/campaign/os_run.py

118 lines
3.6 KiB
Python
Raw Normal View History

from module.config.utils import get_os_reset_remain
from module.logger import logger
from module.os.config import OSConfig
from module.os.map_operation import OSMapOperation
from module.os.operation_siren import OperationSiren
from module.os_handler.action_point import ActionPointLimit
class OSCampaignRun(OSMapOperation):
campaign: OperationSiren
campaign_loaded = False
def load_campaign(self):
if self.campaign_loaded:
return False
config = self.config.merge(OSConfig())
self.campaign = OperationSiren(config=config, device=self.device)
self.campaign.os_init()
self.campaign_loaded = True
return True
def opsi_explore(self):
try:
self.load_campaign()
self.campaign.os_explore()
except ActionPointLimit:
self.config.opsi_task_delay(ap_limit=True)
def opsi_shop(self):
try:
self.load_campaign()
self.campaign.os_shop()
except ActionPointLimit:
self.config.opsi_task_delay(ap_limit=True)
2021-04-27 16:27:55 +08:00
2022-11-27 12:44:38 +08:00
def opsi_voucher(self):
try:
self.load_campaign()
2022-11-27 12:44:38 +08:00
self.campaign.os_voucher()
except ActionPointLimit:
self.config.opsi_task_delay(ap_limit=True)
def opsi_daily(self):
try:
self.load_campaign()
self.campaign.os_daily()
except ActionPointLimit:
self.config.opsi_task_delay(ap_limit=True)
def opsi_meowfficer_farming(self):
try:
self.load_campaign()
self.campaign.os_meowfficer_farming()
except ActionPointLimit:
if get_os_reset_remain() > 0:
2022-05-02 16:36:11 +08:00
self.config.task_delay(server_update=True)
2022-05-28 00:56:29 +08:00
self.config.task_call('Reward')
else:
logger.info('Just less than 1 day to OpSi reset, delay 2.5 hours')
self.config.task_delay(minute=150, server_update=True)
2021-08-22 00:10:14 +08:00
2022-11-11 14:27:15 +08:00
def opsi_hazard1_leveling(self):
try:
self.load_campaign()
2022-11-11 14:27:15 +08:00
self.campaign.os_hazard1_leveling()
except ActionPointLimit:
self.config.task_delay(server_update=True)
def opsi_obscure(self):
try:
self.load_campaign()
self.campaign.os_obscure()
except ActionPointLimit:
self.config.opsi_task_delay(ap_limit=True)
2022-12-11 20:59:16 +08:00
def opsi_month_boss(self):
if self.config.SERVER in ['en', 'tw']:
logger.info(f'OpsiMonthBoss is not supported in {self.config.SERVER},'
' please contact server maintainers')
self.config.task_delay(server_update=True)
self.config.task_stop()
return
2022-12-11 20:59:16 +08:00
try:
self.load_campaign()
self.campaign.clear_month_boss()
except ActionPointLimit:
self.config.opsi_task_delay(ap_limit=True)
def opsi_abyssal(self):
try:
self.load_campaign()
self.campaign.os_abyssal()
except ActionPointLimit:
self.config.opsi_task_delay(ap_limit=True)
def opsi_archive(self):
try:
self.load_campaign()
self.campaign.os_archive()
except ActionPointLimit:
self.config.opsi_task_delay(ap_limit=True)
def opsi_stronghold(self):
try:
self.load_campaign()
self.campaign.os_stronghold()
except ActionPointLimit:
self.config.opsi_task_delay(ap_limit=True)
2022-11-30 01:40:53 +08:00
def opsi_cross_month(self):
try:
self.load_campaign()
self.campaign.os_cross_month()
except ActionPointLimit:
self.campaign.os_cross_month_end()