"log"
"os"
- "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/a1"
- "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/restapi"
- "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/restapi/operations"
- "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/restapi/operations/a1_mediator"
- "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/resthooks"
+ "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/restapi"
+ "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/restapi/operations"
+ "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/restapi/operations/a1_mediator"
+ "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/resthooks"
"github.com/go-openapi/loads"
"github.com/go-openapi/runtime/middleware"
)
api := operations.NewA1API(swaggerSpec)
api.A1MediatorA1ControllerGetAllPolicyTypesHandler = a1_mediator.A1ControllerGetAllPolicyTypesHandlerFunc(func(param a1_mediator.A1ControllerGetAllPolicyTypesParams) middleware.Responder {
- a1.Logger.Debug("handler for get all all policy type")
+ a1.Logger.Debug("handler for get all policy type")
return a1_mediator.NewA1ControllerGetAllPolicyTypesOK().WithPayload(r.rh.GetAllPolicyType())
})
+
+ api.A1MediatorA1ControllerCreatePolicyTypeHandler = a1_mediator.A1ControllerCreatePolicyTypeHandlerFunc(func(params a1_mediator.A1ControllerCreatePolicyTypeParams) middleware.Responder {
+ a1.Logger.Debug("handler for get policy type from policytypeID")
+ if err = r.rh.CreatePolicyType(models.PolicyTypeID(params.PolicyTypeID), *params.Body); err == nil {
+ //Increase prometheus counter
+ return a1_mediator.NewA1ControllerCreatePolicyTypeCreated()
+ }
+ if r.rh.IsTypeAlready(err) || r.rh.IsTypeMismatch(err) {
+ return a1_mediator.NewA1ControllerCreatePolicyTypeBadRequest()
+ }
+ return a1_mediator.NewA1ControllerCreatePolicyTypeServiceUnavailable()
+
+ })
+
return api
}
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())
}
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
+}
"os"
"testing"
- "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/a1"
+ "gerrit.o-ran-sc.org/r/ric-plt/a1/pkg/a1"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/mock"
)
func TestMain(m *testing.M) {
sdlInst = new(SdlMock)
- sdlInst.On("GetAll", "A1m_ns").Return([]string{"a1.policy_instance.1006001.qos",
- "a1.policy_type.1006001",
- "a1.policy_type.20000",
- "a1.policy_inst_metadata.1006001.qos",
- }, nil)
+ sdlInst.On("GetAll", "A1m_ns").Return([]string{"a1.policy_instance.1006001.qos",
+ "a1.policy_type.1006001",
+ "a1.policy_type.20000",
+ "a1.policy_inst_metadata.1006001.qos",
+ }, nil)
- a1.Init()
+ a1.Init()
rh = createResthook(sdlInst)
code := m.Run()
os.Exit(code)
}
func (s *SdlMock) GetAll(ns string) ([]string, error) {
- args := s.MethodCalled("GetAll", ns)
- return args.Get(0).([]string), nil
+ args := s.MethodCalled("GetAll", ns)
+ return args.Get(0).([]string), nil
+}
+
+func (s *SdlMock) SetIfNotExists(ns string, key string, data interface{}) (bool, error) {
+ return true, nil
}
type iSdl interface {
GetAll(string) ([]string, error)
+ SetIfNotExists(ns string, key string, data interface{}) (bool, error)
}