Sync from Azure to LF
[ric-plt/resource-status-manager.git] / RSM / handlers / rmrmsghandlers / resource_status_failure_handler.go
diff --git a/RSM/handlers/rmrmsghandlers/resource_status_failure_handler.go b/RSM/handlers/rmrmsghandlers/resource_status_failure_handler.go
new file mode 100644 (file)
index 0000000..7ae1167
--- /dev/null
@@ -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)
+       }
+}
+
+