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
10 * http://www.apache.org/licenses/LICENSE-2.0
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.
18 * SPDX-License-Identifier: Apache-2.0
19 * ============LICENSE_END=========================================================
22 package org.onap.cps.ncmp.rest.controller;
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;
52 @RequestMapping("${rest.api.ncmp-inventory-base-path}")
53 @RequiredArgsConstructor
54 public class NetworkCmProxyInventoryController implements NetworkCmProxyInventoryApi {
56 private final NetworkCmProxyInventoryFacade networkCmProxyInventoryFacade;
57 private final NcmpRestInputMapper ncmpRestInputMapper;
58 private final DeprecationHelper deprecationHelper;
59 private final RestOutputCmHandleMapper restOutputCmHandleMapper;
62 * Get all cm handle references under a registered DMI plugin.
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
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);
77 final Collection<String> cmHandleIds = networkCmProxyInventoryFacade
78 .southboundCmHandleIdSearch(cmHandleQueryServiceParameters, outputAlternateId);
79 return ResponseEntity.ok(List.copyOf(cmHandleIds));
83 * Execute cm handle query search and return a list of cm handle details. Any number of conditions can be applied.
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
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);
106 * Get all cm-handle IDs under a registered DMI plugin.
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
114 public ResponseEntity<List<String>> getAllCmHandleReferencesForRegisteredDmi(final String dmiPluginIdentifier,
115 final Boolean outputAlternateId) {
117 final Collection<String> cmHandleIds =
118 networkCmProxyInventoryFacade.getAllCmHandleReferencesByDmiPluginIdentifier(dmiPluginIdentifier,
120 return ResponseEntity.ok(List.copyOf(cmHandleIds));
124 * Update DMI Plugin Registration (used for first registration also).
126 * @param restDmiPluginRegistration the registration data
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);
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();
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;
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());
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());