Allow team to be added by name, without member first

This commit is contained in:
nemunaire 2016-01-13 11:31:59 +01:00
parent 181953a9f0
commit 5bc3395b04

View file

@ -6,11 +6,23 @@ import (
) )
var ApiTeamsRouting = map[string]DispatchFunction{ var ApiTeamsRouting = map[string]DispatchFunction{
"GET": listTeam, "GET": listTeam,
"POST": creationTeam, "PUT": creationTeamMembers,
"POST": creationTeam,
"DELETE": deletionTeam, "DELETE": deletionTeam,
} }
type uploadedTeam struct {
Name string
}
type uploadedMember struct {
Firstname string
Lastname string
Nickname string
Company string
}
func listTeam(args []string, body []byte) (interface{}, error) { func listTeam(args []string, body []byte) (interface{}, error) {
if len(args) == 1 { if len(args) == 1 {
// List given team // List given team
@ -31,15 +43,38 @@ func listTeam(args []string, body []byte) (interface{}, error) {
func creationTeam(args []string, body []byte) (interface{}, error) { func creationTeam(args []string, body []byte) (interface{}, error) {
if len(args) == 0 { if len(args) == 0 {
type UploadedMember struct { // Create a new team
Firstname string var ut uploadedTeam
Lastname string if err := json.Unmarshal(body, &ut); err != nil {
Nickname string return nil, err
Company string
} }
return CreateTeam(ut.Name)
} else {
return nil, nil
}
}
func creationTeamMembers(args []string, body []byte) (interface{}, error) {
if len(args) == 1 {
// List given team
if tid, err := strconv.Atoi(string(args[0])); err != nil {
return nil, err
} else if team, err := GetTeam(tid); err != nil {
return nil, err
} else {
var member uploadedMember
if err := json.Unmarshal(body, &member); err != nil {
return nil, err
}
team.AddMember(member.Firstname, member.Lastname, member.Nickname, member.Company)
return team.GetMembers()
}
} else if len(args) == 0 {
// Create a new team // Create a new team
var members []UploadedMember var members []uploadedMember
if err := json.Unmarshal(body, &members); err != nil { if err := json.Unmarshal(body, &members); err != nil {
return nil, err return nil, err
} }
@ -53,10 +88,10 @@ func creationTeam(args []string, body []byte) (interface{}, error) {
} }
} }
return "Ok", nil return team, nil
} }
} else { } else {
return nil,nil return nil, nil
} }
} }