server/frontend/main.go

83 lines
2.8 KiB
Go
Raw Normal View History

2016-01-06 18:30:57 +00:00
package main
import (
2016-01-23 11:26:20 +00:00
"bufio"
2016-01-06 18:30:57 +00:00
"flag"
"fmt"
"log"
"net/http"
"os"
2016-01-23 11:26:20 +00:00
"path"
"time"
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-01-23 11:26:20 +00:00
func touchStartedFile(startSub time.Duration) {
time.Sleep(startSub)
if fd, err := os.Create(path.Join(TeamsDir, startedFile)); err == nil {
log.Println("Started! Go, Go, Go!!")
fd.Close()
} else {
log.Fatal("Unable to start challenge:", err)
2016-01-23 11:26:20 +00:00
}
}
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-01-23 12:19:28 +00:00
var start = flag.Int64("start", 0, fmt.Sprintf("Challenge start timestamp (in 2 minutes: %d)", time.Now().Unix()/60*60+120))
var duration = flag.Duration("duration", 180*time.Minute, "Challenge duration")
var denyChName = flag.Bool("denyChName", false, "Deny team to change their name")
2016-04-28 14:53:52 +00:00
var allowRegistration = flag.Bool("allowRegistration", false, "New team can add itself")
2016-11-19 15:43:57 +00:00
var resolutionRoute = flag.Bool("resolutionRoute", false, "Enable resolution route")
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-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-01-23 11:26:20 +00:00
startTime := time.Unix(*start, 0)
startSub := startTime.Sub(time.Now())
end := startTime.Add(*duration).Add(time.Duration(1 * time.Second))
log.Println("Challenge ends on", end)
if startSub > 0 {
log.Println("Challenge starts at", startTime, "in", startSub)
fmt.Printf("PRESS ENTER TO LAUNCH THE COUNTDOWN ")
bufio.NewReader(os.Stdin).ReadLine()
if _, err := os.Stat(path.Join(TeamsDir, startedFile)); !os.IsNotExist(err) {
os.Remove(path.Join(TeamsDir, startedFile))
}
go touchStartedFile(startTime.Sub(time.Now().Add(time.Duration(1 * time.Second))))
} else {
log.Println("Challenge started at", startTime, "since", -startSub)
go touchStartedFile(time.Duration(0))
}
2016-01-06 18:30:57 +00:00
log.Println("Registering handlers...")
2016-01-23 11:26:20 +00:00
http.Handle(fmt.Sprintf("%s/time.json", *prefix), http.StripPrefix(*prefix, TimeHandler{startTime, *duration}))
2016-11-19 15:43:57 +00:00
if *resolutionRoute {
http.Handle(fmt.Sprintf("%s/resolution/", *prefix), http.StripPrefix(fmt.Sprintf("%s/resolution/", *prefix), ResolutionHandler{}))
}
2016-04-28 14:53:52 +00:00
http.Handle(fmt.Sprintf("%s/", *prefix), http.StripPrefix(*prefix, SubmissionHandler{end, *denyChName, *allowRegistration}))
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)
}
}