Implemented team update method
This commit is contained in:
parent
bcbd415529
commit
4cf0cd233c
9 changed files with 96 additions and 10 deletions
|
@ -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)
|
||||||
|
}
|
||||||
|
|
8
models/team_members_create.go
Normal file
8
models/team_members_create.go
Normal 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
|
||||||
|
}
|
|
@ -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
|
||||||
|
}
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
25
models/teams_update.go
Normal 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
|
||||||
|
}
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue