feat: add music
This commit is contained in:
parent
7a54773e89
commit
9bab65364e
17
character.py
17
character.py
@ -1,17 +0,0 @@
|
|||||||
import json
|
|
||||||
|
|
||||||
from sdgb import sdgb_api
|
|
||||||
|
|
||||||
def character(userId):
|
|
||||||
data = json.dumps({
|
|
||||||
"userId": int(userId),
|
|
||||||
"nextIndex":10000000000,
|
|
||||||
"maxCount":1000000000
|
|
||||||
})
|
|
||||||
|
|
||||||
character_result = json.loads(sdgb_api(data, "GetUserCharacterApi", userId))
|
|
||||||
|
|
||||||
return character_result
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
print(character(int(input())))
|
|
13
charge.py
13
charge.py
@ -1,13 +0,0 @@
|
|||||||
import json
|
|
||||||
|
|
||||||
from sdgb import sdgb_api
|
|
||||||
|
|
||||||
def charge(userId):
|
|
||||||
data = json.dumps({
|
|
||||||
"userId": userId,
|
|
||||||
})
|
|
||||||
|
|
||||||
charge_result = json.loads(sdgb_api(data, "GetUserChargeApi", userId))
|
|
||||||
|
|
||||||
return charge_result
|
|
||||||
|
|
18
item.py
18
item.py
@ -1,18 +0,0 @@
|
|||||||
import json
|
|
||||||
|
|
||||||
from sdgb import sdgb_api
|
|
||||||
|
|
||||||
def item(userId):
|
|
||||||
data = json.dumps({
|
|
||||||
"userId": int(userId),
|
|
||||||
"nextIndex":60000000000,
|
|
||||||
"maxCount":1000000000
|
|
||||||
})
|
|
||||||
|
|
||||||
item_result = json.loads(sdgb_api(data, "GetUserItemApi", userId))
|
|
||||||
|
|
||||||
return item_result
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
a = json.dumps(len(item(11593052)['userItemList']))
|
|
||||||
print(a)
|
|
@ -1,16 +0,0 @@
|
|||||||
import json
|
|
||||||
|
|
||||||
from sdgb import sdgb_api
|
|
||||||
|
|
||||||
def item(userId):
|
|
||||||
data = json.dumps({
|
|
||||||
"userId": int(userId),
|
|
||||||
"nextIndex":0,
|
|
||||||
"maxCount":2000
|
|
||||||
})
|
|
||||||
|
|
||||||
login_bonus_result = json.loads(sdgb_api(data, "GetUserLoginBonusApi", userId))
|
|
||||||
|
|
||||||
return login_bonus_result
|
|
||||||
|
|
||||||
print(item(11593052))
|
|
132
main.py
132
main.py
@ -5,125 +5,17 @@ from datetime import datetime
|
|||||||
from flask import Flask,request,redirect,jsonify
|
from flask import Flask,request,redirect,jsonify
|
||||||
from flask_cors import CORS
|
from flask_cors import CORS
|
||||||
|
|
||||||
from sdgb import felica, sdgb_api, aimedb_api
|
|
||||||
from logout import logout
|
from logout import logout
|
||||||
from login import login
|
from login import login
|
||||||
from ticket import get_ticket
|
from process import *
|
||||||
from charge import charge
|
|
||||||
from map import map
|
|
||||||
from userdata import userdata
|
|
||||||
from character import character
|
|
||||||
|
|
||||||
|
from sdgb import sdgb_api, felica
|
||||||
from mapstock import music_with_retry as mapstock
|
from mapstock import music_with_retry as mapstock
|
||||||
from music import music_with_retry as music
|
from music import music_with_retry as music
|
||||||
from unlock_all import music_with_retry as unlock
|
from unlock_all import music_with_retry as unlock
|
||||||
from map_clear import music_with_retry as map_clear
|
from map_clear import music_with_retry as map_clear
|
||||||
from bonus9 import music_with_retry as login_bonus
|
from bonus9 import music_with_retry as login_bonus
|
||||||
|
|
||||||
def find_map(mapId, user_map_data):
|
|
||||||
for single in user_map_data:
|
|
||||||
if single["mapId"] == mapId:
|
|
||||||
return single
|
|
||||||
else:
|
|
||||||
continue
|
|
||||||
|
|
||||||
def isNewMapList(mapId, user_map_data):
|
|
||||||
if ('{"mapId": ' + str(mapId)) in user_map_data:
|
|
||||||
return 0
|
|
||||||
else:
|
|
||||||
return 1
|
|
||||||
|
|
||||||
def item(item_data, user_character_list):
|
|
||||||
item_list = []
|
|
||||||
character_list = []
|
|
||||||
for single in item_data:
|
|
||||||
if single['kind'] == 9:
|
|
||||||
if ('{"characterId": ' + str(single['id'])) in user_character_list:
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
data = ({
|
|
||||||
"characterId":single['id'],
|
|
||||||
"level":1,
|
|
||||||
"awakening":0,
|
|
||||||
"useCount": 0
|
|
||||||
})
|
|
||||||
character_list.append(data)
|
|
||||||
else:
|
|
||||||
data = ({
|
|
||||||
"itemKind": single['kind'],
|
|
||||||
"itemId": single['id'],
|
|
||||||
"stock": 1,
|
|
||||||
"isValid": True
|
|
||||||
})
|
|
||||||
item_list.append(data)
|
|
||||||
return item_list, character_list, item_data[-1]['distance']
|
|
||||||
|
|
||||||
def aimedb_userId(IDm):
|
|
||||||
return aimedb_api(felica(IDm)), felica(IDm)
|
|
||||||
|
|
||||||
|
|
||||||
def bonus_list_gen(userId):
|
|
||||||
with open('login_bonus.json') as file:
|
|
||||||
cache = json.load(file)
|
|
||||||
bonus_data = []
|
|
||||||
for item in cache:
|
|
||||||
bonus_data.append(item['id'])
|
|
||||||
cache = []
|
|
||||||
data = json.dumps({
|
|
||||||
"userId": int(userId),
|
|
||||||
"nextIndex":0,
|
|
||||||
"maxCount":2000
|
|
||||||
})
|
|
||||||
user_bonus = json.loads(sdgb_api(data, "GetUserLoginBonusApi", userId))['userLoginBonusList']
|
|
||||||
for item in user_bonus:
|
|
||||||
cache.append(item['bonusId'])
|
|
||||||
bonus_list_unexist = list(set(bonus_data) - set(cache))
|
|
||||||
bonus_list = []
|
|
||||||
for item in user_bonus:
|
|
||||||
if item['isComplete'] == False:
|
|
||||||
if item['bonusId'] in [12, 29, 30, 38, 43, 604]:
|
|
||||||
data = ({
|
|
||||||
"bonusId": item['bonusId'],
|
|
||||||
"point": 4,
|
|
||||||
"isCurrent": item['isCurrent'],
|
|
||||||
"isComplete": False
|
|
||||||
})
|
|
||||||
else:
|
|
||||||
data = ({
|
|
||||||
"bonusId": item['bonusId'],
|
|
||||||
"point": 9,
|
|
||||||
"isCurrent": item['isCurrent'],
|
|
||||||
"isComplete": False
|
|
||||||
})
|
|
||||||
bonus_list.append(data)
|
|
||||||
elif item['bonusId'] == 999:
|
|
||||||
data = ({
|
|
||||||
"bonusId": 999,
|
|
||||||
"point": item['point'] // 10 * 10 + 9,
|
|
||||||
"isCurrent": item['isCurrent'],
|
|
||||||
"isComplete": False
|
|
||||||
})
|
|
||||||
bonus_list.append(data)
|
|
||||||
else:
|
|
||||||
pass
|
|
||||||
for item in bonus_list_unexist:
|
|
||||||
if item in [12, 29, 30, 38, 43, 604]:
|
|
||||||
data = ({
|
|
||||||
"bonusId": item,
|
|
||||||
"point": 4,
|
|
||||||
"isCurrent": False,
|
|
||||||
"isComplete": False
|
|
||||||
})
|
|
||||||
else:
|
|
||||||
data = ({
|
|
||||||
"bonusId": item,
|
|
||||||
"point": 9,
|
|
||||||
"isCurrent": False,
|
|
||||||
"isComplete": False
|
|
||||||
})
|
|
||||||
bonus_list.append(data)
|
|
||||||
return bonus_list
|
|
||||||
|
|
||||||
app = Flask(__name__)
|
app = Flask(__name__)
|
||||||
app.json.sort_keys = False
|
app.json.sort_keys = False
|
||||||
app.json.ensure_ascii = False
|
app.json.ensure_ascii = False
|
||||||
@ -150,7 +42,7 @@ def bad_request(e):
|
|||||||
|
|
||||||
@app.route("/")
|
@app.route("/")
|
||||||
def index():
|
def index():
|
||||||
return jsonify({"status": "200 OK", "timestamp": int(time.time()), "info": "Project Fragrance","availableApi": ["qr", "ticket", "mapstock", "unlock", "map"], "date": datetime.now(pytz.timezone('Asia/Shanghai')).strftime('%a, %d %b %Y %H:%M:%S GMT+8')}), 200
|
return jsonify({"status": "200 OK", "timestamp": int(time.time()), "info": "Sennoza - Project Fragrance","availableApi": ["felica", "ticket", "mapstock", "unlock", "music", "map", "bonus"], "date": datetime.now(pytz.timezone('Asia/Shanghai')).strftime('%a, %d %b %Y %H:%M:%S GMT+8')}), 200
|
||||||
|
|
||||||
@app.route("/felica")
|
@app.route("/felica")
|
||||||
def felica_lookup():
|
def felica_lookup():
|
||||||
@ -199,8 +91,8 @@ def ticket():
|
|||||||
ticket_data = get_ticket(userId)
|
ticket_data = get_ticket(userId)
|
||||||
if ticket_data['returnCode'] == 0:
|
if ticket_data['returnCode'] == 0:
|
||||||
logout(userId, accessCode, timestamp)
|
logout(userId, accessCode, timestamp)
|
||||||
returnCode = 405
|
returnCode = 403
|
||||||
status = "405 Method Not Allowed"
|
status = "403 Forbidden"
|
||||||
info = "WARNING: THIS INFO SHOULD NEVER APPEARS. IF YOU SEE THIS WARNING PLEASE CONTACT Telegram@sasakure. Unable to operate. Successfully Logged in. Probably User has had one ticket."
|
info = "WARNING: THIS INFO SHOULD NEVER APPEARS. IF YOU SEE THIS WARNING PLEASE CONTACT Telegram@sasakure. Unable to operate. Successfully Logged in. Probably User has had one ticket."
|
||||||
log = {"UserLoginApiStatus": 1, "UserLogoutApiStatus": 1}
|
log = {"UserLoginApiStatus": 1, "UserLogoutApiStatus": 1}
|
||||||
elif ticket_data['returnCode'] == 1:
|
elif ticket_data['returnCode'] == 1:
|
||||||
@ -295,13 +187,15 @@ def unlock_process():
|
|||||||
@app.route("/music", methods=['POST'])
|
@app.route("/music", methods=['POST'])
|
||||||
def music_post():
|
def music_post():
|
||||||
request_data = request.get_json()
|
request_data = request.get_json()
|
||||||
if 'userId' in request_data and 'music' in request_data:
|
if 'IDm' in request_data and 'music' in request_data:
|
||||||
if request_data['userId'] is None or isinstance(request_data['userId'], int) is False or len(str(request_data['userId'])) != 8:
|
if request_data['IDm'] is None or len(str(request_data['IDm'])) != 16:
|
||||||
return jsonify({"apiName": "music", "apiInfo": "Overwrite Music Data in UserData.", "apiUsage": ""})
|
return jsonify({"apiName": "music", "apiInfo": "Overwrite Music Data in UserData.", "apiUsage": ""})
|
||||||
else:
|
else:
|
||||||
userId = int(request_data['userId'])
|
IDm = request_data['IDm']
|
||||||
|
userId = aimedb_userId(IDm)[0]
|
||||||
|
accessCode = aimedb_userId(IDm)[1]
|
||||||
timestamp = int(time.time())
|
timestamp = int(time.time())
|
||||||
login_data = login(userId, timestamp)
|
login_data = login(userId, accessCode, timestamp)
|
||||||
if login_data['returnCode'] == 102:
|
if login_data['returnCode'] == 102:
|
||||||
returnCode = 403
|
returnCode = 403
|
||||||
status = "403 Forbidden"
|
status = "403 Forbidden"
|
||||||
@ -313,9 +207,9 @@ def music_post():
|
|||||||
info = "Unable to operate. Probably User has logged in."
|
info = "Unable to operate. Probably User has logged in."
|
||||||
log = {}
|
log = {}
|
||||||
elif login_data['returnCode'] == 1:
|
elif login_data['returnCode'] == 1:
|
||||||
logout(userId, timestamp)
|
logout(userId, accessCode, timestamp)
|
||||||
music_data = request_data['music']
|
music_data = request_data['music']
|
||||||
music(userId, music_data)
|
music(userId, accessCode, music_data)
|
||||||
returnCode = 200
|
returnCode = 200
|
||||||
status = "200 OK"
|
status = "200 OK"
|
||||||
info = "Succeed."
|
info = "Succeed."
|
||||||
|
17
map.py
17
map.py
@ -1,17 +0,0 @@
|
|||||||
import json
|
|
||||||
|
|
||||||
from sdgb import sdgb_api
|
|
||||||
|
|
||||||
def map(userId):
|
|
||||||
data = json.dumps({
|
|
||||||
"userId": int(userId),
|
|
||||||
"nextIndex": 0,
|
|
||||||
"maxCount": 600
|
|
||||||
})
|
|
||||||
|
|
||||||
map_result = json.loads(sdgb_api(data, "GetUserMapApi", userId))
|
|
||||||
|
|
||||||
return map_result
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
print(map(int(input())))
|
|
558
music.py
558
music.py
@ -30,22 +30,11 @@ def CalcRandom():
|
|||||||
|
|
||||||
timestamp = int(time.time())
|
timestamp = int(time.time())
|
||||||
|
|
||||||
def music(userId, music_data):
|
def music(userId, accessCode, music_data):
|
||||||
|
|
||||||
music = music_data
|
|
||||||
|
|
||||||
musicId = music['musicId']
|
|
||||||
level = music['level']
|
|
||||||
playCount = music['playCount']
|
|
||||||
achievement = music['achievement']
|
|
||||||
comboStatus = music['comboStatus']
|
|
||||||
syncStatus = music['syncStatus']
|
|
||||||
deluxscoreMax = music['deluxscoreMax']
|
|
||||||
scoreRank = music['scoreRank']
|
|
||||||
|
|
||||||
# UserLogin
|
# UserLogin
|
||||||
|
|
||||||
login_result = login(userId, timestamp)
|
login_result = login(userId, accessCode, timestamp)
|
||||||
|
|
||||||
login_id = login_result['loginId']
|
login_id = login_result['loginId']
|
||||||
login_date = login_result['lastLoginDate']
|
login_date = login_result['lastLoginDate']
|
||||||
@ -61,121 +50,128 @@ def music(userId, music_data):
|
|||||||
|
|
||||||
# UserLog
|
# UserLog
|
||||||
|
|
||||||
|
playloglist = []
|
||||||
|
|
||||||
|
for music in music_data:
|
||||||
|
data = ({
|
||||||
|
"userId": 0,
|
||||||
|
"orderId": 0,
|
||||||
|
"playlogId": login_id,
|
||||||
|
"version": 1050000,
|
||||||
|
"placeId": placeId,
|
||||||
|
"placeName": placeName,
|
||||||
|
"loginDate": int(time.time()),
|
||||||
|
"playDate": datetime.now(pytz.timezone('Asia/Shanghai')).strftime('%Y-%m-%d'),
|
||||||
|
"userPlayDate": datetime.now(pytz.timezone('Asia/Shanghai')).strftime('%Y-%m-%d %H:%M:%S') + '.0',
|
||||||
|
"type": 0,
|
||||||
|
"musicId": music['musicId'],
|
||||||
|
"level": music['level'],
|
||||||
|
"trackNo": len(music_data) - music_data.index(music),
|
||||||
|
"vsMode": 0,
|
||||||
|
"vsUserName": "",
|
||||||
|
"vsStatus": 0,
|
||||||
|
"vsUserRating": 0,
|
||||||
|
"vsUserAchievement": 0,
|
||||||
|
"vsUserGradeRank": 0,
|
||||||
|
"vsRank": 0,
|
||||||
|
"playerNum": 1,
|
||||||
|
"playedUserId1": 0,
|
||||||
|
"playedUserName1": "",
|
||||||
|
"playedMusicLevel1": 0,
|
||||||
|
"playedUserId2": 0,
|
||||||
|
"playedUserName2": "",
|
||||||
|
"playedMusicLevel2": 0,
|
||||||
|
"playedUserId3": 0,
|
||||||
|
"playedUserName3": "",
|
||||||
|
"playedMusicLevel3": 0,
|
||||||
|
"characterId1": userdata['userData']['charaSlot'][0],
|
||||||
|
"characterLevel1": random.randint(1000,6500),
|
||||||
|
"characterAwakening1": 5,
|
||||||
|
"characterId2": userdata['userData']['charaSlot'][1],
|
||||||
|
"characterLevel2": random.randint(1000,6500),
|
||||||
|
"characterAwakening2": 5,
|
||||||
|
"characterId3": userdata['userData']['charaSlot'][2],
|
||||||
|
"characterLevel3": random.randint(1000,6500),
|
||||||
|
"characterAwakening3": 5,
|
||||||
|
"characterId4": userdata['userData']['charaSlot'][3],
|
||||||
|
"characterLevel4": random.randint(1000,6500),
|
||||||
|
"characterAwakening4": 5,
|
||||||
|
"characterId5": userdata['userData']['charaSlot'][4],
|
||||||
|
"characterLevel5": random.randint(1000,6500),
|
||||||
|
"characterAwakening5": 5,
|
||||||
|
"achievement": music['achievement'],
|
||||||
|
"deluxscore": music['deluxscoreMax'],
|
||||||
|
"scoreRank": music['scoreRank'],
|
||||||
|
"maxCombo": random.randint(400,500),
|
||||||
|
"totalCombo": random.randint(700,900),
|
||||||
|
"maxSync": 0,
|
||||||
|
"totalSync": 0,
|
||||||
|
"tapCriticalPerfect": random.randint(200,400),
|
||||||
|
"tapPerfect": random.randint(100,250),
|
||||||
|
"tapGreat": random.randint(0,10),
|
||||||
|
"tapGood": random.randint(0,10),
|
||||||
|
"tapMiss": random.randint(0,10),
|
||||||
|
"holdCriticalPerfect": random.randint(20,40),
|
||||||
|
"holdPerfect": random.randint(0,15),
|
||||||
|
"holdGreat": 0,
|
||||||
|
"holdGood": 0,
|
||||||
|
"holdMiss": 0,
|
||||||
|
"slideCriticalPerfect": random.randint(34,60),
|
||||||
|
"slidePerfect": 0,
|
||||||
|
"slideGreat": 0,
|
||||||
|
"slideGood": 0,
|
||||||
|
"slideMiss": 0,
|
||||||
|
"touchCriticalPerfect": random.randint(20,70),
|
||||||
|
"touchPerfect": 0,
|
||||||
|
"touchGreat": 0,
|
||||||
|
"touchGood": 0,
|
||||||
|
"touchMiss": 0,
|
||||||
|
"breakCriticalPerfect": random.randint(8,30),
|
||||||
|
"breakPerfect": random.randint(7,10),
|
||||||
|
"breakGreat": 0,
|
||||||
|
"breakGood": 0,
|
||||||
|
"breakMiss": 0,
|
||||||
|
"isTap": True,
|
||||||
|
"isHold": True,
|
||||||
|
"isSlide": True,
|
||||||
|
"isTouch": True,
|
||||||
|
"isBreak": True,
|
||||||
|
"isCriticalDisp": True,
|
||||||
|
"isFastLateDisp": True,
|
||||||
|
"fastCount": random.randint(20,30),
|
||||||
|
"lateCount": random.randint(50,70),
|
||||||
|
"isAchieveNewRecord": True,
|
||||||
|
"isDeluxscoreNewRecord": True,
|
||||||
|
"comboStatus": 0,
|
||||||
|
"syncStatus": 0,
|
||||||
|
"isClear": True,
|
||||||
|
'beforeRating': userdata['userData']['playerRating'],
|
||||||
|
'afterRating': userdata['userData']['playerRating'],
|
||||||
|
"beforeGrade": 0,
|
||||||
|
"afterGrade": 0,
|
||||||
|
"afterGradeRank": 2,
|
||||||
|
'beforeDeluxRating': userdata['userData']['playerRating'],
|
||||||
|
'afterDeluxRating': userdata['userData']['playerRating'],
|
||||||
|
"isPlayTutorial": False,
|
||||||
|
"isEventMode": False,
|
||||||
|
"isFreedomMode": False,
|
||||||
|
"playMode": 0,
|
||||||
|
"isNewFree": False,
|
||||||
|
"trialPlayAchievement": -1,
|
||||||
|
"extNum1": 0,
|
||||||
|
"extNum2": 0,
|
||||||
|
"extNum4": 2020,
|
||||||
|
"extBool1": False,
|
||||||
|
"extBool2": False
|
||||||
|
})
|
||||||
|
playloglist.append(data)
|
||||||
|
|
||||||
data = json.dumps({
|
data = json.dumps({
|
||||||
"userId": int(userId),
|
"userId": int(userId),
|
||||||
"userPlaylog": {
|
"userPlaylogList": playloglist
|
||||||
"userId": 0,
|
|
||||||
"orderId": 0,
|
|
||||||
"playlogId": login_id,
|
|
||||||
"version": 1041000,
|
|
||||||
"placeId": placeId,
|
|
||||||
"placeName": placeName,
|
|
||||||
"loginDate": int(time.time()),
|
|
||||||
"playDate": datetime.now(pytz.timezone('Asia/Shanghai')).strftime('%Y-%m-%d'),
|
|
||||||
"userPlayDate": datetime.now(pytz.timezone('Asia/Shanghai')).strftime('%Y-%m-%d %H:%M:%S') + '.0',
|
|
||||||
"type": 0,
|
|
||||||
"musicId": int(musicId),
|
|
||||||
"level": int(level),
|
|
||||||
"trackNo": 1,
|
|
||||||
"vsMode": 0,
|
|
||||||
"vsUserName": "",
|
|
||||||
"vsStatus": 0,
|
|
||||||
"vsUserRating": 0,
|
|
||||||
"vsUserAchievement": 0,
|
|
||||||
"vsUserGradeRank": 0,
|
|
||||||
"vsRank": 0,
|
|
||||||
"playerNum": 1,
|
|
||||||
"playedUserId1": 0,
|
|
||||||
"playedUserName1": "",
|
|
||||||
"playedMusicLevel1": 0,
|
|
||||||
"playedUserId2": 0,
|
|
||||||
"playedUserName2": "",
|
|
||||||
"playedMusicLevel2": 0,
|
|
||||||
"playedUserId3": 0,
|
|
||||||
"playedUserName3": "",
|
|
||||||
"playedMusicLevel3": 0,
|
|
||||||
"characterId1": userdata['userData']['charaSlot'][0],
|
|
||||||
"characterLevel1": random.randint(1000,6500),
|
|
||||||
"characterAwakening1": 5,
|
|
||||||
"characterId2": userdata['userData']['charaSlot'][1],
|
|
||||||
"characterLevel2": random.randint(1000,6500),
|
|
||||||
"characterAwakening2": 5,
|
|
||||||
"characterId3": userdata['userData']['charaSlot'][2],
|
|
||||||
"characterLevel3": random.randint(1000,6500),
|
|
||||||
"characterAwakening3": 5,
|
|
||||||
"characterId4": userdata['userData']['charaSlot'][3],
|
|
||||||
"characterLevel4": random.randint(1000,6500),
|
|
||||||
"characterAwakening4": 5,
|
|
||||||
"characterId5": userdata['userData']['charaSlot'][4],
|
|
||||||
"characterLevel5": random.randint(1000,6500),
|
|
||||||
"characterAwakening5": 5,
|
|
||||||
"achievement": int(achievement),
|
|
||||||
"deluxscore": int(deluxscoreMax),
|
|
||||||
"scoreRank": int(scoreRank),
|
|
||||||
"maxCombo": random.randint(400,500),
|
|
||||||
"totalCombo": random.randint(700,900),
|
|
||||||
"maxSync": 0,
|
|
||||||
"totalSync": 0,
|
|
||||||
"tapCriticalPerfect": random.randint(200,400),
|
|
||||||
"tapPerfect": random.randint(100,250),
|
|
||||||
"tapGreat": random.randint(0,10),
|
|
||||||
"tapGood": random.randint(0,10),
|
|
||||||
"tapMiss": random.randint(0,10),
|
|
||||||
"holdCriticalPerfect": random.randint(20,40),
|
|
||||||
"holdPerfect": random.randint(0,15),
|
|
||||||
"holdGreat": 0,
|
|
||||||
"holdGood": 0,
|
|
||||||
"holdMiss": 0,
|
|
||||||
"slideCriticalPerfect": random.randint(34,60),
|
|
||||||
"slidePerfect": 0,
|
|
||||||
"slideGreat": 0,
|
|
||||||
"slideGood": 0,
|
|
||||||
"slideMiss": 0,
|
|
||||||
"touchCriticalPerfect": random.randint(20,70),
|
|
||||||
"touchPerfect": 0,
|
|
||||||
"touchGreat": 0,
|
|
||||||
"touchGood": 0,
|
|
||||||
"touchMiss": 0,
|
|
||||||
"breakCriticalPerfect": random.randint(8,30),
|
|
||||||
"breakPerfect": random.randint(7,10),
|
|
||||||
"breakGreat": 0,
|
|
||||||
"breakGood": 0,
|
|
||||||
"breakMiss": 0,
|
|
||||||
"isTap": True,
|
|
||||||
"isHold": True,
|
|
||||||
"isSlide": True,
|
|
||||||
"isTouch": True,
|
|
||||||
"isBreak": True,
|
|
||||||
"isCriticalDisp": True,
|
|
||||||
"isFastLateDisp": True,
|
|
||||||
"fastCount": random.randint(20,30),
|
|
||||||
"lateCount": random.randint(50,70),
|
|
||||||
"isAchieveNewRecord": True,
|
|
||||||
"isDeluxscoreNewRecord": True,
|
|
||||||
"comboStatus": 0,
|
|
||||||
"syncStatus": 0,
|
|
||||||
"isClear": True,
|
|
||||||
'beforeRating': userdata['userData']['playerRating'],
|
|
||||||
'afterRating': userdata['userData']['playerRating'],
|
|
||||||
"beforeGrade": 0,
|
|
||||||
"afterGrade": 0,
|
|
||||||
"afterGradeRank": 2,
|
|
||||||
'beforeDeluxRating': userdata['userData']['playerRating'],
|
|
||||||
'afterDeluxRating': userdata['userData']['playerRating'],
|
|
||||||
"isPlayTutorial": False,
|
|
||||||
"isEventMode": False,
|
|
||||||
"isFreedomMode": False,
|
|
||||||
"playMode": 0,
|
|
||||||
"isNewFree": False,
|
|
||||||
"trialPlayAchievement": -1,
|
|
||||||
"extNum1": 0,
|
|
||||||
"extNum2": 0,
|
|
||||||
"extNum4": 3020,
|
|
||||||
"extBool1": False
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
|
|
||||||
userlog_result = json.loads(sdgb_api(data, "UploadUserPlaylogApi", userId))
|
userlog_result = json.loads(sdgb_api(data, "UploadUserPlaylogListApi", userId))
|
||||||
|
|
||||||
# 获取 User Extend
|
# 获取 User Extend
|
||||||
data = json.dumps({
|
data = json.dumps({
|
||||||
@ -219,155 +215,161 @@ def music(userId, music_data):
|
|||||||
# UserAll
|
# UserAll
|
||||||
|
|
||||||
data = json.dumps({
|
data = json.dumps({
|
||||||
"userId": int(userId),
|
"userId": int(userId),
|
||||||
"playlogId": login_id,
|
"playlogId": login_id,
|
||||||
"isEventMode": False,
|
"isEventMode": False,
|
||||||
"isFreePlay": False,
|
"isFreePlay": False,
|
||||||
"upsertUserAll": {
|
"upsertUserAll": {
|
||||||
"userData": [
|
"userData": [
|
||||||
{
|
{
|
||||||
"accessCode": "",
|
"accessCode": int(accessCode),
|
||||||
"userName": userdata['userData']['userName'],
|
"userName": userdata['userData']['userName'],
|
||||||
"isNetMember": 1,
|
"isNetMember": 1,
|
||||||
"iconId": userdata['userData']['iconId'],
|
"point": userdata['userData']['point'],
|
||||||
"plateId": userdata['userData']['plateId'],
|
"totalPoint": userdata['userData']['totalPoint'],
|
||||||
"titleId": userdata['userData']['titleId'],
|
"iconId": userdata['userData']['iconId'],
|
||||||
"partnerId": userdata['userData']['partnerId'],
|
"plateId": userdata['userData']['plateId'],
|
||||||
"frameId": userdata['userData']['frameId'],
|
"titleId": userdata['userData']['titleId'],
|
||||||
"selectMapId": userdata['userData']['selectMapId'],
|
"partnerId": userdata['userData']['partnerId'],
|
||||||
"totalAwake": userdata['userData']['totalAwake'],
|
"frameId": userdata['userData']['frameId'],
|
||||||
"gradeRating": userdata['userData']['gradeRating'],
|
"selectMapId": userdata['userData']['selectMapId'],
|
||||||
"musicRating": userdata['userData']['musicRating'],
|
"totalAwake": userdata['userData']['totalAwake'],
|
||||||
"playerRating": userdata['userData']['playerRating'],
|
"gradeRating": userdata['userData']['gradeRating'],
|
||||||
"highestRating": userdata['userData']['highestRating'],
|
"musicRating": userdata['userData']['musicRating'],
|
||||||
"gradeRank": userdata['userData']['gradeRank'],
|
"playerRating": userdata['userData']['playerRating'],
|
||||||
"classRank": userdata['userData']['classRank'],
|
"highestRating": userdata['userData']['highestRating'],
|
||||||
"courseRank": userdata['userData']['courseRank'],
|
"gradeRank": userdata['userData']['gradeRank'],
|
||||||
"charaSlot": userdata['userData']['charaSlot'],
|
"classRank": userdata['userData']['classRank'],
|
||||||
"charaLockSlot": userdata['userData']['charaLockSlot'],
|
"courseRank": userdata['userData']['courseRank'],
|
||||||
"contentBit": userdata['userData']['contentBit'],
|
"charaSlot": userdata['userData']['charaSlot'],
|
||||||
"playCount": userdata['userData']['playCount'],
|
"charaLockSlot": userdata['userData']['charaLockSlot'],
|
||||||
"currentPlayCount": userdata['userData']['currentPlayCount'],
|
"contentBit": userdata['userData']['contentBit'],
|
||||||
"renameCredit": 0,
|
"playCount": userdata['userData']['playCount'],
|
||||||
"mapStock": userdata['userData']['mapStock'],
|
"currentPlayCount": userdata['userData']['currentPlayCount'],
|
||||||
"eventWatchedDate": userdata['userData']['eventWatchedDate'],
|
"renameCredit": 0,
|
||||||
"lastGameId": "SDGB",
|
"mapStock": userdata['userData']['mapStock'],
|
||||||
"lastRomVersion": userdata['userData']['lastRomVersion'],
|
"eventWatchedDate": userdata['userData']['eventWatchedDate'],
|
||||||
"lastDataVersion": userdata['userData']['lastDataVersion'],
|
"lastGameId": "SDGA",
|
||||||
"lastLoginDate": login_date,
|
"lastRomVersion": userdata['userData']['lastRomVersion'],
|
||||||
"lastPlayDate": datetime.now(pytz.timezone('Asia/Shanghai')).strftime('%Y-%m-%d %H:%M:%S') + '.0',
|
"lastDataVersion": userdata['userData']['lastDataVersion'],
|
||||||
"lastPlayCredit": 1,
|
"lastLoginDate": login_date,
|
||||||
"lastPlayMode": 0,
|
"lastPlayDate": datetime.now(pytz.timezone('Asia/Shanghai')).strftime('%Y-%m-%d %H:%M:%S') + '.0',
|
||||||
"lastPlaceId": placeId,
|
"lastPlayCredit": 1,
|
||||||
"lastPlaceName": placeName,
|
"lastPlayMode": 0,
|
||||||
"lastAllNetId": 0,
|
"lastPlaceId": placeId,
|
||||||
"lastRegionId": regionId,
|
"lastPlaceName": placeName,
|
||||||
"lastRegionName": regionName,
|
"lastAllNetId": 0,
|
||||||
"lastClientId": clientId,
|
"lastRegionId": regionId,
|
||||||
"lastCountryCode": "CHN",
|
"lastRegionName": regionName,
|
||||||
"lastSelectEMoney": 0,
|
"lastClientId": clientId,
|
||||||
"lastSelectTicket": 0,
|
"lastCountryCode": "CHN",
|
||||||
"lastSelectCourse": userdata['userData']['lastSelectCourse'],
|
"lastSelectEMoney": 0,
|
||||||
"lastCountCourse": 0,
|
"lastSelectTicket": 0,
|
||||||
"firstGameId": "SDGB",
|
"lastSelectCourse": userdata['userData']['lastSelectCourse'],
|
||||||
"firstRomVersion": userdata['userData']['firstRomVersion'],
|
"lastCountCourse": 0,
|
||||||
"firstDataVersion": userdata['userData']['firstDataVersion'],
|
"firstGameId": "SDGA",
|
||||||
"firstPlayDate": userdata['userData']['firstPlayDate'],
|
"firstRomVersion": userdata['userData']['firstRomVersion'],
|
||||||
"compatibleCmVersion": userdata['userData']['compatibleCmVersion'],
|
"firstDataVersion": userdata['userData']['firstDataVersion'],
|
||||||
"dailyBonusDate": userdata['userData']['dailyBonusDate'],
|
"firstPlayDate": userdata['userData']['firstPlayDate'],
|
||||||
"dailyCourseBonusDate": userdata['userData']['dailyCourseBonusDate'],
|
"compatibleCmVersion": userdata['userData']['compatibleCmVersion'],
|
||||||
"lastPairLoginDate": userdata['userData']['lastPairLoginDate'],
|
"dailyBonusDate": userdata['userData']['dailyBonusDate'],
|
||||||
"lastTrialPlayDate": userdata['userData']['lastTrialPlayDate'],
|
"dailyCourseBonusDate": userdata['userData']['dailyCourseBonusDate'],
|
||||||
"playVsCount": 0,
|
"lastPairLoginDate": userdata['userData']['lastPairLoginDate'],
|
||||||
"playSyncCount": 0,
|
"lastTrialPlayDate": userdata['userData']['lastTrialPlayDate'],
|
||||||
"winCount": 0,
|
"playVsCount": 0,
|
||||||
"helpCount": 0,
|
"playSyncCount": 0,
|
||||||
"comboCount": 0,
|
"winCount": 0,
|
||||||
"totalDeluxscore": userdata['userData']['totalDeluxscore'],
|
"helpCount": 0,
|
||||||
"totalBasicDeluxscore": userdata['userData']['totalBasicDeluxscore'],
|
"comboCount": 0,
|
||||||
"totalAdvancedDeluxscore": userdata['userData']['totalAdvancedDeluxscore'],
|
"totalDeluxscore": userdata['userData']['totalDeluxscore'],
|
||||||
"totalExpertDeluxscore": userdata['userData']['totalExpertDeluxscore'],
|
"totalBasicDeluxscore": userdata['userData']['totalBasicDeluxscore'],
|
||||||
"totalMasterDeluxscore": userdata['userData']['totalMasterDeluxscore'],
|
"totalAdvancedDeluxscore": userdata['userData']['totalAdvancedDeluxscore'],
|
||||||
"totalReMasterDeluxscore": userdata['userData']['totalReMasterDeluxscore'],
|
"totalExpertDeluxscore": userdata['userData']['totalExpertDeluxscore'],
|
||||||
"totalSync": userdata['userData']['totalSync'],
|
"totalMasterDeluxscore": userdata['userData']['totalMasterDeluxscore'],
|
||||||
"totalBasicSync": userdata['userData']['totalBasicSync'],
|
"totalReMasterDeluxscore": userdata['userData']['totalReMasterDeluxscore'],
|
||||||
"totalAdvancedSync": userdata['userData']['totalAdvancedSync'],
|
"totalSync": userdata['userData']['totalSync'],
|
||||||
"totalExpertSync": userdata['userData']['totalExpertSync'],
|
"totalBasicSync": userdata['userData']['totalBasicSync'],
|
||||||
"totalMasterSync": userdata['userData']['totalMasterSync'],
|
"totalAdvancedSync": userdata['userData']['totalAdvancedSync'],
|
||||||
"totalReMasterSync": userdata['userData']['totalReMasterSync'],
|
"totalExpertSync": userdata['userData']['totalExpertSync'],
|
||||||
"totalAchievement": userdata['userData']['totalAchievement'],
|
"totalMasterSync": userdata['userData']['totalMasterSync'],
|
||||||
"totalBasicAchievement": userdata['userData']['totalBasicAchievement'],
|
"totalReMasterSync": userdata['userData']['totalReMasterSync'],
|
||||||
"totalAdvancedAchievement": userdata['userData']['totalAdvancedAchievement'],
|
"totalAchievement": userdata['userData']['totalAchievement'],
|
||||||
"totalExpertAchievement": userdata['userData']['totalExpertAchievement'],
|
"totalBasicAchievement": userdata['userData']['totalBasicAchievement'],
|
||||||
"totalMasterAchievement": userdata['userData']['totalMasterAchievement'],
|
"totalAdvancedAchievement": userdata['userData']['totalAdvancedAchievement'],
|
||||||
"totalReMasterAchievement": userdata['userData']['totalReMasterAchievement'],
|
"totalExpertAchievement": userdata['userData']['totalExpertAchievement'],
|
||||||
"playerOldRating": userdata['userData']['playerOldRating'],
|
"totalMasterAchievement": userdata['userData']['totalMasterAchievement'],
|
||||||
"playerNewRating": userdata['userData']['playerNewRating'],
|
"totalReMasterAchievement": userdata['userData']['totalReMasterAchievement'],
|
||||||
"banState": 0,
|
"playerOldRating": userdata['userData']['playerOldRating'],
|
||||||
"dateTime": timestamp
|
"playerNewRating": userdata['userData']['playerNewRating'],
|
||||||
}
|
"banState": 0,
|
||||||
],
|
"friendRegistSkip": 1,
|
||||||
"userExtend": [user_extend['userExtend']],
|
"dateTime": timestamp
|
||||||
"userOption": [user_option['userOption']],
|
}
|
||||||
"userCharacterList": [],
|
],
|
||||||
"userGhost": [],
|
"userExtend": [user_extend['userExtend']],
|
||||||
"userMapList": [],
|
"userOption": [user_option['userOption']],
|
||||||
"userLoginBonusList": [],
|
"userCharacterList": [],
|
||||||
"userRatingList": [user_rating['userRating']],
|
"userGhost": [],
|
||||||
"userItemList": [],
|
"userMapList": [],
|
||||||
"userMusicDetailList": [
|
"userLoginBonusList": [],
|
||||||
{
|
"userRatingList": [user_rating['userRating']],
|
||||||
"musicId": musicId,
|
"userItemList": [],
|
||||||
"level": level,
|
"userMusicDetailList": music_data,
|
||||||
"playCount": playCount,
|
"userCourseList": [],
|
||||||
"achievement": achievement,
|
"userFriendSeasonRankingList": [],
|
||||||
"comboStatus": comboStatus,
|
"userChargeList": user_charge['userChargeList'],
|
||||||
"syncStatus": syncStatus,
|
"userFavoriteList": [],
|
||||||
"deluxscoreMax": deluxscoreMax,
|
"userActivityList": [user_activity['userActivity']],
|
||||||
"scoreRank": scoreRank,
|
"userMissionDataList": [],
|
||||||
"extNum1": 0
|
"userWeeklyData": {
|
||||||
}
|
"lastLoginWeek": "2025-01-20 04:00:00",
|
||||||
],
|
"beforeLoginWeek": "2024-09-02 04:00:00",
|
||||||
"userCourseList": [],
|
"friendBonusFlag": True
|
||||||
"userFriendSeasonRankingList": [],
|
},
|
||||||
"userChargeList": user_charge['userChargeList'],
|
"userGamePlaylogList": [
|
||||||
"userFavoriteList": [],
|
{
|
||||||
"userActivityList": [user_activity['userActivity']],
|
"playlogId": login_id,
|
||||||
"userGamePlaylogList": [
|
"version": "1.50.00",
|
||||||
{
|
"playDate": datetime.now(pytz.timezone('Asia/Shanghai')).strftime('%Y-%m-%d %H:%M:%S') + '.0',
|
||||||
"playlogId": login_id,
|
"playMode": 0,
|
||||||
"version": "1.41.00",
|
"useTicketId": -1,
|
||||||
"playDate": datetime.now(pytz.timezone('Asia/Shanghai')).strftime('%Y-%m-%d %H:%M:%S') + '.0',
|
"playCredit": 1,
|
||||||
"playMode": 0,
|
"playTrack": len(music_data),
|
||||||
"useTicketId": -1,
|
"clientId": clientId,
|
||||||
"playCredit": 1,
|
"isPlayTutorial": False,
|
||||||
"playTrack": 1,
|
"isEventMode": False,
|
||||||
"clientId": clientId,
|
"isNewFree": False,
|
||||||
"isPlayTutorial": False,
|
"playCount": 8,
|
||||||
"isEventMode": False,
|
"playSpecial": CalcRandom(),
|
||||||
"isNewFree": False,
|
"playOtherUserId": 0
|
||||||
"playCount": 0,
|
}
|
||||||
"playSpecial": CalcRandom(),
|
],
|
||||||
"playOtherUserId": 0
|
"user2pPlaylog": {
|
||||||
}
|
"userId1": 0,
|
||||||
],
|
"userId2": 0,
|
||||||
"user2pPlaylog": {
|
"userName1": "",
|
||||||
"userId1": 0,
|
"userName2": "",
|
||||||
"userId2": 0,
|
"regionId": 0,
|
||||||
"userName1": "",
|
"placeId": 0,
|
||||||
"userName2": "",
|
"user2pPlaylogDetailList": []
|
||||||
"regionId": 0,
|
},
|
||||||
"placeId": 0,
|
"userIntimateList": [],
|
||||||
"user2pPlaylogDetailList": []
|
"userShopItemStockList": [],
|
||||||
},
|
"userGetPointList": [],
|
||||||
"isNewCharacterList": "",
|
"userTradeItemList": [],
|
||||||
"isNewMapList": "",
|
"userFavoritemusicList": [],
|
||||||
"isNewLoginBonusList": "",
|
"userKaleidxScopeList": [],
|
||||||
"isNewItemList": "",
|
"isNewCharacterList": "",
|
||||||
"isNewMusicDetailList": "0",
|
"isNewMapList": "",
|
||||||
"isNewCourseList": "0",
|
"isNewLoginBonusList": "",
|
||||||
"isNewFavoriteList": "",
|
"isNewItemList": "",
|
||||||
"isNewFriendSeasonRankingList": ""
|
"isNewMusicDetailList": "0" * len(music_data),
|
||||||
|
"isNewCourseList": "",
|
||||||
|
"isNewFavoriteList": "",
|
||||||
|
"isNewFriendSeasonRankingList": "",
|
||||||
|
"isNewUserIntimateList": "",
|
||||||
|
"isNewFavoritemusicList": "",
|
||||||
|
"isNewKaleidxScopeList": ""
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -381,12 +383,12 @@ def music(userId, music_data):
|
|||||||
|
|
||||||
return data
|
return data
|
||||||
|
|
||||||
def music_with_retry(userId, music_data):
|
def music_with_retry(userId, accessCode, music_data):
|
||||||
for i in range(5):
|
for i in range(5):
|
||||||
try:
|
try:
|
||||||
music(userId, music_data)
|
music(userId, accessCode, music_data)
|
||||||
return logout(userId, timestamp)
|
return logout(userId, accessCode, timestamp)
|
||||||
except ValueError as e:
|
except ValueError as e:
|
||||||
logout(userId, timestamp)
|
logout(userId, accessCode, timestamp)
|
||||||
time.sleep(3)
|
time.sleep(3)
|
||||||
return json.dumps({"status": "500 Internal Server Error"}), 500
|
return json.dumps({"status": "500 Internal Server Error"}), 500
|
||||||
|
180
process.py
Normal file
180
process.py
Normal file
@ -0,0 +1,180 @@
|
|||||||
|
import json
|
||||||
|
import pytz
|
||||||
|
import time
|
||||||
|
from sdgb import sdgb_api, aimedb_api, felica
|
||||||
|
from datetime import datetime, timedelta
|
||||||
|
|
||||||
|
from settings import regionId, clientId, placeId
|
||||||
|
|
||||||
|
from logout import logout
|
||||||
|
from login import login
|
||||||
|
|
||||||
|
def find_map(mapId, user_map_data):
|
||||||
|
for single in user_map_data:
|
||||||
|
if single["mapId"] == mapId:
|
||||||
|
return single
|
||||||
|
else:
|
||||||
|
continue
|
||||||
|
|
||||||
|
def isNewMapList(mapId, user_map_data):
|
||||||
|
if ('{"mapId": ' + str(mapId)) in user_map_data:
|
||||||
|
return 0
|
||||||
|
else:
|
||||||
|
return 1
|
||||||
|
|
||||||
|
def item(item_data, user_character_list):
|
||||||
|
item_list = []
|
||||||
|
character_list = []
|
||||||
|
for single in item_data:
|
||||||
|
if single['kind'] == 9:
|
||||||
|
if ('{"characterId": ' + str(single['id'])) in user_character_list:
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
data = ({
|
||||||
|
"characterId":single['id'],
|
||||||
|
"level":1,
|
||||||
|
"awakening":0,
|
||||||
|
"useCount": 0
|
||||||
|
})
|
||||||
|
character_list.append(data)
|
||||||
|
else:
|
||||||
|
data = ({
|
||||||
|
"itemKind": single['kind'],
|
||||||
|
"itemId": single['id'],
|
||||||
|
"stock": 1,
|
||||||
|
"isValid": True
|
||||||
|
})
|
||||||
|
item_list.append(data)
|
||||||
|
return item_list, character_list, item_data[-1]['distance']
|
||||||
|
|
||||||
|
|
||||||
|
def bonus_list_gen(userId):
|
||||||
|
with open('login_bonus.json') as file:
|
||||||
|
cache = json.load(file)
|
||||||
|
bonus_data = []
|
||||||
|
for item in cache:
|
||||||
|
bonus_data.append(item['id'])
|
||||||
|
cache = []
|
||||||
|
data = json.dumps({
|
||||||
|
"userId": int(userId),
|
||||||
|
"nextIndex":0,
|
||||||
|
"maxCount":2000
|
||||||
|
})
|
||||||
|
user_bonus = json.loads(sdgb_api(data, "GetUserLoginBonusApi", userId))['userLoginBonusList']
|
||||||
|
for item in user_bonus:
|
||||||
|
cache.append(item['bonusId'])
|
||||||
|
bonus_list_unexist = list(set(bonus_data) - set(cache))
|
||||||
|
bonus_list = []
|
||||||
|
for item in user_bonus:
|
||||||
|
if item['isComplete'] == False:
|
||||||
|
if item['bonusId'] in [12, 29, 30, 38, 43, 604]:
|
||||||
|
data = ({
|
||||||
|
"bonusId": item['bonusId'],
|
||||||
|
"point": 4,
|
||||||
|
"isCurrent": item['isCurrent'],
|
||||||
|
"isComplete": False
|
||||||
|
})
|
||||||
|
else:
|
||||||
|
data = ({
|
||||||
|
"bonusId": item['bonusId'],
|
||||||
|
"point": 9,
|
||||||
|
"isCurrent": item['isCurrent'],
|
||||||
|
"isComplete": False
|
||||||
|
})
|
||||||
|
bonus_list.append(data)
|
||||||
|
elif item['bonusId'] == 999:
|
||||||
|
data = ({
|
||||||
|
"bonusId": 999,
|
||||||
|
"point": item['point'] // 10 * 10 + 9,
|
||||||
|
"isCurrent": item['isCurrent'],
|
||||||
|
"isComplete": False
|
||||||
|
})
|
||||||
|
bonus_list.append(data)
|
||||||
|
else:
|
||||||
|
pass
|
||||||
|
for item in bonus_list_unexist:
|
||||||
|
if item in [12, 29, 30, 38, 43, 604]:
|
||||||
|
data = ({
|
||||||
|
"bonusId": item,
|
||||||
|
"point": 4,
|
||||||
|
"isCurrent": False,
|
||||||
|
"isComplete": False
|
||||||
|
})
|
||||||
|
else:
|
||||||
|
data = ({
|
||||||
|
"bonusId": item,
|
||||||
|
"point": 9,
|
||||||
|
"isCurrent": False,
|
||||||
|
"isComplete": False
|
||||||
|
})
|
||||||
|
bonus_list.append(data)
|
||||||
|
return bonus_list
|
||||||
|
|
||||||
|
|
||||||
|
def aimedb_userId(IDm):
|
||||||
|
return aimedb_api(felica(IDm)), felica(IDm)
|
||||||
|
|
||||||
|
def map(userId):
|
||||||
|
data = json.dumps({
|
||||||
|
"userId": int(userId),
|
||||||
|
"nextIndex": 0,
|
||||||
|
"maxCount": 600
|
||||||
|
})
|
||||||
|
|
||||||
|
map_result = json.loads(sdgb_api(data, "GetUserMapApi", userId))
|
||||||
|
|
||||||
|
return map_result
|
||||||
|
|
||||||
|
def character(userId):
|
||||||
|
data = json.dumps({
|
||||||
|
"userId": int(userId),
|
||||||
|
"nextIndex":10000000000,
|
||||||
|
"maxCount":1000000000
|
||||||
|
})
|
||||||
|
|
||||||
|
character_result = json.loads(sdgb_api(data, "GetUserCharacterApi", userId))
|
||||||
|
|
||||||
|
return character_result
|
||||||
|
|
||||||
|
|
||||||
|
def userdata(userId):
|
||||||
|
data = json.dumps({
|
||||||
|
"userId": int(userId)
|
||||||
|
})
|
||||||
|
|
||||||
|
userdata_result = json.loads(sdgb_api(data, "GetUserDataApi", userId))
|
||||||
|
|
||||||
|
return userdata_result
|
||||||
|
|
||||||
|
|
||||||
|
def charge(userId):
|
||||||
|
data = json.dumps({
|
||||||
|
"userId": userId,
|
||||||
|
})
|
||||||
|
|
||||||
|
charge_result = json.loads(sdgb_api(data, "GetUserChargeApi", userId))
|
||||||
|
|
||||||
|
return charge_result
|
||||||
|
|
||||||
|
def get_ticket(userId):
|
||||||
|
data = json.dumps({
|
||||||
|
"userId": userId,
|
||||||
|
"userCharge": {
|
||||||
|
"chargeId": 6,
|
||||||
|
"stock": 1,
|
||||||
|
"purchaseDate": (datetime.now(pytz.timezone('Asia/Shanghai')) - timedelta(hours=1)).strftime("%Y-%m-%d %H:%M:%S.0"),
|
||||||
|
"validDate": (datetime.now(pytz.timezone('Asia/Shanghai')) - timedelta(hours=1) + timedelta(days=90)).replace(hour=4, minute=0, second=0).strftime("%Y-%m-%d %H:%M:%S")
|
||||||
|
},
|
||||||
|
"userChargelog": {
|
||||||
|
"chargeId": 6,
|
||||||
|
"price": 4,
|
||||||
|
"purchaseDate": (datetime.now(pytz.timezone('Asia/Shanghai')) - timedelta(hours=1)).strftime("%Y-%m-%d %H:%M:%S.0"),
|
||||||
|
"placeId": placeId,
|
||||||
|
"regionId": regionId,
|
||||||
|
"clientId": clientId
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
ticket_result = json.loads(sdgb_api(data, "UpsertUserChargelogApi", userId))
|
||||||
|
|
||||||
|
return ticket_result
|
@ -1,4 +1,4 @@
|
|||||||
requests
|
httpx
|
||||||
pycryptodome
|
pycryptodome
|
||||||
pytz
|
pytz
|
||||||
flask
|
flask
|
||||||
|
5
sdgb.py
5
sdgb.py
@ -2,7 +2,7 @@ import json
|
|||||||
import zlib
|
import zlib
|
||||||
import pytz
|
import pytz
|
||||||
import hashlib
|
import hashlib
|
||||||
import requests
|
import httpx
|
||||||
|
|
||||||
from binascii import unhexlify, hexlify
|
from binascii import unhexlify, hexlify
|
||||||
import socket
|
import socket
|
||||||
@ -56,8 +56,7 @@ def sdgb_api(data, useApi, userId):
|
|||||||
data_def = zlib.compress(data)
|
data_def = zlib.compress(data)
|
||||||
data_enc = aes.encrypt(data_def)
|
data_enc = aes.encrypt(data_def)
|
||||||
endpoint = "https://mai2exp.sic-rd1.jp:42081/Maimai2Servlet/"
|
endpoint = "https://mai2exp.sic-rd1.jp:42081/Maimai2Servlet/"
|
||||||
requests.packages.urllib3.disable_warnings()
|
r = httpx.post(
|
||||||
r = requests.post(
|
|
||||||
endpoint + get_hash_api(useApi),
|
endpoint + get_hash_api(useApi),
|
||||||
headers = {
|
headers = {
|
||||||
"User-Agent": "%s#%d"%(get_hash_api(useApi), userId),
|
"User-Agent": "%s#%d"%(get_hash_api(useApi), userId),
|
||||||
|
43
ticket.py
43
ticket.py
@ -1,43 +0,0 @@
|
|||||||
import json
|
|
||||||
import pytz
|
|
||||||
import time
|
|
||||||
|
|
||||||
from sdgb import sdgb_api
|
|
||||||
from datetime import datetime, timedelta
|
|
||||||
|
|
||||||
from settings import regionId
|
|
||||||
from settings import clientId
|
|
||||||
from settings import placeId
|
|
||||||
|
|
||||||
from logout import logout
|
|
||||||
from login import login
|
|
||||||
|
|
||||||
def get_ticket(userId):
|
|
||||||
data = json.dumps({
|
|
||||||
"userId": userId,
|
|
||||||
"userCharge": {
|
|
||||||
"chargeId": 6,
|
|
||||||
"stock": 1,
|
|
||||||
"purchaseDate": (datetime.now(pytz.timezone('Asia/Shanghai')) - timedelta(hours=1)).strftime("%Y-%m-%d %H:%M:%S.0"),
|
|
||||||
"validDate": (datetime.now(pytz.timezone('Asia/Shanghai')) - timedelta(hours=1) + timedelta(days=90)).replace(hour=4, minute=0, second=0).strftime("%Y-%m-%d %H:%M:%S")
|
|
||||||
},
|
|
||||||
"userChargelog": {
|
|
||||||
"chargeId": 6,
|
|
||||||
"price": 4,
|
|
||||||
"purchaseDate": (datetime.now(pytz.timezone('Asia/Shanghai')) - timedelta(hours=1)).strftime("%Y-%m-%d %H:%M:%S.0"),
|
|
||||||
"placeId": placeId,
|
|
||||||
"regionId": regionId,
|
|
||||||
"clientId": clientId
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
ticket_result = json.loads(sdgb_api(data, "UpsertUserChargelogApi", userId))
|
|
||||||
|
|
||||||
return ticket_result
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
timestamp = int(time.time())
|
|
||||||
print(timestamp)
|
|
||||||
print(login(timestamp))
|
|
||||||
print(get_ticket())
|
|
||||||
print(logout(timestamp))
|
|
12
userdata.py
12
userdata.py
@ -1,12 +0,0 @@
|
|||||||
import json
|
|
||||||
|
|
||||||
from sdgb import sdgb_api
|
|
||||||
|
|
||||||
def userdata(userId):
|
|
||||||
data = json.dumps({
|
|
||||||
"userId": int(userId)
|
|
||||||
})
|
|
||||||
|
|
||||||
userdata_result = json.loads(sdgb_api(data, "GetUserDataApi", userId))
|
|
||||||
|
|
||||||
return userdata_result
|
|
Loading…
x
Reference in New Issue
Block a user