2  * ============LICENSE_START========================================================================
 
   3  * ONAP : ccsdk feature sdnr wt
 
   4  * =================================================================================================
 
   5  * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved.
 
   6  * =================================================================================================
 
   7  * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
 
   8  * in compliance with the License. You may obtain a copy of the License at
 
  10  * http://www.apache.org/licenses/LICENSE-2.0
 
  12  * Unless required by applicable law or agreed to in writing, software distributed under the License
 
  13  * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
 
  14  * or implied. See the License for the specific language governing permissions and limitations under
 
  16  * ============LICENSE_END==========================================================================
 
  21 package org.onap.ccsdk.features.sdnr.wt.devicemanager.impl.util;
 
  23 import javax.annotation.Nonnull;
 
  24 import org.onap.ccsdk.features.sdnr.wt.devicemanager.types.InternalConnectionStatus;
 
  25 import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.Capabilities;
 
  26 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Host;
 
  27 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.PortNumber;
 
  28 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.node.topology.rev150114.NetconfNode;
 
  29 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.node.topology.rev150114.netconf.node.credentials.Credentials;
 
  30 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.node.topology.rev150114.netconf.node.credentials.credentials.LoginPassword;
 
  31 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.ConnectionLogStatus;
 
  32 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.NetworkElementConnectionBuilder;
 
  33 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.NetworkElementConnectionEntity;
 
  34 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.NetworkElementDeviceType;
 
  35 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.network.element.connection.entity.NodeDetailsBuilder;
 
  36 import org.opendaylight.yangtools.yang.common.QName;
 
  37 import org.slf4j.Logger;
 
  38 import org.slf4j.LoggerFactory;
 
  40 @SuppressWarnings("deprecation")
 
  41 public class NetworkElementConnectionEntitiyUtil {
 
  43     private static final Logger LOG = LoggerFactory.getLogger(NetworkElementConnectionEntitiyUtil.class);
 
  45     private static final QName QNAME_COREMODEL =
 
  46             QName.create("urn:onf:params:xml:ns:yang:core-model", "2017-03-20", "core-model").intern();
 
  50      * Update devicetype and let all other field empty
 
  52      * @param deviceType that should be updated
 
  53      * @return NetworkElementConnectionEntity with related parameter
 
  55     public static NetworkElementConnectionEntity getNetworkConnectionDeviceTpe(NetworkElementDeviceType deviceType) {
 
  56         NetworkElementConnectionBuilder eb = new NetworkElementConnectionBuilder();
 
  57         eb.setDeviceType(deviceType);
 
  62      * Provide device specific data
 
  64      * @param nodeId mountpoint id
 
  66      * @return NetworkElementConnectionEntity specific information
 
  68     public static NetworkElementConnectionEntity getNetworkConnection(String nodeId, @Nonnull NetconfNode nNode) {
 
  70         NetworkElementConnectionBuilder eb = new NetworkElementConnectionBuilder();
 
  72         eb.setId(nodeId).setNodeId(nodeId).setDeviceType(NetworkElementDeviceType.Unknown).setIsRequired(false);
 
  74         // -- connection status
 
  75         ConnectionLogStatus status = InternalConnectionStatus.statusFromNodeStatus(nNode.getConnectionStatus());
 
  79         Capabilities availableCapabilities = Capabilities.getAvailableCapabilities(nNode);
 
  80         Capabilities unAvailableCapabilities = Capabilities.getUnavailableCapabilities(nNode);
 
  82         eb.setCoreModelCapability(availableCapabilities.getRevisionForNamespace(QNAME_COREMODEL));
 
  84         NodeDetailsBuilder nodeDetails =
 
  85                 new NodeDetailsBuilder().setAvailableCapabilities(availableCapabilities.getCapabilities())
 
  86                         .setUnavailableCapabilities(unAvailableCapabilities.getCapabilities());
 
  87         eb.setNodeDetails(nodeDetails.build());
 
  88         // -- host information
 
  89         Host host = nNode.getHost();
 
  90         PortNumber portNumber = nNode.getPort();
 
  91         if (host != null && portNumber != null) {
 
  92             eb.setHost(host.stringValue()).setPort(portNumber.getValue().longValue());
 
  95         Credentials credentials = nNode.getCredentials();
 
  96         if (credentials instanceof LoginPassword) {
 
  97             LoginPassword loginPassword = (LoginPassword) credentials;
 
  98             eb.setUsername(loginPassword.getUsername()).setPassword(loginPassword.getPassword());