2024-11-29 16:34:03 +08:00
|
|
|
package handler
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"net/http"
|
|
|
|
|
|
2024-12-02 16:13:16 +08:00
|
|
|
"modelRT/database"
|
2024-11-29 16:34:03 +08:00
|
|
|
"modelRT/diagram"
|
|
|
|
|
"modelRT/log"
|
|
|
|
|
"modelRT/network"
|
|
|
|
|
|
2024-12-18 16:25:49 +08:00
|
|
|
"github.com/bitly/go-simplejson"
|
2024-11-29 16:34:03 +08:00
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
|
"go.uber.org/zap"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// CircuitDiagramUpdateHandler define circuit diagram update process API
|
|
|
|
|
func CircuitDiagramUpdateHandler(c *gin.Context) {
|
|
|
|
|
logger := log.GetLoggerInstance()
|
2024-12-02 16:13:16 +08:00
|
|
|
pgClient := database.GetPostgresDBClient()
|
2024-11-29 16:34:03 +08:00
|
|
|
|
|
|
|
|
var request network.CircuitDiagramUpdateRequest
|
|
|
|
|
if err := c.ShouldBindJSON(&request); err != nil {
|
|
|
|
|
logger.Error("unmarshal circuit diagram update info failed", zap.Error(err))
|
2024-12-06 16:13:11 +08:00
|
|
|
header := network.FailResponseHeader{Status: http.StatusBadRequest, ErrMsg: err.Error()}
|
|
|
|
|
resp := network.FailureResponse{
|
|
|
|
|
FailResponseHeader: header,
|
2024-11-29 16:34:03 +08:00
|
|
|
}
|
|
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
graph, err := diagram.GetGraphMap(request.PageID)
|
|
|
|
|
if err != nil {
|
|
|
|
|
logger.Error("get topologic data from set by pageID failed", zap.Error(err))
|
2024-12-06 16:13:11 +08:00
|
|
|
header := network.FailResponseHeader{Status: http.StatusBadRequest, ErrMsg: err.Error()}
|
|
|
|
|
resp := network.FailureResponse{
|
|
|
|
|
FailResponseHeader: header,
|
2024-11-29 16:34:03 +08:00
|
|
|
PayLoad: map[string]interface{}{
|
|
|
|
|
"page_id": request.PageID,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2024-12-04 15:57:11 +08:00
|
|
|
var topologicChangeInfos []network.TopologicUUIDChangeInfos
|
2024-12-03 16:38:17 +08:00
|
|
|
for _, topologicLink := range request.TopologicLinks {
|
|
|
|
|
changeInfo, err := network.ParseUUID(topologicLink)
|
|
|
|
|
if err != nil {
|
|
|
|
|
logger.Error("format uuid from string failed", zap.Error(err))
|
2024-12-06 16:13:11 +08:00
|
|
|
header := network.FailResponseHeader{Status: http.StatusBadRequest, ErrMsg: err.Error()}
|
|
|
|
|
resp := network.FailureResponse{
|
|
|
|
|
FailResponseHeader: header,
|
2024-12-03 16:38:17 +08:00
|
|
|
PayLoad: map[string]interface{}{
|
|
|
|
|
"topologic_info": topologicLink,
|
|
|
|
|
},
|
2024-11-29 16:34:03 +08:00
|
|
|
}
|
2024-12-03 16:38:17 +08:00
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
|
return
|
|
|
|
|
}
|
2024-12-04 15:57:11 +08:00
|
|
|
topologicChangeInfos = append(topologicChangeInfos, changeInfo)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// open transaction
|
|
|
|
|
tx := pgClient.Begin()
|
|
|
|
|
|
|
|
|
|
for _, topologicChangeInfo := range topologicChangeInfos {
|
|
|
|
|
err = database.UpdateTopologicIntoDB(c, tx, request.PageID, topologicChangeInfo)
|
2024-12-03 16:38:17 +08:00
|
|
|
if err != nil {
|
2024-12-04 15:57:11 +08:00
|
|
|
tx.Rollback()
|
|
|
|
|
|
|
|
|
|
logger.Error("update topologic info into DB failed", zap.Any("topologic_info", topologicChangeInfo), zap.Error(err))
|
2024-12-06 16:13:11 +08:00
|
|
|
header := network.FailResponseHeader{Status: http.StatusBadRequest, ErrMsg: err.Error()}
|
|
|
|
|
resp := network.FailureResponse{
|
|
|
|
|
FailResponseHeader: header,
|
2024-12-03 16:38:17 +08:00
|
|
|
PayLoad: map[string]interface{}{
|
2024-12-04 15:57:11 +08:00
|
|
|
"topologic_info": topologicChangeInfo,
|
2024-12-03 16:38:17 +08:00
|
|
|
},
|
2024-11-29 16:34:03 +08:00
|
|
|
}
|
2024-12-03 16:38:17 +08:00
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
|
return
|
|
|
|
|
}
|
2024-11-29 16:34:03 +08:00
|
|
|
|
2024-12-04 15:57:11 +08:00
|
|
|
err = graph.UpdateEdge(topologicChangeInfo)
|
2024-12-03 16:38:17 +08:00
|
|
|
if err != nil {
|
2024-12-04 15:57:11 +08:00
|
|
|
tx.Rollback()
|
|
|
|
|
|
|
|
|
|
logger.Error("update topologic info failed", zap.Any("topologic_info", topologicChangeInfo), zap.Error(err))
|
2024-12-06 16:13:11 +08:00
|
|
|
header := network.FailResponseHeader{Status: http.StatusBadRequest, ErrMsg: err.Error()}
|
|
|
|
|
resp := network.FailureResponse{
|
|
|
|
|
FailResponseHeader: header,
|
2024-11-29 16:34:03 +08:00
|
|
|
PayLoad: map[string]interface{}{
|
2024-12-04 15:57:11 +08:00
|
|
|
"topologic_info": topologicChangeInfo,
|
2024-11-29 16:34:03 +08:00
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-12-02 16:13:16 +08:00
|
|
|
|
2024-12-05 14:57:23 +08:00
|
|
|
err = database.UpdateComponentIntoDB(c, tx, request.ComponentInfos)
|
|
|
|
|
if err != nil {
|
|
|
|
|
logger.Error("udpate component info into DB failed", zap.Error(err))
|
2024-12-06 16:13:11 +08:00
|
|
|
header := network.FailResponseHeader{Status: http.StatusBadRequest, ErrMsg: err.Error()}
|
|
|
|
|
resp := network.FailureResponse{
|
|
|
|
|
FailResponseHeader: header,
|
2024-12-05 14:57:23 +08:00
|
|
|
PayLoad: map[string]interface{}{
|
|
|
|
|
"page_id": request.PageID,
|
|
|
|
|
"component_info": request.ComponentInfos,
|
|
|
|
|
},
|
2024-12-02 16:13:16 +08:00
|
|
|
}
|
2024-12-05 14:57:23 +08:00
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
|
return
|
|
|
|
|
}
|
2024-12-02 16:13:16 +08:00
|
|
|
|
2024-12-05 14:57:23 +08:00
|
|
|
err = database.UpdateModelIntoDB(c, tx, request.ComponentInfos)
|
|
|
|
|
if err != nil {
|
|
|
|
|
logger.Error("udpate component model info into DB failed", zap.Error(err))
|
2024-12-06 16:13:11 +08:00
|
|
|
header := network.FailResponseHeader{Status: http.StatusBadRequest, ErrMsg: err.Error()}
|
|
|
|
|
resp := network.FailureResponse{
|
|
|
|
|
FailResponseHeader: header,
|
2024-12-05 14:57:23 +08:00
|
|
|
PayLoad: map[string]interface{}{
|
|
|
|
|
"page_id": request.PageID,
|
|
|
|
|
"component_info": request.ComponentInfos,
|
|
|
|
|
},
|
2024-12-02 16:13:16 +08:00
|
|
|
}
|
2024-12-05 14:57:23 +08:00
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
|
return
|
|
|
|
|
}
|
2024-12-02 16:13:16 +08:00
|
|
|
|
2024-12-05 14:57:23 +08:00
|
|
|
for _, componentInfo := range request.ComponentInfos {
|
2024-12-18 16:25:49 +08:00
|
|
|
paramsJSON, err := simplejson.NewJson([]byte(componentInfo.Params))
|
2024-12-02 16:13:16 +08:00
|
|
|
if err != nil {
|
|
|
|
|
logger.Error("unmarshal component info by concurrent map failed", zap.String("component_params", componentInfo.Params), zap.Error(err))
|
2024-12-06 16:13:11 +08:00
|
|
|
header := network.FailResponseHeader{Status: http.StatusBadRequest, ErrMsg: err.Error()}
|
|
|
|
|
resp := network.FailureResponse{
|
|
|
|
|
FailResponseHeader: header,
|
2024-12-02 16:13:16 +08:00
|
|
|
PayLoad: map[string]interface{}{
|
|
|
|
|
"uuid": componentInfo.UUID,
|
|
|
|
|
"component_params": componentInfo.Params,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
|
return
|
|
|
|
|
}
|
2024-12-18 16:25:49 +08:00
|
|
|
|
|
|
|
|
componentMap, err := paramsJSON.Map()
|
|
|
|
|
if err != nil {
|
|
|
|
|
logger.Error("format params json info to map failed", zap.Error(err))
|
|
|
|
|
header := network.FailResponseHeader{Status: http.StatusBadRequest, ErrMsg: err.Error()}
|
|
|
|
|
resp := network.FailureResponse{
|
|
|
|
|
FailResponseHeader: header,
|
|
|
|
|
PayLoad: map[string]interface{}{
|
|
|
|
|
"uuid": componentInfo.UUID,
|
|
|
|
|
"component_params": componentInfo.Params,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
diagram.UpdateComponentMap(componentInfo.UUID, componentMap)
|
2024-12-02 16:13:16 +08:00
|
|
|
}
|
|
|
|
|
|
2024-12-05 16:32:23 +08:00
|
|
|
if len(request.FreeVertexs) > 0 {
|
|
|
|
|
for _, freeVertex := range request.FreeVertexs {
|
|
|
|
|
graph.FreeVertexs[freeVertex] = struct{}{}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-12-04 15:57:11 +08:00
|
|
|
// commit transsction
|
|
|
|
|
tx.Commit()
|
|
|
|
|
|
2024-12-06 16:13:11 +08:00
|
|
|
resp := network.SuccessResponse{
|
|
|
|
|
SuccessResponseHeader: network.SuccessResponseHeader{Status: http.StatusOK},
|
2024-12-02 16:13:16 +08:00
|
|
|
PayLoad: map[string]interface{}{
|
|
|
|
|
"page_id": request.PageID,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
c.JSON(http.StatusOK, resp)
|
2024-11-29 16:34:03 +08:00
|
|
|
}
|