mirror of
https://github.com/vkaelin/LeagueStats.git
synced 2026-03-25 12:57:28 +00:00
136 lines
4.9 KiB
TypeScript
136 lines
4.9 KiB
TypeScript
import Jax from './Jax'
|
|
// import Logger from '@ioc:Adonis/Core/Logger'
|
|
import { getSeasonNumber } from 'App/helpers'
|
|
import { MatchReferenceDto } from './Jax/src/Endpoints/MatchListEndpoint'
|
|
import { SummonerDTO } from './Jax/src/Endpoints/SummonerEndpoint'
|
|
import { SummonerModel } from '@ioc:Adonis/League'
|
|
|
|
class MatchService {
|
|
/**
|
|
* Add 100 matches at a time to MatchList until the stopFetching condition is true
|
|
* @param account of the summoner
|
|
* @param stopFetching condition to stop fetching the MatchList
|
|
*/
|
|
private async _fetchMatchListUntil (account: SummonerDTO, stopFetching: any) {
|
|
let matchList: MatchReferenceDto[] = []
|
|
let alreadyIn = false
|
|
let index = 0
|
|
do {
|
|
let { matches: newMatchList } = await Jax.Matchlist.accountID(account.accountId, account.region as string, index)
|
|
// Error while fetching Riot API
|
|
if (!newMatchList) {
|
|
matchList = matchList.map(m => {
|
|
m.seasonMatch = getSeasonNumber(m.timestamp)
|
|
return m
|
|
})
|
|
return matchList
|
|
}
|
|
matchList = [...matchList, ...newMatchList]
|
|
alreadyIn = newMatchList.length === 0 || stopFetching(newMatchList)
|
|
// If the match is made in another region : we stop fetching
|
|
if (matchList[matchList.length - 1].platformId.toLowerCase() !== account.region) {
|
|
alreadyIn = true
|
|
}
|
|
index += 100
|
|
} while (!alreadyIn)
|
|
|
|
// Remove matches from MatchList made in another region and tutorial games
|
|
const tutorialModes = [2000, 2010, 2020]
|
|
matchList = matchList
|
|
.filter(m => {
|
|
const sameRegion = m.platformId.toLowerCase() === account.region
|
|
const notATutorialGame = !tutorialModes.includes(m.queue)
|
|
|
|
return sameRegion && notATutorialGame
|
|
})
|
|
.map(m => {
|
|
m.seasonMatch = getSeasonNumber(m.timestamp)
|
|
return m
|
|
})
|
|
|
|
return matchList
|
|
}
|
|
/**
|
|
* Update the full MatchList of the summoner (min. 4 months)
|
|
* @param account of the summoner
|
|
* @param summonerDB summoner in the database
|
|
*/
|
|
public async updateMatchList (account: SummonerDTO, summonerDB: SummonerModel) {
|
|
console.time('matchList')
|
|
|
|
// Summoner has already been searched : we already have a MatchList and we need to update it
|
|
if (summonerDB.matchList) {
|
|
// Get MatchList
|
|
const matchList = await this._fetchMatchListUntil(account, (newMatchList: MatchReferenceDto[]) => {
|
|
return summonerDB.matchList!.some(m => m.gameId === newMatchList[newMatchList.length - 1].gameId)
|
|
})
|
|
// Update Summoner's MatchList
|
|
for (const match of matchList.reverse()) {
|
|
if (!summonerDB.matchList.some(m => m.gameId === match.gameId)) {
|
|
summonerDB.matchList.unshift(match)
|
|
}
|
|
}
|
|
} else { // First search of the Summoner
|
|
const today = Date.now()
|
|
// Get MatchList
|
|
const matchList = await this._fetchMatchListUntil(account, (newMatchList: MatchReferenceDto[]) => {
|
|
return (newMatchList.length !== 100 || today - newMatchList[newMatchList.length - 1].timestamp > 10368000000)
|
|
})
|
|
// Create Summoner's MatchList in Database
|
|
summonerDB.matchList = matchList
|
|
}
|
|
console.timeEnd('matchList')
|
|
}
|
|
|
|
/**
|
|
* Fetch list of matches for a specific Summoner
|
|
* @param account of the summoner
|
|
* @param gameIds of the matches to fetch
|
|
* @param summonerDB summoner in the database
|
|
*/
|
|
// public async getMatches (account, gameIds, summonerDB) {
|
|
// console.time('getMatches')
|
|
|
|
// let matchesDetails = []
|
|
// const matchesToGetFromRiot = []
|
|
// for (let i = 0; i < gameIds.length; ++i) {
|
|
// const matchSaved = await summonerDB.matches().where({ gameId: gameIds[i] }).first()
|
|
// if (matchSaved) {
|
|
// matchesDetails.push(matchSaved)
|
|
// } else {
|
|
// matchesToGetFromRiot.push(gameIds[i])
|
|
// }
|
|
// }
|
|
|
|
// const requests = matchesToGetFromRiot.map(gameId => Jax.Match.get(gameId, account.region))
|
|
// let matchesFromApi = await Promise.all(requests)
|
|
|
|
// /* If we have to store some matches in the db */
|
|
// if (matchesFromApi.length !== 0) {
|
|
// // Try to see why matches are sometimes undefined
|
|
// matchesFromApi.filter(m => {
|
|
// if (m === undefined) {
|
|
// Logger.info(`Match undefined, summoner: ${summonerDB.puuid}`, m)
|
|
// }
|
|
// })
|
|
|
|
// // Transform raw matches data
|
|
// await BasicMatchTransformer.transform(matchesFromApi, { account })
|
|
|
|
// /* Save all matches from Riot Api in db */
|
|
// for (const match of matchesFromApi) {
|
|
// await summonerDB.matches().create(match)
|
|
// match.newMatch = true
|
|
// }
|
|
// matchesDetails = [...matchesDetails, ...matchesFromApi]
|
|
// }
|
|
|
|
// /* Sort matches */
|
|
// matchesDetails.sort((a, b) => (a.date < b.date) ? 1 : -1)
|
|
// console.timeEnd('getMatches')
|
|
|
|
// return matchesDetails
|
|
// }
|
|
}
|
|
|
|
export default new MatchService()
|