Külasta lehte: https://phxc2.ee
Autorid: Rainer Vana, Kevin Akkermann
Aines Programmeerimine II (LTAT.03.007) on näha iga ülesande puhul edetabel. Seal näeb iga ülesande kohta eraldi edetabelit, kuid puudub nende andmete visualiseerimise võimalus.
Võimalused
- Võimaldab vaadata ELO süsteemi järgi parimaid
- Võimaldab vaadata iga kasutaja tulemuste kokkuvõtet
- Saab vaadata mingi ülesannete edetabelit iga 5 minuti tagant. Selleks saab animeerida edetabeleid ja näha, kes millal esitas oma lahenduse jms
edetabelid:
nimi | deadline | sortimine |
---|---|---|
varchar(50) | datetime | varchar(255) |
kasutades sortimine veeru väärtust sorteeritakse ELO jms päringutega tulemusi. Näiteks on sortimine ",d.skoor * 1 ASC", ",d.skoor * 1 DESC, d.skoor2 * 1 ASC"
dataNew: (kaabitsetud andmed)
edetabel_id | edetabel_nimi | osaleja | skoor | skoor2 | aeg |
---|---|---|---|---|---|
int(11) | varchar(30) | varchar(30) | float | float | null | timestamp |
dataFinal: (lõpptulemused)
edetabel_id | edetabel_nimi | osaleja | skoor | skoor2 | aeg | koht |
---|---|---|---|---|---|---|
int(11) | varchar(30) | varchar(30) | float | float | null | timestamp | int(11) |
Java programm, mis kaabitseb lehelt aktiivsete edetabelite tulemusi iga 5 minuti tagant. Täpsemalt alamkaustas
Programm, mis kaabitseb phxc lehekülje. Programmis saab vaadelda edetabeleid, üksikute osalejate tulemusi, millistest edetabelites nad osalenud on, mis nende ELO on ning millised nende tulemused on edetabelites olnud.
Klasside ja funktsioonide info: Klassid, funktsioonid
Kolmekihiline Next.js / Spring Boot / MySQL rakendus, mis näitab kokkuvõtteid terve kursuse peale
Potentsiaalne lahendus:
- API endpoint GET /users
- Iga nädala lõpus kirjutame uude DB tabelisse uuesti arvutatud ELO seisu (nt Cron-iga)
- Tagastab:
[
{
pseudoname: <String>,
ELO: <Float>,
results: [
{
edetabelNimi: <String>,
skoor1: <Float>,
skoor1Unit: <String>,
skoor2: <Float | NULL>,
skoor2Unit: <String | NULL>
},
// ...
]
},
{
pseudoname: <String>,
ELO: <Float>,
results: [
// ...
]
},
// .....
]
Potentsiaalne lahendus:
- API endpoint GET /users/{pseudo}
- Getib andmebaasist kõik selle kasutaja tulemused (igast edetabelist, vali viimane timestamp ja sorteeri kõik tulemused ning ütle, mitmes see kasutaja on)
- Tagastab:
{
pseudoname: <String>,
ELO: <Float>,
results: [
{
edetabelNimi: <String>,
skoor1: <Float>,
skoor1Unit: <String>,
skoor2: <Float | NULL>,
skoor2Unit: <String | NULL>
},
// ...
]
},
Kuna iga 5 minuti tagant on scrapetud, siis saame näidata animatsioonidega, kuidas ajas need tulemused muutusid
Potentsiaalne lahendus:
- API endpoint GET /results/{edetabel_nimi}?type=<all | last>
- last tagastab ainult viimase timestampi
- Tagastab kasvavas järjekorras timestampidega:
[
{
timestamp: <UNIX timestamp>,
results: [
{
pseudo: <String>,
skoor1: <Float>,
skoor2: <Float | NULL>,
},
{
pseudo: <String>,
skoor1: <Float>,
skoor2: <Float | NULL>,
},
]
}
]