Testcase for Get policy type from policy id
[ric-plt/a1.git] / a1-go / pkg / resthooks / resthooks.go
index 5194f37..54ca39d 100644 (file)
 package resthooks
 
 import (
+       "encoding/json"
+       "errors"
+       "fmt"
        "strconv"
        "strings"
 
-       "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/a1"
-       "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/models"
+       "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/a1"
+       "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/models"
        "gerrit.o-ran-sc.org/r/ric-plt/sdlgo"
 )
 
+const (
+       a1PolicyPrefix = "a1.policy_type."
+       a1MediatorNs   = "A1m_ns"
+)
+
+var typeAlreadyError = errors.New("Policy Type already exists")
+var typeMismatchError = errors.New("Policytype Mismatch")
+
+func (rh *Resthook) IsTypeAlready(err error) bool {
+       return err == typeAlreadyError
+}
+func (rh *Resthook) IsTypeMismatch(err error) bool {
+       return err == typeMismatchError
+}
 func NewResthook() *Resthook {
        return createResthook(sdlgo.NewSyncStorage())
 }
@@ -46,19 +63,95 @@ func (rh *Resthook) GetAllPolicyType() []models.PolicyTypeID {
        keys, err := rh.db.GetAll("A1m_ns")
 
        if err != nil {
-               a1.Logger.Error("error in retrieving policy. err: %v", err)
+               a1.Logger.Error("error in retrieving policy. err: %v", err)
                return policyTypeIDs
        }
-       a1.Logger.Debug("keys : %+v", keys)
+       a1.Logger.Debug("keys : %+v", keys)
 
        for _, key := range keys {
-               if strings.HasPrefix(strings.TrimLeft(key, " "), "a1.policy_type.") {
-                       pti := strings.Split(strings.Trim(key, " "), "a1.policy_type.")[1]
+               if strings.HasPrefix(strings.TrimLeft(key, " "), a1PolicyPrefix) {
+                       pti := strings.Split(strings.Trim(key, " "), a1PolicyPrefix)[1]
                        ptii, _ := strconv.ParseInt(pti, 10, 64)
                        policyTypeIDs = append(policyTypeIDs, models.PolicyTypeID(ptii))
                }
        }
 
-       a1.Logger.Debug("return : %+v", policyTypeIDs)
+       a1.Logger.Debug("return : %+v", policyTypeIDs)
        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) {
+               //error message
+               a1.Logger.Debug("Policytype Mismatch")
+               return typeMismatchError
+       }
+       key := a1PolicyPrefix + strconv.FormatInt((int64(policyTypeId)), 10)
+       a1.Logger.Debug("key %+v ", key)
+       if data, err := httprequest.MarshalBinary(); err == nil {
+               a1.Logger.Debug("Marshaled String : %+v", string(data))
+               success, err1 := rh.db.SetIfNotExists(a1MediatorNs, key, string(data))
+               a1.Logger.Info("success:%+v", success)
+               if err1 != nil {
+                       a1.Logger.Error("error :%+v", err1)
+                       return err1
+               }
+               if !success {
+                       a1.Logger.Debug("Policy type %+v already exist", policyTypeId)
+                       return typeAlreadyError
+               }
+       }
+       return nil
+}