From 78fe19c2bf93466983f638dbce47ba8ec1aac723 Mon Sep 17 00:00:00 2001 From: Chris Cromer Date: Wed, 1 Feb 2023 13:18:52 -0300 Subject: [PATCH] add object name routes --- backend/controllers/object_name.go | 129 +++++++++++++++++++++++++++++ backend/routes/object_name.go | 16 ++++ backend/routes/router.go | 1 + 3 files changed, 146 insertions(+) create mode 100644 backend/controllers/object_name.go create mode 100644 backend/routes/object_name.go diff --git a/backend/controllers/object_name.go b/backend/controllers/object_name.go new file mode 100644 index 0000000..c525bd7 --- /dev/null +++ b/backend/controllers/object_name.go @@ -0,0 +1,129 @@ +package controllers + +import ( + "encoding/json" + "net/http" + "strconv" + + "git.cromer.cl/Proyecto-Titulo/alai-server/backend/database" + "git.cromer.cl/Proyecto-Titulo/alai-server/backend/models" + "git.cromer.cl/Proyecto-Titulo/alai-server/backend/utils" + + "github.com/julienschmidt/httprouter" +) + +func ListObjectName(writer http.ResponseWriter, request *http.Request, params httprouter.Params) { + gdb := database.Connect() + defer database.Close(gdb) + + var objectName []models.ObjectName + + result := gdb.Model(&models.ObjectName{}).Order("ID asc").Find(&objectName) + if result.Error != nil { + utils.JSONErrorOutput(writer, http.StatusBadRequest, result.Error.Error()) + return + } else { + writer.Header().Set("Content-Type", "application/json") + writer.WriteHeader(http.StatusOK) + json.NewEncoder(writer).Encode(objectName) + } +} + +func GetObjectName(writer http.ResponseWriter, request *http.Request, params httprouter.Params) { + gdb := database.Connect() + defer database.Close(gdb) + + var objectName models.ObjectName + + result := gdb.Model(&models.ObjectName{}).Find(&objectName, params.ByName("id")) + if result.Error != nil { + utils.JSONErrorOutput(writer, http.StatusBadRequest, result.Error.Error()) + return + } else if result.RowsAffected == 0 { + writer.WriteHeader(http.StatusNotFound) + return + } else { + writer.Header().Set("Content-Type", "application/json") + writer.WriteHeader(http.StatusOK) + json.NewEncoder(writer).Encode(objectName) + } +} + +func CreateObjectName(writer http.ResponseWriter, request *http.Request, params httprouter.Params) { + gdb := database.Connect() + defer database.Close(gdb) + + var objectName models.ObjectName + + decoder := json.NewDecoder(request.Body) + + err := decoder.Decode(&objectName) + if err != nil { + utils.JSONErrorOutput(writer, http.StatusBadRequest, err.Error()) + return + } + + result := gdb.Create(&objectName) + if result.Error != nil { + utils.JSONErrorOutput(writer, http.StatusBadRequest, result.Error.Error()) + return + } else { + writer.WriteHeader(http.StatusNoContent) + } +} + +func UpdateObjectName(writer http.ResponseWriter, request *http.Request, params httprouter.Params) { + gdb := database.Connect() + defer database.Close(gdb) + + var objectName models.ObjectName + + decoder := json.NewDecoder(request.Body) + + err := decoder.Decode(&objectName) + if err != nil { + utils.JSONErrorOutput(writer, http.StatusBadRequest, err.Error()) + return + } + + objectName.ID, err = strconv.ParseUint(params.ByName("id"), 10, 64) + if err != nil { + utils.JSONErrorOutput(writer, http.StatusBadRequest, err.Error()) + return + } + + result := gdb.Updates(&objectName) + if result.Error != nil { + utils.JSONErrorOutput(writer, http.StatusBadRequest, result.Error.Error()) + return + } else if result.RowsAffected == 0 { + writer.WriteHeader(http.StatusNotFound) + return + } else { + writer.WriteHeader(http.StatusNoContent) + } +} + +func DeleteObjectName(writer http.ResponseWriter, request *http.Request, params httprouter.Params) { + gdb := database.Connect() + defer database.Close(gdb) + + var objectName models.ObjectName + var err error + objectName.ID, err = strconv.ParseUint(params.ByName("id"), 10, 64) + if err != nil { + utils.JSONErrorOutput(writer, http.StatusBadRequest, err.Error()) + return + } + + result := gdb.Delete(&objectName) + if result.Error != nil { + utils.JSONErrorOutput(writer, http.StatusBadRequest, result.Error.Error()) + return + } else if result.RowsAffected == 0 { + writer.WriteHeader(http.StatusNotFound) + return + } else { + writer.WriteHeader(http.StatusNoContent) + } +} diff --git a/backend/routes/object_name.go b/backend/routes/object_name.go new file mode 100644 index 0000000..a80c954 --- /dev/null +++ b/backend/routes/object_name.go @@ -0,0 +1,16 @@ +package routes + +import ( + "git.cromer.cl/Proyecto-Titulo/alai-server/backend/controllers" + "git.cromer.cl/Proyecto-Titulo/alai-server/backend/middlewares" + + "github.com/julienschmidt/httprouter" +) + +func ObjectNameRoutes(router *httprouter.Router) { + router.GET("/object-name", controllers.ListObjectName) + router.GET("/object-name/:id", controllers.GetObjectName) + router.POST("/object-name", middlewares.Authenticate(controllers.CreateObjectName)) + router.PATCH("/object-name/:id", middlewares.Authenticate(controllers.UpdateObjectName)) + router.DELETE("/object-name/:id", middlewares.Authenticate(controllers.DeleteObjectName)) +} diff --git a/backend/routes/router.go b/backend/routes/router.go index fd93643..a69874f 100644 --- a/backend/routes/router.go +++ b/backend/routes/router.go @@ -21,6 +21,7 @@ func Initialize() *httprouter.Router { GameRoutes(router) GodotVersionRoutes(router) LevelRoutes(router) + ObjectNameRoutes(router) OSRoutes(router) PlayerRoutes(router) UserRoutes(router)