Added list create and update methods

This commit is contained in:
konrad 2018-06-10 14:14:10 +02:00 committed by kolaente
parent fb4c9d580c
commit f372128784
Signed by untrusted user: konrad
GPG Key ID: F40E70337AB24C9B
7 changed files with 167 additions and 6 deletions

View File

@ -122,4 +122,24 @@ func IsErrIDCannotBeZero(err error) bool {
func (err ErrIDCannotBeZero) Error() string {
return fmt.Sprintf("ID cannot be 0")
}
// ===========
// List errors
// ===========
// ErrListDoesNotExist represents a "ErrListDoesNotExist" kind of error. Used if the list does not exist.
type ErrListDoesNotExist struct{
ID int64
}
// IsErrListDoesNotExist checks if an error is a ErrListDoesNotExist.
func IsErrListDoesNotExist(err error) bool {
_, ok := err.(ErrListDoesNotExist)
return ok
}
func (err ErrListDoesNotExist) Error() string {
return fmt.Sprintf("List does not exist [ID: %d]", err.ID)
}

53
models/lists.go Normal file
View File

@ -0,0 +1,53 @@
package models
type List struct {
ID int64 `xorm:"int(11) autoincr not null unique pk" json:"id"`
Title string `xorm:"varchar(250)" json:"title"`
Description string `xorm:"varchar(1000)" json:"description"`
OwnerID int64 `xorm:"int(11)" json:"ownerID"`
Owner User `xorm:"-" json:"owner"`
Created int64 `xorm:"created" json:"created"`
Updated int64 `xorm:"updated" json:"updated"`
}
func GetListByID(id int64) (list List, err error){
list.ID = id
exists, err := x.Get(&list)
if err != nil {
return List{}, err
}
if !exists {
return List{}, ErrListDoesNotExist{ID: id}
}
// Get the list owner
user, _, err := GetUserByID(list.OwnerID)
if err != nil {
return List{}, err
}
list.Owner = user
return list, nil
}
func CreateOrUpdateList(list *List) (err error) {
// Check if it exists
_, err = GetListByID(list.ID)
if err != nil {
return
}
list.OwnerID = list.Owner.ID
if list.ID == 0 {
_, err = x.Insert(list)
} else {
_, err = x.ID(list.ID).Update(list)
return
}
return
}

View File

@ -8,7 +8,11 @@ import (
_ "github.com/mattn/go-sqlite3" // Because.
)
var x *xorm.Engine
var (
x *xorm.Engine
tables []interface{}
)
func getEngine() (*xorm.Engine, error) {
// Use Mysql if set
@ -26,6 +30,13 @@ func getEngine() (*xorm.Engine, error) {
return xorm.NewEngine("sqlite3", path)
}
func init() {
tables = append(tables,
new(User),
new(List),
)
}
// SetEngine sets the xorm.Engine
func SetEngine() (err error) {
x, err = getEngine()
@ -40,7 +51,9 @@ func SetEngine() (err error) {
x.SetMapper(core.GonicMapper{})
// Sync dat shit
x.Sync(&User{})
if err = x.StoreEngine("InnoDB").Sync2(tables...); err != nil {
return fmt.Errorf("sync database struct error: %v", err)
}
x.ShowSQL(Config.Database.ShowQueries)

View File

@ -16,7 +16,7 @@ func CreateUser(user User) (newUser User, err error) {
// Check if the user already existst with that username
existingUser, exists, err := GetUser(User{Username: newUser.Username})
if err != nil && !IsErrUserDoesNotExist(err){
if err != nil && !IsErrUserDoesNotExist(err) {
return User{}, err
}
if exists {

View File

@ -0,0 +1,75 @@
package v1
import (
"net/http"
"github.com/labstack/echo"
"git.kolaente.de/konrad/list/models"
"strconv"
"fmt"
)
func AddOrUpdateList(c echo.Context) error {
// Get the list
var list *models.List
if err := c.Bind(&list); err != nil {
return c.JSON(http.StatusBadRequest, models.Message{"No list model provided."})
}
// Check if we have an ID other than the one in the struct
id := c.Param("id")
if id != "" {
// Make int
listID, err := strconv.ParseInt(id, 10, 64)
if err != nil {
return c.JSON(http.StatusBadRequest, models.Message{"Invalid ID."})
}
list.ID = listID
}
// Check if the list exists
// ID = 0 means new list, no error
if list.ID != 0 {
_, err := models.GetListByID(list.ID)
if err != nil {
if models.IsErrListDoesNotExist(err) {
return c.JSON(http.StatusBadRequest, models.Message{"The list does not exist."})
} else {
return c.JSON(http.StatusInternalServerError, models.Message{"Could not check if the list exists."})
}
}
}
// Get the current user for later checks
user, err := models.GetCurrentUser(c)
if err != nil {
return c.JSON(http.StatusInternalServerError, models.Message{"An error occured."})
}
list.Owner = user
// update or create...
if list.ID == 0 {
err = models.CreateOrUpdateList(list)
if err != nil {
return c.JSON(http.StatusInternalServerError, models.Message{"An error occured."})
}
} else {
// Check if the user owns the list
oldList, err := models.GetListByID(list.ID)
if err != nil {
return c.JSON(http.StatusInternalServerError, models.Message{"An error occured."})
}
if user.ID != oldList.Owner.ID {
return c.JSON(http.StatusForbidden, models.Message{"You cannot edit a list you don't own."})
}
err = models.CreateOrUpdateList(list)
if err != nil {
return c.JSON(http.StatusInternalServerError, models.Message{"An error occured."})
}
}
return c.JSON(http.StatusOK, list)
}

View File

@ -7,7 +7,6 @@ import (
"net/http"
"strconv"
"strings"
"fmt"
)
// UserAddOrUpdate is the handler to add a user
@ -52,8 +51,6 @@ func UserAddOrUpdate(c echo.Context) error {
return c.JSON(http.StatusInternalServerError, models.Message{"Could not check if the user exists."})
}
fmt.Println(exists)
// Insert or update the user
var newUser models.User
if exists {

View File

@ -50,4 +50,7 @@ func RegisterRoutes(e *echo.Echo) {
// Authetification
a.Use(middleware.JWT(models.Config.JWTLoginSecret))
a.POST("/tokenTest", apiv1.CheckToken)
a.PUT("/lists", apiv1.AddOrUpdateList)
a.POST("/lists/:id", apiv1.AddOrUpdateList)
}