feat: 教学应用配置下发到网元功能

This commit is contained in:
TsMask
2024-07-05 18:44:26 +08:00
parent 94ce2c735e
commit a009c6db73
3 changed files with 47 additions and 13 deletions

View File

@@ -225,7 +225,7 @@ func (s *NeConfigController) DataEdit(c *gin.Context) {
}
// 网元直连
resData, err := neFetchlink.NeConfigInfoEdit(neInfo, body.ParamName, body.Loc, body.ParamData)
resData, err := neFetchlink.NeConfigUpdate(neInfo, body.ParamName, body.Loc, body.ParamData)
if err != nil {
c.JSON(200, result.ErrMsg(err.Error()))
return
@@ -270,7 +270,7 @@ func (s *NeConfigController) DataAdd(c *gin.Context) {
}
// 网元直连
resData, err := neFetchlink.NeConfigInfoAdd(neInfo, body.ParamName, body.Loc, body.ParamData)
resData, err := neFetchlink.NeConfigInstall(neInfo, body.ParamName, body.Loc, body.ParamData)
if err != nil {
c.JSON(200, result.ErrMsg(err.Error()))
return
@@ -308,7 +308,7 @@ func (s *NeConfigController) DataRemove(c *gin.Context) {
}
// 网元直连
resData, err := neFetchlink.NeConfigInfoDel(neInfo, query.ParamName, query.Loc)
resData, err := neFetchlink.NeConfigDelete(neInfo, query.ParamName, query.Loc)
if err != nil {
c.JSON(200, result.ErrMsg(err.Error()))
return

View File

@@ -69,8 +69,8 @@ func NeConfigInfo(neInfo model.NeInfo, paramName string) (map[string]any, error)
return resData, nil
}
// NeConfigInfoEdit 网元配置更新
func NeConfigInfoEdit(neInfo model.NeInfo, paramName, loc string, data map[string]any) (map[string]any, error) {
// NeConfigUpdate 网元配置更新
func NeConfigUpdate(neInfo model.NeInfo, paramName, loc string, data map[string]any) (map[string]any, error) {
// array需要层级
if loc != "" {
loc = fmt.Sprintf("?loc=%v", loc)
@@ -102,8 +102,8 @@ func NeConfigInfoEdit(neInfo model.NeInfo, paramName, loc string, data map[strin
return resData, nil
}
// NeConfigInfoAdd 网元配置新增 array
func NeConfigInfoAdd(neInfo model.NeInfo, paramName, loc string, data map[string]any) (map[string]any, error) {
// NeConfigInstall 网元配置新增 array
func NeConfigInstall(neInfo model.NeInfo, paramName, loc string, data map[string]any) (map[string]any, error) {
// 网元参数配置新增array
neUrl := fmt.Sprintf("http://%s:%d/api/rest/systemManagement/v1/elementType/%s/objectType/config/%s?loc=%v", neInfo.IP, neInfo.Port, strings.ToLower(neInfo.NeType), paramName, loc)
resBytes, err := fetch.PostJSON(neUrl, data, nil)
@@ -131,8 +131,8 @@ func NeConfigInfoAdd(neInfo model.NeInfo, paramName, loc string, data map[string
return resData, nil
}
// NeConfigInfoDel 网元配置删除 array
func NeConfigInfoDel(neInfo model.NeInfo, paramName, loc string) (map[string]any, error) {
// NeConfigDelete 网元配置删除 array
func NeConfigDelete(neInfo model.NeInfo, paramName, loc string) (map[string]any, error) {
// 网元参数配置删除array
neUrl := fmt.Sprintf("http://%s:%d/api/rest/systemManagement/v1/elementType/%s/objectType/config/%s?loc=%v", neInfo.IP, neInfo.Port, strings.ToLower(neInfo.NeType), paramName, loc)
resBytes, err := fetch.Delete(neUrl, nil)

View File

@@ -3,7 +3,9 @@ package service
import (
"encoding/json"
"fmt"
"reflect"
"be.ems/src/framework/utils/parse"
neFetchlink "be.ems/src/modules/network_element/fetch_link"
neModel "be.ems/src/modules/network_element/model"
neService "be.ems/src/modules/network_element/service"
@@ -205,11 +207,43 @@ func (r *PtNeConfigDataService) ApplyToNe(paramUser, neType string) error {
if len(ptConf.ParamData) == 0 {
continue
}
// 单层逐个更新
if ptConf.ParamType == "list" {
dataMap := ptConf.ParamData[0]
for k, v := range dataMap {
fmt.Println(k, v)
for k, v := range ptConf.ParamData[0] {
neFetchlink.NeConfigUpdate(neInfo, ptConf.ParamName, "", map[string]any{k: v})
}
}
// 多层逐个更新
if ptConf.ParamType == "array" {
// 删除原先配置
resData, err := neFetchlink.NeConfigInfo(neInfo, ptConf.ParamName)
if err != nil {
continue
}
if data, ok := resData["data"]; ok {
for i := 0; i < len(data.([]any)); i++ { // 倒序遍历
originIndex := i
newIndex := len(data.([]any)) - originIndex - 1
element := data.([]any)[newIndex]
loc := parse.Number(element.(map[string]any)["index"])
neFetchlink.NeConfigDelete(neInfo, ptConf.ParamName, fmt.Sprint(loc))
}
}
// 遍历新增
for _, v := range ptConf.ParamData {
loc := parse.Number(v["index"])
neFetchlink.NeConfigInstall(neInfo, ptConf.ParamName, fmt.Sprint(loc), v)
// 检查是否有array子层
for vk, vv := range v {
if reflect.TypeOf(vv).Kind() == reflect.Slice {
for i, item := range vv.([]any) {
data := item.(map[string]any)
data["index"] = i
neFetchlink.NeConfigInstall(neInfo, ptConf.ParamName, fmt.Sprintf("%v/%s/%v", loc, vk, i), data)
}
}
}
}
}
}