server/backend/hint.go

52 lines
1.6 KiB
Go
Raw Normal View History

2016-12-09 10:49:29 +00:00
package main
import (
"encoding/json"
"fmt"
2016-12-09 10:49:29 +00:00
"io/ioutil"
2019-07-11 17:52:13 +00:00
"log"
2016-12-09 10:49:29 +00:00
"os"
"srs.epita.fr/fic-server/libfic"
)
type askOpenHint struct {
2019-07-11 17:52:13 +00:00
HintId int64 `json:"id"`
2016-12-09 10:49:29 +00:00
}
func treatOpeningHint(pathname string, team fic.Team) {
var ask askOpenHint
if cnt_raw, err := ioutil.ReadFile(pathname); err != nil {
log.Println("[ERR]", err)
2019-01-17 15:55:54 +00:00
} else if err = json.Unmarshal(cnt_raw, &ask); err != nil {
2016-12-09 10:49:29 +00:00
log.Println("[ERR]", err)
} else if ask.HintId == 0 {
log.Println("[WRN] Invalid content in hint file: ", pathname)
os.Remove(pathname)
} else if hint, err := fic.GetHint(ask.HintId); err != nil {
log.Println("[ERR] Unable to retrieve the given hint:", err)
} else if exercice, err := hint.GetExercice(); err != nil {
log.Println("[ERR] Unable to retrieve the hint's underlying exercice:", err)
} else if !team.HasAccess(exercice) {
log.Println("[!!!] The team asks to open an hint whereas it doesn't have access to the exercice")
2019-01-17 15:55:54 +00:00
} else if err = team.OpenHint(hint); err != nil {
log.Println("[ERR] Unable to open hint", err)
2016-12-09 10:49:29 +00:00
} else {
// Write event
if lvl, err := exercice.GetLevel(); err != nil {
log.Println("[WRN]", err)
2018-12-08 20:17:04 +00:00
} else if theme, err := fic.GetTheme(exercice.IdTheme); err != nil {
log.Println("[WRN]", err)
} else if _, err = fic.NewEvent(fmt.Sprintf("L'équipe %s a dévoilé un indice pour le <strong>%d<sup>e</sup></strong> défi %s&#160;!", team.Name, lvl, theme.Name), "info"); err != nil {
log.Println("[WRN] Unable to create event:", err)
}
2019-07-11 17:52:13 +00:00
genTeamQueue <- &team
appendGenQueue(genStruct{Type: GenEvents})
2019-01-17 15:55:54 +00:00
if err = os.Remove(pathname); err != nil {
2016-12-09 10:49:29 +00:00
log.Println("[ERR]", err)
}
}
}