From 58fc378174faf11391885281759caa39d9b324cc Mon Sep 17 00:00:00 2001 From: mat Date: Sun, 25 Dec 2022 00:44:51 -0600 Subject: fix lastsave hypixel moved it a while ago and i hadn't bothered fixing it --- src/cleaners/skyblock/profile.ts | 18 ++++++++++++++++-- src/cleaners/skyblock/profiles.ts | 8 ++++++-- 2 files changed, 22 insertions(+), 4 deletions(-) (limited to 'src/cleaners/skyblock') diff --git a/src/cleaners/skyblock/profile.ts b/src/cleaners/skyblock/profile.ts index ebe5c47..725b8b9 100644 --- a/src/cleaners/skyblock/profile.ts +++ b/src/cleaners/skyblock/profile.ts @@ -78,12 +78,22 @@ export async function cleanSkyblockProfileResponse( const cleanedMembers: CleanMember[] = (await Promise.all(promises)).filter(m => m) as CleanMember[] + // sometimes it's ms since epoch and sometimes it's a string, so we + // just throw it into new Date() and js will figure it out for us + const lastSave = data.last_save ? (new Date(data.last_save).getTime()) : undefined + // also set the lastSave in the member if options.mainMemberUuid matches + if (options?.mainMemberUuid) { + const mainMember = cleanedMembers.find(m => m.uuid === options.mainMemberUuid) + if (mainMember) mainMember.lastSave = lastSave ?? null + } + if (options?.basic) { const cleanProfile: CleanProfile = { uuid: profileId, name: 'cute_name' in data ? data.cute_name : undefined, members: cleanedMembers, - mode: cleanGameMode(data) + mode: cleanGameMode(data), + lastSave } // we have to do this because of the basic checking typing return cleanProfile as any @@ -111,7 +121,8 @@ export async function cleanSkyblockProfileResponse( minions: minions, minionCount: uniqueMinions, maxUniqueMinions: maxUniqueMinions ?? 0, - mode: cleanGameMode(data) + mode: cleanGameMode(data), + lastSave } return cleanFullProfile } @@ -122,5 +133,8 @@ export interface CleanBasicProfile { // the name depends on the user, so its sometimes not included name?: string + + /** Timestamp for when the profile was last saved for the user. */ + lastSave?: number } diff --git a/src/cleaners/skyblock/profiles.ts b/src/cleaners/skyblock/profiles.ts index 4e9400b..da40ee3 100644 --- a/src/cleaners/skyblock/profiles.ts +++ b/src/cleaners/skyblock/profiles.ts @@ -5,6 +5,7 @@ import { cleanSkyblockProfileResponse } from './profile.js' import typedHypixelApi from 'typed-hypixel-api' +import { ApiOptions } from '../../hypixel.js' export function cleanPlayerSkyblockProfiles(rawProfiles: HypixelPlayerStatsSkyBlockProfiles | undefined): CleanBasicProfile[] { if (!rawProfiles) return [] @@ -20,12 +21,15 @@ export function cleanPlayerSkyblockProfiles(rawProfiles: HypixelPlayerStatsSkyBl } /** Convert an array of raw profiles into clean profiles */ -export async function cleanSkyblockProfilesResponse(data: typedHypixelApi.SkyBlockProfilesResponse['profiles']): Promise { +export async function cleanSkyblockProfilesResponse( + data: typedHypixelApi.SkyBlockProfilesResponse['profiles'], + options: ApiOptions +): Promise { if (!data) return null const promises: Promise[] = [] for (const profile of data) { - promises.push(cleanSkyblockProfileResponse(profile)) + promises.push(cleanSkyblockProfileResponse(profile, options)) } const cleanedProfiles: CleanFullProfile[] = (await Promise.all(promises)).filter((p): p is CleanFullProfile => p !== null) return cleanedProfiles -- cgit