server/backend/choices.go

45 lines
1.3 KiB
Go
Raw Normal View History

2018-12-02 22:18:32 +00:00
package main
import (
"encoding/json"
"log"
"io/ioutil"
"os"
"srs.epita.fr/fic-server/libfic"
)
type wantChoices struct {
FlagId int64 `json:"id"`
}
func treatWantChoices(pathname string, team fic.Team) {
var ask wantChoices
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 {
2018-12-02 22:18:32 +00:00
log.Println("[ERR]", err)
} else if ask.FlagId == 0 {
log.Println("[WRN] Invalid content in wantChoices file: ", pathname)
os.Remove(pathname)
} else if flag, err := fic.GetFlagKey(ask.FlagId); err != nil {
2018-12-02 22:18:32 +00:00
log.Println("[ERR]", err)
} else if !team.CanSeeFlag(flag) {
log.Println("[!!!] The team asks to display choices whereas it doesn't have access to the flag")
} else if exercice, err := flag.GetExercice(); err != nil {
log.Println("[ERR] Unable to retrieve the flag's underlying exercice:", err)
} else if !team.HasAccess(exercice) {
log.Println("[!!!] The team asks to display choices whereas it doesn't have access to the exercice")
2019-01-17 15:55:54 +00:00
} else if err = team.DisplayChoices(flag); err != nil {
2018-12-02 22:18:32 +00:00
log.Println("[ERR]", err)
} else {
2019-01-17 15:55:54 +00:00
if err = genTeamMyFile(team); err != nil {
2018-12-02 22:18:32 +00:00
log.Println("my-", team.Id, ".json generation error: ", err)
}
2019-01-17 15:55:54 +00:00
if err = os.Remove(pathname); err != nil {
2018-12-02 22:18:32 +00:00
log.Println("[ERR]", err)
}
}
}