X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=pkg%2Frestapi%2Foperations%2Fa1_mediator%2Fa1_controller_create_or_replace_policy_instance_parameters.go;h=9bc2307199220241a3489bfc0211feaab1f89b30;hb=9138f03524117e1cc5eb42384dbf5be79cd33e9d;hp=e9b84987c49843af3d23d1e3806a8319d6edb5e7;hpb=b7a743adb64d9a737e505d54fbdbe46777551d06;p=ric-plt%2Fa1.git diff --git a/pkg/restapi/operations/a1_mediator/a1_controller_create_or_replace_policy_instance_parameters.go b/pkg/restapi/operations/a1_mediator/a1_controller_create_or_replace_policy_instance_parameters.go index e9b8498..9bc2307 100644 --- a/pkg/restapi/operations/a1_mediator/a1_controller_create_or_replace_policy_instance_parameters.go +++ b/pkg/restapi/operations/a1_mediator/a1_controller_create_or_replace_policy_instance_parameters.go @@ -37,7 +37,8 @@ import ( ) // NewA1ControllerCreateOrReplacePolicyInstanceParams creates a new A1ControllerCreateOrReplacePolicyInstanceParams object -// no default values defined in spec. +// +// There are no default values defined in the spec. func NewA1ControllerCreateOrReplacePolicyInstanceParams() A1ControllerCreateOrReplacePolicyInstanceParams { return A1ControllerCreateOrReplacePolicyInstanceParams{} @@ -56,6 +57,11 @@ type A1ControllerCreateOrReplacePolicyInstanceParams struct { In: body */ Body interface{} + /*URL send by non-RT RIC. This where non-RT RIC expects status updates on the policy creation + + In: query + */ + NotificationDestination *string /*represents a policy instance identifier. UUIDs are advisable but can be any string Required: true @@ -81,6 +87,8 @@ func (o *A1ControllerCreateOrReplacePolicyInstanceParams) BindRequest(r *http.Re o.HTTPRequest = r + qs := runtime.Values(r.URL.Query()) + if runtime.HasBody(r) { defer r.Body.Close() var body interface{} @@ -91,6 +99,12 @@ func (o *A1ControllerCreateOrReplacePolicyInstanceParams) BindRequest(r *http.Re o.Body = body } } + + qNotificationDestination, qhkNotificationDestination, _ := qs.GetOK("notificationDestination") + if err := o.bindNotificationDestination(qNotificationDestination, qhkNotificationDestination, route.Formats); err != nil { + res = append(res, err) + } + rPolicyInstanceID, rhkPolicyInstanceID, _ := route.Params.GetOK("policy_instance_id") if err := o.bindPolicyInstanceID(rPolicyInstanceID, rhkPolicyInstanceID, route.Formats); err != nil { res = append(res, err) @@ -100,13 +114,30 @@ func (o *A1ControllerCreateOrReplacePolicyInstanceParams) BindRequest(r *http.Re if err := o.bindPolicyTypeID(rPolicyTypeID, rhkPolicyTypeID, route.Formats); err != nil { res = append(res, err) } - if len(res) > 0 { return errors.CompositeValidationError(res...) } return nil } +// bindNotificationDestination binds and validates parameter NotificationDestination from query. +func (o *A1ControllerCreateOrReplacePolicyInstanceParams) bindNotificationDestination(rawData []string, hasKey bool, formats strfmt.Registry) error { + var raw string + if len(rawData) > 0 { + raw = rawData[len(rawData)-1] + } + + // Required: false + // AllowEmptyValue: false + + if raw == "" { // empty values pass all other validations + return nil + } + o.NotificationDestination = &raw + + return nil +} + // bindPolicyInstanceID binds and validates parameter PolicyInstanceID from path. func (o *A1ControllerCreateOrReplacePolicyInstanceParams) bindPolicyInstanceID(rawData []string, hasKey bool, formats strfmt.Registry) error { var raw string @@ -116,7 +147,6 @@ func (o *A1ControllerCreateOrReplacePolicyInstanceParams) bindPolicyInstanceID(r // Required: true // Parameter is provided by construction from the route - o.PolicyInstanceID = raw return nil @@ -148,11 +178,11 @@ func (o *A1ControllerCreateOrReplacePolicyInstanceParams) bindPolicyTypeID(rawDa // validatePolicyTypeID carries on validations for parameter PolicyTypeID func (o *A1ControllerCreateOrReplacePolicyInstanceParams) validatePolicyTypeID(formats strfmt.Registry) error { - if err := validate.MinimumInt("policy_type_id", "path", int64(o.PolicyTypeID), 1, false); err != nil { + if err := validate.MinimumInt("policy_type_id", "path", o.PolicyTypeID, 1, false); err != nil { return err } - if err := validate.MaximumInt("policy_type_id", "path", int64(o.PolicyTypeID), 2.147483647e+09, false); err != nil { + if err := validate.MaximumInt("policy_type_id", "path", o.PolicyTypeID, 2.147483647e+09, false); err != nil { return err }