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==========================================================================
18 package org.onap.ccsdk.features.sdnr.wt.devicemanager.impl.util;
20 import javax.annotation.Nonnull;
21 import org.onap.ccsdk.features.sdnr.wt.devicemanager.types.InternalConnectionStatus;
22 import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.Capabilities;
23 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Host;
24 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.PortNumber;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.node.topology.rev150114.NetconfNode;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.node.topology.rev150114.netconf.node.credentials.Credentials;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.node.topology.rev150114.netconf.node.credentials.credentials.LoginPassword;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.ConnectionLogStatus;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.NetworkElementConnectionBuilder;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.NetworkElementConnectionEntity;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.NetworkElementDeviceType;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.network.element.connection.entity.NodeDetailsBuilder;
33 import org.slf4j.Logger;
34 import org.slf4j.LoggerFactory;
36 @SuppressWarnings("deprecation")
37 public class NetworkElementConnectionEntitiyUtil {
39 private static final Logger LOG = LoggerFactory.getLogger(NetworkElementConnectionEntitiyUtil.class);
42 * Update devicetype and let all other field empties
44 * @param deviceType that should be updated
45 * @return NetworkElementConnectionEntity with related parameter
47 public static NetworkElementConnectionEntity getNetworkConnectionDeviceTpe(NetworkElementDeviceType deviceType) {
48 NetworkElementConnectionBuilder eb = new NetworkElementConnectionBuilder();
49 eb.setDeviceType(deviceType);
54 * Provide device specific data
56 * @param nodeId mountpoint id
58 * @return NetworkElementConnectionEntity specific information
60 public static NetworkElementConnectionEntity getNetworkConnection(String nodeId, @Nonnull NetconfNode nNode) {
62 NetworkElementConnectionBuilder eb = new NetworkElementConnectionBuilder();
64 eb.setId(nodeId).setNodeId(nodeId).setDeviceType(NetworkElementDeviceType.Unknown).setIsRequired(false);
66 // -- connection status
67 ConnectionLogStatus status = InternalConnectionStatus.statusFromNodeStatus(nNode.getConnectionStatus());
71 Capabilities availableCapabilities = Capabilities.getAvailableCapabilities(nNode);
72 Capabilities unAvailableCapabilities = Capabilities.getUnavailableCapabilities(nNode);
74 NodeDetailsBuilder nodeDetails =
75 new NodeDetailsBuilder().setAvailableCapabilities(availableCapabilities.getCapabilities())
76 .setUnavailableCapabilities(unAvailableCapabilities.getCapabilities());
77 eb.setNodeDetails(nodeDetails.build());
78 // -- host information
79 Host host = nNode.getHost();
80 PortNumber portNumber = nNode.getPort();
81 if (host != null && portNumber != null) {
82 eb.setHost(host.stringValue()).setPort(portNumber.getValue().longValue());
85 Credentials credentials = nNode.getCredentials();
86 if (credentials instanceof LoginPassword) {
87 LoginPassword loginPassword = (LoginPassword) credentials;
88 eb.setUsername(loginPassword.getUsername()).setPassword(loginPassword.getPassword());
90 eb.setCoreModelCapability("Unsupported"); // Default value. Specific value (if any) is set in the specific devicemanagers