admin: New route to reset settings to sane default values

This commit is contained in:
nemunaire 2020-11-13 11:25:29 +01:00
parent a8f25471f1
commit 1436d9ca81
4 changed files with 35 additions and 30 deletions

View File

@ -16,6 +16,9 @@ func init() {
router.GET("/api/settings-ro.json", apiHandler(getROSettings)) router.GET("/api/settings-ro.json", apiHandler(getROSettings))
router.GET("/api/settings.json", apiHandler(getSettings)) router.GET("/api/settings.json", apiHandler(getSettings))
router.PUT("/api/settings.json", apiHandler(saveSettings)) router.PUT("/api/settings.json", apiHandler(saveSettings))
router.DELETE("/api/settings.json", apiHandler(func(_ httprouter.Params, _ []byte) (interface{}, error) {
return true, ResetSettings()
}))
router.POST("/api/reset", apiHandler(reset)) router.POST("/api/reset", apiHandler(reset))
} }
@ -61,6 +64,29 @@ func ApplySettings(config settings.FICSettings) {
fic.SubmissionUniqueness = config.SubmissionUniqueness fic.SubmissionUniqueness = config.SubmissionUniqueness
} }
func ResetSettings() error {
return settings.SaveSettings(path.Join(settings.SettingsDir, settings.SettingsFile), settings.FICSettings{
Title: "Challenge FIC",
Authors: "Laboratoire SRS, ÉPITA",
FirstBlood: fic.FirstBlood,
SubmissionCostBase: fic.SubmissionCostBase,
ExerciceCurCoefficient: 1,
HintCurCoefficient: 1,
WChoiceCurCoefficient: 1,
AllowRegistration: false,
CanJoinTeam: false,
DenyTeamCreation: false,
DenyNameChange: false,
AcceptNewIssue: true,
EnableResolutionRoute: false,
PartialValidation: true,
UnlockedChallengeDepth: 0,
SubmissionUniqueness: false,
DisplayAllFlags: false,
EventKindness: false,
})
}
func reset(_ httprouter.Params, body []byte) (interface{}, error) { func reset(_ httprouter.Params, body []byte) (interface{}, error) {
var m map[string]string var m map[string]string
if err := json.Unmarshal(body, &m); err != nil { if err := json.Unmarshal(body, &m); err != nil {
@ -75,6 +101,8 @@ func reset(_ httprouter.Params, body []byte) (interface{}, error) {
return true, fic.ResetExercices() return true, fic.ResetExercices()
} else if t == "game" { } else if t == "game" {
return true, fic.ResetGame() return true, fic.ResetGame()
} else if t == "settings" {
return true, ResetSettings()
} else { } else {
return nil, errors.New("Unknown reset type") return nil, errors.New("Unknown reset type")
} }

View File

@ -168,26 +168,7 @@ func main() {
// Initialize settings and load them // Initialize settings and load them
if !settings.ExistsSettings(path.Join(settings.SettingsDir, settings.SettingsFile)) { if !settings.ExistsSettings(path.Join(settings.SettingsDir, settings.SettingsFile)) {
if err = settings.SaveSettings(path.Join(settings.SettingsDir, settings.SettingsFile), settings.FICSettings{ if err = api.ResetSettings(); err != nil {
Title: "Challenge FIC",
Authors: "Laboratoire SRS, ÉPITA",
FirstBlood: fic.FirstBlood,
SubmissionCostBase: fic.SubmissionCostBase,
ExerciceCurCoefficient: 1,
HintCurCoefficient: 1,
WChoiceCurCoefficient: 1,
AllowRegistration: false,
CanJoinTeam: false,
DenyTeamCreation: false,
DenyNameChange: false,
AcceptNewIssue: true,
EnableResolutionRoute: false,
PartialValidation: true,
UnlockedChallengeDepth: 0,
SubmissionUniqueness: false,
DisplayAllFlags: false,
EventKindness: false,
}); err != nil {
log.Fatal("Unable to initialize settings.json:", err) log.Fatal("Unable to initialize settings.json:", err)
} }
} else { } else {

View File

@ -578,6 +578,7 @@ angular.module("FICApp")
} }
$scope.reset = function(type) { $scope.reset = function(type) {
var txts = { var txts = {
"settings": "En validant, vous remettrez les paramètres de cette page à leur valeur initiale, y compris la date de début du challenge.",
"challenges": "En validant, vous retirerez toutes les données statiques des challenges.", "challenges": "En validant, vous retirerez toutes les données statiques des challenges.",
"teams": "En validant, vous supprimerez l'ensemble des équipes enregistreées.", "teams": "En validant, vous supprimerez l'ensemble des équipes enregistreées.",
"game": "En validant, vous supprimerez toutes les tentatives, les validations, ... faites par les équipes.", "game": "En validant, vous supprimerez toutes les tentatives, les validations, ... faites par les équipes.",

View File

@ -242,15 +242,10 @@
</div> </div>
<div class="col-4"> <div class="col-4 d-flex flex-column">
<div class="card mt-3"> <button ng-click="reset('settings');" class="btn btn-secondary mt-2 mb-1" type="button"><span class="glyphicon glyphicon-trash" aria-hidden="true"></span> Revenir aux paramètres par défaut</button>
<button ng-click="reset('challenges')" class="btn btn-secondary" type="button"><span class="glyphicon glyphicon-trash" aria-hidden="true"></span> Effacer les challenges et les thèmes</button> <button ng-click="reset('challenges')" class="btn btn-secondary mt-2 mb-1" type="button"><span class="glyphicon glyphicon-trash" aria-hidden="true"></span> Effacer les challenges et les thèmes</button>
</div> <button ng-click="reset('teams');" class="btn btn-secondary mt-1 mb-1" type="button"><span class="glyphicon glyphicon-trash" aria-hidden="true"></span> Effacer les équipes</button>
<div class="card mt-3"> <button ng-click="reset('game');" class="btn btn-secondary mt-1 mb-2" type="button"><span class="glyphicon glyphicon-trash" aria-hidden="true"></span> Effacer la partie (tentatives, indices, ...)</button>
<button ng-click="reset('teams');" class="btn btn-secondary" type="button"><span class="glyphicon glyphicon-trash" aria-hidden="true"></span> Effacer les équipes</button>
</div>
<div class="card mt-3">
<button ng-click="reset('game');" class="btn btn-secondary" type="button"><span class="glyphicon glyphicon-trash" aria-hidden="true"></span> Effacer la partie (tentatives, indices, ...)</button>
</div>
</div> </div>
</div> </div>