X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=a1-go%2Fpkg%2Fresthooks%2Fresthooks.go;fp=a1-go%2Fpkg%2Fresthooks%2Fresthooks.go;h=54ca39d74ef4c125b7ecea62357ec64834e0cd1b;hb=686447316fc67f7b1777d94c5e02293786cec98d;hp=0a832ff9e605704ec7202c71ee9dd8fed71f86c2;hpb=d5aa5be4fc3723e15f8298f826c803384f2f1a19;p=ric-plt%2Fa1.git diff --git a/a1-go/pkg/resthooks/resthooks.go b/a1-go/pkg/resthooks/resthooks.go index 0a832ff..54ca39d 100644 --- a/a1-go/pkg/resthooks/resthooks.go +++ b/a1-go/pkg/resthooks/resthooks.go @@ -21,7 +21,9 @@ package resthooks import ( + "encoding/json" "errors" + "fmt" "strconv" "strings" @@ -78,6 +80,57 @@ func (rh *Resthook) GetAllPolicyType() []models.PolicyTypeID { return policyTypeIDs } +func (rh *Resthook) GetPolicyType(policyTypeId models.PolicyTypeID) *models.PolicyTypeSchema { + a1.Logger.Debug("GetPolicyType1") + + var policytypeschema *models.PolicyTypeSchema + var keys [1]string + + key := a1PolicyPrefix + strconv.FormatInt((int64(policyTypeId)), 10) + keys[0] = key + + a1.Logger.Debug("key : %+v", key) + + valmap, err := rh.db.Get(a1MediatorNs, keys[:]) + + a1.Logger.Debug("policytype map : ", valmap) + + if len(valmap) == 0 { + a1.Logger.Error("policy type Not Present for policyid : %v", policyTypeId) + return policytypeschema + } + + if err != nil { + a1.Logger.Error("error in retrieving policy type. err: %v", err) + return policytypeschema + } + + if valmap[key] == nil { + a1.Logger.Error("policy type Not Present for policyid : %v", policyTypeId) + return policytypeschema + } + + a1.Logger.Debug("keysmap : %+v", valmap[key]) + + var item models.PolicyTypeSchema + valStr := fmt.Sprint(valmap[key]) + + a1.Logger.Debug("Policy type for %+v : %+v", key, valStr) + valkey := "`" + valStr + "`" + valToUnmarshall, err := strconv.Unquote(valkey) + if err != nil { + panic(err) + } + + a1.Logger.Debug("Policy type for %+v : %+v", key, string(b)) + errunm := json.Unmarshal([]byte(valToUnmarshall), &item) + + a1.Logger.Debug(" Unmarshalled json : %+v", (errunm)) + a1.Logger.Debug("Policy type Name : %v", (item.Name)) + + return &item +} + func (rh *Resthook) CreatePolicyType(policyTypeId models.PolicyTypeID, httprequest models.PolicyTypeSchema) error { a1.Logger.Debug("CreatePolicyType function") if policyTypeId != models.PolicyTypeID(*httprequest.PolicyTypeID) {