c0744e91ebe0632dadc01627110a38ea587018d6
[cps.git] /
1 /*
2  *  ============LICENSE_START=======================================================
3  *  Copyright (C) 2021-2022 Bell Canada
4  *  Modifications Copyright (C) 2022-2025 OpenInfra Foundation Europe. All rights reserved.
5  *  ================================================================================
6  *  Licensed under the Apache License, Version 2.0 (the "License");
7  *  you may not use this file except in compliance with the License.
8  *  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
13  *  distributed under the License is distributed on an "AS IS" BASIS,
14  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  *  See the License for the specific language governing permissions and
16  *  limitations under the License.
17  *
18  *  SPDX-License-Identifier: Apache-2.0
19  *  ============LICENSE_END=========================================================
20  */
21
22 package org.onap.cps.ncmp.rest.controller;
23
24 import io.micrometer.core.annotation.Timed;
25 import jakarta.validation.Valid;
26 import java.util.Collection;
27 import java.util.List;
28 import java.util.stream.Collectors;
29 import lombok.RequiredArgsConstructor;
30 import org.onap.cps.ncmp.api.inventory.NetworkCmProxyInventoryFacade;
31 import org.onap.cps.ncmp.api.inventory.models.CmHandleQueryApiParameters;
32 import org.onap.cps.ncmp.api.inventory.models.CmHandleQueryServiceParameters;
33 import org.onap.cps.ncmp.api.inventory.models.CmHandleRegistrationResponse;
34 import org.onap.cps.ncmp.api.inventory.models.CmHandleRegistrationResponse.Status;
35 import org.onap.cps.ncmp.api.inventory.models.DmiPluginRegistrationResponse;
36 import org.onap.cps.ncmp.rest.api.NetworkCmProxyInventoryApi;
37 import org.onap.cps.ncmp.rest.model.CmHandleQueryParameters;
38 import org.onap.cps.ncmp.rest.model.CmHandlerRegistrationErrorResponse;
39 import org.onap.cps.ncmp.rest.model.DmiPluginRegistrationErrorResponse;
40 import org.onap.cps.ncmp.rest.model.RestDmiPluginRegistration;
41 import org.onap.cps.ncmp.rest.model.RestOutputCmHandle;
42 import org.onap.cps.ncmp.rest.util.CountCmHandleSearchExecution;
43 import org.onap.cps.ncmp.rest.util.DeprecationHelper;
44 import org.onap.cps.ncmp.rest.util.NcmpRestInputMapper;
45 import org.onap.cps.ncmp.rest.util.RestOutputCmHandleMapper;
46 import org.springframework.http.HttpStatus;
47 import org.springframework.http.ResponseEntity;
48 import org.springframework.web.bind.annotation.RequestMapping;
49 import org.springframework.web.bind.annotation.RestController;
50
51 @RestController
52 @RequestMapping("${rest.api.ncmp-inventory-base-path}")
53 @RequiredArgsConstructor
54 public class NetworkCmProxyInventoryController implements NetworkCmProxyInventoryApi {
55
56     private final NetworkCmProxyInventoryFacade networkCmProxyInventoryFacade;
57     private final NcmpRestInputMapper ncmpRestInputMapper;
58     private final DeprecationHelper deprecationHelper;
59     private final RestOutputCmHandleMapper restOutputCmHandleMapper;
60
61     /**
62      * Get all cm handle references under a registered DMI plugin.
63      *
64      * @param cmHandleQueryParameters DMI plugin identifier
65      * @param outputAlternateId       Boolean for cm handle reference type either
66      *                                cm handle id (False) or alternate id (True)
67      * @return                        list of cm handle IDs
68      */
69     @Override
70     @CountCmHandleSearchExecution(methodName = "searchCmHandleIds", interfaceName = "CPS-NCMP-I-01",
71         description = "Search for cm handle ids within CPS-NCMP-I-01 interface")
72     public ResponseEntity<List<String>> searchCmHandleIds(final CmHandleQueryParameters cmHandleQueryParameters,
73                                                           final Boolean outputAlternateId) {
74         final CmHandleQueryServiceParameters cmHandleQueryServiceParameters = ncmpRestInputMapper
75                 .toCmHandleQueryServiceParameters(cmHandleQueryParameters);
76
77         final Collection<String> cmHandleIds = networkCmProxyInventoryFacade
78                 .southboundCmHandleIdSearch(cmHandleQueryServiceParameters, outputAlternateId);
79         return ResponseEntity.ok(List.copyOf(cmHandleIds));
80     }
81
82     /**
83      * Execute cm handle query search and return a list of cm handle details. Any number of conditions can be applied.
84      *
85      * @param cmHandleQueryParameters the cm handle query parameters
86      * @param outputDmiProperties boolean value to determine the inclusion of additional properties
87      * @return collection of cm handles
88      */
89     @Override
90     @SuppressWarnings("deprecation") // mapOldConditionProperties method will be removed in Release 17
91     public ResponseEntity<List<RestOutputCmHandle>> searchCmHandles(
92             final CmHandleQueryParameters cmHandleQueryParameters,
93             final Boolean outputDmiProperties) {
94         final CmHandleQueryApiParameters cmHandleQueryApiParameters =
95                 deprecationHelper.mapOldConditionProperties(cmHandleQueryParameters);
96         final boolean outputDmiPropertiesAsPrimitive = Boolean.TRUE.equals(outputDmiProperties);
97         final List<RestOutputCmHandle> restOutputCmHandles =
98                 networkCmProxyInventoryFacade.southboundCmHandleSearch(cmHandleQueryApiParameters)
99                         .map(handle -> restOutputCmHandleMapper
100                                 .toRestOutputCmHandle(handle, outputDmiPropertiesAsPrimitive))
101                         .collectList().block();
102         return ResponseEntity.ok(restOutputCmHandles);
103     }
104
105     /**
106      * Get all cm-handle IDs under a registered DMI plugin.
107      *
108      * @param dmiPluginIdentifier DMI plugin identifier
109      * @param outputAlternateId   Boolean for cm handle reference type either
110      *                            cm handle id (False) or alternate id (True)
111      * @return list of cm handle IDs
112      */
113     @Override
114     public ResponseEntity<List<String>> getAllCmHandleReferencesForRegisteredDmi(final String dmiPluginIdentifier,
115                                                                                  final Boolean outputAlternateId) {
116
117         final Collection<String> cmHandleIds =
118             networkCmProxyInventoryFacade.getAllCmHandleReferencesByDmiPluginIdentifier(dmiPluginIdentifier,
119                 outputAlternateId);
120         return ResponseEntity.ok(List.copyOf(cmHandleIds));
121     }
122
123     /**
124      * Update DMI Plugin Registration (used for first registration also).
125      *
126      * @param restDmiPluginRegistration the registration data
127      */
128     @Override
129     @Timed(value = "cps.ncmp.inventory.controller.update",
130         description = "Time taken to handle registration request")
131     public ResponseEntity updateDmiPluginRegistration(
132         final @Valid RestDmiPluginRegistration restDmiPluginRegistration) {
133         final DmiPluginRegistrationResponse dmiPluginRegistrationResponse =
134             networkCmProxyInventoryFacade.updateDmiRegistration(
135                 ncmpRestInputMapper.toDmiPluginRegistration(restDmiPluginRegistration));
136         final DmiPluginRegistrationErrorResponse failedRegistrationErrorResponse =
137             getFailureRegistrationResponse(dmiPluginRegistrationResponse);
138         return allRegistrationsSuccessful(failedRegistrationErrorResponse)
139             ? new ResponseEntity<>(HttpStatus.OK)
140             : new ResponseEntity<>(failedRegistrationErrorResponse, HttpStatus.INTERNAL_SERVER_ERROR);
141     }
142
143     private boolean allRegistrationsSuccessful(
144         final DmiPluginRegistrationErrorResponse dmiPluginRegistrationErrorResponse) {
145         return dmiPluginRegistrationErrorResponse.getFailedCreatedCmHandles().isEmpty()
146                 && dmiPluginRegistrationErrorResponse.getFailedUpdatedCmHandles().isEmpty()
147                 && dmiPluginRegistrationErrorResponse.getFailedRemovedCmHandles().isEmpty()
148                 && dmiPluginRegistrationErrorResponse.getFailedUpgradeCmHandles().isEmpty();
149     }
150
151     private DmiPluginRegistrationErrorResponse getFailureRegistrationResponse(
152         final DmiPluginRegistrationResponse dmiPluginRegistrationResponse) {
153         final DmiPluginRegistrationErrorResponse dmiPluginRegistrationErrorResponse =
154             new DmiPluginRegistrationErrorResponse();
155         dmiPluginRegistrationErrorResponse.setFailedCreatedCmHandles(
156             getFailedResponses(dmiPluginRegistrationResponse.getCreatedCmHandles()));
157         dmiPluginRegistrationErrorResponse.setFailedUpdatedCmHandles(
158             getFailedResponses(dmiPluginRegistrationResponse.getUpdatedCmHandles()));
159         dmiPluginRegistrationErrorResponse.setFailedRemovedCmHandles(
160             getFailedResponses(dmiPluginRegistrationResponse.getRemovedCmHandles()));
161         dmiPluginRegistrationErrorResponse.setFailedUpgradeCmHandles(
162                 getFailedResponses(dmiPluginRegistrationResponse.getUpgradedCmHandles()));
163         return dmiPluginRegistrationErrorResponse;
164     }
165
166     private List<CmHandlerRegistrationErrorResponse> getFailedResponses(
167             final List<CmHandleRegistrationResponse> cmHandleRegistrationResponseList) {
168         return cmHandleRegistrationResponseList.stream()
169                 .filter(cmHandleRegistrationResponse -> cmHandleRegistrationResponse.getStatus() == Status.FAILURE)
170                 .map(this::toCmHandleRegistrationErrorResponse).collect(Collectors.toList());
171     }
172
173     private CmHandlerRegistrationErrorResponse toCmHandleRegistrationErrorResponse(
174         final CmHandleRegistrationResponse registrationResponse) {
175         return new CmHandlerRegistrationErrorResponse()
176             .cmHandle(registrationResponse.getCmHandle())
177             .errorCode(registrationResponse.getNcmpResponseStatus().getCode())
178             .errorText(registrationResponse.getErrorText());
179     }
180
181 }