mirror of
https://git.rwth-aachen.de/acs/public/villas/web-backend-go/
synced 2025-03-30 00:00:12 +01:00
183 lines
4.8 KiB
Go
183 lines
4.8 KiB
Go
package visualization
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
"git.rwth-aachen.de/acs/public/villas/villasweb-backend-go/common"
|
|
"git.rwth-aachen.de/acs/public/villas/villasweb-backend-go/routes/simulation"
|
|
)
|
|
|
|
func RegisterVisualizationEndpoints(r *gin.RouterGroup) {
|
|
|
|
r.GET("", getVisualizations)
|
|
r.POST("", addVisualization)
|
|
r.PUT("/:visualizationID", updateVisualization)
|
|
r.GET("/:visualizationID", getVisualization)
|
|
r.DELETE("/:visualizationID", deleteVisualization)
|
|
}
|
|
|
|
// getVisualizations godoc
|
|
// @Summary Get all visualizations of simulation
|
|
// @ID getVisualizations
|
|
// @Produce json
|
|
// @Tags visualizations
|
|
// @Success 200 {array} common.VisualizationResponse "Array of visualizations to which belong to simulation"
|
|
// @Failure 401 "Unauthorized Access"
|
|
// @Failure 403 "Access forbidden."
|
|
// @Failure 404 "Not found"
|
|
// @Failure 500 "Internal server error"
|
|
// @Param simulationID query int true "Simulation ID"
|
|
// @Router /visualizations [get]
|
|
func getVisualizations(c *gin.Context) {
|
|
|
|
ok, sim := simulation.CheckPermissions(c, common.Read, "query", -1)
|
|
if !ok {
|
|
return
|
|
}
|
|
|
|
db := common.GetDB()
|
|
var vis []common.Visualization
|
|
err := db.Order("ID asc").Model(sim).Related(&vis, "Visualizations").Error
|
|
if common.ProvideErrorResponse(c, err) {
|
|
return
|
|
}
|
|
|
|
serializer := common.VisualizationsSerializer{c, vis}
|
|
c.JSON(http.StatusOK, gin.H{
|
|
"visualizations": serializer.Response(),
|
|
})
|
|
}
|
|
|
|
// addVisualization godoc
|
|
// @Summary Add a visualization to a simulation
|
|
// @ID addVisualization
|
|
// @Accept json
|
|
// @Produce json
|
|
// @Tags visualizations
|
|
// @Param inputVis body common.VisualizationResponse true "Visualization to be added incl. ID of simulation"
|
|
// @Success 200 "OK."
|
|
// @Failure 401 "Unauthorized Access"
|
|
// @Failure 403 "Access forbidden."
|
|
// @Failure 404 "Not found"
|
|
// @Failure 500 "Internal server error"
|
|
// @Router /visualizations [post]
|
|
func addVisualization(c *gin.Context) {
|
|
|
|
var newVis Visualization
|
|
err := c.BindJSON(&newVis)
|
|
if err != nil {
|
|
errormsg := "Bad request. Error binding form data to JSON: " + err.Error()
|
|
c.JSON(http.StatusBadRequest, gin.H{
|
|
"error": errormsg,
|
|
})
|
|
return
|
|
}
|
|
|
|
ok, _ := simulation.CheckPermissions(c, common.Create, "body", int(newVis.SimulationID))
|
|
if !ok {
|
|
return
|
|
}
|
|
|
|
// add visualization to DB and add association to simulation
|
|
err = newVis.addToSimulation()
|
|
if common.ProvideErrorResponse(c, err) == false {
|
|
c.JSON(http.StatusOK, gin.H{
|
|
"message": "OK.",
|
|
})
|
|
}
|
|
|
|
}
|
|
|
|
// updateVisualization godoc
|
|
// @Summary Update a visualization
|
|
// @ID updateVisualization
|
|
// @Tags visualizations
|
|
// @Accept json
|
|
// @Produce json
|
|
// @Param inputVis body common.VisualizationResponse true "Visualization to be updated"
|
|
// @Success 200 "OK."
|
|
// @Failure 401 "Unauthorized Access"
|
|
// @Failure 403 "Access forbidden."
|
|
// @Failure 404 "Not found"
|
|
// @Failure 500 "Internal server error"
|
|
// @Param visualizationID path int true "Visualization ID"
|
|
// @Router /visualizations/{visualizationID} [put]
|
|
func updateVisualization(c *gin.Context) {
|
|
|
|
ok, v := CheckPermissions(c, common.Update, "path", -1)
|
|
if !ok {
|
|
return
|
|
}
|
|
|
|
var modifiedVis Visualization
|
|
err := c.BindJSON(&modifiedVis)
|
|
if err != nil {
|
|
errormsg := "Bad request. Error binding form data to JSON: " + err.Error()
|
|
c.JSON(http.StatusBadRequest, gin.H{
|
|
"error": errormsg,
|
|
})
|
|
return
|
|
}
|
|
|
|
err = v.update(modifiedVis)
|
|
if common.ProvideErrorResponse(c, err) == false {
|
|
c.JSON(http.StatusOK, gin.H{
|
|
"message": "OK.",
|
|
})
|
|
}
|
|
}
|
|
|
|
// getVisualization godoc
|
|
// @Summary Get a visualization
|
|
// @ID getVisualization
|
|
// @Tags visualizations
|
|
// @Produce json
|
|
// @Success 200 {object} common.VisualizationResponse "Requested visualization."
|
|
// @Failure 401 "Unauthorized Access"
|
|
// @Failure 403 "Access forbidden."
|
|
// @Failure 404 "Not found"
|
|
// @Failure 500 "Internal server error"
|
|
// @Param visualizationID path int true "Visualization ID"
|
|
// @Router /visualizations/{visualizationID} [get]
|
|
func getVisualization(c *gin.Context) {
|
|
|
|
ok, vis := CheckPermissions(c, common.Read, "path", -1)
|
|
if !ok {
|
|
return
|
|
}
|
|
|
|
serializer := common.VisualizationSerializer{c, vis.Visualization}
|
|
c.JSON(http.StatusOK, gin.H{
|
|
"visualization": serializer.Response(),
|
|
})
|
|
}
|
|
|
|
// deleteVisualization godoc
|
|
// @Summary Delete a visualization
|
|
// @ID deleteVisualization
|
|
// @Tags visualizations
|
|
// @Produce json
|
|
// @Success 200 "OK."
|
|
// @Failure 401 "Unauthorized Access"
|
|
// @Failure 403 "Access forbidden."
|
|
// @Failure 404 "Not found"
|
|
// @Failure 500 "Internal server error"
|
|
// @Param visualizationID path int true "Visualization ID"
|
|
// @Router /visualizations/{visualizationID} [delete]
|
|
func deleteVisualization(c *gin.Context) {
|
|
ok, vis := CheckPermissions(c, common.Delete, "path", -1)
|
|
if !ok {
|
|
return
|
|
}
|
|
|
|
err := vis.delete()
|
|
if common.ProvideErrorResponse(c, err) {
|
|
return
|
|
}
|
|
|
|
c.JSON(http.StatusOK, gin.H{
|
|
"message": "OK.",
|
|
})
|
|
}
|