Implemented team update method

This commit is contained in:
konrad 2018-07-14 18:29:24 +02:00 committed by kolaente
parent bcbd415529
commit 4cf0cd233c
No known key found for this signature in database
GPG key ID: F40E70337AB24C9B
9 changed files with 96 additions and 10 deletions

View file

@ -358,7 +358,7 @@ func (err ErrNeedToBeNamespaceAdmin) Error() string {
// Team errors // Team errors
// ============ // ============
// ErrTeamNameCannotBeEmpty represents an error, where a namespace owner is empty. // ErrTeamNameCannotBeEmpty represents an error where a team name is empty.
type ErrTeamNameCannotBeEmpty struct { type ErrTeamNameCannotBeEmpty struct {
TeamID int64 TeamID int64
} }
@ -372,3 +372,18 @@ func IsErrTeamNameCannotBeEmpty(err error) bool {
func (err ErrTeamNameCannotBeEmpty) Error() string { func (err ErrTeamNameCannotBeEmpty) Error() string {
return fmt.Sprintf("Team name cannot be empty [Team ID: %d]", err.TeamID) return fmt.Sprintf("Team name cannot be empty [Team ID: %d]", err.TeamID)
} }
// ErrTeamDoesNotExist represents an error where a team does not exist
type ErrTeamDoesNotExist struct {
TeamID int64
}
// IsErrTeamDoesNotExist checks if an error is ErrTeamDoesNotExist.
func IsErrTeamDoesNotExist(err error) bool {
_, ok := err.(ErrTeamDoesNotExist)
return ok
}
func (err ErrTeamDoesNotExist) Error() string {
return fmt.Sprintf("Team does not exist [Team ID: %d]", err.TeamID)
}

View file

@ -0,0 +1,8 @@
package models
// Create implements the create method to assign a user to a team
func (tm *TeamMember) Create(doer *User, id int64) (err error) {
tm.TeamID = id
_, err = x.Insert(tm)
return
}

View file

@ -7,7 +7,7 @@ type Team struct {
Description string `xorm:"varchar(250)" json:"description"` Description string `xorm:"varchar(250)" json:"description"`
CreatedByID int64 `xorm:"int(11) not null" json:"-"` CreatedByID int64 `xorm:"int(11) not null" json:"-"`
CreatedBy *User `xorm:"-" json:"created_by"` CreatedBy User `xorm:"-" json:"created_by"`
Members []*User `xorm:"-" json:"members"` Members []*User `xorm:"-" json:"members"`
Created int64 `xorm:"created" json:"created"` Created int64 `xorm:"created" json:"created"`
@ -25,17 +25,21 @@ func (Team) TableName() string {
// AfterLoad gets the created by user object // AfterLoad gets the created by user object
func (t *Team) AfterLoad() { func (t *Team) AfterLoad() {
// Get the owner // Get the owner
*t.CreatedBy, _, _ = GetUserByID(t.CreatedByID) t.CreatedBy, _, _ = GetUserByID(t.CreatedByID)
} }
// TeamMember defines the relationship between a user and a team // TeamMember defines the relationship between a user and a team
type TeamMember struct { type TeamMember struct {
ID int64 `xorm:"int(11) autoincr not null unique pk" json:"id"` ID int64 `xorm:"int(11) autoincr not null unique pk" json:"id"`
TeamID int64 `xorm:"int(11) not null" json:"team_id"` TeamID int64 `xorm:"int(11) not null" json:"team_id"`
UserID int64 `xorm:"int(11) not null" json:"user_id"` UserID int64 `xorm:"int(11) not null" json:"user_id"`
IsAdmin bool `xorm:"tinyint(1)" json:"is_admin"`
Created int64 `xorm:"created" json:"created"` Created int64 `xorm:"created" json:"created"`
Updated int64 `xorm:"updated" json:"updated"` Updated int64 `xorm:"updated" json:"updated"`
CRUDable `xorm:"-" json:"-"`
Rights `xorm:"-" json:"-"`
} }
// TableName makes beautiful table names // TableName makes beautiful table names
@ -84,3 +88,16 @@ func GetAllTeamsByNamespaceID(id int64) (teams []*Team, err error) {
return return
} }
// GetTeamByID gets a team by its ID
func GetTeamByID(id int64) (team Team, err error) {
exists, err := x.Where("id = ?", id).Get(&team)
if err != nil {
return
}
if !exists {
return team, ErrTeamDoesNotExist{id}
}
return
}

View file

@ -7,14 +7,16 @@ func (t *Team) Create(doer *User, _ int64) (err error) {
return ErrTeamNameCannotBeEmpty{} return ErrTeamNameCannotBeEmpty{}
} }
// Set the id to 0, otherwise the creation fails because of double keys
t.CreatedByID = doer.ID t.CreatedByID = doer.ID
t.CreatedBy = doer t.CreatedBy = *doer
_, err = x.Insert(t) _, err = x.Insert(t)
if err != nil { if err != nil {
return return
} }
// Insert the current user as member and admin
tm := TeamMember{TeamID: t.ID, UserID: doer.ID, IsAdmin: true}
err = tm.Create(doer, t.ID)
return return
} }

View file

@ -1,7 +1,19 @@
package models package models
// CanCreate checks if the user can create a new team // CanCreate checks if the user can create a new team
func (n *Team) CanCreate(user *User, id int64) bool { func (t *Team) CanCreate(user *User, id int64) bool {
// This is currently a dummy function, later on we could imagine global limits etc. // This is currently a dummy function, later on we could imagine global limits etc.
return true return true
} }
// CanUpdate checks if the user can update a team
func (t *Team) CanUpdate(user *User, id int64) bool {
// Check if the current user is in the team and has admin rights in it
exists, _ := x.Where("team_id = ?", id).
And("user_id = ?", user.ID).
And("is_admin = ?", true).
Get(&TeamMember{})
return exists
}

25
models/teams_update.go Normal file
View file

@ -0,0 +1,25 @@
package models
// Update is the handler to create a team
func (t *Team) Update(id int64) (err error) {
// Check if we have a name
if t.Name == "" {
return ErrTeamNameCannotBeEmpty{}
}
// Check if the team exists
_, err = GetTeamByID(id)
if err != nil {
return
}
_, err = x.ID(id).Update(t)
if err != nil {
return
}
// Get the newly updated team
*t, err = GetTeamByID(id)
return
}

View file

@ -58,6 +58,10 @@ func (c *WebHandler) CreateWeb(ctx echo.Context) error {
return echo.NewHTTPError(http.StatusNotFound, "The namespace name cannot be empty.") return echo.NewHTTPError(http.StatusNotFound, "The namespace name cannot be empty.")
} }
if models.IsErrTeamNameCannotBeEmpty(err) {
return echo.NewHTTPError(http.StatusBadRequest, "The team name cannot be empty.")
}
return echo.NewHTTPError(http.StatusInternalServerError) return echo.NewHTTPError(http.StatusInternalServerError)
} }

View file

@ -1,6 +1,7 @@
package crud package crud
import ( import (
"fmt"
"git.kolaente.de/konrad/list/models" "git.kolaente.de/konrad/list/models"
"github.com/labstack/echo" "github.com/labstack/echo"
"net/http" "net/http"
@ -50,6 +51,8 @@ func (c *WebHandler) UpdateWeb(ctx echo.Context) error {
return echo.NewHTTPError(http.StatusBadRequest, "The namespace owner cannot be empty.") return echo.NewHTTPError(http.StatusBadRequest, "The namespace owner cannot be empty.")
} }
fmt.Println(err)
return echo.NewHTTPError(http.StatusInternalServerError) return echo.NewHTTPError(http.StatusInternalServerError)
} }

View file

@ -120,5 +120,5 @@ func RegisterRoutes(e *echo.Echo) {
a.GET("/teams/:id", teamHandler.ReadOneWeb) a.GET("/teams/:id", teamHandler.ReadOneWeb)
a.PUT("/teams", teamHandler.CreateWeb) a.PUT("/teams", teamHandler.CreateWeb)
a.POST("/teams/:id", teamHandler.UpdateWeb) a.POST("/teams/:id", teamHandler.UpdateWeb)
a.POST("/teams/:id", teamHandler.DeleteWeb) a.DELETE("/teams/:id", teamHandler.DeleteWeb)
} }