Too much things

This commit is contained in:
nemunaire 2016-01-25 03:09:22 +01:00
parent d35bdca3b1
commit f3a15b00e9
15 changed files with 640 additions and 17 deletions

View file

@ -40,18 +40,21 @@ func treatSubmission(pathname string, team_id string, exercice_id string) {
log.Println(id, "[WRN] Unable to change team name:", err)
}
genTeamMyFile(team)
if _, err := fic.NewEvent(fmt.Sprintf("Souhaitons bonne chance à l'équipe <strong>%s</strong> qui vient de nous rejoindre !", team.Name), "alert-info"); err != nil {
log.Println(id, "[WRN] Unable to create event:", err)
}
}
if err := os.Remove(pathname); err != nil {
log.Println(id, "[ERR]", err)
}
} else if eid, err := strconv.Atoi(exercice_id); err != nil {
log.Println(id, "[ERR]", err)
} else if exercice, err := fic.GetExercice(eid); err != nil {
} else if exercice, err := fic.GetExercice(int64(eid)); err != nil {
log.Println(id, "[ERR]", err)
} else if theme, err := exercice.GetTheme(); err != nil {
log.Println(id, "[ERR]", err)
} else {
if solved, err := exercice.CheckResponse(keys, team); err != nil {
if solved, firstTry, err := exercice.CheckResponse(keys, team); err != nil {
log.Println(id, "[ERR]", err)
} else if solved {
exercice.Solved(team)
@ -59,11 +62,27 @@ func treatSubmission(pathname string, team_id string, exercice_id string) {
if err := os.Remove(pathname); err != nil {
log.Println(id, "[ERR]", err)
}
// Write event
if lvl, err := exercice.GetLevel(); err != nil {
log.Println(id, "[ERR]", err)
} else if _, err := fic.NewEvent(fmt.Sprintf("L'équipe %s a résolu le <strong>%d<sup>e</sup></strong> challenge %s !", team.Name, lvl, theme.Name), "alert-success"); err != nil {
log.Println(id, "[WRN] Unable to create event:", err)
}
} else {
log.Printf("%s Team %d submit an invalid solution for exercice %d (%s : %s)\n", id, team.Id, exercice.Id, theme.Name, exercice.Title)
if err := os.Remove(pathname); err != nil {
log.Println(id, "[ERR]", err)
}
// Write event
if firstTry {
if lvl, err := exercice.GetLevel(); err != nil {
log.Println(id, "[ERR]", err)
} else if _, err := fic.NewEvent(fmt.Sprintf("L'équipe %s tente le <strong>%d<sup>e</sup></strong> challenge %s !", team.Name, lvl, theme.Name), "alert-warning"); err != nil {
log.Println(id, "[WRN] Unable to create event:", err)
}
}
}
genTeamMyFile(team)
}
@ -72,6 +91,11 @@ func treatSubmission(pathname string, team_id string, exercice_id string) {
func genTeamMyFile(team fic.Team) error {
dirPath := path.Join(TeamsDir, fmt.Sprintf("%d", team.Id))
started := true
if _, err := os.Stat(path.Join(TeamsDir, "started")); os.IsNotExist(err) {
started = false
}
if s, err := os.Stat(dirPath); os.IsNotExist(err) {
os.MkdirAll(dirPath, 0777)
} else if !s.IsDir() {
@ -86,5 +110,15 @@ func genTeamMyFile(team fic.Team) error {
return err
}
if !started {
if my, err := fic.MyJSONTeam(&team, false); err != nil {
return err
} else if j, err := json.Marshal(my); err != nil {
return err
} else if err := ioutil.WriteFile(path.Join(dirPath, "wait.json"), j, 0666); err != nil {
return err
}
}
return nil
}