Fixed bug that prevented getallmodVersionInfo() from caching data, also made HTTP 429 handling more intelligent

This commit is contained in:
2022-02-26 18:07:53 -06:00
parent 3d61098f9e
commit 3693e23a73
2 changed files with 36 additions and 25 deletions

View File

@@ -25,8 +25,10 @@ base_api_url = "https://api.modrinth.com:443/api/v1"
def failCheck(response, functOrigin):
print("Status Code is: "+str(response.status_code))
if response.status_code == 429:
print("Too many requests!"+'\n'+"Waiting for 30 seconds...")
time.sleep(30) # Wait 30 seconds
sleep_time = int(response.headers["X-Ratelimit-Reset"])+1
print("Too many requests!"+'\n'+"Waiting for "+str(sleep_time)+" seconds...")
print(response.headers)
time.sleep(sleep_time) # Wait until API ratelimit is over
print("Retrying "+functOrigin+"...")
return True
elif response.status_code != 200:
@@ -36,46 +38,50 @@ dataCache = {}
def cacheData(function_name, cached_data):
print("Caching data!")
dataCache[function_name] = cached_data
#print(dataCache)
print("Stored "+function_name+"'s data to cache")
#
def modInfo(project):
print("Calling modInfo()...")
if "modInfo" in dataCache:
print("Returning cached data!")
return dataCache["modInfo"]
response = session.get(base_api_url+"/mod/"+project, family=socket.AF_INET)
if failCheck(response, "modInfo") == True: #Attempt to requery API
else:
response = session.get(base_api_url+"/mod/"+project, family=socket.AF_INET)
api_response = response.json()
cacheData("modInfo", api_response)
return api_response
if failCheck(response, "modInfo") == True: #Attempt to requery API
response = session.get(base_api_url+"/mod/"+project, family=socket.AF_INET)
api_response = response.json()
cacheData("modInfo", api_response)
return api_response
def getVersions(project):
print("Calling getVersions()...")
if "getVersions" in dataCache:
print("Returning cached data!")
return dataCache["getVersions"]
workingDict = modInfo(project)
versions = workingDict["versions"]
cacheData("getVersions", versions)
return versions
else:
workingDict = modInfo(project)
versions = workingDict["versions"]
cacheData("getVersions", versions)
return versions
def getAllModVersionInfo(project):
print("Calling getAllModVersionInfo()...")
if "getAllModVersionInfo" in dataCache:
print("Returning cached data!")
return dataCache["getAllMinecraftVersionInfo"]
versions = getVersions(project)
responseList = []
numberOfVersions = len(versions)
for item in range(numberOfVersions):
response = session.get(base_api_url+"/version/"+versions[item], family=socket.AF_INET)
if failCheck(response, "getAllModVersionInfo") == True: #Attempt to requery API
return dataCache["getAllModVersionInfo"]
else:
versions = getVersions(project)
responseList = []
numberOfVersions = len(versions)
for item in range(numberOfVersions):
response = session.get(base_api_url+"/version/"+versions[item], family=socket.AF_INET)
api_response = response.json()
responseList.append(api_response)
cacheData("getAllMinecraftVersionInfo", responseList)
return responseList
if failCheck(response, "getAllModVersionInfo") == True: #Attempt to requery API
response = session.get(base_api_url+"/version/"+versions[item], family=socket.AF_INET)
api_response = response.json()
responseList.append(api_response)
cacheData("getAllModVersionInfo", responseList)
return responseList
def determine(project, whatToDetermine):
print("Calling determine()...")