2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
21 package org.openecomp.sdc.be.distribution.servlet;
23 import javax.annotation.Resource;
24 import javax.inject.Singleton;
25 import javax.servlet.ServletContext;
26 import javax.servlet.http.HttpServletRequest;
27 import javax.ws.rs.Consumes;
28 import javax.ws.rs.GET;
29 import javax.ws.rs.HeaderParam;
30 import javax.ws.rs.POST;
31 import javax.ws.rs.Path;
32 import javax.ws.rs.Produces;
33 import javax.ws.rs.core.Context;
34 import javax.ws.rs.core.MediaType;
35 import javax.ws.rs.core.Response;
37 import org.openecomp.sdc.be.config.BeEcompErrorManager;
38 import org.openecomp.sdc.be.dao.api.ActionStatus;
39 import org.openecomp.sdc.be.distribution.AuditHandler;
40 import org.openecomp.sdc.be.distribution.DistributionBusinessLogic;
41 import org.openecomp.sdc.be.distribution.api.client.RegistrationRequest;
42 import org.openecomp.sdc.be.distribution.api.client.ServerListResponse;
43 import org.openecomp.sdc.be.impl.WebAppContextWrapper;
44 import org.openecomp.sdc.be.model.operations.api.StorageOperationStatus;
45 import org.openecomp.sdc.be.resources.data.auditing.AuditingActionEnum;
46 import org.openecomp.sdc.be.servlets.BeGenericServlet;
47 import org.openecomp.sdc.common.api.ArtifactTypeEnum;
48 import org.openecomp.sdc.common.api.Constants;
49 import org.openecomp.sdc.common.config.EcompErrorName;
50 import org.openecomp.sdc.common.datastructure.Wrapper;
51 import org.openecomp.sdc.common.util.HttpUtil;
52 import org.openecomp.sdc.exception.ResponseFormat;
53 import org.slf4j.Logger;
54 import org.slf4j.LoggerFactory;
55 import org.springframework.web.context.WebApplicationContext;
57 import com.jcabi.aspects.Loggable;
59 import fj.data.Either;
61 @Loggable(prepend = true, value = Loggable.DEBUG, trim = false)
64 public class DistributionServlet extends BeGenericServlet {
66 private static Logger log = LoggerFactory.getLogger(DistributionServlet.class.getName());
68 private DistributionBusinessLogic distributionLogic;
71 @Path("/distributionUebCluster")
72 @Consumes(MediaType.APPLICATION_JSON)
73 @Produces(MediaType.APPLICATION_JSON)
74 public Response getUebServerList(@Context final HttpServletRequest request, @HeaderParam(value = Constants.X_ECOMP_INSTANCE_ID_HEADER) String instanceId, @HeaderParam(value = Constants.X_ECOMP_REQUEST_ID_HEADER) String requestId,
75 @HeaderParam(value = Constants.AUTHORIZATION_HEADER) String authorization, @HeaderParam(value = Constants.ACCEPT_HEADER) String accept) {
77 String url = request.getMethod() + " " + request.getRequestURI();
78 log.debug("Start handle request of {}", url);
79 Response response = null;
80 ResponseFormat responseFormat = null;
81 if (instanceId == null) {
82 responseFormat = getComponentsUtils().getResponseFormat(ActionStatus.MISSING_X_ECOMP_INSTANCE_ID);
83 response = buildErrorResponse(responseFormat);
84 getComponentsUtils().auditMissingInstanceId(AuditingActionEnum.GET_UEB_CLUSTER, responseFormat.getStatus().toString(), responseFormat.getFormattedMessage());
88 Either<ServerListResponse, ResponseFormat> actionResponse = distributionLogic.getUebServerList();
90 if (actionResponse.isRight()) {
91 responseFormat = actionResponse.right().value();
92 response = buildErrorResponse(responseFormat);
94 responseFormat = getComponentsUtils().getResponseFormat(ActionStatus.OK);
95 response = buildOkResponse(responseFormat, actionResponse.left().value());
98 getComponentsUtils().auditGetUebCluster(AuditingActionEnum.GET_UEB_CLUSTER, instanceId, null, responseFormat.getStatus().toString(), responseFormat.getFormattedMessage());
101 } catch (Exception e) {
102 BeEcompErrorManager.getInstance().processEcompError(EcompErrorName.BeRestApiGeneralError, "failed to get ueb serbver list from cofiguration");
103 BeEcompErrorManager.getInstance().logBeRestApiGeneralError("failed to get ueb serbver list from cofiguration");
104 log.debug("failed to get ueb serbver list from cofiguration", e);
105 responseFormat = getComponentsUtils().getResponseFormat(ActionStatus.GENERAL_ERROR);
106 getComponentsUtils().auditGetUebCluster(AuditingActionEnum.GET_UEB_CLUSTER, instanceId, null, responseFormat.getStatus().toString(), responseFormat.getFormattedMessage());
107 response = buildErrorResponse(responseFormat);
114 * Returns list of valid artifact types for validation done in the distribution client.<br>
115 * The list is the representation of the values of the enum ArtifactTypeEnum.
120 * @param authorization
125 @Path("/artifactTypes")
126 @Consumes(MediaType.APPLICATION_JSON)
127 @Produces(MediaType.APPLICATION_JSON)
128 public Response getValidArtifactTypes(@Context final HttpServletRequest request, @HeaderParam(value = Constants.X_ECOMP_INSTANCE_ID_HEADER) String instanceId, @HeaderParam(value = Constants.X_ECOMP_REQUEST_ID_HEADER) String requestId,
129 @HeaderParam(value = Constants.AUTHORIZATION_HEADER) String authorization, @HeaderParam(value = Constants.ACCEPT_HEADER) String accept) {
131 String url = request.getMethod() + " " + request.getRequestURI();
132 log.debug("Start handle request of {}", url);
133 Response response = null;
135 Wrapper<Response> responseWrapper = new Wrapper<>();
137 validateHeaders(responseWrapper, request, AuditingActionEnum.GET_VALID_ARTIFACT_TYPES);
138 if (responseWrapper.isEmpty()) {
139 response = buildOkResponse(getComponentsUtils().getResponseFormat(ActionStatus.OK), ArtifactTypeEnum.values());
141 response = responseWrapper.getInnerElement();
147 @Path("/registerForDistribution")
148 @Consumes(MediaType.APPLICATION_JSON)
149 @Produces(MediaType.APPLICATION_JSON)
150 public Response registerForDistribution(@Context final HttpServletRequest request, String requestJson) {
151 String url = request.getMethod() + " " + request.getRequestURI();
152 log.debug("Start handle request of {}", url);
155 Wrapper<Response> responseWrapper = new Wrapper<>();
156 Wrapper<RegistrationRequest> registrationRequestWrapper = new Wrapper<>();
158 validateHeaders(responseWrapper, request, AuditingActionEnum.ADD_KEY_TO_TOPIC_ACL);
160 if (responseWrapper.isEmpty()) {
161 validateJson(responseWrapper, registrationRequestWrapper, requestJson);
163 if (responseWrapper.isEmpty()) {
164 validateEnv(responseWrapper, registrationRequestWrapper.getInnerElement().getDistrEnvName());
167 if (responseWrapper.isEmpty()) {
168 distributionLogic.handleRegistration(responseWrapper, registrationRequestWrapper.getInnerElement(), buildAuditHandler(request, registrationRequestWrapper.getInnerElement()));
170 BeEcompErrorManager.getInstance().processEcompError(EcompErrorName.BeDistributionEngineSystemError, DistributionBusinessLogic.REGISTER_IN_DISTRIBUTION_ENGINE, "registration validation failed");
171 BeEcompErrorManager.getInstance().logBeDistributionEngineSystemError(DistributionBusinessLogic.REGISTER_IN_DISTRIBUTION_ENGINE, "registration validation failed");
174 return responseWrapper.getInnerElement();
178 @Path("/unRegisterForDistribution")
179 @Consumes(MediaType.APPLICATION_JSON)
180 @Produces(MediaType.APPLICATION_JSON)
181 public Response unRegisterForDistribution(@Context final HttpServletRequest request, String requestJson) {
182 String url = request.getMethod() + " " + request.getRequestURI();
183 log.debug("Start handle request of {}", url);
186 Wrapper<Response> responseWrapper = new Wrapper<>();
187 Wrapper<RegistrationRequest> unRegistrationRequestWrapper = new Wrapper<>();
189 validateHeaders(responseWrapper, request, AuditingActionEnum.REMOVE_KEY_FROM_TOPIC_ACL);
191 if (responseWrapper.isEmpty()) {
192 validateJson(responseWrapper, unRegistrationRequestWrapper, requestJson);
194 if (responseWrapper.isEmpty()) {
195 validateEnv(responseWrapper, unRegistrationRequestWrapper.getInnerElement().getDistrEnvName());
197 if (responseWrapper.isEmpty()) {
198 distributionLogic.handleUnRegistration(responseWrapper, unRegistrationRequestWrapper.getInnerElement(), buildAuditHandler(request, unRegistrationRequestWrapper.getInnerElement()));
200 BeEcompErrorManager.getInstance().processEcompError(EcompErrorName.BeDistributionEngineSystemError, DistributionBusinessLogic.UN_REGISTER_IN_DISTRIBUTION_ENGINE, "unregistration validation failed");
201 BeEcompErrorManager.getInstance().logBeDistributionEngineSystemError(DistributionBusinessLogic.UN_REGISTER_IN_DISTRIBUTION_ENGINE, "unregistration validation failed");
204 return responseWrapper.getInnerElement();
207 private void validateEnv(Wrapper<Response> responseWrapper, String distrEnvName) {
210 StorageOperationStatus environmentStatus = distributionLogic.getDistributionEngine().isEnvironmentAvailable();
212 // StorageOperationStatus environmentStatus =
213 // distributionLogic.getDistributionEngine().isEnvironmentAvailable(distrEnvName);
214 if (environmentStatus != StorageOperationStatus.OK) {
215 if (environmentStatus == StorageOperationStatus.DISTR_ENVIRONMENT_NOT_FOUND) {
216 Response missingHeaderResponse = buildErrorResponse(distributionLogic.getResponseFormatManager().getResponseFormat(ActionStatus.DISTRIBUTION_ENV_DOES_NOT_EXIST));
217 responseWrapper.setInnerElement(missingHeaderResponse);
219 Response missingHeaderResponse = buildErrorResponse(distributionLogic.getResponseFormatManager().getResponseFormat(ActionStatus.GENERAL_ERROR));
220 responseWrapper.setInnerElement(missingHeaderResponse);
226 private void init(HttpServletRequest request) {
227 if (distributionLogic == null) {
228 distributionLogic = getDistributionBL(request.getSession().getServletContext());
232 private void validateHeaders(Wrapper<Response> responseWrapper, HttpServletRequest request, AuditingActionEnum auditingAction) {
233 if (request.getHeader(Constants.X_ECOMP_INSTANCE_ID_HEADER) == null) {
234 Response missingHeaderResponse = buildErrorResponse(distributionLogic.getResponseFormatManager().getResponseFormat(ActionStatus.MISSING_X_ECOMP_INSTANCE_ID));
235 responseWrapper.setInnerElement(missingHeaderResponse);
237 ResponseFormat responseFormat = getComponentsUtils().getResponseFormat(ActionStatus.MISSING_X_ECOMP_INSTANCE_ID);
238 getComponentsUtils().auditMissingInstanceId(auditingAction, responseFormat.getStatus().toString(), responseFormat.getFormattedMessage());
244 private void validateJson(Wrapper<Response> responseWrapper, Wrapper<RegistrationRequest> registrationRequestWrapper, String requestJson) {
245 if (requestJson == null || requestJson.isEmpty()) {
246 Response missingBodyResponse = buildErrorResponse(distributionLogic.getResponseFormatManager().getResponseFormat(ActionStatus.MISSING_BODY));
247 responseWrapper.setInnerElement(missingBodyResponse);
249 Either<RegistrationRequest, Exception> eitherRegistration = HttpUtil.convertJsonStringToObject(requestJson, RegistrationRequest.class);
250 if (eitherRegistration.isLeft()) {
251 RegistrationRequest registrationRequest = eitherRegistration.left().value();
252 if (registrationRequest.getApiPublicKey() == null) {
253 Response missingBodyResponse = buildErrorResponse(distributionLogic.getResponseFormatManager().getResponseFormat(ActionStatus.MISSING_PUBLIC_KEY));
254 responseWrapper.setInnerElement(missingBodyResponse);
256 } else if (registrationRequest.getDistrEnvName() == null) {
257 Response missingBodyResponse = buildErrorResponse(distributionLogic.getResponseFormatManager().getResponseFormat(ActionStatus.MISSING_ENV_NAME));
258 responseWrapper.setInnerElement(missingBodyResponse);
260 registrationRequestWrapper.setInnerElement(registrationRequest);
263 Response missingBodyResponse = buildErrorResponse(distributionLogic.getResponseFormatManager().getResponseFormat(ActionStatus.MISSING_BODY));
264 responseWrapper.setInnerElement(missingBodyResponse);
270 private DistributionBusinessLogic getDistributionBL(ServletContext context) {
271 WebAppContextWrapper webApplicationContextWrapper = (WebAppContextWrapper) context.getAttribute(Constants.WEB_APPLICATION_CONTEXT_WRAPPER_ATTR);
272 WebApplicationContext webApplicationContext = webApplicationContextWrapper.getWebAppContext(context);
273 return webApplicationContext.getBean(DistributionBusinessLogic.class);
276 private AuditHandler buildAuditHandler(HttpServletRequest request, RegistrationRequest registrationRequest) {
277 return new AuditHandler(getComponentsUtils(), request.getHeader(Constants.X_ECOMP_INSTANCE_ID_HEADER), registrationRequest);