23c79f7638304bafe61f0926e76dc19d87489590
[ccsdk/features.git] /
1 /*
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
9  *
10  * http://www.apache.org/licenses/LICENSE-2.0
11  *
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
15  * the License.
16  * ============LICENSE_END==========================================================================
17  */
18 package org.onap.ccsdk.features.sdnr.wt.devicemanager.impl.util;
19
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;
35
36 @SuppressWarnings("deprecation")
37 public class NetworkElementConnectionEntitiyUtil {
38
39     private static final Logger LOG = LoggerFactory.getLogger(NetworkElementConnectionEntitiyUtil.class);
40
41     /**
42      * Update devicetype and let all other field empties
43      *
44      * @param deviceType that should be updated
45      * @return NetworkElementConnectionEntity with related parameter
46      */
47     public static NetworkElementConnectionEntity getNetworkConnectionDeviceTpe(NetworkElementDeviceType deviceType) {
48         NetworkElementConnectionBuilder eb = new NetworkElementConnectionBuilder();
49         eb.setDeviceType(deviceType);
50         return eb.build();
51     }
52
53     /**
54      * Provide device specific data
55      *
56      * @param nodeId mountpoint id
57      * @param nNode data
58      * @return NetworkElementConnectionEntity specific information
59      */
60     public static NetworkElementConnectionEntity getNetworkConnection(String nodeId, @Nonnull NetconfNode nNode) {
61
62         NetworkElementConnectionBuilder eb = new NetworkElementConnectionBuilder();
63         // -- basics
64         eb.setId(nodeId).setNodeId(nodeId).setDeviceType(NetworkElementDeviceType.Unknown).setIsRequired(false);
65
66         // -- connection status
67         ConnectionLogStatus status = InternalConnectionStatus.statusFromNodeStatus(nNode.getConnectionStatus());
68         eb.setStatus(status);
69
70         // -- capabilites
71         Capabilities availableCapabilities = Capabilities.getAvailableCapabilities(nNode);
72         Capabilities unAvailableCapabilities = Capabilities.getUnavailableCapabilities(nNode);
73
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());
83         }
84
85         Credentials credentials = nNode.getCredentials();
86         if (credentials instanceof LoginPassword) {
87             LoginPassword loginPassword = (LoginPassword) credentials;
88             eb.setUsername(loginPassword.getUsername()).setPassword(loginPassword.getPassword());
89         }
90         eb.setCoreModelCapability("Unsupported"); // Default value. Specific value (if any) is set in the specific devicemanagers
91         return eb.build();
92     }
93 }