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=0a832ff9e605704ec7202c71ee9dd8fed71f86c2;hb=ab3e9ee563b7467bcda8ebbc4187b971690599d2;hp=5194f375752558bb53381d138c6a3f91eebb62bc;hpb=5e1198877328ed29a72e67c585825f8362b4d862;p=ric-plt%2Fa1.git diff --git a/a1-go/pkg/resthooks/resthooks.go b/a1-go/pkg/resthooks/resthooks.go index 5194f37..0a832ff 100644 --- a/a1-go/pkg/resthooks/resthooks.go +++ b/a1-go/pkg/resthooks/resthooks.go @@ -21,14 +21,29 @@ package resthooks import ( + "errors" "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 +61,44 @@ 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) 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 +}