afad1098c72ca6b37f9069200d1a74657efe86a5
[cps.git] / cps-ncmp-rest / src / main / java / org / onap / cps / ncmp / rest / mapper / RestOutputCmHandleStateMapper.java
1 /*
2  * ============LICENSE_START=======================================================
3  * Copyright (C) 2022 Nordix Foundation
4  * ================================================================================
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  *       http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  * SPDX-License-Identifier: Apache-2.0
18  * ============LICENSE_END=========================================================
19  */
20
21 package org.onap.cps.ncmp.rest.mapper;
22
23 import org.mapstruct.Mapper;
24 import org.mapstruct.Mapping;
25 import org.mapstruct.Named;
26 import org.mapstruct.NullValueCheckStrategy;
27 import org.mapstruct.NullValuePropertyMappingStrategy;
28 import org.onap.cps.ncmp.api.inventory.CompositeState;
29 import org.onap.cps.ncmp.rest.model.DataStores;
30 import org.onap.cps.ncmp.rest.model.RestOutputCmHandleState;
31 import org.onap.cps.ncmp.rest.model.SyncState;
32
33 @Mapper(componentModel = "spring", nullValueCheckStrategy = NullValueCheckStrategy.ALWAYS,
34         nullValuePropertyMappingStrategy = NullValuePropertyMappingStrategy.SET_TO_DEFAULT)
35 public interface RestOutputCmHandleStateMapper {
36
37     @Mapping(target = "dataSyncState", source = "dataStores", qualifiedByName = "dataStoreToDataSyncState")
38     @Mapping(target = "lockReason.reason", source = "lockReason.lockReasonCategory")
39     RestOutputCmHandleState toRestOutputCmHandleState(CompositeState compositeState);
40
41     /**
42      * Convert from CompositeState datastore to RestOutput Datastores.
43      *
44      * @param compositeStateDataStore Composite State data stores
45      * @return DataStores
46      */
47     @Named("dataStoreToDataSyncState")
48     static DataStores toDataStores(CompositeState.DataStores compositeStateDataStore) {
49
50         if (compositeStateDataStore == null) {
51             return null;
52         }
53
54         final DataStores dataStores = new DataStores();
55
56         if (compositeStateDataStore.getOperationalDataStore() != null) {
57             final SyncState operationalSyncState = new SyncState();
58             operationalSyncState.setState(compositeStateDataStore.getOperationalDataStore().getSyncState().name());
59             operationalSyncState.setLastSyncTime(compositeStateDataStore.getOperationalDataStore().getLastSyncTime());
60             dataStores.setOperational(operationalSyncState);
61         }
62
63
64         return dataStores;
65
66     }
67
68 }