server/frontend/settings.go

90 lines
2.8 KiB
Go
Raw Normal View History

2017-11-22 00:52:08 +00:00
package main
import (
"io/ioutil"
2017-11-22 00:52:08 +00:00
"log"
"os"
"path"
2017-11-22 00:52:08 +00:00
"time"
"srs.epita.fr/fic-server/settings"
)
var startedFile = "started"
2017-11-22 00:52:08 +00:00
var SettingsDistDir = "./SETTINGSDIST/"
2017-11-22 00:52:08 +00:00
var touchTimer *time.Timer = nil
var challengeStart time.Time
var challengeEnd time.Time
2017-11-22 00:52:08 +00:00
func touchStartedFile() {
if fd, err := os.Create(startedFile); err == nil {
2017-11-22 00:52:08 +00:00
log.Println("Started! Go, Go, Go!!")
fd.Close()
} else {
log.Fatal("Unable to start challenge:", err)
}
}
func reloadSettings(config *settings.Settings) {
// Copy the new settings file for distribution
if data, err := ioutil.ReadFile(path.Join(settings.SettingsDir, settings.SettingsFile)); err != nil {
log.Println("Unable to read settings file:", err)
2021-11-22 14:35:07 +00:00
} else if err = ioutil.WriteFile(path.Join(SettingsDistDir, settings.SettingsFile+".tmp"), data, 0644); err != nil {
log.Println("Unable to write tmp settings file:", err)
2021-11-22 14:35:07 +00:00
} else if err := os.Rename(path.Join(SettingsDistDir, settings.SettingsFile+".tmp"), path.Join(SettingsDistDir, settings.SettingsFile)); err != nil {
log.Println("Unable to move new settings file:", err)
}
2022-05-01 20:33:59 +00:00
// Copy the challenge info file for distribution
if data, err := ioutil.ReadFile(path.Join(settings.SettingsDir, settings.ChallengeFile)); err != nil {
log.Println("Unable to read challenge info file:", err)
} else if err = ioutil.WriteFile(path.Join(SettingsDistDir, settings.ChallengeFile+".tmp"), data, 0644); err != nil {
log.Println("Unable to write tmp challenge info file:", err)
} else if err := os.Rename(path.Join(SettingsDistDir, settings.ChallengeFile+".tmp"), path.Join(SettingsDistDir, settings.ChallengeFile)); err != nil {
log.Println("Unable to move new challenge info file:", err)
}
if challengeStart != config.Start || challengeEnd != config.End {
2017-11-22 00:52:08 +00:00
if touchTimer != nil {
touchTimer.Stop()
}
if config.Start.Unix() == 0 {
log.Println("WARNING: No challenge start defined!")
if _, err := os.Stat(startedFile); !os.IsNotExist(err) {
os.Remove(startedFile)
}
return
}
2021-11-22 14:35:07 +00:00
startSub := time.Until(config.Start)
2017-11-22 00:52:08 +00:00
if startSub > 0 {
log.Println("Challenge will starts at", config.Start, "in", startSub)
if _, err := os.Stat(startedFile); !os.IsNotExist(err) {
os.Remove(startedFile)
2017-11-22 00:52:08 +00:00
}
2021-11-22 14:35:07 +00:00
touchTimer = time.AfterFunc(config.Start.Sub(time.Now().Add(time.Duration(1*time.Second))), touchStartedFile)
2017-11-22 00:52:08 +00:00
} else {
log.Println("Challenge started at", config.Start, "since", -startSub)
touchStartedFile()
}
log.Println("Challenge ends on", config.End)
challengeStart = config.Start
challengeEnd = config.End
2017-11-22 00:52:08 +00:00
} else {
log.Println("Configuration reloaded, but start/end times doesn't change.")
}
enableResolutionRoute = config.EnableResolutionRoute
denyNameChange = config.DenyNameChange
acceptNewIssues = config.AcceptNewIssue
2017-11-22 00:52:08 +00:00
allowRegistration = config.AllowRegistration
}