forked from Hay1tsme/artemis
		
	
		
			
				
	
	
		
			263 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			263 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import json
 | |
| from decimal import Decimal
 | |
| from base64 import b64encode
 | |
| from typing import Any, Dict
 | |
| from hashlib import md5
 | |
| from datetime import datetime
 | |
| 
 | |
| from core.config import CoreConfig
 | |
| from core.data import Data, cached
 | |
| from titles.cxb.config import CxbConfig
 | |
| from titles.cxb.base import CxbBase
 | |
| from titles.cxb.const import CxbConstants
 | |
| 
 | |
| class CxbRevSunriseS2(CxbBase):
 | |
|     def __init__(self, cfg: CoreConfig, game_cfg: CxbConfig) -> None:
 | |
|         super().__init__(cfg, game_cfg)
 | |
|         self.version = CxbConstants.VER_CROSSBEATS_REV_SUNRISE_S2_OMNI
 | |
|         
 | |
|     def handle_data_path_list_request(self, data: Dict) -> Dict:
 | |
|         return { "data": "" }
 | |
| 
 | |
|     @cached(lifetime=86400)    
 | |
|     def handle_data_music_list_request(self, data: Dict) -> Dict:
 | |
|         ret_str = ""
 | |
|         with open(r"titles/cxb/rss2_data/MusicArchiveList.csv") as music:
 | |
|             lines = music.readlines()
 | |
|             for line in lines:
 | |
|                 line_split = line.split(',')
 | |
|                 ret_str += f"{line_split[0]},{line_split[1]},{line_split[2]},{line_split[3]},{line_split[4]},{line_split[5]},{line_split[6]},{line_split[7]},{line_split[8]},{line_split[9]},{line_split[10]},{line_split[11]},{line_split[12]},{line_split[13]},{line_split[14]},\r\n"
 | |
|                 
 | |
|         return({"data":ret_str})
 | |
| 
 | |
|     @cached(lifetime=86400)    
 | |
|     def handle_data_item_list_detail_request(self, data: Dict) -> Dict:
 | |
|         #ItemListIcon load
 | |
|         ret_str = "#ItemListIcon\r\n"
 | |
|         with open(r"titles/cxb/rss2_data/Item/ItemList_Icon.csv", encoding="utf-8") as item:
 | |
|             lines = item.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|                             
 | |
|         #ItemListTitle load
 | |
|         ret_str += "\r\n#ItemListTitle\r\n"
 | |
|         with open(r"titles/cxb/rss2_data/Item/ItemList_Title.csv", encoding="utf-8") as item:
 | |
|             lines = item.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
| 
 | |
|         return({"data":ret_str})
 | |
| 
 | |
|     @cached(lifetime=86400)    
 | |
|     def handle_data_shop_list_detail_request(self, data: Dict) -> Dict:
 | |
|         #ShopListIcon load
 | |
|         ret_str = "#ShopListIcon\r\n"
 | |
|         with open(r"titles/cxb/rss2_data/Shop/ShopList_Icon.csv", encoding="utf-8") as shop:
 | |
|             lines = shop.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|                             
 | |
|         #ShopListMusic load
 | |
|         ret_str += "\r\n#ShopListMusic\r\n"
 | |
|         with open(r"titles/cxb/rss2_data/Shop/ShopList_Music.csv", encoding="utf-8") as shop:
 | |
|             lines = shop.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|                         
 | |
|         #ShopListSale load
 | |
|         ret_str += "\r\n#ShopListSale\r\n"
 | |
|         with open(r"titles/cxb/rss2_data/Shop/ShopList_Sale.csv", encoding="shift-jis") as shop:
 | |
|             lines = shop.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|                             
 | |
|         #ShopListSkinBg load
 | |
|         ret_str += "\r\n#ShopListSkinBg\r\n"
 | |
|         with open(r"titles/cxb/rss2_data/Shop/ShopList_SkinBg.csv", encoding="shift-jis") as shop:
 | |
|             lines = shop.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|                             
 | |
|         #ShopListSkinEffect load
 | |
|         ret_str += "\r\n#ShopListSkinEffect\r\n"
 | |
|         with open(r"titles/cxb/rss2_data/Shop/ShopList_SkinEffect.csv", encoding="shift-jis") as shop:
 | |
|             lines = shop.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|                             
 | |
|         #ShopListSkinNotes load
 | |
|         ret_str += "\r\n#ShopListSkinNotes\r\n"
 | |
|         with open(r"titles/cxb/rss2_data/Shop/ShopList_SkinNotes.csv", encoding="shift-jis") as shop:
 | |
|             lines = shop.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|                             
 | |
|         #ShopListTitle load
 | |
|         ret_str += "\r\n#ShopListTitle\r\n"
 | |
|         with open(r"titles/cxb/rss2_data/Shop/ShopList_Title.csv", encoding="utf-8") as shop:
 | |
|             lines = shop.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|         return({"data":ret_str})
 | |
|         
 | |
|     def handle_data_extra_stage_list_request(self, data: Dict) -> Dict:
 | |
|         return({"data":""})
 | |
|         
 | |
|     def handle_data_ex0001_request(self, data: Dict) -> Dict:
 | |
|         return({"data":""})
 | |
|         
 | |
|     def handle_data_one_more_extra_list_request(self, data: Dict) -> Dict:
 | |
|         return({"data":""})
 | |
|         
 | |
|     def handle_data_bonus_list10100_request(self, data: Dict) -> Dict:
 | |
|         return({"data":""})
 | |
|         
 | |
|     def handle_data_oe0001_request(self, data: Dict) -> Dict:
 | |
|         return({"data":""})
 | |
|         
 | |
|     def handle_data_free_coupon_request(self, data: Dict) -> Dict:
 | |
|         return({"data":""})
 | |
| 
 | |
|     @cached(lifetime=86400)    
 | |
|     def handle_data_news_list_request(self, data: Dict) -> Dict:
 | |
|         ret_str = ""
 | |
|         with open(r"titles/cxb/rss2_data/NewsList.csv", encoding="UTF-8") as news:
 | |
|             lines = news.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|         return({"data":ret_str})
 | |
| 
 | |
|     def handle_data_tips_request(self, data: Dict) -> Dict:
 | |
|         return({"data":""})
 | |
|         
 | |
|     def handle_data_release_info_list_request(self, data: Dict) -> Dict:
 | |
|         return({"data":""})
 | |
|     
 | |
|     @cached(lifetime=86400)
 | |
|     def handle_data_random_music_list_request(self, data: Dict) -> Dict:
 | |
|         ret_str = ""
 | |
|         with open(r"titles/cxb/rss2_data/MusicArchiveList.csv") as music:
 | |
|             lines = music.readlines()
 | |
|             count = 0
 | |
|             for line in lines:
 | |
|                 line_split = line.split(",")
 | |
|                 ret_str += str(count) + "," + line_split[0] + "," + line_split[0] + ",\r\n"
 | |
| 
 | |
|         return({"data":ret_str})
 | |
|     
 | |
|     @cached(lifetime=86400)
 | |
|     def handle_data_license_request(self, data: Dict) -> Dict:
 | |
|         ret_str = ""
 | |
|         with open(r"titles/cxb/rss2_data/License.csv", encoding="UTF-8") as licenses:
 | |
|             lines = licenses.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|         return({"data":ret_str})
 | |
|     
 | |
|     @cached(lifetime=86400)
 | |
|     def handle_data_course_list_request(self, data: Dict) -> Dict:
 | |
|         ret_str = ""
 | |
|         with open(r"titles/cxb/rss2_data/Course/CourseList.csv", encoding="UTF-8") as course:
 | |
|             lines = course.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|         return({"data":ret_str})
 | |
| 
 | |
|     @cached(lifetime=86400)
 | |
|     def handle_data_csxxxx_request(self, data: Dict) -> Dict:
 | |
|         extra_num = int(data["dldate"]["filetype"][-4:])
 | |
|         ret_str = ""
 | |
|         with open(fr"titles/cxb/rss2_data/Course/Cs{extra_num}.csv", encoding="shift-jis") as course:
 | |
|             lines = course.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|         return({"data":ret_str})
 | |
|         
 | |
|     def handle_data_mission_list_request(self, data: Dict) -> Dict:
 | |
|         return({"data":""})
 | |
|         
 | |
|     def handle_data_mission_bonus_request(self, data: Dict) -> Dict:
 | |
|         return({"data":""})
 | |
|         
 | |
|     def handle_data_unlimited_mission_request(self, data: Dict) -> Dict:
 | |
|         return({"data":""})
 | |
|         
 | |
|     def handle_data_partner_list_request(self, data: Dict) -> Dict:
 | |
|         ret_str = ""
 | |
|         # Lord forgive me for the sins I am about to commit
 | |
|         for i in range(0,10):
 | |
|             ret_str += f"80000{i},{i},{i},0,10000,,\r\n"
 | |
|             ret_str += f"80000{i},{i},{i},1,10500,,\r\n"
 | |
|             ret_str += f"80000{i},{i},{i},2,10500,,\r\n"
 | |
|         for i in range(10,13):
 | |
|             ret_str += f"8000{i},{i},{i},0,10000,,\r\n"
 | |
|             ret_str += f"8000{i},{i},{i},1,10500,,\r\n"
 | |
|             ret_str += f"8000{i},{i},{i},2,10500,,\r\n"
 | |
|         ret_str +="\r\n---\r\n0,150,100,100,100,100,\r\n"
 | |
|         for i in range(1,130):
 | |
|             ret_str +=f"{i},100,100,100,100,100,\r\n"
 | |
|                     
 | |
|         ret_str += "---\r\n"
 | |
|         return({"data": ret_str})
 | |
|     
 | |
|     @cached(lifetime=86400)
 | |
|     def handle_data_partnerxxxx_request(self, data: Dict) -> Dict:
 | |
|         partner_num = int(data["dldate"]["filetype"][-4:])
 | |
|         ret_str = f"{partner_num},,{partner_num},1,10000,\r\n"
 | |
|         with open(r"titles/cxb/rss2_data/Partner0000.csv") as partner:
 | |
|             lines = partner.readlines()
 | |
|             for line in lines:
 | |
|                 ret_str += f"{line[:-1]}\r\n"
 | |
|         return({"data": ret_str})
 | |
|     
 | |
|     def handle_data_server_state_request(self, data: Dict) -> Dict:
 | |
|         return({"data": True})
 | |
|     
 | |
|     def handle_data_settings_request(self, data: Dict) -> Dict:
 | |
|         return({"data": "2,\r\n"})
 | |
| 
 | |
|     def handle_data_story_list_request(self, data: Dict) -> Dict:
 | |
|         #story id, story name, game version, start time, end time, course arc, unlock flag, song mcode for menu
 | |
|         ret_str = "\r\n"
 | |
|         ret_str += f"st0000,RISING PURPLE,10104,1464370990,4096483201,Cs1000,-1,purple,\r\n"
 | |
|         ret_str += f"st0001,REBEL YELL,10104,1467999790,4096483201,Cs1000,-1,chaset,\r\n"
 | |
|         ret_str += f"st0002,REMNANT,10104,1502127790,4096483201,Cs1000,-1,overcl,\r\n"
 | |
|         return({"data": ret_str})
 | |
|         
 | |
|     def handle_data_stxxxx_request(self, data: Dict) -> Dict:
 | |
|         story_num = int(data["dldate"]["filetype"][-4:])
 | |
|         ret_str = ""
 | |
|         # Each stories appears to have 10 pieces based on the wiki but as on how they are set.... no clue
 | |
|         for i in range(1,11):
 | |
|             ret_str +=f"{i},st000{story_num}_{i-1},,,,,,,,,,,,,,,,1,,-1,1,\r\n"
 | |
|         return({"data": ret_str})
 | |
| 
 | |
|     def handle_data_event_stamp_list_request(self, data: Dict) -> Dict:
 | |
|         return({"data":"Cs1002,1,1,1,1,1,1,1,1,1,1,\r\n"})
 | |
| 
 | |
|     def handle_data_premium_list_request(self, data: Dict) -> Dict:
 | |
|         return({"data": "1,,,,10,,,,,99,,,,,,,,,100,,\r\n"})
 | |
| 
 | |
|     def handle_data_event_list_request(self, data: Dict) -> Dict:
 | |
|         return({"data":"Cs4001,0,10000,1601510400,1604188799,1,nv2006,1,\r\nCs4005,0,10000,1609459200,1615766399,1,nv2006,1,\r\n"})
 | |
| 
 | |
|     def handle_data_event_detail_list_request(self, data: Dict) -> Dict:
 | |
|         event_id = data["dldate"]["filetype"].split("/")[2]
 | |
|         if "Cs4001" in event_id:
 | |
|             return({"data":"#EventMusicList\r\n1,zonzon2,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,\r\n2,moonki,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,\r\n3,tricko,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,\r\n"})
 | |
|         elif "Cs4005" in event_id:
 | |
|             return({"data":"#EventMusicList\r\n2,firstl,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,\r\n2,valent,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,\r\n2,dazzli2,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,\r\n"})
 | |
|         elif "EventStampMapListCs1002" in event_id:
 | |
|             return({"data":"1,2,1,1,2,3,9,5,6,7,8,9,10,\r\n"})
 | |
|         elif "EventStampList" in event_id:
 | |
|             return({"data":"Cs1002,1,1,1,1,1,1,1,1,1,1,\r\n"})
 | |
|         else:
 | |
|             return({"data":""})
 | |
|     
 | |
|     def handle_data_event_stamp_map_list_csxxxx_request(self, data: Dict) -> Dict:
 | |
|         event_id = data["dldate"]["filetype"].split("/")[2]
 | |
|         if "EventStampMapListCs1002" in event_id:
 | |
|             return({"data":"1,2,1,1,2,3,9,5,6,7,8,9,10,\r\n"})
 | |
|         else:
 | |
|             return({"data":""})
 |