implemented creation of thing via parambinder

This commit is contained in:
konrad 2018-07-18 08:56:19 +02:00 committed by kolaente
parent ebb5b332b6
commit de95ff40bf
No known key found for this signature in database
GPG key ID: F40E70337AB24C9B
21 changed files with 39 additions and 40 deletions

View file

@ -2,7 +2,7 @@ package models
// CRUDable defines the crud methods // CRUDable defines the crud methods
type CRUDable interface { type CRUDable interface {
Create(*User, int64) error Create(*User) error
ReadOne(int64) error ReadOne(int64) error
ReadAll(*User) (interface{}, error) ReadAll(*User) (interface{}, error)
Update(int64) error Update(int64) error

View file

@ -6,7 +6,7 @@ type List struct {
Title string `xorm:"varchar(250)" json:"title"` Title string `xorm:"varchar(250)" json:"title"`
Description string `xorm:"varchar(1000)" json:"description"` Description string `xorm:"varchar(1000)" json:"description"`
OwnerID int64 `xorm:"int(11)" json:"-"` OwnerID int64 `xorm:"int(11)" json:"-"`
NamespaceID int64 `xorm:"int(11)" json:"-"` NamespaceID int64 `xorm:"int(11)" json:"-" param:"nid"`
Owner User `xorm:"-" json:"owner"` Owner User `xorm:"-" json:"owner"`
Items []*ListItem `xorm:"-" json:"items"` Items []*ListItem `xorm:"-" json:"items"`

View file

@ -33,7 +33,7 @@ func (l *List) Update(id int64) (err error) {
} }
// Create implements the create method of CRUDable // Create implements the create method of CRUDable
func (l *List) Create(doer *User, id int64) (err error) { func (l *List) Create(doer *User) (err error) {
// Check rights // Check rights
user, _, err := GetUserByID(doer.ID) user, _, err := GetUserByID(doer.ID)
if err != nil { if err != nil {

View file

@ -9,7 +9,7 @@ type ListItem struct {
DueDateUnix int64 `xorm:"int(11)" json:"dueDate"` DueDateUnix int64 `xorm:"int(11)" json:"dueDate"`
ReminderUnix int64 `xorm:"int(11)" json:"reminderDate"` ReminderUnix int64 `xorm:"int(11)" json:"reminderDate"`
CreatedByID int64 `xorm:"int(11)" json:"-"` // ID of the user who put that item on the list CreatedByID int64 `xorm:"int(11)" json:"-"` // ID of the user who put that item on the list
ListID int64 `xorm:"int(11)" json:"listID"` ListID int64 `xorm:"int(11)" json:"listID" param:"listid"`
Created int64 `xorm:"created" json:"created"` Created int64 `xorm:"created" json:"created"`
Updated int64 `xorm:"updated" json:"updated"` Updated int64 `xorm:"updated" json:"updated"`

View file

@ -1,8 +1,8 @@
package models package models
// Create is the implementation to create a list item // Create is the implementation to create a list item
func (i *ListItem) Create(doer *User, lID int64) (err error) { func (i *ListItem) Create(doer *User) (err error) {
i.ListID = lID //i.ListID = lID
i.ID = 0 i.ID = 0
return createOrUpdateListItem(i, doer) return createOrUpdateListItem(i, doer)

View file

@ -21,8 +21,8 @@ func (i *ListItem) CanUpdate(doer *User, id int64) bool {
} }
// CanCreate determines if a user has the right to create a list item // CanCreate determines if a user has the right to create a list item
func (i *ListItem) CanCreate(doer *User, lID int64) bool { func (i *ListItem) CanCreate(doer *User) bool {
// A user can create an item if he has write acces to its list // A user can create an item if he has write acces to its list
list, _ := GetListByID(lID) list, _ := GetListByID(i.ListID)
return list.CanWrite(doer) return list.CanWrite(doer)
} }

View file

@ -93,8 +93,8 @@ func (l *List) CanUpdate(doer *User, id int64) bool {
} }
// CanCreate checks if the user can update a list // CanCreate checks if the user can update a list
func (l *List) CanCreate(doer *User, nID int64) bool { func (l *List) CanCreate(doer *User) bool {
// A user can create a list if he has write access to the namespace // A user can create a list if he has write access to the namespace
n, _ := GetNamespaceByID(nID) n, _ := GetNamespaceByID(l.NamespaceID)
return n.CanWrite(doer) return n.CanWrite(doer)
} }

View file

@ -1,7 +1,7 @@
package models package models
// Create implements the creation method via the interface // Create implements the creation method via the interface
func (n *Namespace) Create(doer *User, _ int64) (err error) { func (n *Namespace) Create(doer *User) (err error) {
// Check if we have at least a name // Check if we have at least a name
if n.Name == "" { if n.Name == "" {
return ErrNamespaceNameCannotBeEmpty{NamespaceID: 0, UserID: doer.ID} return ErrNamespaceNameCannotBeEmpty{NamespaceID: 0, UserID: doer.ID}

View file

@ -83,7 +83,7 @@ func (n *Namespace) CanDelete(user *User) bool {
} }
// CanCreate checks if the user can create a new namespace // CanCreate checks if the user can create a new namespace
func (n *Namespace) CanCreate(user *User, id int64) bool { func (n *Namespace) CanCreate(user *User) 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
} }

View file

@ -7,5 +7,5 @@ type Rights interface {
CanRead(*User) bool CanRead(*User) bool
CanDelete(*User) bool CanDelete(*User) bool
CanUpdate(*User, int64) bool CanUpdate(*User, int64) bool
CanCreate(*User, int64) bool CanCreate(*User) bool
} }

View file

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

View file

@ -4,7 +4,7 @@ package models
type TeamNamespace struct { type TeamNamespace 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" param:"teamid"` TeamID int64 `xorm:"int(11) not null" json:"team_id" param:"teamid"`
NamespaceID int64 `xorm:"int(11) not null" json:"namespace_id" param:"nid"` NamespaceID int64 `xorm:"int(11) not null" json:"namespace_id" param:"namespaceid"`
Right NamespaceRight `xorm:"int(11)" json:"right"` Right NamespaceRight `xorm:"int(11)" json:"right"`
Created int64 `xorm:"created" json:"created"` Created int64 `xorm:"created" json:"created"`

View file

@ -1,13 +1,17 @@
package models package models
import "fmt"
// Create creates a new team <-> namespace relation // Create creates a new team <-> namespace relation
func (tn *TeamNamespace) Create(doer *User, nID int64) (err error) { func (tn *TeamNamespace) Create(doer *User) (err error) {
// Check if the rights are valid // Check if the rights are valid
if tn.Right != NamespaceRightAdmin && tn.Right != NamespaceRightRead && tn.Right != NamespaceRightWrite { if tn.Right != NamespaceRightAdmin && tn.Right != NamespaceRightRead && tn.Right != NamespaceRightWrite {
return ErrInvalidTeamRight{tn.Right} return ErrInvalidTeamRight{tn.Right}
} }
fmt.Println(tn.NamespaceID)
// Check if the team exists // Check if the team exists
_, err = GetTeamByID(tn.TeamID) _, err = GetTeamByID(tn.TeamID)
if err != nil { if err != nil {
@ -15,11 +19,10 @@ func (tn *TeamNamespace) Create(doer *User, nID int64) (err error) {
} }
// Check if the namespace exists // Check if the namespace exists
_, err = GetNamespaceByID(nID) _, err = GetNamespaceByID(tn.NamespaceID)
if err != nil { if err != nil {
return return
} }
tn.NamespaceID = nID
// Insert the new team // Insert the new team
_, err = x.Insert(tn) _, err = x.Insert(tn)

View file

@ -18,7 +18,7 @@ func (tn *TeamNamespace) Delete() (err error) {
// Delete the relation // Delete the relation
_, err = x.Where("team_id = ?", tn.TeamID). _, err = x.Where("team_id = ?", tn.TeamID).
And("namespace_id = ?", tn.NamespaceID). And("namespace_id = ?", tn.NamespaceID).
Delete(tn) Delete(TeamNamespace{})
return return
} }

View file

@ -1,7 +1,7 @@
package models package models
// CanCreate checks if one can create a new team <-> namespace relation // CanCreate checks if one can create a new team <-> namespace relation
func (tn *TeamNamespace) CanCreate(user *User, _ int64) bool { func (tn *TeamNamespace) CanCreate(user *User) bool {
n, _ := GetNamespaceByID(tn.NamespaceID) n, _ := GetNamespaceByID(tn.NamespaceID)
return n.IsAdmin(user) return n.IsAdmin(user)
} }

View file

@ -1,7 +1,7 @@
package models package models
// Create is the handler to create a team // Create is the handler to create a team
func (t *Team) Create(doer *User, _ int64) (err error) { func (t *Team) Create(doer *User) (err error) {
// Check if we have a name // Check if we have a name
if t.Name == "" { if t.Name == "" {
return ErrTeamNameCannotBeEmpty{} return ErrTeamNameCannotBeEmpty{}
@ -17,6 +17,6 @@ func (t *Team) Create(doer *User, _ int64) (err error) {
// Insert the current user as member and admin // Insert the current user as member and admin
tm := TeamMember{TeamID: t.ID, UserID: doer.ID, IsAdmin: true} tm := TeamMember{TeamID: t.ID, UserID: doer.ID, IsAdmin: true}
err = tm.Create(doer, t.ID) err = tm.Create(doer)
return return
} }

View file

@ -1,7 +1,7 @@
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 (t *Team) CanCreate(user *User, id int64) bool { func (t *Team) CanCreate(user *User) 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
} }

View file

@ -52,7 +52,7 @@ func CreateUser(user User) (newUser User, err error) {
// Create the user's namespace // Create the user's namespace
newN := &Namespace{Name: newUserOut.Username, Description: newUserOut.Username + "'s namespace.", Owner: newUserOut} newN := &Namespace{Name: newUserOut.Username, Description: newUserOut.Username + "'s namespace.", Owner: newUserOut}
err = newN.Create(&newUserOut, 0) err = newN.Create(&newUserOut)
if err != nil { if err != nil {
return User{}, err return User{}, err
} }

View file

@ -14,8 +14,9 @@ func (c *WebHandler) CreateWeb(ctx echo.Context) error {
p := reflect.ValueOf(c.CObject).Elem() p := reflect.ValueOf(c.CObject).Elem()
p.Set(reflect.Zero(p.Type())) p.Set(reflect.Zero(p.Type()))
// Get the object // Get the object & bind params to struct
if err := ctx.Bind(&c.CObject); err != nil { if err := ParamBinder(c.CObject, ctx); err != nil {
fmt.Println(err)
return echo.NewHTTPError(http.StatusBadRequest, "No or invalid model provided.") return echo.NewHTTPError(http.StatusBadRequest, "No or invalid model provided.")
} }
@ -26,21 +27,21 @@ func (c *WebHandler) CreateWeb(ctx echo.Context) error {
} }
// Get an ID if we have one // Get an ID if we have one
var id int64 /*var id int64
if ctx.Param("id") != "" { if ctx.Param("id") != "" {
id, err = models.GetIntURLParam("id", ctx) id, err = models.GetIntURLParam("id", ctx)
if err != nil { if err != nil {
return echo.NewHTTPError(http.StatusBadRequest, "Bad id.") return echo.NewHTTPError(http.StatusBadRequest, "Bad id.")
} }
} }*/
// Check rights // Check rights
if !c.CObject.CanCreate(&currentUser, id) { if !c.CObject.CanCreate(&currentUser) {
return echo.NewHTTPError(http.StatusForbidden) return echo.NewHTTPError(http.StatusForbidden)
} }
// Create // Create
err = c.CObject.Create(&currentUser, id) err = c.CObject.Create(&currentUser)
if err != nil { if err != nil {
if models.IsErrListDoesNotExist(err) { if models.IsErrListDoesNotExist(err) {
return echo.NewHTTPError(http.StatusBadRequest, "The list does not exist.") return echo.NewHTTPError(http.StatusBadRequest, "The list does not exist.")

View file

@ -9,11 +9,6 @@ import (
// DeleteWeb is the web handler to delete something // DeleteWeb is the web handler to delete something
func (c *WebHandler) DeleteWeb(ctx echo.Context) error { func (c *WebHandler) DeleteWeb(ctx echo.Context) error {
// Get the ID
/*id, err := models.GetIntURLParam("id", ctx)
if err != nil {
return echo.NewHTTPError(http.StatusBadRequest, "Invalid ID.")
}*/
// Bind params to struct // Bind params to struct
if err := ParamBinder(c.CObject, ctx); err != nil { if err := ParamBinder(c.CObject, ctx); err != nil {
return echo.NewHTTPError(http.StatusBadRequest, "Invalid URL param.") return echo.NewHTTPError(http.StatusBadRequest, "Invalid URL param.")

View file

@ -94,12 +94,12 @@ func RegisterRoutes(e *echo.Echo) {
a.GET("/lists/:id", listHandler.ReadOneWeb) a.GET("/lists/:id", listHandler.ReadOneWeb)
a.POST("/lists/:id", listHandler.UpdateWeb) a.POST("/lists/:id", listHandler.UpdateWeb)
a.DELETE("/lists/:listid", listHandler.DeleteWeb) a.DELETE("/lists/:listid", listHandler.DeleteWeb)
a.PUT("/namespaces/:id/lists", listHandler.CreateWeb) a.PUT("/namespaces/:nid/lists", listHandler.CreateWeb)
itemHandler := &crud.WebHandler{ itemHandler := &crud.WebHandler{
CObject: &models.ListItem{}, CObject: &models.ListItem{},
} }
a.PUT("/lists/:id", itemHandler.CreateWeb) a.PUT("/lists/:listid", itemHandler.CreateWeb)
a.DELETE("/items/:listitemid", itemHandler.DeleteWeb) a.DELETE("/items/:listitemid", itemHandler.DeleteWeb)
a.POST("/items/:id", itemHandler.UpdateWeb) a.POST("/items/:id", itemHandler.UpdateWeb)
@ -117,8 +117,8 @@ func RegisterRoutes(e *echo.Echo) {
CObject: &models.TeamNamespace{}, CObject: &models.TeamNamespace{},
} }
a.GET("/namespaces/:id/teams", namespaceTeamHandler.ReadAllWeb) a.GET("/namespaces/:id/teams", namespaceTeamHandler.ReadAllWeb)
a.PUT("/namespaces/:id/teams", namespaceTeamHandler.CreateWeb) a.PUT("/namespaces/:namespaceid/teams", namespaceTeamHandler.CreateWeb)
a.DELETE("/namespaces/:nid/teams/:teamid", namespaceTeamHandler.DeleteWeb) a.DELETE("/namespaces/:namespaceid/teams/:teamid", namespaceTeamHandler.DeleteWeb)
teamHandler := &crud.WebHandler{ teamHandler := &crud.WebHandler{
CObject: &models.Team{}, CObject: &models.Team{},