admin: add button to disable inactive teams
This commit is contained in:
parent
48fcfec0d0
commit
088c2402cd
4 changed files with 61 additions and 1 deletions
|
@ -6,6 +6,7 @@ import (
|
|||
"strings"
|
||||
"time"
|
||||
|
||||
"srs.epita.fr/fic-server/admin/pki"
|
||||
"srs.epita.fr/fic-server/libfic"
|
||||
|
||||
"github.com/julienschmidt/httprouter"
|
||||
|
@ -24,6 +25,8 @@ func init() {
|
|||
func(httprouter.Params, []byte) (interface{}, error) {
|
||||
return nginxGenTeams()
|
||||
}))
|
||||
router.POST("/api/disableinactiveteams", apiHandler(disableInactiveTeams))
|
||||
router.POST("/api/enableallteams", apiHandler(enableAllTeams))
|
||||
router.GET("/api/teams-members-nginx", apiHandler(
|
||||
func(httprouter.Params, []byte) (interface{}, error) {
|
||||
return nginxGenMember()
|
||||
|
@ -166,6 +169,47 @@ func updateTeam(team fic.Team, body []byte) (interface{}, error) {
|
|||
return ut, nil
|
||||
}
|
||||
|
||||
func disableInactiveTeams(_ httprouter.Params, _ []byte) (interface{}, error) {
|
||||
if teams, err := fic.GetTeams(); err != nil {
|
||||
return nil, err
|
||||
} else {
|
||||
for _, team := range teams {
|
||||
var serials []uint64
|
||||
serials, err = pki.GetTeamSerials(TeamsDir, team.Id)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if len(serials) == 0 {
|
||||
if team.Active {
|
||||
team.Active = false
|
||||
team.Update()
|
||||
}
|
||||
} else if !team.Active {
|
||||
team.Active = true
|
||||
team.Update()
|
||||
}
|
||||
}
|
||||
|
||||
return true, nil
|
||||
}
|
||||
}
|
||||
|
||||
func enableAllTeams(_ httprouter.Params, _ []byte) (interface{}, error) {
|
||||
if teams, err := fic.GetTeams(); err != nil {
|
||||
return nil, err
|
||||
} else {
|
||||
for _, team := range teams {
|
||||
if !team.Active {
|
||||
team.Active = true
|
||||
team.Update()
|
||||
}
|
||||
}
|
||||
|
||||
return true, nil
|
||||
}
|
||||
}
|
||||
|
||||
func addTeamMember(team fic.Team, body []byte) (interface{}, error) {
|
||||
var members []fic.Member
|
||||
if err := json.Unmarshal(body, &members); err != nil {
|
||||
|
|
Reference in a new issue