c28b9245b656f00e3833e5fb30dc1d48a8e69968
[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
19 package org.onap.ccsdk.features.sdnr.wt.devicemanager.ne.factory;
20
21 import java.util.Optional;
22 import org.eclipse.jdt.annotation.NonNull;
23 import org.onap.ccsdk.features.sdnr.wt.devicemanager.ne.service.NetworkElement;
24 import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.DeviceManagerServiceProvider;
25 import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfAccessor;
26
27 public interface NetworkElementFactory {
28
29     /**
30      * Called after connect of device. Decide if devicemanger should be started to manage device.
31      * @param accessor function to access device and get information from mountpoint
32      * @param serviceProvider provides base device manager services.
33      * @return Empty or NetworkElement object
34      */
35     Optional<NetworkElement> create(@NonNull NetconfAccessor accessor,
36             @NonNull DeviceManagerServiceProvider serviceProvider);
37
38     /**
39      * Called directly after factory registration to allow initialization
40      * @param serviceProvider provides base device manager services.
41      */
42     default void init(DeviceManagerServiceProvider serviceProvider) {
43     }
44
45
46 }