RTD change to document migration to Spring Boot 3.0
[cps.git] / cps-ncmp-rest / src / main / java / org / onap / cps / ncmp / rest / mapper / CmHandleStateMapper.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.CmHandleCompositeState;
30 import org.onap.cps.ncmp.rest.model.DataStores;
31 import org.onap.cps.ncmp.rest.model.LockReason;
32 import org.onap.cps.ncmp.rest.model.SyncState;
33
34 @Mapper(componentModel = "spring", nullValueCheckStrategy = NullValueCheckStrategy.ALWAYS,
35         nullValuePropertyMappingStrategy = NullValuePropertyMappingStrategy.SET_TO_DEFAULT)
36 public interface CmHandleStateMapper {
37
38     @Mapping(target = "dataSyncState", source = "dataStores", qualifiedByName = "dataStoreToDataSyncState")
39     @Mapping(target = "lockReason", source = "lockReason", qualifiedByName = "toExternalLockReason")
40     CmHandleCompositeState toCmHandleCompositeStateExternalLockReason(CompositeState compositeState);
41
42     /**
43      * Convert from CompositeState datastore to RestOutput Datastores.
44      *
45      * @param compositeStateDataStore Composite State data stores
46      * @return DataStores
47      */
48     @Named("dataStoreToDataSyncState")
49     static DataStores toDataStores(CompositeState.DataStores compositeStateDataStore) {
50
51         if (compositeStateDataStore == null) {
52             return null;
53         }
54
55         final DataStores dataStores = new DataStores();
56
57         if (compositeStateDataStore.getOperationalDataStore() != null) {
58             final SyncState operationalSyncState = new SyncState();
59             operationalSyncState.setSyncState(compositeStateDataStore.getOperationalDataStore()
60                     .getDataStoreSyncState().name());
61             operationalSyncState.setLastSyncTime(compositeStateDataStore.getOperationalDataStore().getLastSyncTime());
62             dataStores.setOperational(operationalSyncState);
63         }
64
65         return dataStores;
66     }
67
68     /**
69      * Convert Internal Lock Reason to External Lock Reason.
70      *
71      * @param internalLockReason Internal Lock Reason
72      *
73      * @return externalLockReason
74      */
75     @Named("toExternalLockReason")
76     static LockReason toExternalLockReason(CompositeState.LockReason internalLockReason) {
77         final LockReason externalLockReason = new LockReason();
78         if (internalLockReason.getLockReasonCategory() != null) {
79             externalLockReason.setReason("LOCKED_MISBEHAVING");
80         }
81         externalLockReason.setDetails(internalLockReason.getDetails());
82         return externalLockReason;
83     }
84
85 }