X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=RSM%2Fhandlers%2Frmrmsghandlers%2Fresource_status_failure_handler.go;fp=RSM%2Fhandlers%2Frmrmsghandlers%2Fresource_status_failure_handler.go;h=7ae11670989d882c76e2e8caf43a52122bfb0c05;hb=7b80668df78103cebafdfb7caa0070dc92ed3779;hp=0000000000000000000000000000000000000000;hpb=66db8f159a8034a65cc02f3ff4701cdfb908b496;p=ric-plt%2Fresource-status-manager.git diff --git a/RSM/handlers/rmrmsghandlers/resource_status_failure_handler.go b/RSM/handlers/rmrmsghandlers/resource_status_failure_handler.go new file mode 100644 index 0000000..7ae1167 --- /dev/null +++ b/RSM/handlers/rmrmsghandlers/resource_status_failure_handler.go @@ -0,0 +1,49 @@ +// +// Copyright 2019 AT&T Intellectual Property +// Copyright 2019 Nokia +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// + +package rmrmsghandlers + +import ( + "rsm/converters" + "rsm/e2pdus" + "rsm/logger" + "rsm/models" +) + +type ResourceStatusFailureHandler struct { + logger *logger.Logger + unpacker converters.Asn1PduUnpacker +} + +func NewResourceStatusFailureHandler(logger *logger.Logger, unpacker converters.Asn1PduUnpacker) ResourceStatusFailureHandler { + return ResourceStatusFailureHandler{ + logger:logger, + unpacker: unpacker, + } +} + +func (h ResourceStatusFailureHandler) Handle(request *models.RmrRequest) { + h.logger.Infof("#ResourceStatusFailureHandler.Handle - RAN name: %s - Received resource status failure notification", request.RanName) + pduAsString, err := h.unpacker.UnpackX2apPduAsString(request.Len, request.Payload, e2pdus.MaxAsn1CodecMessageBufferSize) + if err != nil { + h.logger.Errorf("#ResourceStatusFailureHandler.Handle - unpack failed. Error: %v", err) + } else { + h.logger.Infof("#ResourceStatusFailureHandler.Handle - RAN name: %s - message: %s", request.RanName, pduAsString) + } +} + +