Move common code from clients to super class

Refactor existing client classes to make them more generic and ready for extensions

Signed-off-by: Rafal Wrzesniak <r.wrzesniak@partner.samsung.com>
Change-Id: Ibf41a7739e5df8254649b56a6bef64be0f1057cc
Signed-off-by: Rafal Wrzesniak <r.wrzesniak@partner.samsung.com>
Issue-ID: CCSDK-3455
diff --git a/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/DMaaPFaultVESMsgConsumer.java b/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/DMaaPFaultVESMsgConsumer.java
index 6daeb49..e21903b 100644
--- a/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/DMaaPFaultVESMsgConsumer.java
+++ b/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/DMaaPFaultVESMsgConsumer.java
@@ -3,6 +3,7 @@
  * ONAP : ccsdk feature sdnr wt
  * =================================================================================================
  * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved.
+ * Copyright (C) 2021 Samsung Electronics Intellectual Property. All rights reserved.
  * =================================================================================================
  * 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
@@ -23,6 +24,7 @@
 import java.io.IOException;
 import java.time.Instant;
 import java.time.ZoneId;
+import java.util.Map;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.SeverityType;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
@@ -96,10 +98,14 @@
             String sdnrUser = getSDNRUser();
             String sdnrPasswd = getSDNRPasswd();
 
-            FaultNotificationClient faultClient = getFaultNotificationClient(baseUrl);
+            Map<String, String> payloadMapMessage = FaultNotificationClient.createFaultNotificationPayloadMap(faultNodeId,
+                    Integer.toString(faultSequence), faultOccurrenceTime, faultObjectId, faultReason, faultSeverity);
+
+            FaultNotificationClient faultClient = new FaultNotificationClient(baseUrl);
+            LOG.debug("Setting RESTConf Authorization values - {} : {}", sdnrUser, sdnrPasswd);
             faultClient.setAuthorization(sdnrUser, sdnrPasswd);
-            faultClient.sendFaultNotification(faultNodeId, Integer.toString(faultSequence), faultOccurrenceTime,
-                    faultObjectId, faultReason, faultSeverity);
+            String message = faultClient.prepareMessageFromPayloadMap(payloadMapMessage);
+            faultClient.sendNotification(message);
 
         } catch (IOException e) {
             LOG.info("Cannot parse json object ");
diff --git a/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/DMaaPPNFRegVESMsgConsumer.java b/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/DMaaPPNFRegVESMsgConsumer.java
index 1d95ea5..d278a73 100644
--- a/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/DMaaPPNFRegVESMsgConsumer.java
+++ b/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/DMaaPPNFRegVESMsgConsumer.java
@@ -3,6 +3,7 @@
  * ONAP : ccsdk feature sdnr wt mountpoint-registrar
  * =================================================================================================
  * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved.
+ * Copyright (C) 2021 Samsung Electronics Intellectual Property. All rights reserved.
  * =================================================================================================
  * 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
@@ -21,6 +22,7 @@
 import com.fasterxml.jackson.databind.JsonNode;
 import com.fasterxml.jackson.databind.ObjectMapper;
 import java.io.IOException;
+import java.util.Map;
 import org.eclipse.jdt.annotation.Nullable;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
@@ -111,27 +113,35 @@
             String sdnrUser = getSDNRUser();
             String sdnrPasswd = getSDNRPasswd();
 
-            PNFMountPointClient mountpointClient = getPNFMountPointClient(baseUrl);
-            LOG.debug("Setting RESTConf Authorization values - {} : {}", sdnrUser, sdnrPasswd);
-            mountpointClient.setAuthorization(sdnrUser, sdnrPasswd);
-
-            if ((null != pnfId) && null != pnfIPAddress && (null != pnfCommProtocol) && (null != pnfUsername)
-                    && (null != pnfCommPort)) {
-                mountpointClient.pnfMountPointCreate(pnfId, pnfIPAddress, pnfCommProtocol, pnfKeyId, pnfUsername,
-                        pnfPasswd, pnfCommPort);
-            } else {
-                LOG.warn(
-                        "One of the mandatory fields has a null value - pnfId = {} : pnfIPAddress = {} : pnfCommProtocol = {} : pnfUsername {} : "
-                                + "pnfCommPort {}",
-                        pnfId, pnfIPAddress, pnfCommProtocol, pnfUsername, pnfCommPort,
-                        "- not invoking mountpoint creation");
+            if (hasNullInRequiredField(pnfId, pnfIPAddress, pnfCommPort, pnfCommProtocol, pnfUsername)) {
+                LOG.warn("One of the mandatory fields has a null value - pnfId = {} : pnfIPAddress = {} : " +
+                         "pnfCommProtocol = {} : pnfUsername {} : pnfCommPort {} - not invoking mountpoint creation",
+                          pnfId, pnfIPAddress, pnfCommProtocol, pnfUsername, pnfCommPort);
+                return;
             }
+
+            Map<String, String> payloadMap = PNFMountPointClient.createPNFNotificationPayloadMap(pnfId, pnfIPAddress,
+                    pnfCommPort, pnfCommProtocol, pnfUsername, pnfPasswd, pnfKeyId);
+
+            PNFMountPointClient mountPointClient = new PNFMountPointClient(baseUrl);
+            LOG.debug("Setting RESTConf Authorization values - {} : {}", sdnrUser, sdnrPasswd);
+            mountPointClient.setAuthorization(sdnrUser, sdnrPasswd);
+            String message = mountPointClient.prepareMessageFromPayloadMap(payloadMap);
+            mountPointClient.sendNotification(message);
+
         } catch (IOException e) {
             LOG.info("Cannot parse json object, ignoring the received PNF Registration VES Message. Reason: {}",
                     e.getMessage());
         }
     }
 
+    private boolean hasNullInRequiredField(String pnfId, String pnfIPAddress, String pnfCommPort,
+                                           String pnfCommProtocol, String pnfUsername) {
+
+        return pnfId == null || pnfIPAddress == null || pnfCommProtocol == null ||
+                pnfCommPort == null || pnfUsername == null;
+    }
+
     private String getPNFIPAddress(JsonNode dmaapMessageRootNode) {
         String ipAddress = dmaapMessageRootNode.at("/event/pnfRegistrationFields/oamV6IpAddress").textValue();
         if (ipAddress != null && ipAddress != "")
diff --git a/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/FaultNotificationClient.java b/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/FaultNotificationClient.java
index 11f46ff..6851475 100644
--- a/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/FaultNotificationClient.java
+++ b/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/FaultNotificationClient.java
@@ -3,6 +3,7 @@
  * ONAP : ccsdk feature sdnr wt
  * =================================================================================================
  * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved.
+ * Copyright (C) 2021 Samsung Electronics Intellectual Property. All rights reserved.
  * =================================================================================================
  * 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
@@ -18,86 +19,57 @@
 
 package org.onap.ccsdk.features.sdnr.wt.mountpointregistrar.impl;
 
-import java.io.IOException;
-import java.util.Base64;
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
-import org.onap.ccsdk.features.sdnr.wt.common.http.BaseHTTPClient;
-import org.onap.ccsdk.features.sdnr.wt.common.http.BaseHTTPResponse;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
 
-public class FaultNotificationClient extends BaseHTTPClient {
+import static org.onap.ccsdk.features.sdnr.wt.mountpointregistrar.impl.MessageClient.MessageType.*;
+import static org.onap.ccsdk.features.sdnr.wt.mountpointregistrar.impl.MessageClient.SendMethod.*;
 
-    private static final Logger LOG = LoggerFactory.getLogger(FaultNotificationClient.class);
+
+public class FaultNotificationClient extends MessageClient {
+
     private static final String FAULT_NOTIFICATION_URI = "restconf/operations/devicemanager:push-fault-notification";
-    private final Map<String, String> headerMap;
+    public static final String NODE_ID = "@node-id@", COUNTER = "@counter@", TIMESTAMP = "@timestamp@",
+            OBJECT_ID = "@object-id@", PROBLEM = "@problem@", SEVERITY = "@severity@";
+    public static final List<String> REQUIRED_FIELDS = List.of(NODE_ID, COUNTER, TIMESTAMP, OBJECT_ID, PROBLEM, SEVERITY);
 
-    // @formatter:off
     private static final String FAULT_PAYLOAD = "{\n"
             + "  \"devicemanager:input\": {\n"
-            + "    \"devicemanager:node-id\": \"@node-id@\",\n"
-            + "    \"devicemanager:counter\": \"@counter@\",\n"
-            + "    \"devicemanager:timestamp\": \"@timestamp@\",\n"
-            + "    \"devicemanager:object-id\": \"@object-id@\",\n"
-            + "    \"devicemanager:problem\": \"@problem@\",\n"
-            + "    \"devicemanager:severity\": \"@severity@\"\n"
+            + "    \"devicemanager:node-id\": \"" + NODE_ID + "\",\n"
+            + "    \"devicemanager:counter\": \"" + COUNTER + "\",\n"
+            + "    \"devicemanager:timestamp\": \"" + TIMESTAMP + "\",\n"
+            + "    \"devicemanager:object-id\": \"" + OBJECT_ID + "\",\n"
+            + "    \"devicemanager:problem\": \"" + PROBLEM + "\",\n"
+            + "    \"devicemanager:severity\": \"" + SEVERITY + "\"\n"
             + "  }\n"
             + "}";
-    // @formatter:on
 
 
     public FaultNotificationClient(String baseUrl) {
-        super(baseUrl);
-
-        this.headerMap = new HashMap<>();
-        this.headerMap.put("Content-Type", "application/json");
-        this.headerMap.put("Accept", "application/json");
+        super(baseUrl, FAULT_NOTIFICATION_URI);
     }
 
-    public void setAuthorization(String username, String password) {
-        String credentials = username + ":" + password;
-        this.headerMap.put("Authorization", "Basic " + new String(Base64.getEncoder().encode(credentials.getBytes())));
-
+    @Override
+    public String prepareMessageFromPayloadMap(Map<String, String> notificationPayloadMap) {
+        return super.prepareMessageFromPayloadMap(notificationPayloadMap, FAULT_PAYLOAD, REQUIRED_FIELDS);
     }
 
-    public boolean sendFaultNotification(String faultNodeId, String faultCounter, String faultOccurrenceTime,
-            String faultObjectId, String faultReason, String faultSeverity) {
-        String message = "";
-
-        message = updateFaultPayload(faultNodeId, faultCounter, faultOccurrenceTime, faultObjectId, faultReason,
-                faultSeverity);
-
-        LOG.debug("Payload after updating values is: {}",message);
-
-        return sendFaultRequest("POST", message) == 200;
-
+    @Override
+    public boolean sendNotification(String message) {
+        return super.sendNotification(message, POST, json);
     }
 
-    private static String updateFaultPayload(String faultNodeId, String faultCounter, String faultOccurrenceTime,
-            String faultObjectId, String faultReason, String faultSeverity) {
-        // @formatter:off
-        return FAULT_PAYLOAD.replace("@node-id@", faultNodeId)
-                .replace("@counter@", faultCounter)
-                .replace("@timestamp@", faultOccurrenceTime)
-                .replace("@object-id@", faultObjectId)
-                .replace("@problem@", faultReason)
-                .replace("@severity@", faultSeverity);
-        // @formatter:on
+    public static Map<String, String> createFaultNotificationPayloadMap(String nodeId, String counter, String timestamp,
+                                                                        String objectId, String problem, String severity) {
+        HashMap<String, String> map = new HashMap<>();
+        map.put(NODE_ID, nodeId);
+        map.put(COUNTER, counter);
+        map.put(TIMESTAMP, timestamp);
+        map.put(OBJECT_ID, objectId);
+        map.put(PROBLEM, problem);
+        map.put(SEVERITY, severity);
+        return map;
     }
 
-
-    private int sendFaultRequest(String method, String message) {
-        LOG.debug("In sendFaultRequest - {}-{}",method,message);
-        BaseHTTPResponse response;
-        try {
-            String uri = FAULT_NOTIFICATION_URI;
-            response = this.sendRequest(uri, method, message, headerMap);
-            LOG.debug("finished with responsecode {}", response.code);
-            return response.code;
-        } catch (IOException e) {
-            LOG.warn("problem sending fault message {}", e.getMessage());
-            return -1;
-        }
-    }
 }
diff --git a/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/MessageClient.java b/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/MessageClient.java
new file mode 100644
index 0000000..534dbde
--- /dev/null
+++ b/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/MessageClient.java
@@ -0,0 +1,108 @@
+/*
+ * Copyright (C) 2021 Samsung Electronics
+ * 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 org.onap.ccsdk.features.sdnr.wt.mountpointregistrar.impl;
+
+import java.io.IOException;
+import java.util.Base64;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import org.onap.ccsdk.features.sdnr.wt.common.http.BaseHTTPClient;
+import org.onap.ccsdk.features.sdnr.wt.common.http.BaseHTTPResponse;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+public abstract class MessageClient extends BaseHTTPClient {
+
+    private static final Logger LOG = LoggerFactory.getLogger(MessageClient.class);
+    protected final Map<String, String> headerMap;
+    private String notificationUri;
+
+    protected enum SendMethod {
+        PUT, POST
+    }
+
+    protected enum MessageType {
+        xml, json
+    }
+
+    public MessageClient(String baseUrl, String notificationUri) {
+        super(baseUrl);
+        setNotificationUri(notificationUri);
+        headerMap = new HashMap<>();
+    }
+
+    public void setAuthorization(String username, String password) {
+        String credentials = username + ":" + password;
+        headerMap.put("Authorization", "Basic " + new String(Base64.getEncoder().encode(credentials.getBytes())));
+    }
+
+
+    public abstract String prepareMessageFromPayloadMap(Map<String, String> notificationPayloadMapMessage);
+
+    protected String prepareMessageFromPayloadMap(Map<String, String> payloadMapMessage, String messagePayload,
+                                                  List<String> requiredFields) {
+        String message = "";
+        if (inputMapHasAllRequiredFields(payloadMapMessage, requiredFields)) {
+            message = insertValuesToPayload(payloadMapMessage, messagePayload);
+        } else {
+            LOG.warn("Input map is missing required fields.");
+        }
+        return message;
+    }
+
+    private boolean inputMapHasAllRequiredFields(Map<String, String> mapToValidate, List<String> requiredFields) {
+        if (mapToValidate == null || mapToValidate.isEmpty()) {
+            return false;
+        }
+        for (String requiredField : requiredFields) {
+            if (!mapToValidate.containsKey(requiredField)) {
+                LOG.warn("Missing required field {}", requiredField);
+                return false;
+            }
+        }
+        return true;
+    }
+
+    private String insertValuesToPayload(Map<String, String> payloadMapMessage, String payload) {
+        for (Map.Entry<String, String> entry : payloadMapMessage.entrySet()) {
+            payload = payload.replace(entry.getKey(), entry.getValue() != null ? entry.getValue() : "null");
+        }
+        return payload;
+    }
+
+
+    public abstract boolean sendNotification(String message);
+
+    protected boolean sendNotification(String message, SendMethod method, MessageType messageType) {
+        LOG.debug("In sendRequestNotification - {}-{}", method, message);
+        headerMap.put("Content-Type", "application/".concat(messageType.toString()));
+        headerMap.put("Accept", "application/".concat(messageType.toString()));
+        BaseHTTPResponse response;
+        try {
+            response = sendRequest(notificationUri, method.toString(), message, headerMap);
+        } catch (IOException e) {
+            LOG.warn("Problem sending fault message: {}", e.getMessage());
+            return false;
+        }
+        LOG.debug("Finished with response code {}", response.code);
+        return response.isSuccess();
+    }
+
+    protected void setNotificationUri(String notificationUri) {
+        this.notificationUri = notificationUri;
+    }
+
+
+}
diff --git a/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/PNFMountPointClient.java b/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/PNFMountPointClient.java
index b271e8a..961f7fe 100644
--- a/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/PNFMountPointClient.java
+++ b/sdnr/wt/mountpoint-registrar/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/impl/PNFMountPointClient.java
@@ -3,6 +3,7 @@
  * ONAP : ccsdk feature sdnr wt
  * =================================================================================================
  * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved.
+ * Copyright (C) 2021 Samsung Electronics Intellectual Property. All rights reserved.
  * =================================================================================================
  * 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
@@ -18,32 +19,32 @@
 
 package org.onap.ccsdk.features.sdnr.wt.mountpointregistrar.impl;
 
-import java.io.IOException;
-import java.util.Base64;
-import java.util.HashMap;
-import java.util.Map;
-import java.util.regex.Matcher;
-import java.util.regex.Pattern;
 import org.eclipse.jdt.annotation.NonNull;
 import org.onap.ccsdk.features.sdnr.wt.common.database.requests.BaseRequest;
-import org.onap.ccsdk.features.sdnr.wt.common.http.BaseHTTPClient;
-import org.onap.ccsdk.features.sdnr.wt.common.http.BaseHTTPResponse;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
 
-public class PNFMountPointClient extends BaseHTTPClient {
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
 
-    private static final Logger LOG = LoggerFactory.getLogger(PNFMountPointClient.class);
+import static org.onap.ccsdk.features.sdnr.wt.mountpointregistrar.impl.MessageClient.MessageType.*;
+import static org.onap.ccsdk.features.sdnr.wt.mountpointregistrar.impl.MessageClient.SendMethod.PUT;
+
+public class PNFMountPointClient extends MessageClient {
+
     private static final String MOUNTPOINT_URI =
             "restconf/config/network-topology:network-topology/topology/topology-netconf/node/";
-    private final Map<String, String> headerMap;
-    // @formatter:off
+    public static final String DEVICE_NAME = "@device-name@", DEVICE_IP = "@device-ip@", DEVICE_PORT = "@device-port@",
+            USERNAME = "@username@", PASSWORD = "@password@", KEY_ID = "@key-id@";
+    private static final String PROTOCOL = "protocol";
+    public static List<String> REQUIRED_FIELDS_SSH = List.of(PROTOCOL, DEVICE_NAME, DEVICE_IP, DEVICE_PORT, USERNAME, PASSWORD);
+    public static List<String> REQUIRED_FIELDS_TLS = List.of(PROTOCOL, DEVICE_NAME, DEVICE_IP, DEVICE_PORT, USERNAME, KEY_ID);
+
     private static final String SSH_PAYLOAD = "<node xmlns=\"urn:TBD:params:xml:ns:yang:network-topology\">\n"
-            + "  <node-id>@device-name@</node-id>\n"
-            + "  <host xmlns=\"urn:opendaylight:netconf-node-topology\">@device-ip@</host>\n"
-            + "  <port xmlns=\"urn:opendaylight:netconf-node-topology\">@device-port@</port>\n"
-            + "  <username xmlns=\"urn:opendaylight:netconf-node-topology\">@username@</username>\n"
-            + "  <password xmlns=\"urn:opendaylight:netconf-node-topology\">@password@</password>\n"
+            + "  <node-id>" + DEVICE_NAME + "</node-id>\n"
+            + "  <host xmlns=\"urn:opendaylight:netconf-node-topology\">" + DEVICE_IP + "</host>\n"
+            + "  <port xmlns=\"urn:opendaylight:netconf-node-topology\">" + DEVICE_PORT + "</port>\n"
+            + "  <username xmlns=\"urn:opendaylight:netconf-node-topology\">" + USERNAME + "</username>\n"
+            + "  <password xmlns=\"urn:opendaylight:netconf-node-topology\">" + PASSWORD + "</password>\n"
             + "  <tcp-only xmlns=\"urn:opendaylight:netconf-node-topology\">false</tcp-only>\n"
             + "  <!-- non-mandatory fields with default values, you can safely remove these if you do not wish to override any of these values-->\n"
             + "  <reconnect-on-changed-schema xmlns=\"urn:opendaylight:netconf-node-topology\">false</reconnect-on-changed-schema>\n"
@@ -54,15 +55,14 @@
             + "  <!-- keepalive-delay set to 0 turns off keepalives-->\n"
             + "  <keepalive-delay xmlns=\"urn:opendaylight:netconf-node-topology\">120</keepalive-delay>\n"
             + "</node>";
-    // @formatter:on
-    // @formatter:off
+
     private static final String TLS_PAYLOAD = "<node xmlns=\"urn:TBD:params:xml:ns:yang:network-topology\">\n"
-            + "  <node-id>@device-name@</node-id>\n"
-            + "  <host xmlns=\"urn:opendaylight:netconf-node-topology\">@device-ip@</host>\n"
-            + "  <port xmlns=\"urn:opendaylight:netconf-node-topology\">@device-port@</port>\n"
+            + "  <node-id>" + DEVICE_NAME + "</node-id>\n"
+            + "  <host xmlns=\"urn:opendaylight:netconf-node-topology\">" + DEVICE_IP + "</host>\n"
+            + "  <port xmlns=\"urn:opendaylight:netconf-node-topology\">" + DEVICE_PORT + "</port>\n"
             + "  <key-based xmlns=\"urn:opendaylight:netconf-node-topology\">\n"
-            + "  <username xmlns=\"urn:opendaylight:netconf-node-topology\">@username@</username>\n"
-            + "  <key-id>@key-id@</key-id>\n"
+            + "  <username xmlns=\"urn:opendaylight:netconf-node-topology\">" + USERNAME + "</username>\n"
+            + "  <key-id>" + KEY_ID + "</key-id>\n"
             + "  </key-based>\n"
             + "  <tcp-only xmlns=\"urn:opendaylight:netconf-node-topology\">false</tcp-only>\n"
             + "  <protocol xmlns=\"urn:opendaylight:netconf-node-topology\">\n"
@@ -77,81 +77,48 @@
             + "<!-- keepalive-delay set to 0 turns off keepalives-->\n"
             + "<keepalive-delay xmlns=\"urn:opendaylight:netconf-node-topology\">120</keepalive-delay>\n"
             + "</node>";
-    // @formatter:on
+
 
     public PNFMountPointClient(String baseUrl) {
-        super(baseUrl);
-
-        this.headerMap = new HashMap<>();
-        this.headerMap.put("Content-Type", "application/xml");
-        this.headerMap.put("Accept", "application/xml");
+        super(baseUrl, MOUNTPOINT_URI);
     }
 
-    public void setAuthorization(String username, String password) {
-        String credentials = username + ":" + password;
-        this.headerMap.put("Authorization", "Basic " + new String(Base64.getEncoder().encode(credentials.getBytes())));
-
-    }
-
-    public boolean pnfMountPointCreate(@NonNull String pnfName, @NonNull String ipAddress, @NonNull String protocol, String keyId,
-            String username, String password, @NonNull String commPort) {
+    @Override
+    public String prepareMessageFromPayloadMap(Map<String, String> notificationPayloadMap) {
+        updateNotificationUriWithPnfName(notificationPayloadMap.get(DEVICE_NAME));
         String message = "";
-        if (protocol.equals("TLS")) {
-            message = updateTLSPayload(pnfName, ipAddress, username, keyId, commPort);
-        } else { //SSH
-            message = updatePayload(pnfName, ipAddress, username, password, commPort);
+        if(!notificationPayloadMap.containsKey(PROTOCOL)) {
+            return message;
         }
-        LOG.debug("Payload after updating values is: {}", redactMessage(message, protocol));
-        return pnfRequest(pnfName, "PUT", message) == 200;
-
-    }
-
-    private static String updatePayload(String pnfName, String ipAddress, String username, String password,
-            String portNo) {
-        // @formatter:off
-        return SSH_PAYLOAD.replace("@device-name@", pnfName)
-                .replace("@device-ip@", ipAddress)
-                .replace("@device-port@", portNo)
-                .replace("@username@", username)
-                .replace("@password@", password);
-        // @formatter:on
-    }
-
-    private static String updateTLSPayload(String pnfName, String ipAddress, String username, String keyId,
-            String portNo) {
-        // @formatter:off
-        return TLS_PAYLOAD.replace("@device-name@", pnfName)
-                .replace("@device-ip@", ipAddress)
-                .replace("@username@", username)
-                .replace("@key-id@", keyId)
-                .replace("@device-port@", portNo);
-        // @formatter:on
-    }
-
-    private int pnfRequest(String pnfName, String method, String message) {
-        LOG.info("In pnfRequest - {} : {} ", pnfName, method);
-        BaseHTTPResponse response;
-        try {
-            String uri = MOUNTPOINT_URI + BaseRequest.urlEncodeValue(pnfName);
-            response = this.sendRequest(uri, method, message, headerMap);
-            LOG.debug("finished with responsecode {}", response.code);
-            return response.code;
-        } catch (IOException e) {
-            LOG.warn("problem registering {} : {}", pnfName, e.getMessage());
-            return -1;
+        if(notificationPayloadMap.get(PROTOCOL).equals("SSH")) {
+            message = super.prepareMessageFromPayloadMap(notificationPayloadMap, SSH_PAYLOAD, REQUIRED_FIELDS_SSH);
+        } else if(notificationPayloadMap.get(PROTOCOL).equals("TLS")) {
+            message = super.prepareMessageFromPayloadMap(notificationPayloadMap, TLS_PAYLOAD, REQUIRED_FIELDS_TLS);
         }
+        return message;
     }
 
-    private String redactMessage(String message, String protocol) {
-        String REGEX = "";
-        if (("TLS").equals(protocol)) {
-            REGEX = "(<key-id.*>)(.*)(<\\/key-id>)";
-        } else {
-            REGEX = "(<password.*>)(.*)(<\\/password>)";
-        }
-        Pattern p = Pattern.compile(REGEX, Pattern.MULTILINE);
-        Matcher matcher = p.matcher(message);
-        return matcher.replaceAll("$1*********$3");
+    private void updateNotificationUriWithPnfName(String pnfName) {
+        setNotificationUri(MOUNTPOINT_URI + BaseRequest.urlEncodeValue(pnfName));
+    }
+
+    @Override
+    public boolean sendNotification(String message) {
+        return super.sendNotification(message, PUT, xml);
+    }
+
+    public static Map<String, String> createPNFNotificationPayloadMap(@NonNull String pnfName, @NonNull String ipAddress,
+                                                                      @NonNull String commPort, @NonNull String protocol,
+                                                                      String username, String password, String keyId) {
+        HashMap<String, String> map = new HashMap<>();
+        map.put(DEVICE_NAME, pnfName);
+        map.put(DEVICE_IP, ipAddress);
+        map.put(DEVICE_PORT, commPort);
+        map.put(PROTOCOL, protocol);
+        map.put(USERNAME, username);
+        map.put(PASSWORD, password);
+        map.put(KEY_ID, keyId);
+        return map;
     }
 
 }
diff --git a/sdnr/wt/mountpoint-registrar/provider/src/test/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/test/TestFaultNotificationClient.java b/sdnr/wt/mountpoint-registrar/provider/src/test/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/test/TestFaultNotificationClient.java
index 9fb35e6..fa289aa 100644
--- a/sdnr/wt/mountpoint-registrar/provider/src/test/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/test/TestFaultNotificationClient.java
+++ b/sdnr/wt/mountpoint-registrar/provider/src/test/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/test/TestFaultNotificationClient.java
@@ -3,6 +3,7 @@
  * ONAP : ccsdk feature sdnr wt
  * =================================================================================================
  * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved.
+ * Copyright (C) 2021 Samsung Electronics Intellectual Property. All rights reserved.
  * =================================================================================================
  * 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
@@ -18,7 +19,7 @@
 
 package org.onap.ccsdk.features.sdnr.wt.mountpointregistrar.test;
 
-import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertTrue;
 import java.io.IOException;
 import java.util.Map;
 import javax.annotation.Nonnull;
@@ -41,10 +42,12 @@
     public void testFaultNotificationClient() {
         testClient = new TestFaultNotificationClient();
         testClient.setAuthorization("admin", "admin");
-        assertEquals(true, testClient.sendFaultNotification("TEST_50001", "1", "2019-11-20T09:25:19.948Z",
-                "SEDNKSAHQ01M01nSky01", "lossOfSignal", "Critical"));
-        assertEquals(true, testClient.sendFaultNotification("TEST_50001", "1", "2019-11-20T09:25:19.948Z",
-                "SEDNKSAHQ01M01nSky01", "lossOfSignal", "Critical"));
+        Map<String, String> payloadMap = FaultNotificationClient.createFaultNotificationPayloadMap(
+                "TEST_50001", "1", "2019-11-20T09:25:19.948Z",
+                "SEDNKSAHQ01M01nSky01", "lossOfSignal", "Critical");
+        String msg = testClient.prepareMessageFromPayloadMap(payloadMap);
+        assertTrue(testClient.sendNotification(msg));
+        assertTrue(testClient.sendNotification(msg));
     }
 
     @Override
diff --git a/sdnr/wt/mountpoint-registrar/provider/src/test/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/test/TestPNFMountPointClient.java b/sdnr/wt/mountpoint-registrar/provider/src/test/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/test/TestPNFMountPointClient.java
index ad87c20..9db9071 100644
--- a/sdnr/wt/mountpoint-registrar/provider/src/test/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/test/TestPNFMountPointClient.java
+++ b/sdnr/wt/mountpoint-registrar/provider/src/test/java/org/onap/ccsdk/features/sdnr/wt/mountpointregistrar/test/TestPNFMountPointClient.java
@@ -3,6 +3,7 @@
  * ONAP : ccsdk feature sdnr wt
  * =================================================================================================
  * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved.
+ * Copyright (C) 2021 Samsung Electronics Intellectual Property. All rights reserved.
  * =================================================================================================
  * 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
@@ -18,7 +19,7 @@
 
 package org.onap.ccsdk.features.sdnr.wt.mountpointregistrar.test;
 
-import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertTrue;
 import java.io.IOException;
 import java.util.Map;
 import javax.annotation.Nonnull;
@@ -41,11 +42,14 @@
     public void testPNFMountPointClient() {
         testClient = new TestPNFMountPointClient();
         testClient.setAuthorization("admin", "admin");
-        assertEquals(true,
-                testClient.pnfMountPointCreate("TEST 50001", "127.0.0.1", "TLS", "key_id", "admin", "admin", "17380"));
+        Map<String, String> payloadMap = PNFMountPointClient.createPNFNotificationPayloadMap(
+                "TEST 50001", "127.0.0.1", "TLS", "key_id",
+                "admin", "admin", "17380");
+        String msg = testClient.prepareMessageFromPayloadMap(payloadMap);
 
-        assertEquals(true,
-                testClient.pnfMountPointCreate("TEST_50001", "127.0.0.1", "SSH", "key_id", "admin", "admin", "17380"));
+        assertTrue(testClient.sendNotification(msg));
+        assertTrue(testClient.sendNotification(msg));
+
     }
 
     @Override