2016-01-06 18:30:57 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
2016-01-23 11:26:20 +00:00
|
|
|
"path"
|
|
|
|
"time"
|
2016-12-30 11:45:14 +00:00
|
|
|
|
|
|
|
"srs.epita.fr/fic-server/settings"
|
2016-01-06 18:30:57 +00:00
|
|
|
)
|
|
|
|
|
2016-01-23 11:26:20 +00:00
|
|
|
const startedFile = "started"
|
|
|
|
|
|
|
|
var TeamsDir string
|
2016-01-06 18:30:57 +00:00
|
|
|
var SubmissionDir string
|
|
|
|
|
2016-12-30 11:45:14 +00:00
|
|
|
var touchTimer *time.Timer = nil
|
|
|
|
|
|
|
|
func touchStartedFile() {
|
2016-01-23 11:26:20 +00:00
|
|
|
if fd, err := os.Create(path.Join(TeamsDir, startedFile)); err == nil {
|
|
|
|
log.Println("Started! Go, Go, Go!!")
|
|
|
|
fd.Close()
|
|
|
|
} else {
|
2016-11-19 15:44:26 +00:00
|
|
|
log.Fatal("Unable to start challenge:", err)
|
2016-01-23 11:26:20 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-30 11:45:14 +00:00
|
|
|
func reloadSettings(config settings.FICSettings) {
|
|
|
|
if challengeStart != config.Start || challengeEnd != config.End {
|
|
|
|
if touchTimer != nil {
|
|
|
|
touchTimer.Stop()
|
|
|
|
}
|
|
|
|
startSub := config.Start.Sub(time.Now())
|
|
|
|
if startSub > 0 {
|
|
|
|
log.Println("Challenge will starts at", config.Start, "in", startSub)
|
|
|
|
|
|
|
|
if _, err := os.Stat(path.Join(TeamsDir, startedFile)); !os.IsNotExist(err) {
|
|
|
|
os.Remove(path.Join(TeamsDir, startedFile))
|
|
|
|
}
|
|
|
|
|
|
|
|
touchTimer = time.AfterFunc(config.Start.Sub(time.Now().Add(time.Duration(1 * time.Second))), touchStartedFile)
|
|
|
|
} else {
|
|
|
|
log.Println("Challenge started at", config.Start, "since", -startSub)
|
|
|
|
touchStartedFile()
|
|
|
|
}
|
|
|
|
log.Println("Challenge ends on", config.End)
|
|
|
|
|
|
|
|
challengeStart = config.Start
|
|
|
|
challengeEnd = config.End
|
|
|
|
} else {
|
|
|
|
log.Println("Configuration reloaded, but start/end times doesn't change.")
|
|
|
|
}
|
|
|
|
|
|
|
|
enableResolutionRoute = config.EnableResolutionRoute
|
|
|
|
denyNameChange = config.DenyNameChange
|
|
|
|
allowRegistration = config.AllowRegistration
|
|
|
|
}
|
|
|
|
|
2016-01-06 18:30:57 +00:00
|
|
|
func main() {
|
2016-11-19 15:17:53 +00:00
|
|
|
var bind = flag.String("bind", "127.0.0.1:8080", "Bind port/socket")
|
2016-01-06 18:30:57 +00:00
|
|
|
var prefix = flag.String("prefix", "", "Request path prefix to strip (from proxy)")
|
2016-11-19 15:44:26 +00:00
|
|
|
flag.StringVar(&TeamsDir, "teams", "./TEAMS", "Base directory where save teams JSON files")
|
2016-01-06 18:30:57 +00:00
|
|
|
flag.StringVar(&SubmissionDir, "submission", "./submissions/", "Base directory where save submissions")
|
|
|
|
flag.Parse()
|
|
|
|
|
2016-10-13 17:02:41 +00:00
|
|
|
log.SetPrefix("[frontend] ")
|
|
|
|
|
2016-12-30 11:45:14 +00:00
|
|
|
SubmissionDir = path.Clean(SubmissionDir)
|
|
|
|
|
2016-01-06 18:30:57 +00:00
|
|
|
log.Println("Creating submission directory...")
|
|
|
|
if _, err := os.Stat(SubmissionDir); os.IsNotExist(err) {
|
|
|
|
if err := os.MkdirAll(SubmissionDir, 0777); err != nil {
|
|
|
|
log.Fatal("Unable to create submission directory: ", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-30 11:45:14 +00:00
|
|
|
// Load configuration
|
|
|
|
settings.LoadAndWatchSettings(path.Join(TeamsDir, settings.SettingsFile), reloadSettings)
|
2016-01-23 11:26:20 +00:00
|
|
|
|
2016-12-30 11:45:14 +00:00
|
|
|
// Register handlers
|
|
|
|
http.Handle(fmt.Sprintf("%s/chname/", *prefix), http.StripPrefix(fmt.Sprintf("%s/chname/", *prefix), ChNameHandler{}))
|
2016-12-09 10:55:44 +00:00
|
|
|
http.Handle(fmt.Sprintf("%s/openhint/", *prefix), http.StripPrefix(fmt.Sprintf("%s/openhint/", *prefix), HintHandler{}))
|
2016-12-30 11:45:14 +00:00
|
|
|
http.Handle(fmt.Sprintf("%s/registration", *prefix), http.StripPrefix(fmt.Sprintf("%s/registration", *prefix), RegistrationHandler{}))
|
|
|
|
http.Handle(fmt.Sprintf("%s/resolution/", *prefix), http.StripPrefix(fmt.Sprintf("%s/resolution/", *prefix), ResolutionHandler{}))
|
|
|
|
http.Handle(fmt.Sprintf("%s/submission/", *prefix), http.StripPrefix(fmt.Sprintf("%s/submission/", *prefix), SubmissionHandler{}))
|
|
|
|
http.Handle(fmt.Sprintf("%s/time.json", *prefix), http.StripPrefix(*prefix, TimeHandler{}))
|
2016-01-06 18:30:57 +00:00
|
|
|
|
2016-12-30 11:45:14 +00:00
|
|
|
// Serve pages
|
2016-01-06 18:30:57 +00:00
|
|
|
log.Println(fmt.Sprintf("Ready, listening on %s", *bind))
|
|
|
|
if err := http.ListenAndServe(*bind, nil); err != nil {
|
|
|
|
log.Fatal("Unable to listen and serve: ", err)
|
|
|
|
}
|
|
|
|
}
|